/* ----------------------------------------
田舎暮らし特集
---------------------------------------- */
.sp_off {
 display: none !important;
}

.iju_menu ul {
 width: 90%;
 margin: 30px auto;
 display: -webkit-flex;
 display: -moz-flex;
 display: -ms-flex;
 display: -o-flex;
 display: flex;
 justify-content: space-between;
 flex-wrap: wrap;
 background: #fff;
 box-shadow: 0 0 6px rgb(0 0 0 / 15%);
 border-radius: 5px;
}


.iju_menu ul li {
 width: 50%;
}

.iju_menu ul li a {
 display: block;
 color: #4e3426;
 text-align: center;
 font-size: 14px;
 font-weight: bold;
 line-height: 50px;
 position: relative;
}

.iju_menu ul li a::before {
 content: "";
 display: block;
 width: 0;
 height: 0;
 border-top: 4px solid transparent;
 border-left: 4px solid #ccc;
 border-bottom: 4px solid transparent;
 position: absolute;
 right: 15px;
 top: 22px;
 transform: rotate(90deg);
}

.iju_menu ul li:nth-child(3) a {
 font-size: 11px;
}

.iju_wrap {
 overflow: hidden;
}

.iju_wrap h2 {
 font-size: 5vw;
 font-weight: bold;
 margin: 0 0 30px;
 line-height: 30px;
 letter-spacing: 0.01em;
 text-align: center;
}

.iju_wrap p {
 color: #000;
 font-size: 3.5vw;
 line-height: 180%;
 letter-spacing: 0.01em;
 font-weight: 500;
}

.iju_wrap h2::after {
 content: "";
 display: block;
 background: url(../iju/img/ti_border.png);
 background-size: contain;
 background-repeat: no-repeat;
 width: 100px;
 height: 10px;
 margin: 10px auto;
}

.iju_main {
 width: 100%;
 background: url(../iju/img/main_bg.png);
 background-position: center;
 background-size: cover;
 height: 260px;
 box-sizing: border-box;
 text-align: center;
 padding: 7vw 5% 0;
}

.iju_about {
 width: 90%;
 margin: 60px auto;
 position: relative;
}

.iju_about::before {
 content: "";
 display: block;
 background: url(../iju/img/c_point.png);
 background-size: contain;
 background-repeat: no-repeat;
 width: 100px;
 height: 118px;
 position: absolute;
 left: -3%;
 top: -35px;
}

.iju_about::after {
 content: "";
 display: block;
 background: url(../iju/img/w_icon01.png);
 background-size: contain;
 background-repeat: no-repeat;
 width: 60px;
 height: 94px;
 position: absolute;
 right: -12%;
 top: -20px;
}


.iju_about ul {
 margin: 40px 0;
 position: relative;
}

.iju_about ul li:nth-child(2) {
 margin-bottom: 130px;
}

.iju_about ul li:nth-child(2)::before {
 content: "";
 display: block;
 background: url(../iju/img/about_bg.png);
 background-size: contain;
 background-repeat: no-repeat;
 width: 145%;
 height: 300px;
 position: absolute;
 left: 0;
 bottom: -110px;
 z-index: -1;
}

.iju_about ul li {
 margin-bottom: 40px;
 position: relative;
}


.iju_about_txt {}

.iju_about_txt h3 {
 font-size: 4.5vw;
 font-weight: bold;
 letter-spacing: 0.05em;
 line-height: 30px;
 margin: 15px 0;
}

.iju_about_txt h3 span {
 color: #efb460;
 font-size: 6vw;
 font-weight: bold;
 letter-spacing: 0.05em;
 margin-right: 10px;
}

.iju_about_txt p {
 font-weight: 500;
 text-align: left;
}

.iju_about_txt p a {
 color: #000;
 text-decoration: underline;
}


.iju_bukken {
 width: 90%;
 box-sizing: border-box;
 margin: 60px auto 120px;
 border-radius: 15px;
 box-shadow: 0 0 8px rgb(0 0 0 / 20%);
 overflow: hidden;
 position: relative;
 padding: 30px 0;
 background: url(../iju/img/bukken_bg.png);
 background-position: -195px 310px;
 background-repeat: no-repeat;
}

.iju_bukken::before {
 content: "";
 display: block;
 background: url(../iju/img/bukken_icon01.png);
 width: 105px;
 height: 56px;
 position: absolute;
 right: -33px;
 top: 43px;
}

.iju_bukken::after {
 content: "";
 display: block;
 background: url(../iju/img/bukken_icon02.png);
 background-size: contain;
 background-repeat: no-repeat;
 width: 121px;
 height: 40px;
 position: absolute;
 right: 180px;
 top: 15px;
}

.iju_bukken iframe {
 display: block;
 width: 100%;
 height: 280px;
 margin: 0 auto;
 border: none;
}

.iju_bukken_more a {
 display: block;
 width: 250px;
 border-radius: 30px;
 line-height: 43px;
 height: 45px;
 box-sizing: border-box;
 margin: 15px auto 0;
 background: #3a8f3e;
 border: 2px solid #fff;
 text-align: center;
 color: #fff;
 font-size: 14px;
 font-weight: bold;
}

.iju_bukken_more a:hover {
 background: #fff;
 color: #3a8f3e;
}

.sien_wrap {
 width: 100%;
 background: #85c2ba;
 text-align: center;
}

.sien_wrap p {
 color: #fff;
}

.sien_inner {
 width: 90%;
 margin: 0 auto;
 padding: 60px 0;
}

.sien_ti {
 position: relative;

}

.sien_ti::before {
 content: "";
 display: block;
 background: url(../iju/img/sien_icon.png);
 background-size: contain;
 background-repeat: no-repeat;
 width: 60%;
 height: 80px;
 margin: -110px auto 20px;
}

.sien_ti h2 {
 color: #fff;
 display: flex;
 justify-content: center;
 align-items: center;
 margin-bottom: 20px;
}

.sien_ti h2::before {
 content: "";
 display: inline-block;
 background: url(../iju/img/ti_icon_l.png);
 width: 40px;
 height: 60px;
 margin-right: 10px;
}

.sien_ti h2::after {
 content: "";
 display: inline-block;
 background: url(../iju/img/ti_icon_r.png);
 width: 39px;
 height: 60px;
 margin: 0 0 0 10px;
}

.sien_ti p {
 text-align: left;
}

.sien_ti p span {
 display: inline-block;
 background: #fff;
 color: #85c2ba;
 padding: 0 5px;
 margin: 0 5px;
}

.sien_wrap ul {
 margin: 40px 0;
}

.sien_wrap ul li {
 background: #fff;
 padding: 20px 5%;
 margin-bottom: 20px;
}

.sien_wrap ul li p {
 color: #000;
 margin-top: 30px;
}

.sien_wrap ul li p a {
 color: #000;
 text-decoration: underline;
}

.sien_contact {
 box-sizing: border-box;
 border: 1px solid #fff;
 padding: 30px 10%;
 position: relative;
 background: #85c2ba;
 margin: 0 auto;
 box-shadow: 10px 10px 0 #fff;
}


