@charset "utf-8";
@import url('https://fonts.googleapis.com/css2?family=Noto+Sans+JP:wght@400;500&family=Noto+Serif+JP:wght@400;500&display=swap');
/* CSS style.css */
.serif {
    font-family: 'Noto Serif JP', "ＭＳ Ｐ明朝", "MS PMincho", "ヒラギノ明朝 Pro W3", "Hiragino Mincho Pro", serif;
}
.sans {
    font-family: 'Noto Sans JP', "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", "メイリオ", Meiryo, Osaka, "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
}
.Gothic {
    font-family: "Helvetica Neue", Arial, "Hiragino Kaku Gothic ProN", "Hiragino Sans", Meiryo, sans-serif;
}
/*------------------------------
リセットCSS
------------------------------*/
h1, h2, h3, h4, h5, h6, p, ul, ol, li, a {
    line-height: 1.6em;
    font-size: 18px;
    color: #000;
    font-family: 'Noto Serif JP', "ＭＳ Ｐ明朝", "MS PMincho", "ヒラギノ明朝 Pro W3", "Hiragino Mincho Pro", serif;
}
/*------------------------------
基本
------------------------------*/
html {
    scroll-behavior: smooth;
}
.wrapper, .header_sou {
    width: 100%;
    text-align: center;
    margin: 0 auto;
}
.inner, .fv_img {
    width: 100%;
    max-width: 1170px;
    margin: 0 auto;
}
a {
    color: #45569E;
}
a:hover {
    opacity: 0.8;
}
.plan_link, .plan_link2, .now_tel_link {
    color: #000;
}
.inner860 {
    max-width: 860px;
    margin: 0 auto;
}
.bg_gray {
    background-color: #f0efeb;
}
.cont_h2 {
    font-size: 26px;
    letter-spacing: 2px;
}
.cont_h2ver2 {
    font-size: 28px;
    letter-spacing: 2px;
}
.cont_h2ver3 {
    font-size: 46px;
}
.cont_p {
    font-size: 22px;
    font-weight: 600;
    letter-spacing: 1px;
    line-height: 1.8em;
}
.cont_p_ver2 {
    font-size: 15px;
    line-height: 1.8em;
}
.cont_p_ver3 {
    font-size: 28px;
    line-height: 1.8em;
}
.now_tel_p, .font_18 {
    font-size: 18px;
}
.font_15 {
    font-size: 15px;
}
.font_16 {
    font-size: 16px;
}
.font_19 {
    font-size: 19px;
}
.font_s200 {
    font-size: 200%;
}
.font_s180 {
    font-size: 180%;
}
.font_s170 {
    font-size: 170%;
}
.font_s150 {
    font-size: 150%;
}
.font_s120 {
    font-size: 120%;
}
.font_s90 {
    font-size: 90%;
}
.font_s80 {
    font-size: 80%;
}
.font_s70 {
    font-size: 70%;
}
.font_s60 {
    font-size: 60%;
}
.font_s50 {
    font-size: 50%;
}
.font_s40 {
    font-size: 40%;
}
.ml_m02 {
    margin-left: -0.2em;
}
.ml_m04 {
    margin-left: -0.4em;
}
.ml_m05 {
    margin-left: -0.5em;
}
.ml_m08 {
    margin-left: -0.8em;
}
.ml_m10 {
    margin-left: -1em;
}
.ml_05 {
    margin-left: 0.5em;
}
.ml_10 {
    margin-left: 1em;
}
.mr_05 {
    margin-right: 0.5em;
}
.mr_08 {
    margin-right: 0.8em;
}
.mr_m05 {
    margin-right: -0.5em;
}
.mr_m08 {
    margin-right: -0.8em;
}
.mr_m03 {
    margin-right: -0.3em;
}
.mb_0 {
    margin-bottom: 0px !important;
}
.mb_6 {
    margin-bottom: 6px !important;
}
.mb_10 {
    margin-bottom: 10px !important;
}
.mb_20 {
    margin-bottom: 20px !important;
}
.mb_30 {
    margin-bottom: 30px !important;
}
.mb_40 {
    margin-bottom: 40px !important;
}
.mb_50 {
    margin-bottom: 50px !important;
}
.mb_60 {
    margin-bottom: 60px !important;
}
.mb_80 {
    margin-bottom: 80px !important;
}
.mb_100 {
    margin-bottom: 100px !important;
}
.mb_160 {
    margin-bottom: 160px !important;
}
.flex {
    display: flex;
}
.mt_10 {
    margin-top: 10px !important;
}
.mt_20 {
    margin-top: 20px !important;
}
.mt_30 {
    margin-top: 30px !important;
}
.mt_40 {
    margin-top: 40px !important;
}
.mt_80 {
    margin-top: 80px !important;
}
.mt_100 {
    margin-top: 100px !important;
}
.pb_10 {
    padding-bottom: 10px !important;
}
.pb_20 {
    padding-bottom: 20px !important;
}
.pb_30 {
    padding-bottom: 20px !important;
}
.pb_50 {
    padding-bottom: 50px !important;
}
.pb_200 {
    padding-bottom: 200px !important;
}
.pt_30 {
    padding-top: 30px !important;
}
.pb_100 {
    padding-bottom: 100px !important;
}
.white {
    color: #FFF;
}
.red {
    color: #D52427;
}
.blue {
    color: #45569E;
}
.letter_s2 {
    letter-spacing: 2px;
}
.letter_sm1 {
    letter-spacing: -1px;
}
.t_nowrap {
    white-space: nowrap;
}
.f_bold {
    font-weight: bold;
}
.t_center {
    text-align: center
}
.t_right {
    text-align: right;
}
.t_left {
    text-align: left;
}
.sec02_01, .sec02_02, .sec02_03, .sec02_04, .sec02v2_01, .sec02v2_02, .sec02v2_04, .sec02v2_03 {
    max-width: 1200px;
    width: 100%;
    margin: 0 auto;
}
/*****************
contents
*****************/
.head_logo {
    justify-content: space-between;
    align-items: center;
    max-width: 1170px;
    width: 100%;
}
.top_logo {
    width: 70%;
    max-width: 320px;
    padding-right: 10px;
    text-align: left;
}
.top_logo_img {
    max-width: 302px;
}
.tel_box {
    width: 60%;
    padding-right: 12px;
}
.top_h2 {
    font-size: 120%;
}
.top_tel {
    color: #45569E;
    font-size: 150%;
    font-weight: bold;
    letter-spacing: 1px;
    transform: scale(1.2, 1);
    margin-right: 16px;
    line-height: 1em;
    display: inline-block;
}
.kengaku_link_box {
    width: 36%;
    padding-right: 20px;
    text-align: right;
}
.kengaku_link {
    color: #FFF;
    text-align: center;
    background-color: #45569E;
    padding: 10px 10px 6px;
    ;
    border-radius: 6px;
    display: inline-block;
    height: 2em;
    font-weight: bold;
    letter-spacing: 2px;
    width: 282px;
}
.fv_img {
    position: relative;
}
.fv_h2 {
    position: absolute;
    top: 67px;
    right: 22px;
    text-align: right;
    font-size: 41px;
    line-height: 2.2em;
    letter-spacing: 2px;
}
.sec01 {
    position: relative;
    z-index: 5;
    padding-top: 80px;
}
.sec01_box {
    justify-content: center;
    max-width: 960px;
    margin: 0 auto;
}
.sec01_box figure {
	width:calc(100% / 2);
	text-align:center;
}
.sec01_box img {
    max-width: 434px;
    width: 100%;
    margin-bottom: 20px;
}
.sec01_box .cont_p {
    margin: 0 auto 2em;
    max-width: 270px;
    font-weight: 500;
    font-size: 19px;
    text-align: center;
    padding-left: 40px;
    letter-spacing: -2px;
    line-height: 2em;
}
.sec01:after {
    position: absolute;
    content: '';
    bottom: 0;
    height: 70px;
    width: 100%;
    background-color: #FFF;
    z-index: -1;
}
.sec02_01, .sec02_02, .sec02_03, .sec02_04 {
    background-repeat: no-repeat;
    background-size: auto;
}
.sec02_01 {
    background-image: url(img/jyumokusou_bg01.jpg);
    background-position: right center;
}
.sec02_02 {
    background-image: url(img/jyumokusou_01.png);
    background-position: left center;
}
.sec02_03 {
    background-image: url(img/jyumokusou_02.png);
    background-position: right center;
}
.sec02_04 {
    background-image: url(img/jyumokusou_03.png);
    background-position: right top;
}
.sec02_02 p {
    position: relative;
    z-index: 5;
}
.sec02_box {
    position: relative;
    top: 100px;
    z-index: 5;
    justify-content: space-between;
}
.sec02_05 {
    position: relative;
    background-image: url(img/cont_bg001.jpg);
    clip-path: polygon(0 26vw, 100% 0, 100% 100%, 0 100%);
    width: 100%;
    padding: 200px 0 0;
    margin-top: -575px;
}
.sec02_box_img {
    max-width: 495px;
}
.sec02_box_img img {
    margin-bottom: 16px;
}
.sec02_box_t {
    width: 40%;
}
.sec02_box_t img {
    margin-top: -17px;
    max-width: 300px;
}
.cont_p_ver2.t_left {
    padding-left: 28px;
}
.sec02_box_t .cont_p_ver2.t_left {
    line-height: 2.3em;
}
.sec02_box_t .cont_p_ver2.mb_30 {
    margin-top: -6px;
}
.sec02_05_rap {
    margin: 450px auto 0;
}
.sec02_05_rap .cont_p_ver3.t_center {
    letter-spacing: 1px;
}
.sec02_05 .youtube {
    position: relative;
    width: 100%;
    padding-top: 56.25%;
}
.sec02_05 iframe {
    position: absolute;
    top: 0;
    right: 0;
    width: 100%;
    height: 100%;
}
.movie {
	width: 1170px;
	margin: 100px auto 0;
}
.movie .youtube {
    position: relative;
    width: 100%;
    padding-top: 56.25%;
}
.movie iframe {
    position: absolute;
    top: 0;
    right: 0;
    width: 100%;
    height: 100%;
}
.now_tel {
    background-color: #FFF;
    border: 2px #45569E solid;
    text-align: center;
    padding: 40px 0 0;
}
.naw_tel_number {
    font-size: 48px;
    font-family: "ヒラギノ明朝 Pro W3", "Hiragino Mincho Pro", serif;
    letter-spacing: 0.1em;
    line-height: 1em;
}
.naw_tel_number a {
    font-size: 48px;
}
.tel_logo {
    position: relative;
    top: 6px;
    left: -15px;
}
.tel_logo img {
    width: 56px;
}
.sns_box {
    background-color: #45569E;
    justify-content: space-between;
    padding: 20px;
}
.nou_tel_p2 {
    font-size: 24px;
    line-height: 1.2em;
    text-align: left;
}
.sns_box .font_s60 {
    display: inline-block;
    padding-top: 10px;
    line-height: 1.6em;
}
.sns_box figure {
    max-width: 86px;
    width: 20%;
    margin: 0 30px;
}
.bg_gray_domu {
    background-image: url(img/jyumokusou_05.png);
    background-repeat: no-repeat;
    background-position: center top;
    background-size: cover;
    height: 144px;
    width: 100%;
    position: relative;
    margin-top: -144px;
}
.sec03 {
    padding: 0 0 100px;
}
.sec03_rap {
    justify-content: space-between;
    width: 100%;
}
.sec03_rap.mb_16 {
    margin-bottom: 16px;
}
.sec03_box {
    border: #333 2px solid;
    border-radius: 20px;
    background-color: #FFF;
    width: 31%;
    padding: 30px 0px;
}
.sec03_box_img {
    width: 192px;
    height: 202px;
    text-align: center;
    margin: 0 auto 20px;
}
.sec03_box_p, .sec03_box_p2 {
    text-align: center;
    width: 200px;
    margin: 0 auto;
    font-size: 16px;
}
.sec04_box {
    padding-bottom: 70px;
    justify-content: space-between;
    align-items: center;
}
.sec04_box_img {
    position: relative;
    max-width: 458px;
    width: 56%;
    right: 30px;
}
.sec04_h2 {
    position: absolute;
    top: 32px;
    left: 130px;
    font-size: 36px;
    font-weight: 500;
    letter-spacing: -1px;
    white-space: nowrap;
    overflow: hidden;
}
.sec04_box_text {
    text-align: left;
    width: 46%;
}
.sec04_box_p {
    font-size: 15px;
    padding-top: 80px;
    line-height: 1.8em;
}
.s4b1 {
    background-image: url(img/jyumokusou_06.png);
    background-repeat: repeat-y;
    background-position: center top -94px;
    ;
}
.sec04_h2 .font_s40 {
    position: relative;
    display: inline-block;
    top: -8px;
}
.sec05 {
    background-image: url(img/jyumokusou_04.png);
    background-repeat: no-repeat;
    background-position: right bottom;
    padding-bottom: 160px;
}
.sec05_link {
    margin: -50px auto 60px;
    padding-top: 60px;
    text-align: center;
}
.plan_link {
    max-width: 449px;
    width: 100%;
    display: inline-block;
    text-align: center;
    font-size: 22px;
    background-color: #45569E;
    color: #fff;
    padding: 20px 0;
    border-radius: 40px;
}
.sec02.ver2 {
    background-image: url(img/jyumokusou_29.jpg);
    background-repeat: no-repeat;
    background-position: left top;
    padding: 100px 0 0;
}
.sec02v2_01, .sec02v2_02, .sec02v2_03, .sec02v2_04, .sec02v2_05 {
    background-repeat: no-repeat;
    background-size: auto;
}
.sec02v2_01 {
    position: relative;
    background-image: url(img/jyumokusou_16.png);
    background-position: right top;
}
.sec02v2_01:before {
    position: absolute;
    content: '';
    top: 300px;
    left: 0;
    background-image: url(img/jyumokusou_01.png);
    background-position: left top;
    background-repeat: no-repeat;
    background-size: auto;
    max-width: 292px;
    width: 100%;
    max-height: 292px;
    height: 100%;
}
.sec02v2_02, .sec02v2_04 {
    background-image: url(img/jyumokusou_31.jpg);
    background-position: right top;
}
.sec02v2_03, .sec02v2_05 {
    background-image: url(img/jyumokusou_01.png);
    background-position: left top;
}
.sec02v2_05 {
    position: relative;
}
.sec02v2_05:before {
    position: absolute;
    content: '';
    top: 0;
    clip-path: polygon(0 12%, 100% 0, 100% 100%, 0 100%);
    width: 100%;
    padding: 1000px 0 0;
    margin-top: 140px;
    z-index: -1;
    background-image: url(img/cont_bg002.jpg);
    background-repeat: repeat-y;
    background-position: center top;
    background-size: 100%;
}
.sec02v2_img_rap {
    flex-wrap: wrap;
}
.sec02v2_img_rap img {
    max-width: 400px;
    position: relative;
    z-index: 0;
}
.sec02v2_img_l {
    width: 50%;
    text-align: left;
}
.sec02v2_img_r {
    width: 50%;
    text-align: right;
}
.mt_m108 {
    margin-top: -108px;
}
.sec06 {
    width: 100%;
    overflow: hidden;
    margin: 50px auto 0;
    background-size: 100%;
    position: relative;
    padding: 50px 0;
}
.sec06_box {
    justify-content: space-between;
    align-items: center;
    position: relative;
    margin-bottom: 100px;
}
.sec06:after {
    position: absolute;
    content: '';
    width: 0;
    height: 0;
    border-style: solid;
    border-width: 100px 50vw 0 50vw;
    border-color: transparent #45569E transparent #45569E;
    left: 0;
    right: 0;
    margin: 0 auto;
    bottom: 0px;
}
.sec06_box:before {
    position: absolute;
    content: '';
    bottom: -55px;
    left: 0;
    right: 0;
    display: inline-block;
    margin: 0 auto;
    border-bottom: #45569E solid 4px;
    width: 150px;
}
.sec06_box.last:before {
    border-bottom: none;
}
.sec06 span.h2ver2 {
    font-size: 36px;
    margin-left: 20px;
    padding-left: 30px;
    position: relative;
    bottom: 3px;
}
.sec06 span.h2ver2:before {
    position: absolute;
    content: '';
    top: 10px;
    left: 0;
    border-left: #45569E solid 6px;
    height: 36px;
}
.sec06 span.h2ver2.tayuna {
    position: relative;
    top: 10px;
}
.sec06_img {
    max-width: 397px;
}
.sec06_text {
    width: 50%;
    text-align: left;
}
.sec06_ul {
    margin-left: 20px;
    margin-bottom: 30px;
}
.sec06_li {
    list-style-type: decimal;
    font-size: 15px;
    line-height: 2.1em;
}
.sec07 {
    padding: 80px 0 140px;
    background-color: #45569E;
    background-image: url(img/jyumokusou_24.png);
    background-repeat: no-repeat;
    background-position: right bottom;
    background-size: auto;
}
.sec07_h2 {
    text-align: center;
    font-size: 30px;
    margin-bottom: 60px;
}
.sec07_rap {
    background-color: #FFF;
    padding-bottom: 30px;
    margin-bottom: 60px;
    position: relative;
}
.sec07_rap.ver01:before, .sec07_rap.ver01:after {
    position: absolute;
    content: '';
    background-size: auto;
    width: 316px;
    height: 266px;
}
.sec07_rap.ver01:before {
    background-image: url(img/jyumokusou_21.png);
    top: -130px;
    right: -130px;
}
.sec07_rap.ver01:after {
    background-image: url(img/jyumokusou_21.png);
    bottom: 130px;
    left: -220px;
}
.sec07_rap.ver02:before, .sec07_rap.ver02:after {
    position: absolute;
    content: '';
    background-size: auto;
}
.sec07_rap.ver02:before {
    background-image: url(img/jyumokusou_22.png);
    top: -168px;
    right: -130px;
    width: 442px;
    height: 258px;
}
.sec07_rap.ver02:after {
    background-image: url(img/jyumokusou_21.png);
    bottom: 130px;
    left: -220px;
    width: 316px;
    height: 266px;
}
.sec07_rap.ver03:before, .sec07_rap.ver03:after {
    position: absolute;
    content: '';
    background-size: auto;
}
.sec07_rap.ver03:before {
    background-image: url(img/jyumokusou_21.png);
    top: -113px;
    right: -130px;
    width: 316px;
    height: 266px;
}
.sec07_rap.ver03:after {
    background-image: url(img/jyumokusou_23.png);
    bottom: -130px;
    left: -220px;
    width: 409px;
    height: 273px;
}
.sec07_products {
    width: 9em;
    display: inline-block;
}
.sec07_price {
    width: 5em;
    display: inline-block;
    text-align: right;
}
.h2_box {
    border-bottom: #45569E solid 3px;
    margin: 30px 40px 30px 70px;
    align-items: center;
    padding: 40px 0 20px;
}
.h2_box h2 {
    font-size: 30px;
    width: 48%;
}
.h2_box p {
    width: 52%;
    font-size: 13px;
    line-height: 1.6em;
}
.sec07_co_box {
    justify-content: space-between;
    align-items: center;
    margin: 0 40px 60px 70px;
}
.sec07_img {
    width: 50%;
    max-width: 325px;
}
.sec07_text {
    width: 50%;
}
.sec07_p1 {
    line-height: 2em;
    margin-bottom: 22px;
}
p.sub_copy {
	font-size: 1.2rem;
}
.cost-feature {
	margin-left: 2rem;
    margin-bottom: 10px;
}
.cost-feature li {
	font-size: 1rem;
}
.sec08 {
    padding: 200px 0 60px;
    background-image: url(img/jyumokusou_17.png);
    background-repeat: no-repeat;
    background-position: left top;
    background-size: auto;
}
.sec08_p1, .sec08_p2, .sec08_p3, .sec08_p4 {
    background-image: url(img/jyumokusou_18.png);
    background-repeat: no-repeat;
    background-position: left top;
    background-size: auto;
    height: 95px;
    display: grid;
    align-items: center;
    padding-left: 50px;
    margin-bottom: 20px;
}
.sec08_p2 {
    margin-left: 13%;
}
.sec08_p3 {
    margin-left: 26%;
}
.sec08_p4 {
    margin-left: 39%;
}
.sec08_p5 {
    font-size: 19px;
    line-height: 2em;
    background-color: #45569E;
    border-radius: 16px;
    padding: 20px 0;
    letter-spacing: 2px;
}
.sec09 {
    width: 100%;
    overflow: hidden;
    position: relative;
    padding: 0 0 80px;
    background-color: #f1efec;
}
.sec09:before {
    position: absolute;
    content: '';
    width: 0;
    height: 0;
    border-style: solid;
    border-width: 0 50vw 100px 50vw;
    border-color: #f1efec #fff #f1efec #fff;
    left: 0;
    right: 0;
    margin: 0 auto;
    top: 0px;
}
.sec09 .cont_h2ver2 {
    margin-top: 100px;
}
.sec09_rap {
    justify-content: space-between;
}
.sec09_box {
    width: 26%;
    border-radius: 30px;
    background-color: #FFF;
    padding: 30px 3% 20px;
    text-align: center;
}
.sec09_img {
    max-width: 145px;
    width: 100%;
    margin: 20px auto 30px;
}
.sec09 .font_16 {
    letter-spacing: 1px;
}
.sec09 .font_18.last {
    padding: 15px 0;
}
.sec10 {
    background-image: url(img/cont_bg001.jpg);
    background-repeat: repeat-y;
    background-position: center top -10px;
    background-size: cover;
    padding: 80px 0 20px;
}
.sec10_rap {
    padding: 100px 0 100px;
}
.sec10_box01 {
    background-color: #FFF;
    margin-bottom: 40px;
}
.sec10_box01 figure {
    max-width: 408px;
    width: 50%;
}
.sec10_text {
    width: 50%;
    padding: 4% 3% 2% 5%;
}
.sec10_link {
    margin: 0 auto;
    text-align: center;
    margin-top: 50px;
}
.plan_link2 {
    width: 100%;
    max-width: 200px;
    font-size: 16px;
    margin: 0 auto;
    background-color: #45569E;
    color: #fff;
    padding: 15px 80px;
    border-radius: 40px;
}
.sec10 .cont_h2ver2.ver2 {
    line-height: 0.6em;
}
.sec10_rap2 {
    justify-content: space-between;
}
.sec10_box02 {
    background: #FFF;
    width: 41%;
    padding: 6% 3% 7% 4%;
}
.sec10_p1 {
    border-bottom: #45569E 4px dotted;
    font-size: 18px;
    padding-bottom: 16px;
    margin-bottom: 20px;
}
.sec11 {
    padding: 100px 0 100px;
    position: relative;
}
.sec11:before {
    position: absolute;
    content: '';
    left: 0;
    right: 0;
    bottom: 0;
    border-bottom: #45569E solid 5px;
    width: 150px;
    margin: 0 auto;
}
/*------------------------------
ここからアコーディオンのCSS--accordion_innr--
------------------------------*/
.accordionwrap {
    max-width: 860px;
    margin: 0 auto;
}
.checkbox_inp {
    display: none;
}
.accordion_innr {
    width: 100%;
    display: block;
    background-color: #FFF;
    margin-bottom: 26px;
}
.accordion_open {
    cursor: pointer;
    background-color: #dde1ed;
}
.label_op_box {
    display: flex;
    width: 100%;
    padding: 24px 0 20px;
    justify-content: space-between;
    align-items: center;
    position: relative;
}
.accordion_open {
    position: relative;
    max-width: 860px;
    width: 100%;
    display: block;
    background-color: #dde1ed;
}
.open_cont {
    background-image: url(img/jyumokusou_19.png);
    width: 80%;
    display: block;
    text-align: left;
    margin-left: 84px;
    padding-left: 1.4em;
    font-size: 17px;
    font-weight: 500;
    line-height: 1.4em;
    background-repeat: no-repeat;
    background-position: left -4px top 1px;
    background-size: auto;
}
.open_icon_l {
    color: #06F;
    font-size: 32px;
    width: 70px;
    height: 100%;
    display: block;
    position: absolute;
    border-radius: 10px 50% 50% 10px;
}
.open_icon_l .qa_a {
    width: 35px;
    height: 35px;
    position: relative;
    top: 34%;
    left: 56px;
}
.open_icon_r {
    position: absolute;
    width: 37px;
    height: 37px;
    right: 95px;
    display: block;
}
.qa_a2 {
    transition: 0.6s;
}
.accordion_close {
    display: block;
    height: 0;
    overflow: hidden;
    padding: 0;
    opacity: 0;
    padding: 0 10px;
    transition: 0.6s;
    font-weight: 700;
}
.label_cl_box {
    font-size: 16px;
    text-align: left;
    padding: 10px 85px 20px 75px;
    line-height: 1.4em;
    background-image: url(img/jyumokusou_20.png);
    background-repeat: no-repeat;
    background-position: left 73px top 9px;
    background-size: auto;
    text-indent: 1.4em;
    position: relative;
}
.label_cl_box:before {
    position: absolute;
    content: '';
    left: 70px;
    top: 0;
    border-bottom: #000 solid 1px;
    width: 84%;
}
.checkbox_inp:checked + .accordion_open + .accordion_close {
    height: auto;
    opacity: 1;
    background: #dde1ed;
    font-size: 120%;
}
.checkbox_inp:checked + .accordion_open .open_icon_r .qa_a2 {
    transform: rotate(45deg);
}
.sec12 {
    padding: 100px 0 60px;
}
.sec12_logo {
    max-width: 321px;
    margin: 0 auto;
}
.sec11_box {
    justify-content: space-between;
}
.sec11_map {
    max-width: 420px;
    width: 100%;
}
.sec11_p1 {
    border: #000 solid 2px;
    display: inline-block;
    padding: 4px 14px;
    font-size: 15px;
}
.sec11_text {
    align-items: center;
    justify-content: space-around;
}
.g_map {
    max-width: 1170px;
    margin: 0 auto;
    width: 100%;
}
.g_map iframe {
    width: 100%;
    height: 400px;
}
.sec13 {
    background-color: #f0efeb;
    background-image: url(img/jyumokusou_06.png);
    background-repeat: repeat-y;
    background-position: center top -180px;
    position: relative;
    padding: 100px 0 122px;
}
.sec13:before {
    position: absolute;
    content: '';
    bottom: 0;
    right: 0;
    background-image: url(img/jyumokusou_57.jpg);
    background-repeat: no-repeat;
    background-position: right bottom;
    background-size: auto;
    max-width: 281px;
    height: 104px;
    width: 100%;
}
.sec13_h2 {
    font-size: 35px;
    line-height: 1.4em;
    letter-spacing: 3px;
    margin-bottom: 16px;
}
.form_wrap {
    background-color: #FFF;
    padding: 80px 100px;
}
.footer {
    background-image: url(img/jyumokusou_58.jpg);
    background-repeat: no-repeat;
    background-position: left top;
    padding: 120px 0 0;
}
.footer_rap {
    justify-content: space-between;
}
.footer_box {
    height: 450px;
}
.footer_box.ver1 {
    width: 35%;
    padding: 80px 6% 0 10px;
	margin-right:50px;
}
.footer_box.ver2 {
    width: 60%;
	text-align:right;
}
.copyright {
    font-size: 14px;
    text-align: center;
    background-color: #f0efeb;
    padding: 14px 0;
    width: 100%;
}
.fb_iframe_widget iframe {
    height: 485px !important;
}
.fb_iframe_widget span {
}
.fb_iframe_widget iframe {
}
.footer_box ver2 ._5v3q ._5pbx p:first-child {
    font-size: 16px;
}
/****221216追記***/
.fb_iframe{
	width: 100%;
	white-space:320px;
}
.sec11_p3{
	margin-left:16px;
}
.sec01_box{
	flex-wrap: wrap;
}
/********************************
レスポンシブ
********************************/
@media screen and (min-width: 1400px) {
    .sec02v2_05 {
        background-position: left 16vw top;
    }
}
@media screen and (max-width: 1170px) {
    .fv_h2 {
        font-size: 4.4vw;
    }
    .sec07 .inner860 {
        width: 90%;
    }
    .sec07_rap.ver01:before, .sec07_rap.ver01:after {
        background-size: contain;
        width: 100%;
        background-repeat: no-repeat;
        right: 0;
        background-position: right;
    }
    .sec07_rap.ver02:before, .sec07_rap.ver02:after {
        right: 0;
        background-size: contain;
        width: 100%;
        background-repeat: no-repeat;
        background-position: right;
    }
    .sec07_rap.ver03:before, .sec07_rap.ver03:after {
        width: 100%;
        left: 0;
        background-size: contain;
    }
}
@media screen and (max-width: 860px) {
    .sec04_h2 {
        font-size: 4.2vw;
        left: 14vw;
    }
    .pc_only.v2 {
        display: none;
    }

}
/********************************
モバイル共通
********************************/
.sp_only_b {
    display: none;
}
.sp_only, .br_sp {
    display: none;
}
.sp_only480, .br_sp480 {
    display: none;
}
@media only screen and (max-width: 767px) {
    /********************************
モバイル基本
********************************/
    .pc_only {
        display: none;
    }
    .sp_only_b {
        display: block;
    }
    .sp_only, .br_sp {
        display: inline-block;
    }
    .flex_column {
        flex-direction: column;
    }
    .flex {
        flex-direction: column
    }
    .sp_width90, .inner860, .sec01_box figure, .sec02_box_t, .sec06_text {
        width: 90%;
        margin-left: 5%;
        margin-right: 5%;
        text-align: center;
    }
    .sp_mb_20 {
        margin-bottom: 20px !important;
    }
    .cont_p, .sec01_box .cont_p {
        font-size: 16px;
        line-height: 1.4em;
    }
    .sp_align_l, .sec04_box_text {
        text-align: left;
    }
    /***共通***/
    .head_logo {
        max-width: 767px;
        width: 100%;
    }
    .margin_0, top_tel, .kengaku_link {
        margin: 0;
    }
    .padding_0, .kengaku_link_box, .sec01_box .cont_p, .cont_p_ver2.t_left {
        padding: 0;
    }
    .kengaku_link {
        padding: 10px 0 6px;
        width: 300px;
    }
    .top_tel {
        margin-right: 0;
    }
    .tel_box {
        padding-right: 0;
    }
    .tel_box .t_right {
        text-align: center;
    }
    .fv_h2 {
        top: 30px;
        text-shadow: 3px 3px 3px #000, -3px -3px 3px #000;
    }
    .header_sou.pb_100 {
        padding-bottom: 20px !important;
    }
    .sec01_box .cont_p {
        margin-bottom: 30px;
    }
    .t_center.mb_160 {
        margin-bottom: 30px !important;
    }
    .sec02_03 {
        background: none;
    }
    .sec02_box_img {
        margin-top: -70px;
    }
    .sec02_box_t {
        margin-bottom: 50px;
    }
    .naw_tel_number {
        font-size: 30px;
    }
    .naw_tel_number a {
        font-size: 30px;
    }
    .tel_logo img {
        width: 40px;
    }
    .sns_box {
        margin: 0;
        width: inherit;
    }
    .sns_box figure {
        width: 50%;
        max-width: inherit;
        margin: 0 auto 20px;
    }
    .sns_01 {
        order: 1;
    }
    .sns_02 {
        order: 3;
    }
    .bg_gray_domu {
        height: 60px;
        margin-top: -60px;
    }
    .sec02_05_rap.pb_200 {
        padding-bottom: 100px !important;
    }
    .sec02_box .cont_p_ver3 {
        line-height: 1;
    }
	.movie {
		width: 94%;
	}
    .now_tel {
        padding-top: 10px !important;
    }
    .text-center {
        text-align: center;
    }
    .sec03_box {
        margin-bottom: 20px;
        width: 80%;
        margin: 0 10% 20px;
    }
    .sec03_box_img {
        margin: 0 auto 20px;
    }
    .sec03_box_p {
        width: 80%;
    }
    .sec03_box_p, .sec03_box_p2 {
        text-align: left;
    }
    .sec03 {
        padding-bottom: 30px;
    }
    .sec04_box_img {
        width: 100%;
        right: inherit;
    }
    .sec04_box {
        padding-bottom: 20px;
    }
    .sec04_box.inner860 {
        margin-left: 3% !important;
    }
    .sec04_box_p {
        padding-top: 20px;
        width: 100%;
    }
    .sec04_box_text {
        width: 90%;
        padding-left: 10%;
    }
    .sec04_h2 {
        top: 14px;
        left: 86px;
        font-size: 19px;
        line-height: 1.4em;
        text-align: left;
    }
    .sec04_h2.ver2 {
        line-height: 2.8em;
    }
    .sec04_h2 .font_s40 {
        top: 0;
    }
    .plan_link {
        background-size: contain;
        max-width: 260px;
        font-size: 20px;
        padding: 10px 0;
        margin-bottom: 20px;
    }
    .sec05 {
        background-size: 60%;
        padding-bottom: 75px;
    }
    .sec05_link {
        margin: -80px auto 0;
    }
    .sec02.ver2 {
        background-size: 60%;
        padding-top: 14px;
    }
    .sec02.ver2 .cont_p {
        text-align: left;
    }
    .sec02v2_01 {
        background: none;
    }
    .sec02v2_img_l, .sec02v2_img_r {
        width: 100%;
        text-align: center;
    }
    .cont_p_ver2.t_left {
        text-align: left;
        padding-bottom: 10px;
    }
    .sec02v2_05 .cont_p_ver2.t_left, .cont_p_ver2 {
        text-align: center;
        padding-bottom: 10px;
    }
    .mt_m108 {
        margin: 0;
    }
    .sec02v2_img_l.mt_100 {
        margin-top: 30px !important;
    }
    .sec02v2_05 .inner860 {
        background-color: rgba(255, 255, 255, 0) !important;
    }
    .sec02v2_05:before {
        padding-top: 1900px;
        margin-top: 162px;
    }
    .cont_p_ver2.mb_20, .sec02v2_img_l.mt_100.mb_20 {
        margin-bottom: 0 !important;
    }
    .sec06 {
        margin-top: 0;
    }
    .cont_h2ver3 {
        font-size: 33px;
        text-align: left;
        margin-bottom: 20px;
        line-height: 1em;
    }
    .sec06 span.h2ver2 {
        font-size: 20px;
        margin-left: 10px;
        padding-left: 20px;
    }
    .sec06 span.h2ver2:before {
        top: -3px;
    }
    .sec06_text, .sec06_ul.cont_p_ver2 {
        margin: 10px auto 10px;
        text-align: left;
    }
    .cont_h2ver3 .sp_only {
        position: relative;
        top: -20px;
        left: 50px;
    }
    .sec06_box {
        margin-bottom: 70px;
    }
    .sec06_box:before {
        bottom: -30px;
    }
    .sec06:after {
        border-width: 70px 50vw 0 50vw;
    }
    .sec07 .inner860 {
        width: 90%;
    }
    .sec07 {
        padding: 40px 0 52px;
        background-size: 40%;
    }
    .sec07_h2 {
        margin-bottom: 30px;
    }
    .sec07_rap.ver01:before, .sec07_rap.ver01:after, .sec07_rap.ver02:before, .sec07_rap.ver02:after, .sec07_rap.ver03:before, .sec07_rap.ver03:after {
        width: 40%;
    }
    .sec07_products,
    .sec07_price,
    .sec07_tax {
        font-size: 0.9em;
    }
    .h2_box {
        margin: 20px 10px 20px;
        padding: 10px 0 10px;
    }
    .h2_box h2 {
        width: 100%;
        font-size: 25px;
        margin-bottom: 10px;
    }
    .h2_box p {
        width: 100%;
        text-align: left;
    }
    .sec07_co_box, .sec07_p1 {
        width: 100%;
        margin: 0;
    }
    .sec07_img, .sec07_text {
        width: 90%;
        max-width: inherit;
        margin-bottom: 10px;
    }
    .sec07_text, .sec07_text .cont_p_ver2 {
        text-align: left;
    }
    .sec07_rap.ver03:after {
        bottom: -120px;
    }
    .sec08 {
        background-size: 40%;
        padding: 100px 0 60px;
        margin-top: -1px;
    }
    .sec08 .cont_h2ver2 {
        font-size: 26px;
    }
    .sec08_p1, .sec08_p2, .sec08_p3, .sec08_p4 {
        text-align: left;
        height: inherit;
        background-position: left center;
        padding-left: 26px;
        margin-bottom: 30px;
        margin-left: 0;
        font-size: 90%;
    }
    .sec08_p4.ver2 {
        height: 95px;
    }
    .sec08_p5 {
        line-height: 1.6em;
        padding: 20px;
    }
    .sec09:before {
        border-width: 0 50vw 50px 50vw;
    }
    .sec09_box {
        width: 94%;
        margin-bottom: 20px;
    }
    .sec09 {
        padding-bottom: 40px;
    }
    .sec09 .font_16 {
        width: 90%;
        margin: auto;
    }
    .sec10 {
        background-size: auto;
        padding: 40px 0 40px
    }
    .sec10_rap {
        padding: 30px 0 30px;
    }
    .sec10_box01 figure {
        width: 100%;
        max-width: inherit;
    }
    .sec10_text {
        width: 92%;
        padding: 14px 4% 20px;
        text-align: left;
    }
    .sec10_text .cont_h2ver2 {
        font-size: 22px;
    }
    .sec10_box02 .font_16 {
        text-align: left;
    }
    .sec10_link {
        margin: 30px auto 16px;
    }
    .sec10_box02 {
        width: 93%;
        margin-bottom: 20px;
    }
    .sec10_rap2.mb_30 {
        margin-bottom: 0 !important;
    }
    .sec10_box02 .font_16 {
        text-align: left;
    }
    .sec10 .font_16.mb_80 {
        margin-bottom: 40px !important;
    }
    .open_cont {
        margin-left: 20px;
    }
    .open_icon_r {
        right: 10px;
        width: 20px;
        height: 20px;
    }
    .label_cl_box {
        padding: 10px 10px 20px;
        background-position: left 7px top 9px;
    }
    .label_cl_box:before {
        left: 14px;
        width: 95%;
    }
    .sec11 {
        padding: 40px 0 40px;
    }
    .sec11_map {
        margin: 0 auto;
    }
    .sec12 {
        padding: 40px 0 30px;
    }
    .sec11_p1 {
        margin-bottom: 10px;
    }
    .sec11_p2 {
        margin-bottom: 30px;
    }
    .sec11_box.mb_100 {
        margin-bottom: 30px !important;
    }
    .form_wrap.inner860 {
        width: inherit;
    }
    .sec13 {
        padding: 40px 0 122px;
    }
    .sec13:before {
        background-size: 50%;
    }
    .sec13 .inner860 {
        width: 80%;
    }
    .sec13_h2 {
        font-size: 27px;
    }
    .sec13 .font_15 {
        margin-bottom: 30px !important;
        font-size: 13px;
    }
    .footer {
        background-size: 40%;
        padding: 60px 0 200px;
    }
    .footer_rap {
        padding-bottom: 20px;
    }
    .footer_box {
        width: 96%;
    }
    .footer_box.ver1 {
        padding: 40px 2% 30px;
        height: 300px;
		width:80%;
		display:block;
		margin:0 auto;
    }
    .footer_box.ver2 {
        margin-bottom: 20px;
        padding: 10px 0% 50px;
		width:100%;
		text-align:center;
		margin:0 auto;
		min-height:500px;
    }
	.fb_iframe{
	width:90%;
	max-width:320px;
	}
.sec01_box figure{
	width:100%;
	margin-left: 0;
}
	.sec06_img {
    max-width: 100%;
}
}
@media only screen and (max-width: 480px) {
    .sp_only480, .br_sp480 {
        display: inline-block;
    }
    .d_block_r {
        display: block;
        text-align: right;
    }
    .plan_link2 {
        padding: 10px 60px;
    }
    .sec02v2_05:before {
        padding-top: 402vw;
    }
    .sec07_co_box .sp_sec07 {
        text-align: right;
        font-size: 16px;
    }
    div.mfp_buttons {
        margin-bottom: 20px;
    }
}
/***********************************
フローティングバナー追加230518
***********************************/
.floating_area{
	width:27rem;
	background-color:rgba(255, 255, 255,1);
	border-radius: 1rem 0 0 1rem;
	text-align:center;
	display:flex;
	justify-content: center;
	padding:1rem 0;
	position:fixed;
	right:0;
	bottom:107px;
	z-index:8;
}
.floating_box{
	gap:10px;
	margin-bottom:10px;
}
.floating_btn001{
	position:relative;
	display: inline-grid;
	align-items: center;
	background-color: #45569E;
	border:1px solid #45569E;
	color:#FFF;
	padding:0.2rem 0.4rem;
	border-radius:0.6rem;
	line-height:1.2rem;
	z-index:6;
	overflow:hidden;
	font-size:18px;
	width:100%;
	
}
.floating_btn001 span.font_s80{
	font-size:80%;
}
.floating_btn001:hover{
	color:#45569E;
	opacity:1;
}
.floating_btn001:after ,
.pop-up-open:after {
	content: '';
	/*絶対配置で位置を指定*/
	position: absolute;
	top: 0;
	left: 0;
	/*色や形状*/
	width: 102%;
	height: 102%;
	/*アニメーション*/
	transition: transform .4s ;
	transform: scale(0, 1);
	transform-origin: right top;
}
.floating_btn001:after{
	background:#f1efec ;/*背景色*/
}
.pop-up-open:after {
	background:#45569E ;/*背景色*/
}
.floating_btn001:hover:after,
.pop-up-open:hover:after{
	transform-origin:left top;
	transform:scale(1, 1);
	z-index: -1;
}
span.online {
    line-height: 1;
    display: block;
}
/**popup***/
.pop-up-open {
	position:relative;
	cursor:pointer;
	display: inline-grid;
	align-items: center;
	background-color: #f1efec;
	border:1px solid #45569E;
	color:#45569E;
	padding:0.4em 0;
	border-radius:0.6rem;
	line-height:1.2rem;
	min-height:1.8rem;
	width:100%;
	z-index:2;
	overflow:hidden;
	margin-bottom:0.6rem;
	font-size: 20px;
}
.pop-up-open:hover{
	color:#FFF;
}
.pop-up {
	display: none;
}
.pop-up-overlay {
	display: none; 
}
.pop-up:checked + .pop-up-overlay {
	display: block;
	z-index: 9999;
	background-color: #00000070;
	position: fixed;
	width: 100%;
	height: 100vh;
	top: 0;
	left: 0;
}
.pop-up-window {
	width: 90%;
	max-width:500px;
	height: 100px;
	border-radius: 6px;
	display: flex;
	justify-content: center;
	align-items: center;
	position: fixed;
	top: 18%;
	left: 50%;
	transform: translate(-50%, -50%);
}
.pop-up-box {
	position:absolute;
	font-size: 18px;
	margin: 30px auto 0;
	top:-90%;
}
.pop-up-close {
	cursor:pointer;
	position: absolute;
	top: -60px;
	right: 0px;
	font-size: 30px;
	height:30px;
	width:30px;
	display: grid;
	align-items: center;
	background-color:#FFF;
	z-index:2;
		border-radius:6px;
}
.pop-text-window{
	padding:10px;
	color:#000;
}
.pop-text-submit{
	padding:10px;
}
/**end:popup***/
.floating_p2{
	font-size:14px;
}
.floating_p3 , .floating_p3 a{
	position:relative;
	color:#E07768;
	font-size:40px;
	font-weight:bold;
	letter-spacing: 4px;
	margin-bottom: 10px;
}
.floating_p3 img{
	position:relative;
	width:50px;
	height:auto;
	top:7px;
	padding-right:10px;
}
.floating_p2.v2{
	margin-top:-4px;
}
.pop-up-box{
	border-radius:10px;
}
.pop-up-box img{
	width:100%;
	max-width:500px;
	height:auto;
	border-radius:6px;
}
.flo_area_head{
	position:fixed;
	font-size:30px;
	border:none;
	border-radius:8px 8px 0 0;
	padding:6px 15px;
	color:#45569E;
	right:0;
	bottom: 360px;
	cursor:pointer;
	transition: 0.4s;
}
.flo_area_head.is-open{
	top:auto;
	bottom:0;
	opacity:0.4;
	border-radius:8px;
}
.flo_area_body{
	opacity:1;
	transition: 0.4s;
}
.flo_area_body.is-open{
	opacity:0;
	height:0;
	display:none;
}
@media only screen and (max-width: 767px){
.floating_box{
	flex-direction: row;
	justify-content: space-between;
}
.floating_area_rap{
	width:96%;
	padding:0 2%;
}
.floating_area{
	width:100%;
	position:fixed;
	top: inherit;
	bottom:0;
	background-color:#ffffff;
	border-radius:0;
	padding:1rem 0 2rem;
	right:inherit;
}
.floating_p3, .floating_p3 a{
	font-size:26px;
	margin-top:-14px
}
.floating_btn001{
	white-space:nowrap;
	padding: 0.2rem 0rem;
	width:100%;
}
.floating_p3 img{
	width: 38px;
	top: 8px;
}
.pop-up-open{
	margin-bottom: 0.2rem;
	padding: 0.2em 0;
}
.floating_p2 {
	font-size: 16px;
    margin-bottom: 10px;
}
.flo_area_head{
	top:inherit;
	bottom:241px;
}
}
.fb_iframe{
	width: 100%;
	white-space:320px;
}
/*****************
0619文字を大きくする修正
******************/
.sec11_p3{
	margin-left:16px;
}
.sec11_map{
	max-width:none;
}
.sec11_text.flex {
	justify-content: center;
	gap:1em;
}
.cont_h2ver2 .font_s50.custom0619{
	margin-top: -0.5em;
	text-align:right;
	display:block;
	line-height:0.6em;
}
/**480**/
@media only screen and (max-width: 480px) {
.sec11_p1 , .sec11_p2.font_16 , .font_16 , .sec06_li , .sec02v2_05 .cont_p_ver2.t_left, .cont_p_ver2 , .h2_box p , .cont_h2ver2 .font_s50 ,
.sns_box .font_s60 , .sec04_box_p , .sec04_h2 .font_s40 , .sec08_p1, .sec08_p2, .sec08_p3, .sec08_p4 , .open_cont , .label_cl_box{
	font-size:18px;
}
.sec06 span.h2ver2 , .sec07_p1.sp_only .sec07_products, .sec07_p1.sp_only .sec07_price , .sec08_p5{
	font-size:24px;
}
.fv_h2{
	font-size:20px;
}
.sec07_p1.sp_only .sec07_products , .sec07_p1.sp_only .t_right {
	 display:block;
}
.top_h2 {
	font-size: 200%;
}
.cont_h2ver2 .font_s50.custom0619{
	line-height:1.6em;
}
.fv_img img {
	object-fit: cover;
	height: 340px;
}
.top_tel a{
	font-size:26px;
}
.label_cl_box{
	background-size: 29px;
}
.right_bloc{
	text-align:right;
	display:block;
}
.footer .inner860{
	width:96%;
	margin-left:2%;
	margin-right:2%;
}
.footer .sns_box.flex.inner860{
	width: auto;
	margin-left:0;
	margin-right:0;
}
.sec11_p3.font_16{
	margin-left:0;
	text-align:left;
}
.sec13 .sp-break , .sec13 .contact-form th , .sec13 .contact-form td{
	line-height:2em;
}
.sec13 .note{
	text-align:left;
}
.cont_h2ver2{
	font-size:26px;
	white-space:nowrap;
}
.cont_h2ver2.mb_30.ver2{
	white-space:normal;
}
.sec04_h2{
	left:80px;
}
.sec04_h2.v2{
	margin-top:-6px;
}
.sec05_link{
	margin: -40px auto 0;
}
.sec07_p1.sp_only br{
	line-height:0;
	height:0;
	display: contents;
}
.cont_h2ver2 .font_s50.custom0619{
	margin-top: -0.5em;
	text-align:right;
	display:block;
}
.cont_h2ver2.mb_30.ver2 .font_s50{
	margin-top:0;
	display:inline;
}
.cont_h2ver2.mb_30.ver2{
	line-height:1em;
}
.cont_p, .sec01_box .cont_p {
	font-size: 22px;
	line-height: 1.6em;
	text-align:left;
	letter-spacing:normal;
	padding-left:1em;
}
.h2ver2 .font_s50{
	font-size:80%;
	text-align: right;
	display:block;
	line-height:0.5em;
	font-weight:normal;
}
.sec06_li{
	line-height:1.8rem;
}
.sec06_ul , .sec06_text, .sec06_ul.cont_p_ver2{
	margin-bottom:0;
	padding-bottom:0;
}
.sec04_h2.v2 {
	margin-top:14px;
	font-size: 16px;
}
}
/********スライダー追加********/
.sliderArea .slick-next{
	right: 10px;
}
.sliderArea .slick-prev{
	left: 10px;
	z-index: 1;
}