.sien_contact h3 {
 display: inline-block;
 text-align: left;
 color: #fff;
 font-size: 4vw;
 font-weight: bold;
 line-height: 160%;
 border-bottom: 1px solid #fff;
 margin: 0 0 20px;
 padding-bottom: 10px;
}

.sien_contact p {
 text-align: left;
}

.sien_contact p a {
 text-decoration: underline;
 color: #fff;
}

.sien_contact_more a {
 display: block;
 width: 90%;
 border-radius: 30px;
 line-height: 48px;
 height: 50px;
 box-sizing: border-box;
 margin: 15px auto 0;
 background: #f6a229;
 border: 2px solid #f6a229;
 text-align: center;
 color: #fff;
 font-size: 3.5vw;
 font-weight: bold;
 letter-spacing: 0.05em;
 position: relative;
}

.sien_contact_more a::before {
 content: "";
 width: 8px;
 height: 8px;
 border-top: solid 2px #fff;
 border-right: solid 2px #fff;
 display: block;
 transform: rotate(45deg);
 position: absolute;
 top: 18px;
 right: 20px;
}

.sien_contact_more a:hover {
 background: #fff;
 color: #f6a229;
}

.sien_contact_more a:hover::before {
 border-top: solid 2px #f6a229;
 border-right: solid 2px #f6a229;
}

.work_wrap {
 width: 90%;
 margin: 60px auto;
 position: relative;
}

.work_wrap::before {
 content: "";
 display: block;
 background: url(../iju/img/work_icon.png);
 background-size: contain;
 background-repeat: no-repeat;
 width: 50px;
 height: 40px;
 position: absolute;
 left: 0;
 top: -20px;
}


.work_con {
 margin-top: 40px;
}

.work_con_item {
 border: 2px solid #4e3426;
 border-radius: 10px;
 background-color: #d2e7f9;
 background-image: url(../iju/img/work_bg.png);
 background-position: center;
 padding: 20px 5%;
 box-sizing: border-box;
 margin-bottom: 30px;
}

.work_con_item h3 {
 background: #fff;
 border: 2px solid #4e3426;
 border-radius: 10px;
 width: 80%;
 text-align: center;
 margin: 0 auto 15px;
 position: relative;
 font-size: 4vw;
 font-weight: bold;
 letter-spacing: 0.1em;
 line-height: 40px;
}

.work_con_item h3::before {
 content: "";
 display: block;
 background: url(../iju/img/work_ti_icon.png);
 background-size: contain;
 background-repeat: no-repeat;
 width: 18px;
 height: 15px;
 position: absolute;
 left: 10px;
 top: 13px;
}

.work_con_item ul {
 background: #fff;
 border: 2px solid #4e3426;
 border-radius: 10px;
 padding: 15px 4%;
}

.work_con_item ul li {
 font-size: 3.5vw;
 line-height: 180%;
 letter-spacing: 0.05em;
}

.work_con a:hover {
 opacity: 0.8;
}

.iju_contact_wrap {
 width: 100%;
 background: #fff8ed;
 padding: 40px 0 35px;
 margin: 60px 0;
 overflow: hidden;
}

.iju_contact_inner {
 width: 90%;
 margin: 0 auto;
 position: relative;
 text-align: center;
}

.iju_contact_inner::before {
 content: "";
 display: block;
 background: url(../iju/img/w_icon02.png);
 width: 138px;
 height: 198px;
 position: absolute;
 right: -110px;
 bottom: -25px;
}

.iju_contact_inner::after {
 content: "";
 display: block;
 background: url(../iju/img/w_icon03.png);
 width: 105px;
 height: 223px;
 position: absolute;
 left: -140px;
 bottom: 0;
}

.iju_contact_inner p {
 font-size: 4vw;
 font-weight: bold;
 letter-spacing: 0.1em;
 margin: 0;
}

.iju_tel {
 background: #fff;
 padding: 10px 0;
 box-sizing: border-box;
 font-size: 6vw;
 font-weight: bold;
 letter-spacing: 0.05em;
 margin: 30px auto;
}

.iju_tel span {
 font-size: 12px;
 font-weight: 500;
 letter-spacing: 0;
}

.iju_contact_inner ul {}

.iju_contact_inner ul li a {
 display: block;
 width: 90%;
 text-align: center;
 background: #f6a229;
 color: #fff;
 font-weight: bold;
 line-height: 50px;
 border-radius: 10px;
 box-shadow: 0 5px 0 #c58220;
 position: relative;
 font-size: 3.8vw;
 letter-spacing: 0.1em;
 margin: 0 auto 15px;
}

.iju_contact_inner ul li a::before {
 content: "";
 width: 8px;
 height: 8px;
 border-top: solid 2px #fff;
 border-right: solid 2px #fff;
 display: block;
 transform: rotate(45deg);
 position: absolute;
 top: 20px;
 right: 17px;
}

.iju_contact_inner ul li a:hover {
 box-shadow: none;
 transform: translateY(4px);
}

.iju_voice_wrap {
 width: 90%;
 margin: 60px auto 0;
 position: relative;
}

.iju_voice_wrap::before {
 content: "";
 display: block;
 background: url(../iju/img/u_voice.png);
 background-size: contain;
 background-repeat: no-repeat;
 width: 100px;
 height: 118px;
 position: absolute;
 right: -10px;
 top: -35px;
}

.iju_voice_wrap iframe {
 display: block;
 width: 100%;
 height: 290px;
 margin: 40px 0 20px;
}


.iju_voice_con ul li a {
 display: block;
 width: 260px;
 color: #000;
 margin: 0 auto;
}

.iju_voice_con ul li a:hover img {
 transform: scale(1.1, 1.1);
 transition: 0.6s;
}

.iju_v_img {
 display: block;
 width: 260px;
 height: 180px;
 overflow: hidden;
 border-radius: 10px;
}

.iju_v_img img {
 width: 260px;
 height: 180px !important;
 object-fit: cover;
 border-radius: 10px;
 transition: 0.6s;

}

.iju_v_ti {
 display: block;
 font-size: 18px;
 font-weight: bold;
 line-height: 30px;
 letter-spacing: 0.05em;
 margin: 10px 0;
 display: -webkit-box;
 display: -ms-flexbox;
 -webkit-box-orient: vertical;
 -ms-flex-direction: column;
 -webkit-line-clamp: 2;
 overflow: hidden;
}

.iju_v_name {
 font-size: 14px;
 font-weight: bold;
 line-height: 14px;
}

.iju_v_more a {
 display: block;
 width: 250px;
 border-radius: 30px;
 line-height: 48px;
 height: 50px;
 box-sizing: border-box;
 margin: 30px auto;
 background: #fff;
 border: 2px solid #4e3426;
 text-align: center;
 color: #4e3426;
 font-size: 16px;
 font-weight: bold;
 position: relative;
}

.iju_v_more a::before {
 content: "";
 width: 8px;
 height: 8px;
 border-top: solid 2px #4e3426;
 border-right: solid 2px #4e3426;
 display: block;
 transform: rotate(45deg);
 position: absolute;
 top: 18px;
 right: 20px;
}

.iju_v_more a:hover {
 color: #fff;
 background: #4e3426;
}

.iju_v_more a:hover::before {
 border-top: solid 2px #fff;
 border-right: solid 2px #fff;
}

.iju_table {
 width: 100%;
}

.iju_table_ti {
 background: #4e3426;
 color: #fff;
 font-size: 4.5vw;
 font-weight: bold;
 letter-spacing: 0.05em;
 text-align: center;
 line-height: 60px;
}

.iju_table h3 {
 font-size: 4vw;
 font-weight: bold;
 letter-spacing: 0.05em;
 margin: 30px 0;
 text-align: center;
}

.iju_table_con,
.iju_table_con_r {
 border: 2px solid #4e3426;
 padding: 20px;
}


.iju_table_con ul {
 display: block;
 padding: 0;
 margin: 0;
}

.iju_table_con ul li {
 padding: 0;
}

.iju_table_con ul li span {
 display: block;
 line-height: 40px;
 background: #4e3426;
 color: #fff;
 font-size: 3.8vw;
 font-weight: bold;
 letter-spacing: 0.05em;
 text-align: center;
 margin-bottom: 10px;
}

.iju_table_con ul li p {
 font-size: 3.5vw;
 line-height: 180%;
 font-weight: 500;
 margin: 0;
 text-align: left;
}

.iju_table_con ul li:not(:last-child) {
 margin-bottom: 20px;
}

.iju_table_subti {
 background: #4e3426;
 color: #fff;
 font-size: 16px;
 font-weight: bold;
 letter-spacing: 0.05em;
 text-align: center;
 line-height: 40px;
}

.iju_table_con_r p {
 font-size: 3.5vw;
 line-height: 180%;
 margin: 10px 0 !important;
 text-align: left;
}

.iju_table_con_r ul {
 display: block;
 padding: 0;
 margin: 0;
}

.iju_table_con_r ul li {
 padding: 0;
 font-size: 3.5vw;
 line-height: 180%;
 font-weight: bold;
 text-align: left;
 margin-bottom: 0;
}

.iju_table_con_r p span {
 font-weight: bold;
}


/* 田舎暮らし特集
---------------------------------------- */


/*-------------------------------------- 
sitemap 
---------------------------------------- */
.sitemap_ti h2 {
 width: 90%;
 font-size: 24px;
 margin: 30px auto;
 font-weight: 500;
 line-height: 1;
 font-weight: bold;
 text-align: left;
 border-bottom: none !important;
}

.sitemap_wrap {
 width: 90%;
 margin: 0 auto 60px;
 background: #f8f8f8;
 padding: 30px 5%;
 box-sizing: border-box;
}

.sitemap_inner {
 margin-bottom: 30px;
}

.sitemap_inner:last-child {
 margin-bottom: 0;
}

.sitemap_inner h3 {
 font-size: 22px;
 margin: 0 0 10px;
 font-weight: 500;
 line-height: 1.7;
}

.sitemap_inner ul {
 background: #fff;
 padding: 15px 5%;
}

.sitemap_inner ul li a {
 font-size: 14px;
 color: #333;
 line-height: 1.7;
 position: relative;
 padding-left: 20px;
 margin-bottom: 5px;
 display: block;
}

.sitemap_inner ul li a::before {
 content: "";
 width: 6px;
 height: 6px;
 border-top: 1px solid #3a8f3e;
 border-right: 1px solid #3a8f3e;
 -webkit-transform: rotate(45deg);
 transform: rotate(45deg);
 position: absolute;
 left: 0;
 top: 8px;
}

.sitemap_group {
 padding-left: 10% !important;
}

.sitemap_group_ti {
 margin-left: -5%;
}

/* sitemap
---------------------------------------- */


/* ----------------------------------------
awards
---------------------------------------- */
.aw_footer_wrap {
 background: #f5f5f5f5;
 padding-top: 5px;
}

.awards_wrap {
 overflow: hidden;
}

.aw_main_wrap {
 background: url(../awards/img/main_bg.png);
 background-size: cover;
 background-position: 20%;
 display: flex;
 justify-content: center;
 align-items: center;
 height: 150px;
 padding: 0 10%;
}

.aw_top_txt {
 width: 90%;
 margin: 40px auto;
}

.aw_top_txt p {
 font-size: 15px;
 line-height: 28px;
 color: #111;
 text-align: left;
}

.aw_top_txt ul {
 display: flex;
 justify-content: center;
 flex-wrap: wrap;
 margin-top: 30px;
}

.aw_top_txt ul li {
 width: 50%;
}

.aw_list_wrap {
 background: #f5f5f5;
 padding: 40px 5%;
}

.aw_list_wrap p {
 font-size: 16px;
 line-height: 26px;
 color: #111;
 letter-spacing: 0.05em;
}

.aw_list_ti {
 position: relative;
}

.aw_list_ti::before {
 content: "";
 display: block;
 width: 15%;
 height: 1px;
 background: #111;
 position: absolute;
 bottom: 15px;
 left: 0;
}

.aw_list_ti::after {
 content: "";
 display: block;
 width: 15%;
 height: 1px;
 background: #111;
 position: absolute;
 bottom: 15px;
 right: 0;
}


.aw_list_ti h2 {
 font-size: 30px;
 line-height: 1;
 font-weight: bold;
 text-align: center;
 color: #111;
 letter-spacing: 0.05em;
 margin: 0;
}

.aw_list_ti h2::before {
 content: "";
 background: url(../awards/img/ti_icon.png);
 background-size: contain;
 background-repeat: no-repeat;
 display: block;
 width: 30px;
 height: 26px;
 margin: 0 auto 10px;
}

.aw_list_anker {}

.aw_list_anker ul {
 display: flex;
 justify-content: center;
 flex-wrap: wrap;
 margin: 30px auto;
}

.aw_list_anker ul li {
 width: 32%;
 margin: 0.5%;
}

.aw_list_anker ul li a {
 display: block;
 background: #fff;
 color: #aaa;
 border: 1px solid #ccc;
 font-size: 14px;
 font-weight: bold;
 letter-spacing: 0.05em;
 position: relative;
 text-align: center;
 padding: 10px 0;
 border-radius: 3px;
}

.aw_list_anker ul li a::after {
 content: "";
 width: 6px;
 height: 6px;
 border-top: 1px solid #ccc;
 border-right: 1px solid #ccc;
 -webkit-transform: rotate(45deg);
 transform: rotate(135deg);
 position: absolute;
 right: 50%;
 bottom: 6px;
}

.aw_list_inner {
 background: #fff;
 padding: 30px 5%;
 border-radius: 15px;
 box-sizing: border-box;
 margin: 0 auto 40px;
}


.aw_list_inner h3 {
 font-size: 24px;
 line-height: 1;
 font-weight: bold;
 color: #111;
 letter-spacing: 0.05em;
 margin: 0;
 padding-bottom: 15px;
 border-bottom: 3px solid #ccc;
 position: relative;
 margin-bottom: 30px;
}

.aw_list_inner h3::before {
 content: "";
 display: block;
 width: 20%;
 height: 3px;
 background: #65b820;
 position: absolute;
 left: 0;
 bottom: -3px;
}

.aw_list_img {}

.aw_list_img ul {
 display: -webkit-flex;
 display: -moz-flex;
 display: -ms-flex;
 display: -o-flex;
 display: flex;
 justify-content: space-between;
}

.aw_list_con img {
 margin-top: 20px;
}

.aw_list_con ul li:not(:last-child) {
 border-bottom: 1px dashed #ccc;
 padding-bottom: 25px;
 margin-bottom: 25px;
}

.aw_list_con ul li h4 {
 font-size: 18px;
 line-height: 1.6;
 font-weight: bold;
 color: #111;
 letter-spacing: 0.05em;
 margin: 0;
 position: relative;
 padding-left: 15px;
}

.aw_list_con ul li h4:not(:first-child) {
 margin-top: 10px;
}

.aw_list_con .aw_lt_fz {}

.aw_list_con ul li h4::before {
 content: "";
 display: block;
 width: 8px;
 height: 8px;
 background: #65b820;
 position: absolute;
 top: 11px;
 left: 0;
}

.aw_list_con ul li h4 span {
 display: block;
 font-weight: 500;
 color: #111;
 line-height: 1;
}

.aw_list_con p {
 font-size: 14px;
 line-height: 24px;
 text-align: center;
 margin-top: 15px;
 text-align: left;
}

/* awards
---------------------------------------- */

/* ============================================
     sozoku
  ============================================ */
    .so_main_wrap {
    position: relative;
    width: 100%;
    height: 310px;
    background-image: url(/sozoku/img/main_bg.webp);
    background-repeat: no-repeat;
    background-position-x: center;
    background-size: cover;
    padding: 0px;
    overflow: hidden;
    position: relative;
    }

    .so_main_ti {
    bottom: 9%;
    left: 4%;
    position: absolute;
    }

    .so_main_wrap h2 {
    position: relative;
    font-family: 'Noto Serif JP', serif;
    font-size: 24px;
    font-weight: 600;
    color: #fff;
    margin: 0px;
    line-height: 1.5;
    }
    .so_main_wrap h2 span{
        border-bottom: solid 1px #fff;
        padding: 0px 0px 10px 0x;
        font-weight: 600;
    
    }

    .so_main_wrap p {
    position: relative;
    margin-top: 10px;
    font-size: 14px;
    color: rgba(255, 255, 255, 0.92);
    line-height: 1.8;
    font-family: 'Noto Serif JP', serif;
    }

  .so_nayami_wrap {
    background: #ecf4ef;
    padding: 50px 0px 40px 0px;
    font-family: 'Noto Serif JP', serif;
  }

  .so_nayami_box {
    margin: 0 auto;
    background: #fff;
    border: 2px solid #009348;
    border-radius: 4px;
    padding: 0px 4%;
    padding-top: 0px;
    border-radius: 10px;
    width: 92%;
    box-sizing: border-box;
    position: relative;
  }
  .so_nayami_box img{
    width: 20%;
    right: 2%;
    bottom: 0px;
    margin: auto;
    position: absolute;
    z-index: 10;
  }

  .so_nayami_box > h2 {
    text-align: center;
    font-size: 21px;
    font-weight: 600;
    margin-bottom: 30px;
    position: relative;
    margin: 0px;
    margin-bottom: 20px;
    margin-top: -17px;
    padding-bottom: 20px;
    line-height: 1.1;
    border-bottom: solid 2px #009348;
  }

  .so_nayami_box > h2 span {
display: block;
    text-align: center;
    font-size: 15px;
    font-weight: 600;
    background-color: #009348;
    width: fit-content;
    margin: auto;
    color: #fff;
    line-height: 2.4;
    margin-bottom: 15px;
    padding: 0px 20px;
    border-radius: 50px;
  }

  .so_nayami_box ul {
    list-style: none;
    position: relative;
  }
  .so_nayami_box ul li {
display: flex;
    align-items: flex-start;
    gap: 10px;
    font-size: 14px;
    line-height: 1.6;
    padding: 10px 0px 10px 11%;
    border-bottom: 1px solid #f0f0f0;
    background-color: #f4f4f4;
    position: relative;
    background-image: url(/sozoku/img/check_icon.webp);
    background-repeat: no-repeat;
    background-position-y: center;
    background-size: 19px;
    background-position-x: 4%;
    margin-bottom: 14px;

  }

  /* center the illustration - decorative */
  .so_nayami_box {
    position: relative;
  }
  .so_omoi_wrap {
width: 92%;
    margin: 40px auto;

  }

  .so_omoi_tex {
  }

  .so_omoi_tex h2 {
    font-family: 'Noto Serif JP', serif;
    font-size: 25px;
    font-weight: 600;
    position: relative;
    margin: 0px;
    margin-top: 0px;
    margin-bottom: 25px;
    padding-bottom: 26px;
    line-height: 1.1;
  }
  .so_omoi_tex h2::before {
    content: '';
    background-repeat: no-repeat;
    position: absolute;
    width: 58px;
    height: 2px;
    background-color: #3a8f3e;
    left: 0px;
    bottom: 0px;
}
  .so_omoi_tex p {
    font-size: 14px;
    margin-bottom: 20px;
    line-height: 1.6;
  }

  .so_omoi_img {
    width: 100%;
    position: relative;
    height: 200px;
    overflow: hidden;
    border-radius: 5px;
  }
    .so_omoi_img:last-child {
    object-fit: cover;
    width: 100%;
    height: 270px;
    }
  .so_omoi_img_b{
    position: absolute;
    bottom: -140px;
    right: clamp(150px, 22vw, 420px);
    width: clamp(150px, 28vw, 520px);
  }


  .so_example_wrap {
    margin-top: clamp(15px, 14vw, 250px);
    margin-bottom: clamp(40px, 7vw, 120px);
  }
  .so_example_wrap iframe{
    width: 100%;
    height: 340px;
    
  }
  .so_example_wrap > h2 {
    font-weight: 600;
    font-size: 25px;
    position: relative;
    margin: 0px;
    margin-top: 0px;
    margin-bottom: 25px;
    padding-bottom: 26px;
    line-height: 1.1;
    text-align: center;
    font-family: 'Noto Serif JP', serif;
  }
  .so_example_wrap > h2::before {
    content: '';
    background-repeat: no-repeat;
    position: absolute;
    width: 58px;
    height: 2px;
    background-color: #3a8f3e;
    left: 0px;
    right: 0px;
    bottom: 0px;
    margin: auto;
}
  .so_example_box {
    
  }
  .so_example_box ul {
    list-style: none;
    margin: 0 auto;
    padding: 0px;
  }
  .so_example_box ul li {
    width: 280px;
  }
  .so_example_box ul li a {
    display: block;
    background: #fff;
    border-radius: 5px;
    background-color: #f4f4f4;
    padding: 15px 5%;
    box-sizing: border-box;
    color: #000;
    position: relative;
    text-decoration: none;
}


  .so_example_img {
    width: 100%;
    height: 175px;
    background-color: #fff;
    border-radius: 5px;
    overflow: hidden;
  }
  .so_example_img img{
object-fit: cover;
        width: 100%;
        height: 175px;
        filter: brightness(84%);
  }
  .so_example_ti {
        font-family: 'Noto Serif JP', serif;
        font-size: 16px;
        line-height: 1.6;
        color: #fff;
        text-shadow: 1px 1px 4px #000000b5;
        position: absolute;
        left: 9%;
        top: 133px;
        font-weight: 600;
  }

  .so_example_ti span {
        display: block;
        font-size: 12px;
  }

  .so_example_box ul li a p {
        line-height: 1.4;
        font-size: 14px;
        margin: 15px 0px 10px 0px;
        display: -webkit-box;
        -webkit-box-orient: vertical;
        -webkit-line-clamp: 3;
        overflow: hidden;
  }

  .so_example_link {
    width: 60%;
    height: 48px;
    margin: 20px auto 0 auto;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 14px;
    font-weight: 600;
    border-radius: 5px;
    position: relative;
    border: solid 1px #333;
  }
  .so_example_link::before {
        content: "";
        width: 7px;
        height: 7px;
        display: block;
        border-top: solid 1px #009348;
        border-left: solid 1px #009348;
        transform: rotate(135deg);
        position: absolute;
        top: 50%;
        right: 18px;
        transform: translateY(-50%) rotate(135deg);
    }
    .so_example_box .slick-prev, .so_example_box .slick-next{
        width: 40px;
        height: 40px;
    }
    .so_example_box .slick-prev:before, .so_example_box .slick-next:before{
    width: 10px;
    height: 10px;
    }
    .so_example_box .slick-prev:before {
    border-bottom: 1px solid #000;
    border-left: 1px solid #000;
    left: 17px;
    }
    .so_example_box .slick-next::before {
        right: 17px;
    }
    .so_example_box .slick-dots li{
        margin: 0px 3px;
    }
    .so_example_box .slick-slide{
        margin: 0px 10px;
    }



.so_inquiry_wrap {
  background: #009348;
}
.so_inq_in {
  width: 92%;
  margin: 0 auto;
  padding: 40px 0;
  font-family: 'Noto Serif JP', serif;
  & .so_all_ti h2 {
        text-align: center;
        font-family: 'Noto Serif JP', serif;
        font-size: 20px;
        font-weight: 600;
        position: relative;
        margin: 0px;
        margin-bottom: 25px;
        padding-bottom: 25px;
        line-height: 1.4;
        color: #fff;
          &::before {
          content: '';
          background-repeat: no-repeat;
          position: absolute;
          width: 58px;
          height: 2px;
          background-color: #fff;
          left: 0px;
          right: 0px;
          bottom: 0px;
          margin: auto;
          }
  }
  & .so_all_ti::before {
    content: '';
    background-repeat: no-repeat;
    position: absolute;
    width: 58px;
    height: 2px;
    background-color: #3a8f3e;
    left: 0px;
    right: 0px;
    bottom: 0px;
    margin: auto;
  }
}
.so_inq_btn {
}
.so_inq_mail a {
    width: 100%;
    border-radius: 5px;
    border: solid 1px #fff;
    box-sizing: border-box;
    background: #fff;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 16px;
    font-weight: 500;
    position: relative;
    padding: 18px 0px;
  & i {
        position: absolute;
        top: 16px;
        left: 7%;
        margin: auto;
        color: #009348;
        font-size: 24px;
  }
  &::before {
    content: "";
    width: 10px;
    height: 10px;
    display: block;
    border-top: solid 2px #009348;
    border-left: solid 2px #009348;
    transform: rotate(135deg);
    position: absolute;
    top: 50%;
    right: 30px;
    transform: translateY(-50%) rotate(135deg);
  }
  &:hover {
    background: #009348;
    color: #fff;
    & i {
      color: #fff;
    }
    &::before {
      border-top: solid 2px #fff;
    border-left: solid 2px #fff;
    }
  }
}
.so_inq_tel {
    width: 100%;
    box-sizing: border-box;
    border-radius: 5px;
    border: solid 1px #fff;
    padding: 0px 0;
    background: #008742;
    margin: 20px 0px 0px;
}
.so_inq_tel ul {
}
.so_inq_tel ul li {
    width: 100%;
    color: #fff;
    font-size: 16px;
    font-weight: 600;
    text-align: center;
    padding: 16px 0px;
  & a {
        display: block;
        margin: 4px 0 0 0;
        color: #fff;
        font-size: 27px;
        font-weight: 500;
        display: flex;
        justify-content: center;
        align-items: center;
        line-height: 1;
    & i {
      font-size: 18px;
      margin-right: 5px;
    }
  }
}
.so_inq_tel ul li:nth-child(1) {
  border-bottom: solid 1px #fff;
}
.so_inq_btn p {
    text-align: center;
    font-size: 14px;
    font-weight: 500;
    color: #fff;
    margin-top: 17px;
}

  .so_strong_wrap {
    background-image: url(/sozoku/img/strong_bg.webp);
    padding: clamp(40px, 7vw, 120px) clamp(0px, 0%, 0px);
  }

  .so_strong_wrap > h2 {
    font-weight: 600;
    font-size: 25px;
    position: relative;
    margin: 0px;
    margin-top: 0px;
    margin-bottom: 25px;
    padding-bottom: 26px;
    line-height: 1.1;
    text-align: center;
    font-family: 'Noto Serif JP', serif;
  }

  .so_strong_wrap > h2::before {
    content: '';
    background-repeat: no-repeat;
    position: absolute;
    width: 58px;
    height: 2px;
    background-color: #3a8f3e;
    left: 0px;
    right: 0px;
    bottom: 0px;
    margin: auto;
}

  .so_strong_wrap > ul {
    list-style: none;
  }

  .so_strong_wrap > ul > li {
    position: relative;
    margin-bottom: 60px;
  }
  .so_strong_wrap > ul > li:last-child {
    margin-bottom: 0px;
  }
  .so_strong_wrap > ul > li::after{
    content: "";
    width: 100%;
    height: 200px;
    display: block;
    background-size: cover;
    margin-top: 20px;
  }
  .so_strong_wrap > ul > li:nth-child(1):after{
    background-image: url(/sozoku/img/strong_img01.webp);
    right: 0px;
  }
    .so_strong_wrap > ul > li:nth-child(2):after{
    background-image: url(/sozoku/img/strong_img02.webp);
    left: 0px;
  }
    .so_strong_wrap > ul > li:nth-child(3):after{
    background-image: url(/sozoku/img/strong_img03.webp);
    right: 0px;
  }
.so_strong_li_in{
    width: 92%;
    margin: 0 auto;
}
.so_strong_wrap > ul > li:nth-child(odd) .so_strong_li_in{
    justify-content: left;
}
.so_strong_wrap > ul > li:nth-child(even) .so_strong_li_in{
    justify-content: right;
}
  .so_strong_tex {
    width: 100%;
  }



  .so_strong_tex h3 {
    font-family: 'Noto Serif JP', serif;
    font-size: 18px;
    font-weight: 600;
    line-height: 1.5;
    position: relative;
    text-align: center;
    margin: 0px;
    padding: 25px 0px;
  }
.so_strong_tex h3 span{
    color: #009348;
        font-weight: 600;
}
.so_strong_tex h3::before {
    content: '';
    position: absolute;
    top: 0px;
    left: 0px;
    width: 40px;
    height: 40px;
    border-top: 2px solid #009348;
    border-left: 2px solid #009348;
  }

.so_strong_tex h3::after {
    content: '';
    position: absolute;
    bottom: 0px;
    right: 0px;
    width: 40px;
    height: 40px;
    border-bottom: 2px solid #009348;
    border-right: 2px solid #009348;
  }


  .so_strong_tex p {
    font-size: 14px;
    line-height: 2;
    margin: auto;
    margin-top: 15px;
  }

  /* Corner bracket decoration */
  .so_strong_tex {
    position: relative;
  }
  .so_qa_wrap{
    background-image: url(/sozoku/img/qa_bg.webp);
    padding: 40px 0px;
  }

  .so_qa_wrap > h2 {
    font-weight: 600;
    font-size: 25px;
    position: relative;
    margin: 0px;
    margin-top: 0px;
    margin-bottom: 25px;
    padding-bottom: 26px;
    line-height: 1.1;
    text-align: center;
    font-family: 'Noto Serif JP', serif;
}
  .so_qa_wrap > h2::before {
    content: '';
    background-repeat: no-repeat;
    position: absolute;
    width: 58px;
    height: 2px;
    background-color: #3a8f3e;
    left: 0px;
    right: 0px;
    bottom: 0px;
    margin: auto;
}
/* QA */

.so_qa_wrap .accordionbox{
	width: 92%;
	margin:auto;
}
.so_qa_wrap .js-animation.is-show {
    opacity: 1;
    visibility: visible;
    transform: translateY(0px);
}
.so_qa_wrap .qa_block {
    display: block;
    overflow: hidden;
    cursor: pointer;
    margin-bottom: clamp(20px, 3vw, 50px);
    border: solid 2px #3a8f3e;
    border-radius: 5px;
}
.so_qa_wrap .qa_block:last-child{
	margin-bottom: 0px;
}
.so_qa_wrap .accordionlist dt:first-child, .so_qa_wrap .accordionlist dt:nth-child(2) {
    border-top: none !important;
}
.so_qa_wrap .accordion_icon, .so_qa_wrap .accordion_icon span {
    display: inline-block;
    transition: all .4s;
    box-sizing: border-box;
}
.so_qa_wrap .accordionlist dt .title.active {
    color: #000;
    border-radius: 10px 10px 0px 0px;
}
.so_qa_wrap .accordion_icon.active span:nth-of-type(2) {
    top: 5px;
    transform: rotate(180deg);
    -webkit-transform: rotate(180deg);
    -moz-transform: rotate(180deg);
    -ms-transform: rotate(180deg);
    -o-transform: rotate(180deg);
}
.so_qa_wrap .accordion_icon.active span:nth-of-type(1) {
    display: none;
}
.so_qa_wrap .accordionlist dt .title {
    position: relative;
    background-color: #ecf4ef;
    display: block;
    width: 100%;
    box-sizing: border-box;
    text-align: left;
    color: #000;
    font-size: 18px;
    padding-left: 109px;
    line-height: 20px !important;
    padding: 10px 0px 10px 4%;
    background-repeat: no-repeat;
    background-position: 30px 21px;
    border-radius: 10px;
    display: flex;
    justify-content: left;
    align-items: center;
    margin: 0px;
}
.so_qa_wrap .accordionlist dt .title span{
  font-family: "游ゴシック体", "Yu Gothic", YuGothic, "ヒラギノ角ゴ Pro", "Hiragino Kaku Gothic Pro", "メイリオ", Meiryo, "MS Pゴシック", "MS PGothic", sans-serif;
        font-size: 27px;
        font-weight: bold;
        margin-right: 20px;
        color: #009348;
        display: block;
        margin-top: -8px;
}
.so_qa_wrap .accordionlist dt .title p {
font-weight: 600;
    line-height: 23px;
    margin: 0px;
    font-size: 15px;
    padding-right: 10%;
    display: flex;
    align-items: center;
    font-family: 'Noto Serif JP', serif;
    }
.so_qa_wrap .accordion_icon {
    position: absolute;
    width: 18px;
    height: 18px;
    /* float: right; */
    margin-right: 25px;
    margin-top: -3vw;
    margin-top: 20px;
    top: 3px;
    bottom: 0px;
    right: 3%;
    margin: auto;
}
.so_qa_wrap .accordion_icon span {
    position: absolute;
    left: 0px;
    width: 18px;
    height: 2px;
    background-color: #3a8f3e;
    -ms-border-radius: 4px;
    -moz-border-radius: 4px;
    -o-border-radius: 4px;
}
.so_qa_wrap .accordion_icon span:nth-of-type(1) {
    top: 5px;
    transform: rotate(0deg);
    -webkit-transform: rotate(0deg);
    -moz-transform: rotate(0deg);
    -ms-transform: rotate(0deg);
    -o-transform: rotate(0deg);
}
.so_qa_wrap .accordion_icon span:nth-of-type(2) {
    top: 5px;
    transform: rotate(90deg);
    -webkit-transform: rotate(90deg);
    -moz-transform: rotate(90deg);
    -ms-transform: rotate(90deg);
    -o-transform: rotate(90deg);
}
.so_qa_wrap .accordionlist dt {
    display: block;
    overflow: hidden;
    position: relative;

}
.so_qa_wrap .accordionlist dd {
    position: relative;
    display: none;
    background: #eee;
    padding: clamp(15px, 2.4vw, 40px) clamp(14px, 3vw, 50px);
    margin: 0;
    background: #fff;
    text-align: left;
    background-image: url(/test/img/sale_answer_icon.webp);
    background-repeat: no-repeat;
    background-position: 30px 44px;
    border-top: none;
    border-radius: 0px 0px 10px 10px;
}
.so_qa_wrap .accordionlist dd img{
    margin: 20px auto 0px auto;
    display: block;
}
.so_qa_wrap .accordionlist dd p{
    font-size: clamp(14px, 1.0vw, 18px);
    line-height: 1.6;
    color: #000;
    display: flex;
    align-items: center;
}
.so_qa_wrap .accordionlist dd span{
    font-size: 27px;
    font-weight: bold;
    margin-right: 20px;
    color: #d72a2a;
    display: block;
}
.qa_libox{
    width: 100%;
    display: flex;
    justify-content: space-between;
    align-items: self-start;
    flex-wrap: wrap;
    margin-top: clamp(20px, 3vw, 40px);

}
.qa_libox li{
    background-color: #f4f4f4;
    width: 48.8%;
    margin-bottom: clamp(15px, 2vw, 25px);
    padding: clamp(15px, 2vw, 30px) clamp(20px, 3vw, 40px);
    border-radius: 5px;
    box-sizing: border-box;
}
.qa_libox li span{
display: block !important;
    font-weight: bold !important;
    font-size: clamp(15px, 1.4vw, 20px) !important;
    margin-bottom: clamp(10px, 1.0vw, 15px) !important;
    background-image: url(/sozoku/img/check_icon2.webp) !important;
    background-size: clamp(22px, 1.7vw, 29px) !important;
    background-repeat: no-repeat !important;
    line-height: clamp(28px, 2vw, 36px) !important;
    padding-left: clamp(21px, 2.7vw, 35px) !important;
    color: #000 !important;
}
.qa_libox_tex{
font-size: clamp(12px, 1.0vw, 17px);
    line-height: 1.6;
}

/* kanri */
  .chinta_kanri_container {
    margin: 0px 0 0 0;
  }
  .kan_main_wrap {
    display: flex;
    align-items: center;
    justify-content: space-between;
    flex-direction: column-reverse;
    width: 100%;
    position: relative;
  }
  .kan_main_le {
    width: 94%;
    margin: 25px 0 0 0;
    & h2 {
      font-size: clamp(30px, 8.3vw, 40px);
      font-weight: 600;
      line-height: 1;
      margin: 0 0 20px 0;
      & span {
        color: #009348;
      }
    }
    & p {
        font-size: 14px;
        line-height: 26px;
        font-weight: 500;
    }
  }
  .kan_main_ri {
  }
  .kan_main_treat {
    position: absolute;
    bottom: -60px;
    right: 3vw;
    width: 53vw;
    max-width: 570px;
  }
  .kan_worries_wrap {
    padding: 130px 0 80px 0;
    width: 92%;
    margin: 0 auto;
  }
  .kan_all_ti {
    position: relative;
    & h2 {
      font-size: clamp(26px, 7.2vw, 36px);
      font-weight: 500;
      text-align: center;
      margin: 0 0 50px 0;
      line-height: 1;
    }
    &::before {
      content: "";
      width: 50px;
      height: 2px;
      background: #009348;
      position: absolute;
      bottom: -25px;
      right: 0;
      left: 0;
      margin: 0 auto;
    }
  }
  
  .kan_worries_wrap ul {
    width: 100%;
    display: flex;
    flex-wrap: wrap;
    gap: 3vw;
    justify-content: space-between;
    margin-bottom: 30px;
    & li {
      width: 48%;
    }
  }
  .kan_worr_te {
    text-align: center;
    font-size: 14px;
    line-height: 26px;
    & span {
      color: #dd0000;
    }
  }
  
  
  .kan_inquiry_wrap {
    background: #009348;
  }
  .kan_inq_in {
    width: 92%;
    margin: 0 auto;
    padding: 50px 0;
    & .kan_all_ti h2 {
      color: #fff;
      font-size: 20px;
      line-height: 1.4;
    }
    & .kan_all_ti::before {
      background: #fff;
    }
  }
  .kan_inq_btn {
    display: flex;
    justify-content: space-between;
    flex-direction: column;
    gap: 20px 0;
    width: 100%;
    margin: 0 auto;
  }
  .kan_inq_mail a {
    width: 100%;
    border-radius: 5px;
    border: solid 1px #fff;
    box-sizing: border-box;
    background: #fff;
    height: 60px;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 16px;
    font-weight: 500;
    position: relative;
    & i {
      position: absolute;
      top: 20px;
      left: 18px;
      color: #009348;
      font-size: 22px;
    }
    &::before {
      content: "";
      width: 8px;
      height: 8px;
      display: block;
      border-top: solid 2px #009348;
      border-left: solid 2px #009348;
      transform: rotate(135deg);
      position: absolute;
      top: 50%;
      right: 20px;
      transform: translateY(-50%) rotate(135deg);
    }
    &:hover {
      background: #009348;
      color: #fff;
      & i {
        color: #fff;
      }
      &::before {
        border-top: solid 2px #fff;
      border-left: solid 2px #fff;
      }
    }
  }
  .kan_inq_tel {
    width: 100%;
    box-sizing: border-box;
    border-radius: 5px;
    border: solid 1px #fff;
    background: #008742;
  }
  .kan_inq_tel ul {
    display: flex;
    flex-direction: column;
  }
  .kan_inq_tel ul li {
    width: 100%;
    color: #fff;
    font-size: 16px;
    font-weight: 600;
    text-align: center;
    padding: 16px 0;
    & a {
      display: block;
      margin: 5px 0 0 0;
      color: #fff;
      font-size: 24px;
      font-weight: 600;
      display: flex;
      justify-content: center;
      align-items: center;
      line-height: 1;
      & i {
        font-size: 18px;
        margin-right: 5px;
      }
    }
  }
  .kan_inq_tel ul li:nth-child(1) {
    border-bottom: solid 1px #fff;
  }

  .kan_inq_te_sp {
    text-align: center;
    font-size: 14px;
    font-weight: 500;
    color: #fff;
  }
  .kan_service_wrap {
    position: relative;
    margin: 80px 0 0 0;
    /* &::before {
      content: "";
      width: 100%;
      height: 770px;
      background: #ecf4ef;
      position: absolute;
      bottom: 0;
      z-index: -1;
    } */
  }
  .kan_servi_in {
    width: 92%;
    margin: 0 auto;
  }
  .kan_servi_te {
    position: relative;
    padding: 20px 15px;
    margin: 50px auto 30px auto;
    border: solid 2px #ccc;
    z-index: -1;
    &::before {
      content: "";
      width: 80vw;
      height: 300px;
      background: #fff;
      position: absolute;
      top: -10px;
      right: 0;
      left: 0;
      margin: 0 auto;
      z-index: -1;
    }
    &::after {
      content: "";
      width: 110%;
      height: 190px;
      background: #fff;
      position: absolute;
      top: 30px;
      /* right: 0; */
      left: -5px;
      /* margin: 0 auto; */
      z-index: -1;
    }
    
  }
  .kan_servi_te p {
    font-size: 14px;
    line-height: 26px;
    text-align: center;
    width: 92%;
    margin: 0 auto;
    & span {
      color: #dd0000;
    }
  }
  .kan_servi_plan {
    display: flex;
    justify-content: space-between;
    flex-direction: column;
    gap: 40px 0;
  }
  .kan_servi_plan li {
    width: 100%;
    border-radius: 5px;
    box-shadow: 0 0 10px rgb(51, 51, 51, 0.2);
    text-align: center;
    padding-bottom: 25px;
    background: #fff;
    & h3 {
      font-size: 26px;
      font-weight: 500;
      line-height: 1;
      margin: 25px 0;
    }
    & p {
      color: #fff;
      background: #009348;
      width: 90%;
      margin: 0 auto;
      font-size: 16px;
      font-weight: 500;
      border-radius: 5px;
      padding: 20px 0 18px 0;
    }
  }
  .kan_servi_btn {
    width: 100%;
    margin-top: 30px;
  }
  .kan_servi_btn ul {
    display: flex;
    & li {
      width: 50%;
    }
  }
  .kan_servi_btn ul li a {
    width: 100%;
    display: block;
    box-sizing: border-box;
    text-align: center;
    line-height: 1;
    font-size: 24px;
    line-height: 30px;
    font-weight: 500;
    color: #fff;
    padding-top: 80px;
    height: 280px;
    position: relative;
    &::before {
      content: "";
      width: 40px;
      height: 40px;
      border-radius: 50%;
      border: solid 1px #fff;
      position: absolute;
      bottom: 70px;
      right: 0;
      left: 0;
      margin: 0 auto;
      transition: .3s;
    }
    &::after {
      content: "";
      width: 8px;
      height: 8px;
      display: block;
      border-top: solid 1px #fff;
      border-left: solid 1px #fff;
      transform: rotate(225deg);
      position: absolute;
      bottom: 88px;
      right: 0;
      left: 0;
      margin: 0 auto;
      transform: rotate(225deg);
      transition: .3s;
    }
    &:hover::before {
      bottom: 60px;
    }
    &:hover::after {
      bottom: 83px;
    }
  }
  .kan_servi_btn ul li:nth-child(1) a {
    border-right: solid 1px #fff;
    background-image: url(../kanri/img/kan_service_btn01_sp.webp);
    background-repeat: no-repeat;
    background-size: cover;
    background-position: center;

  }
  .kan_servi_btn ul li:nth-child(2) a {
    background-image: url(../kanri/img/kan_service_btn02_sp.webp);
    background-repeat: no-repeat;
    background-size: cover;
    background-position: center;
  }
  
  .kan_bukken_wrap {
    padding: 50px 0;
    position: relative;
    background-image: url(../kanri/img/kan_service_bg_sp.webp);
    background-position: bottom center;
    background-repeat: no-repeat;
  }
  .kan_bukk_in {
    width: 92%;
    margin: 0 auto;
  }
  .kan_bukk_con {
    display: flex;
    justify-content: space-between;
    flex-direction: column;
    gap: 30px 0;
  }
  .kan_bukk_day,.kan_bukk_update {
    width: 100%;
    border-radius: 5px;
    box-sizing: border-box;
    background: #fff;
    & p {
      font-size: 22px;
      font-weight: 500;
      line-height: 1;
      padding: 20px 0;
      text-align: center;
      color: #fff;
    }
    & ul {
      padding: 20px;
      box-sizing: border-box;
      display: flex;
      flex-direction: column;
      gap: 20px 0;
      position: relative;
      &::after {
        content: "";
        width: 2px;
        height: 370px;
        background: #008742;
        position: absolute;
        top: 60px;
        left: 65px;
      }
      & li {
        padding-left: 20px;
        font-size: 15px;
        line-height: 22px;
        position: relative;
        & span {
          font-size: 17px;
        }
        &::before {
          content: "";
          width: 10px;
          height: 10px;
          border-radius: 50%;
          position: absolute;
          top: 5px;
          left: 3px;
        }
      }
    }
  }
  .kan_bukk_day {
    border: solid 2px #008742;
    & p {
      background: #008742;
    }
    & ul li::before {
      background: #008742;
    }
  }
  .kan_bukk_update {
    border: solid 2px #2c4a73;
    & p {
      background: #2c4a73;
    }
    & ul::after {
      background: #2c4a73;
      height: 520px;
    }
    & ul li::before {
      background: #2c4a73;
    }
  }
  .kan_bukk_mess {
    padding: 20px;
    border-radius: 10px;
    border: solid 1px #cccccc;
    margin: 50px 0 0 0;
    background: #ecf4ef;
    position: relative;
    &:before {
      content: "";
      width: 1px;
      height: 50px;
      background: #ccc;
      position: absolute;
      right: 0;
      left: 0;
      margin: 0 auto;
      top: -18px;
  }
    }
  
  .kan_bukk_mess p {
    background: #fff;
    border-radius: 10px;
    text-align: center;
    font-size: 15px;
    line-height: 28px;
    padding: 20px 10px;
  }
  .kan_kaikei_wrap {
    padding: 50px 0;
    background: #f4f4f4;
  }
  .kan_kaikei_flow {
    position: relative;
    &::before {
      content: "";
      width: 57vw;
      height: 48vw;
      background-image: url(../kanri/img/kan_account_bg.webp);
      background-size: cover;
      position: absolute;
      bottom: -30px;
      right: 0;
      
    }
  }
  .kan_kaikei_in {
    width: 92%;
    margin: 0 auto;
    display: flex;
    flex-direction: column;
    gap: 30px 0px;
  }
  .kan_kai_le {
    text-align: center;
    & img {
      width: 80%;
    }
    & p {
      font-size: 14px;
      line-height: 26px;
      margin-top: 10px;
    }
  }
  .kan_kai_ri {
    margin-top: 20px;
    & p {
      font-size: 28px;
      font-weight: 500;
      line-height: 1;
      text-align: center;
    }
    & ul {
        display: flex;
        flex-direction: column;
        gap: 15px 0;
        position: relative;
        margin: 20px auto 0 auto;
        width: 86%;
      &::after {
        content: "";
        width: 1px;
        height: 150px;
        background: #008742;
        position: absolute;
        top: -20px;
        left: -16px;
        visibility: unset;
      }
      & li {
        font-size: 15px;
        position: relative;
        &::before {
          content: "";
          width: 10px;
          height: 10px;
          border-radius: 50%;
          position: absolute;
          top: 6px;
          left: -21px;
          background: #008742;
        }
      }
    }
  }
  .kan_kai_con ul {
    display: flex;
    flex-direction: column;
    width: 92%;
    margin: 30px auto 0 auto;
    border: solid 1px #008742;
    border-radius: 5px;
  }
  .kan_kai_con ul li {
    width: 100%;
    display: flex;
    align-items: center;
    padding: 15px 15px 15px 10px;
    box-sizing: border-box;
    gap: 0 10px;
    & .kan_kai_point {
      color: #008742;
      font-size: 11px;
      font-weight: 500;
      display: flex;
      flex-direction: column;
      align-items: center;
      & span {
        font-size: 24px;
        font-weight: 500;
        display: inline-block;
        margin-top: -5px;
      }
    }
    & .kan_kai_te {
      font-size: 15px;
      line-height: 25px;
    }
  }
  .kan_kai_con ul li:nth-child(1),
  .kan_kai_con ul li:nth-child(2),
  .kan_kai_con ul li:nth-child(3) {
    border-bottom: solid 1px #008742;
  }
  
  /* kanri 
  -----------------*/