@charset "utf-8";

  body {
    font-family: 'Montserrat', 'Noto Sans JP', sans-serif;
    font-size: 16px;
    line-height: 1.6;
    color: #333;
  }

h1, h2, h3, h4, ul, ol, dl, dt, dd, p {
  margin: 0;
  padding: 0;
}

.main-title-area-head {
  position: relative;
  top: 15px;
  z-index: 10;
}


#col-logo{
  display: flex;
  align-items: flex-end;
  gap: 12px;             /* 間隔 */
  /* 必要なら最大幅などを指定 */
  /* max-width: 1200px; margin: 0 auto; padding: 8px 16px; */
}

#col-logo .logo{
  flex: 0 0 auto;        /* ロゴは伸縮させない */
}

#col-logo .logo img{
  display: block;
  height: 40px;          /* サイトに合わせて調整 */
  width: auto;
}

#col-logo h1{
  margin: 0;             /* デフォルト余白をリセット */
  flex: 1 1 auto;        /* 余った横幅を占める */
  text-align: right;     /* 文字を右寄せ */
  font-size: 14px;       /* サイトに合わせて調整 */
  line-height: 1.4;
  font-weight: 600;
  color: #fff;
}


ul, ol {
  margin: 0;
  padding: 0;
  list-style-type: none;
}
.tx_bold{
  font-weight: bold;
}
.tx_orange{
  color: #ed6d00;
}
.heading{
  font-size: clamp(1.375rem, 0.8235rem + 2.3529vw, 2.5rem);
  margin-bottom: 0.618em;
}
.tx_c{
  text-align: center!important;
}

/* -----------------------
header
----------------------- */
.header__simple img {
    width: 100px;
    margin: 16px 0px;
    height: auto;
}
.header__simple .inner {
        max-width: 1280px;
        padding: 0 40px;
        margin: 0 auto;
    }

@media screen and (min-width:768px) {
.header__simple img {
    width: 140px;
}
}
@media screen and (min-width:1080px) {
.header__simple img {
    margin: 23px 0px 10px;
}
}

  /* -------------------
  新メインビジュアル
  --------------------- */
  #main_visual {
    margin: 0 auto;
    background: #FFF7EB;
    padding-bottom: 40px;
  }
  .mv_contents {
    width: 350px;
    margin: 0 auto;
    padding-top: 20px;
  }
  .mv_subtitle {
    font-size: 16px;
    font-weight: 700;
    position: relative;
    padding-left: 22px;
    width: 311px;
    margin: 0 auto;
  }

.mv_subtitle::before {
    position: absolute;
    content: '';
    top: 3px;
    left: 0px;
    background-color: #333;
    width: 2px;
    height: 18px;
    transform: rotate(-35deg);
}
.mv_subtitle::after {
    position: absolute;
    content: '';
    top: 3px;
    right: 15px;
    background-color: #333;
    width: 2px;
    height: 18px;
    transform: rotate(35deg);
}

  .mv_title {
    margin-top: 4px;
    font-size: 21px;
    font-weight: 700;
    line-height: 1.4em;
  }
    .mv_title span {
      color: #FF9900;
    }
    .mv_logo {
      margin: 14px auto 0;
      width: 320px;
      height: 78px;
    }
    .mv_maintxt {
      font-size: 12px;
      margin-top: 14px;
      font-weight: 700;
    }
     h1 {
      font-size: 12px;
      margin-top: 4px;
     }
     .btn-contact.mv {
    padding-top: 32px;
  }
  .btn-contact.mv a {
    margin: 0 auto;
  }
  .price_attention.pc {
    display: none;
  }
  .price_attention.sp {
    font-size: 10px;
    margin-top: 8px;
    opacity: 0.8;
    text-align: right;
  }
  .btn-contact.mv p {
    font-size: 14px;
    font-weight: 700;
    text-align: center;
    position: relative;
    padding-bottom: 10px;
    width: 300px;
    margin: 0 auto;
  }
   .btn-contact.mv p::before {
    position: absolute;
    content: "";
    top: 3px;
    left: 32px;
    background-color: rgb(51, 51, 51);
    width: 2px;
    height: 18px;
    transform: rotate(-35deg);
   }
   .btn-contact.mv p::after {
    position: absolute;
    content: "";
    top: 3px;
    right: 32px;
    background-color: rgb(51, 51, 51);
    width: 2px;
    height: 18px;
    transform: rotate(35deg);
   }

   /* slider */

.slide-items {
  width: 100%;
  /* height: 100%; */
  margin-top: 10px;
}

.slide-items img {
  width: 100%;
  object-fit: cover;
  border-radius: 6px;
}
.slick-next, .slick-prev {
  display: none !important;
}

   
   /* .slide {
    width: 100%;
   } */
   .mv_point_sp {
    width: 300px;
    margin: 10px auto 0;
  }
  .mv_point_pc {
    display: none;
  }
   .form {
    display: none;
   }
   #form .bg_green {
  background-color: #E8F5E6;
  max-width: 1000px;
    margin: 0 auto;
}

    @media(min-width:768px) {
        .btn-contact.voice {
    padding-top: 40px;
  }
  .mv_point_sp {
    width: 400px;
  }

    }

  @media(min-width:768px) {
  #main_visual {
    /* width: 500px; */
    margin: 0 auto;
  }

  .mv_contents {
    width: 500px;
    padding-top: 40px;
  }
  .mv_subtitle {
    font-size: 22px;
    width: 400px;
    padding-left: 16px;
  }
  .mv_subtitle::before {
    top: 8px;
    left: 0px;
    height: 20px;
}
.mv_subtitle::after {
    top: 8px;
    right: 18px;
    height: 20px;
}
  .mv_title {
    font-size: 31px;
    margin-top: 2px;
  }
  .mv_logo {
    margin-top: 24px;
    height: 118px;
    width: 100%;
  }

  .mv_maintxt {
    font-size: 16px;
    margin-top: 24px;
}
h1 {
    font-size: 16px;
}
.btn-contact.mv {
    padding-top: 20px;
}
.btn-contact.mv a {
    background: #ED6D00;
  }
}

@media(min-width:920px) {
  #main_visual {
    width: 100%;
    padding: 0px 20px 40px;
  }

  .mv_contents {
    display: flex;
    width: 100%;
    justify-content: center;
    gap:20px;
  }
  .mv_maintitle {
    display: flex;
    flex-direction: row-reverse;
    align-items: center;
    justify-content: center;
    gap: 10px;
  }
  .mv_txt {
    width: 530px;
  }
  .mv_subtitle {
    font-size: 18px;
    width: 330px;
    margin: 0 auto;
  }
    .mv_subtitle::before {
    top:8px;
    left: 0px;
    height: 20px;
}
.mv_subtitle::after {
    top: 6px;
    right: 14px;
    height: 20px;
}
   .mv_title {
    font-size: 20px;
  }
  .mv_logo {
    width: 174px;
    margin-top: 0;
    height: 42px;
  }
  /* .mv_pconly.point {
    width: 300px;
    margin-top: 20px;
  } */
    .mv_maintxt,
    h1 {
    font-size: 14px;
    }
    .mv_maintxt {
        margin-top: 10px;
    }
    .btn-contact.mv {
    display: none;
}

.btn-contact.mv a {
    margin: 0;
  }

  .price_attention.sp {
    display: none;
  }
  .price_attention.pc {
    display: block;
    font-size: 10px;
    text-align: right;
    opacity: 0.8;
    width: 880px;
    margin: 10px auto;
  }
  .mv_point_sp {
    display: none;
  }
  .mv_point_pc {
    display: block;
    width: 500px;
    margin: 24px auto 0;
  }
  .form {
    display: block;
    width: 320px;
    border: 4px solid #44AF35;
    border-radius: 8px;
    background: white;
    overflow: hidden;
    overflow-y: auto;
    height: 485px;
   }
   .form_title {
    color: white;
    background-color: #44AF35;
    text-align: center;
    padding: 12px;
    font-size: 13px;
   }
   .form_title span {
    border: 2px solid white;
    padding: 4px 8px;
    margin-right: 10px;
    font-size: 12px;
   }
   .slide-items img {
  border-radius: 10px;
}
}

@media(min-width:1100px) {
   #main_visual {
    width: 100%;
    padding: 0 40px 40px;
  }

  .mv_contents {
    gap:20px;
  }
}
@media(min-width:1200px) {
   .mv_contents {
    max-width: 1300px;
  }
  .mv_subtitle {
    font-size: 24px;
    width: 428px;
  }
      .mv_subtitle::before {
    top: 11px;
    left: 0px;
    height: 26px;
}
.mv_subtitle::after {
    top: 10px;
        right: 12px;
        height: 26px;
}
  .mv_title {
    font-size: 28px;
    line-height: 1.4em;
    margin-top: 0;
  }
  .mv_logo {
    width: 290px;
    margin-top: 0;
    height: 70px;
  }
      .mv_maintxt,
      h1 {
    font-size: 16px;
      }
     .mv_maintxt {
      margin-top: 0;
     }
     .mv_pconly {
    width: 560px;
  }
  .btn-contact.mv {
    padding-top: 0;
  }
  .mv_txt {
        width: 750px;
    }
    .mv_contents {
    gap: 40px;
  }
      .form {
        height: 636px;
      }
    .price_attention.pc {
    width: 1115px;
    }
}
@media(min-width:1240px) {
  .form {
    width: 340px;
   }
}
@media(min-width:1280px) {
  .form {
    width: 360px;
    height: 675px;
   }
   .mv_txt {
        width: 800px;
    }
    .price_attention.pc {
    width: 1213px;
    }

    .mv_point_pc {
    width: 600px;
  }
}


  /* -------------------
  ロゴスライダー
  --------------------- */
#slider {
  padding: 40px 0 0;
}
.marquee {
  --gap: 20px;
  --item-width: 100px;
  overflow: hidden;
  width: 100%;
}

.marquee__track {
  display: flex;
  width: max-content;
  will-change: transform;
  transform: translate3d(0,0,0);
  contain: layout paint;
  /* 念のためガタつき低減 */
  backface-visibility: hidden;
}

.marquee__list {
  display: flex;
  flex: none;          /* 伸縮禁止＝幅ズレ防止 */
  /* ★ 継ぎ目の原因 → これを削除（リスト間のマージンは0） */
  margin-right: 20px;
}
.marquee__list:last-child {
  margin-right: 0;
}
.marquee__item {
  flex: none;          /* 各アイテム固定幅 */
  width: var(--item-width);
  margin-right: var(--gap); /* 余白はアイテム側だけで作る */
}
.marquee__item:last-child { margin-right: 0; }

.marquee__item img {
  display: block;
  width: 100%;
  height: auto;
  object-fit: contain;
}
@media(min-width:768px) {
#slider {
  padding: 64px 0 0;
}
}
@media(min-width:1280px) {
  .marquee {
    --item-width: 180px;
  }
}
@media (prefers-reduced-motion: reduce) {
  .marquee__track { transform: none !important; }
}
/* @media (min-width: 768px) {
  #slider {
  padding: 100px 0;
}
} */


/* ----------------
ボタン 
----------------*/

.btn-contact {
  padding-top: 80px;
}

.btn-contact a {
  color: #ffffff;
  text-align: center;
  background: #ED6D00;
  border-radius: 5px;
  font-weight: bold;
  padding: 18px;
  width: 380px;
  display: block;
  font-size: 20px;
  text-decoration: none;
  position: relative;
}
.btn-contact a::after {
    content: "";
    display: block;
    position: absolute;
    background: url(https://www.shinko-jp.com/cms/wp-content/themes/shinko/images/lp-offmeshi/chevron-right.svg) 50% 50% no-repeat;
    background-size: contain;
    width: 18px;
    height: 18px;
    top: 50%;
    right: 24px;
    transform: translateY(-50%);
}
@media(max-width:767px) {
  .btn-contact a {
    width: 300px;
    font-size: 16px;
  }
  .btn-contact {
    padding-top: 40px;
  }
}

.btn-contact a:hover {
  transition: 0.3s linear;
  color: white;
  filter: brightness(0.7) !important;
    opacity: 1;
}

.btn-contact a i {
  margin-left: 15px;
}

.title {
  text-align: center;
  overflow: hidden;
}

.title h2 {
color: #ed6d00;
  font-size: 28px;
  font-weight: bold;
  margin-bottom: 40px;
  line-height: 1.5;
  position: relative;
  display: inline-block;
  min-width: 120px;
  padding: 8px 0;
  margin-left: auto!important;
  margin-right: auto!important;
}


.title h2:before {
  content: "";
  width: 40px;
  height: 40px;
  top: 50%;
  left: -72px;
  transform: translateY(-50%);
  position: absolute;
  background: url(https://www.shinko-jp.com/cms/wp-content/themes/shinko/images/lp-offmeshi/gochiso-san.svg);
  background-position: 50% 50%;
  background-repeat: no-repeat;
  background-size: 40px;
}
.title h2:after {
  content: "";
  width: 40px;
  height: 40px;
  top: 50%;
  right: -72px;
  transform: translateY(-50%);
  position: absolute;
  background: url(https://www.shinko-jp.com/cms/wp-content/themes/shinko/images/lp-offmeshi/gochiso-san.svg);
  background-position: 50% 50%;
  background-repeat: no-repeat;
  background-size: 40px;
}
.text_box{
  background: #fff;
    padding: 16px 24px;
    border-radius: 16px;
    border: 4px solid #ed6d00;
}
@media(max-width:767px) {
  .title h2 {
    font-size: 20px;
    line-height: 1.3;
  }
  .title h2:before{
    width: 32px;
    height: 32px;
    left: -48px;
    background-size: 32px;
  }
  .title h2:after{
    width: 32px;
    height: 32px;
    right: -48px;
    background-size: 32px;
  }
  .text_box{
    max-width: calc(100% - 16px);
  }
}


#offmeshiba .image_box{ 
  background: url(https://www.shinko-jp.com/cms/wp-content/themes/shinko/images/lp-offmeshi/offmeshiba_on.webp) 50% 50% no-repeat;
  background-size: contain;
}
#offmeshiba .image_box img{
  transition: 240ms ease-in-out;
  opacity: 1;
}
#offmeshiba .image_box:hover img{
  opacity: 0;
}


#about, #problem, #feature, #price, #step, #voice,#comparison {
  padding-top: 80px;
      text-align: center;
  clear: both;
}

#about p, #problem p, #feature p, #item p, #price p, #step p, #voice p,#comparison p {
    text-align: left;
    padding-top: 10px;
}


@media(max-width:767px) {
#about, #problem, #feature, #price, #step, #voice,#comparison {
    padding-top: 60px;
  }
}



#problem,#step {
    background-color: #fff7eb;
    padding-bottom: 80px;
    margin-top: 80px;
}
@media(max-width:767px) {
#problem,#step {
    padding-bottom: 60px;
    margin-top: 60px;
  }
  }


.main-title-area h1, .main-title-area img, .swiper-slide img {

}

#feature img {
width: 100%;
}

#feature .card-article-01 {
    margin-bottom: 30px;
}

#item .title h3 {
color: #ed6d00;
  font-size: 26px;
  font-weight: bold;
  line-height: 1.5;
  position: relative;
  display: inline-block;
  padding: 10px 0 20px 0;
  margin-left: auto!important;
  margin-right: auto!important;
}

#item p, #problem p, #feature p, #item p, #price p, #step p, #voice p, #comparison p {
    text-align: left;
    padding-top: 10px;
}

#item .card-article-01,#item .card-article-02 {
margin-bottom: 30px;
}

.item-wrap {
    padding-top: 60px;
}

@media(max-width:767px) {

.item-wrap {
    padding-top: 30px;
}

#item .card-article-01 h3,#item .card-article-02 h3 { 
    font-size: 22px;
}


}

#item .card-article-01 .itembox-body img {
  width:100%;
}

#item .card-article-01 h3 {
  display: block;
  padding: 10px 0px;
}

#item .card-article-01 h3 img{
display: block;
    padding-bottom: 10px;
    margin: 0 auto;
}
#item .card-article-01 {
    background-color: #ed6d00;
    color: #fff;
}



#item .card-article-02 {
    background-color: #45B035;
    color: #fff;
    margin-bottom: 30px;
}

#item .card-article-02 .itembox-body {
    padding: 10px;
}

#item .card-article-02 h3 {
display: block;
    padding: 10px 0px;
}

#item .card-article-01 h3 {
    color: #fff;
}

#item .card-article-01 a:hover {
    text-decoration: none;
    filter: alpha(opacity=50);
    -moz-opacity: 0.5;
    opacity: 0.5;
    transition-property: all;
    transition: 0.3s linear;
    display: block;
}

#problem .text {
    font-size: 24px;
    font-weight: bold;
    line-height: 2;
    margin-left: 15%;
}
.reason_box h3{
  font-size: 24px;
}


#problem .text:before {
    background-image: url(https://www.shinko-jp.com/cms/wp-content/themes/shinko/images/lp-offmeshi/icon_checkbox.svg);
    margin-left: -40px;
    position: absolute;
    content: '';
    background-size: contain;
    background-repeat: no-repeat;
    background-position: 0 5px;
    display: inline-block;
    width: 34px;
    vertical-align: middle;
    height: 40px;
    top: 12px;
}


@media(max-width:1199px) {

#problem .text,.reason_box h3 {
font-size: 22px;
}
}

@media(max-width:991px) {
#problem .text,.reason_box h3 {
font-size: 18px;
}
#problem .text:before {
    margin-left: -34px;
    width: 28px;
}    
}


@media(max-width:767px) {


#problem .text,.reason_box h3 {
    font-size: 18px;
    line-height: 1.6;
}

#problem .text:before {
    width: 20px;
    margin-top: -3px;
    margin-left: -33px;

}
}

#step h3{
    background-color: #ed6d00;
    color: #fff;
    padding: 5px;
    font-size: 24px;

}

#step .card-article-01 {

    margin-bottom: 30px;

}

#step .card-article-01 .itembox-body {
    padding: 20px 0;

}


#step h4 {
    color: #ed6d00;
    font-size: 28px;
    font-weight: bold;
    line-height: 1.5;
    position: relative;
    display: block;
    min-width: 120px;
    padding-bottom: 20px;
    margin-left: auto!important;
    margin-right: auto!important;
}
 .pay {
    width: 100%;
  }
@media (min-width:920px){
  .pay {
    width: 600px;
    margin: 0 auto;
  }
}

/* --------------------
QA 
--------------------*/
#faq{
  padding-top: 80px;
}
.faq_list{
	display: flex;
	flex-direction: column;
	gap: 10px;
}
.faq_list li{
	background-color: #f3faf3;
	/* padding: 24px 12px 24px 16px; */
	border-radius: 8px;
}
.faq_list li details {
  box-shadow: none;
  background-color: transparent;
}
details summary::marker,
:is(::-webkit-details-marker) {
	display: none;
}
details[open] summary::marker {
	display: none;
}
details summary{
	position: relative;
	padding: 24px 12px 24px 16px;
	list-style: none;
  background-color: transparent;
}
details summary::before{
	content: '';
	background: url(https://www.shinko-jp.com/cms/wp-content/themes/shinko/images/lp-offmeshi/icon_down.svg) 50% 50% no-repeat;
	background-size: contain;
	width: 16px;
	height: 9px;
	display: block;
	position: absolute;
	top: 32px;
  right: 9px;
	transform: translateY(-50%) rotate(0deg);
}
details .text_box p {
  font-size: 14px;
  line-height: 1.7em;
}
details .text_box {
  border: none;
  background-color: transparent;
}
details[open] summary::before{
	transform: translateY(-50%) rotate(180deg);
}
summary h3{
	padding-left: 30px;
	font-size: 14px;
	position: relative;
	letter-spacing: 0.3px;
}
summary h3::before{
	content: 'Q';
	font-size: 20px;
	font-weight: bold;
	line-height: 1;
	color: #44af35;
	position: absolute;
	top: 0;
	left: 0;
}
details .text_box{
	padding: 20px 8px 20px 39px;
	position: relative;
  margin: 0 8px;
	border-top: 2px solid #d0ebcd;
  border-radius: 0;
}
details[open] .text_box{
	animation: fadeIn 0.5s ease forwards;
}
@keyframes fadeIn {
  0% {
    opacity: 0; 
    transform: translateY(-10px); 
  }
  100% {
    opacity: 1;
    transform: none;
  }
}
details .text_box::before{
	content: 'A';
	font-size: 24px;
	font-weight: bold;
	line-height: 1;
	color: #7fc874;
	position: absolute;
	top: 20px;
	left: 8px;
}
details .text_box h4{
	font-size: 14px;
}
details .spacer{
	height: 1em;
}
@media (min-width:768px){
  summary h3::before {
        top: -2px;
  }
}
@media (min-width:920px){
	/* .faq_list li {
		padding: 32px 24px 32px 48px;
	} */
	details summary{
		padding: 32px 24px 32px 48px;
	}
  summary h3{
	font-size: 16px;
}
	details summary::before{
		width: 20px;
		height: 11px;
		top: 40px;
    right: 24px;
	}
  details .text_box p {
  font-size: 16px;
  line-height: 1.7em;
}
	summary h3{
		padding-left: 48px;
	}
	summary h3::before{
		top: -2px;
		font-size: 24px;
	}
	details .text_box{
		padding: 24px 24px 32px 88px;
	}
	.faq summary h3{
		padding-left: 48px;
	font-size: 20px;
}
details .text_box::before {
    top: 25px;
    left: 40px;
}
}


@media(min-width:920px) {
    #faq{
    padding-top: 120px;
  }
}





#price p {    padding-top: 30px;
    display: block;}



#breadcrumb{
	margin: 60px 0 0 0;
	border-top: 1px solid #e7e7e7;
	padding: 20px 0 20px 0;
	background: #fff;
}
.breadcrumb-list-set li{
	float: left;
	font-size: 12px;
	margin-bottom: 5px;
}
.breadcrumb-list-set li:last-child{
	margin-bottom: 0;
}
.breadcrumb-list-set li:after{
	content: "";
  display: inline-block;
  width: 8px;
  height: 8px;
  border-right: 2px solid #ccc;
  border-bottom: 2px solid #ccc;
  margin: 0 15px;
  position: relative;
  transform: rotate(-45deg);
}
.breadcrumb-list-set li:last-child:after{
	display: none;
}
.breadcrumb-list-set li a{
	text-decoration: none;
    color: #000;
}
.breadcrumb-list-set li a:hover{
	text-decoration: underline;
}
@media (max-width: 767px){
	#section-breadcrumb{
		padding: 20px 0 20px 0;
	}
}



#item .movie p {
text-align: center;
}

.movie{
	padding: 80px 0 0;
}
.movie h2{
	color: #ed6d00;
	font-weight: bold;
	font-size: 20px;
	margin-bottom: 24px;

}
.movie p{
	font-size: 13px;
}

.yt_box{
	overflow: hidden;
	width: 100%;
	height: 0;
	padding-bottom: 56.5%;
	position: relative;
	margin-bottom: 8px;
}
.yt_box iframe{
	position: absolute;
	width: 100%;
	height: 100%;
	top: 0;
	left: 0;
}
@media (min-width:768px) {
.movie h2{
  font-size: 28px;
}
}
@media (min-width:920px) {
	.movie{
		padding: 120px 0 0;
	}
}


@media (max-width:350px) {

	.movie h2{
		font-size: 16px;
			}
}






.item_grid{
  grid-template-columns: 1fr 1fr;
  grid-gap: 16px;
}
.lum-lightbox-inner img{
  margin: auto;
}
.item {
  padding-bottom: 1em;
}
.item h3{
  margin-top: 0.4em;
  font-size: 16px;
  font-weight: bold;
  line-height: 1.414;
}
.item p{
  margin-top: 0.4em;
  font-size: 13px;
  line-height: 1.414;
}
.item .oroshi_price{
  text-align: right;
}
.item .oroshi_price p{
  text-align: left;
  display: inline-block;
  padding-left: 0.5em;
  padding-right: 0.5em;
  border-bottom: 1px solid;
  line-height: 1;
}
.item .oroshi_price p span{
  font-size: 1.8em;
  font-weight: bold;
  color: #e16a11;
}
@media (min-width:768px){
  .item_grid{
    grid-template-columns: 1fr 1fr 1fr;
    grid-gap: 20px;
  }
}

.option_menu{
  margin: 80px 0 48px;
  padding: 64px 0;
  background: #fff7eb;
}
.option_menu table{
  max-width: 570px;
  width: 100%;
  margin: 24px auto 0;
  border-collapse: collapse;
  background-color: #fff;
}
.option_menu table th,
.option_menu table td{
  padding: 20px 12px;
  border: 1px solid #dcdcdc;
}
.option_menu table th{
  text-align: center;
  background: #f5f5f5;
}
.option_menu table tr:first-child th{
  background: #ffffff;
}

/*20240605追記*/
.bg_lightorange{
  background: #FFF7EB;
}
h2:has(+ .heading){
  margin-bottom: 24px;
  padding-bottom: 0;
}
h2 + .heading{
  font-size: 16px;
  font-weight: bold;
  margin-bottom: 0;
}
#ofm_reason{
  margin-top: 80px;
  padding: 80px 0;
}
#ofm_reason .lp_flex_wrap{
  width: inherit;
  margin-inline: auto;
}
#ofm_reason .flex_item{
  max-width: 320px;
}
.reason_box{
  padding-left: 32px;
  position: relative;
}
.reason_box::before{
  content: '';
  position: absolute;
  background: url(https://www.shinko-jp.com/cms/wp-content/themes/shinko/images/lp-offmeshi/icon_checkbox.svg) 50% 50% no-repeat;
  width: 34px;
  height: 40px;
  top: 26px;
  left: 0px;
}
.reason_box .textbox{
  padding-left: 0;
  padding-right: 0;
  padding-bottom: 0;
  text-align: left;
}
.reason_box .textbox p{
  font-size: 14px;
}
.hikaku_table_box{
  padding: 16px 0 16px;
  overflow-x: auto;
}
.hikaku_table{
  border-collapse: collapse;
  min-width: max-content;
  width: 100%;
}
.hikaku_table th,
.hikaku_table td{
  border: 1px solid #9D9D9D;
  padding: 12px 16px;
}
.hikaku_table td{
  text-align: center;
}
.hikaku_table .offmeshi_col{
  background: #FFFCD6;
  font-weight: bold;
  position: relative;
  border-left: 4px solid #F08000;
  border-right: 4px solid #F08000;
  font-size: 16px;
}
.hikaku_table th.offmeshi_col{
  background: #F08000;
  padding: 8px 16px 16px;
  min-width: 200px;
}
.hikaku_table th.offmeshi_col img{
  width: 140px;
}
.hikaku_table th.offmeshi_col::before{
  content: '';
  position: absolute;
  display: block;
  width: calc(100% + 8px);
  height: 16px;
  border-radius: 16px 16px 0 0;
  background: #F08000;
  top: -16px;
  left: -4px;
}
.hikaku_table tr:last-child .offmeshi_col::before{
  content: '';
  position: absolute;
  display: block;
  width: calc(100% + 8px);
  height: 4px;
  border-radius: 0 0 8px 8px;
  background: #F08000;
  bottom: -4px;
  left: -4px;
}
.bg_lightgray{
  background: #EAEAEA;
}
.bg_lightblue{
  background: #7CA7BE;
  color: #fff;
  text-align: center;
  min-width: 120px;
}
.bg_lightblue:nth-child(4){
  border-right-color: #fff;
}
.bg_lightblue:nth-child(5){
  border-left-color: #fff;
}
#problem{
  padding-bottom: 40px;
  position: relative;
}
#problem::after{
  content: '';
  position: absolute;
  width: 100%;
  aspect-ratio: 20/1;
  background: url(https://www.shinko-jp.com/cms/wp-content/themes/shinko/images/lp-offmeshi/onayami_triangle.svg) 50% 50% no-repeat;
  background-size: contain;
  left: 50%;
  bottom: 0;
  transform: translate(-50%, 90%);
  max-width: 1000px;
  max-height: 54px;
}
.jitsugen_grid {
  margin-bottom: 80px;
}
.jitsugen_grid .card img{
  aspect-ratio: 16 / 9;
  height: auto;
  object-fit: cover;
}
#item .card-article-01.chokusou-card{
  background-color: #000000;
}
#item .card-article-01.chokusou-card h3{
  padding: 0;
  margin: 0;
}
#item .card-article-01.chokusou-card h3 img{
  padding: 0;
  margin: 0 auto;
}

.reason_box::before{
  content: '';
  width: 32px;
  height: 32px;
  top: 25px;
  left: -10px;
}
@media(max-width:1199px) {
  #problem .text,.reason_box h3 {
  font-size: 22px;
  }
  .reason_box::before{
    content: '';
    width: 28px;
    height: 30px;
    top: 25px;
    left: -8px;
  }
}
@media(max-width:991px) {
  #problem .text,.reason_box h3 {
  font-size: 20px;
  }
  #problem .text:before {
      margin-left: -34px;
      width: 25px;
      top: 11px;
  }
  .reason_box::before{
    content: '';
    width: 28px;
    height: 30px;
    top: 22px;
    left: -4px;
  }
}
 @media(max-width:767px) {
  #problem .text,.reason_box h3 {
      font-size: 18px;
      line-height: 1.6;
  }
  #problem .text:before {
      width: 20px;
      margin-top: 0px;
      margin-left: -33px;
  }
  .reason_box::before{
    content: '';
    width: 20px;
    height: 20px;
    top: 30px;
    left: 0px;
  }
  .reason_box .textbox p br{
    display: none;
  }
}
 @media(min-width:920px) {
  #voice{
    margin-top: 0;
    padding: 120px 0 0;
  }
  #ofm_reason{
      margin-top: 120px;
    }
 }

.wpcf7-contact-form-not-found{
  display: none;
}

/* ---------------------
TOPページ head内CSS  
--------------------- */

.tab_nav{
  border-bottom: 3px solid #e16a11;
  margin-top: 2em;
}
.tab_nav nav ul{
  width: 100%;
  display: flex;
  justify-content: space-around;
  text-align: center;
}
.tab_nav nav ul li{
  width: calc(50% - 4px);
}
.tab_nav nav ul li a{
  display: flex;
  background-color: #f4f4f4;
  border: 3px solid #e9e8e8;
  border-bottom: none;
  display: block;
  padding: 20px;
}
.tab_nav nav ul li a:hover{
  background-color: #fff;
}
.tab_nav nav ul li img{
  width: auto;
  max-width: 90%;
  height: auto;
}
.tab_nav nav ul li.current{
  padding: 16px;
  border: 3px solid #e16a11;
  border-bottom: none;
  background-color: #fff;
  position: relative;
  display: flex;
}
.tab_nav nav ul li.current::after{
  content: '';
  display: block;
  position: absolute;
  width: 100%;
  height: 5px;
  background: #fff;
  bottom: -5px;
  left: 0;
}
.tab_nav nav ul li.current,
.tab_nav nav ul li a{
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  align-items: center;
  color: #221815;
}
.tab_nav nav ul li span{
  width: 100%;
  font-weight: bold;
  font-size: 12px;
  margin-top: 0.5em;
}
@media (max-width: 374px) {
  .tab_nav nav ul li a{
    padding: 14px;
  }
  .tab_nav nav ul li span{
    font-size: 10px;
  }
}
@media (min-width: 768px){
  .tab_nav nav ul li {
    width: calc(50% - 8px);
  }
  .tab_nav nav ul li span{
    font-size: 18px;
  }
  .inner{
    padding: 0 16px;
  }
}
@media (min-width: 1024px){
  .tab_nav nav ul li {
    width: calc(50% - 12px);
  }
}
.yt_bnr{
  max-inline-size: max-content;
  margin-inline: auto;
  margin-top: 32px;
}
.yt_bnr img{
  max-width: 100%;
  height: auto;
}

/* -------------------------------
サービス一覧
---------------------------------- */

#introduction {
    background:linear-gradient(180deg, #FFFFFF, #F9F8F3);
    margin-top: 80px;
    padding-bottom: 80px;
}
/* #introduction h2 {
    font-size:clamp(1.25rem,1.1296rem + .4938vw,1.5rem);
    line-height:1.8
} */
#introduction h2 span {
    padding-bottom:3px;
    background:linear-gradient(0deg, #ECA515 3px, rgba(255, 255, 255, 0) 3px)
}
#introduction .heading {
    font-size:clamp(.9375rem,.8642rem + .3128vw,1.125rem);
    margin-top:2em;
    line-height:1.618
}
#introduction .heading p {
    text-align:left
}
@media screen and (min-width: 920px) {
  #introduction {
    margin-top: 120px;
    padding-bottom: 120px;
}
    #introduction .heading p {
        text-align:center;
    }
}
#introduction .service_list {
    gap:40px 24px;
    padding: 0 13px;
}
#introduction .service_list li {
    background:#fff;
    border-radius:8px;
    box-shadow:0px 1px 6px -3px rgba(0,0,0,.5);
    overflow:hidden
}
#introduction .service_list li:hover{
  opacity: 0.7;
    transition: 0.5s;
    box-shadow: 0 4px 13px 0px rgba(0, 0, 0, 0.1);
}
#introduction .service_list li a>img {
    aspect-ratio:1.66/1;
    -o-object-fit:cover;
    object-fit:cover;
    width:100%;
    height: auto;
}
#introduction .service_list li a div {
    padding:24px 24px 32px;
    text-align:center
}
#introduction .service_list li a div img {
    width:75%;
    margin-inline:auto;
    height: auto;
}
#introduction .service_list li a div h3 {
    text-align:left;
    display:inline-flex;
    align-items:center;
    height:3.2em;
    line-height:1.414;
    font-size: 18px;
    color: #41a732;
}
#introduction .service_list li a div p {
    text-align:left;
    color:#2b2b2b;
    font-size:14px;
}
.txtlink a {
  color: #00A867;
  text-align: center;
  font-weight: 700;
  display: block;
  margin-top: 40px;
    font-size: 14px;
}
.txtlink a:hover {
  color: #00A867;
filter: brightness(0.7);
}
.txtlink a::after {
    content: "";
    background: url(https://www.shinko-jp.com/cms/wp-content/themes/shinko/images/lp-offmeshi/icon_next_textlink.svg) 50% 50% no-repeat;
    width: 1em;
    height: 1em;
    display: inline-block;
    vertical-align: text-top;
    margin-left: 1em;
}
.flex_wrap {
    display: flex;
    flex-wrap: wrap;
}
.jstfy_c {
    justify-content: center;
}


@media screen and (min-width: 580px) {
    #introduction .service_list {
        gap:32px 24px
    }
    #introduction .service_list li {
        width:calc(50% - 12px)
    }
}
@media screen and (min-width: 920px) {
    #introduction .service_list {
        gap:32px 32px
    }
    #introduction .service_list li {
        width:calc(33% - 20px);
        transition:.24s cubic-bezier(0.25, 0.46, 0.45, 0.94);
        box-shadow:0px 0px 6px -3px rgba(0,0,0,.5)
    }
    #introduction .service_list li.one_fourth {
        width:calc(40% - 25px)
    }
    #introduction .service_list li.one_fourth a div img {
        width:64%
    }
    #introduction .service_list li.one_fourth a div h3 {
        font-size:18px;
        color: #44af35;
    }
    #introduction .service_list li.one_fourth a div p {
        font-size:14px
    }
    #introduction .service_list li:hover {
        box-shadow:0px 0px 6px -5px rgba(0,0,0,.8);
        color:#44af35;
      }
}
@media screen and (min-width: 1080px) {
  #introduction .service_list li.one_fourth {
        width:calc(25% - 25px)
    }
}

/* ---------------------------------
TOP　pickupカテゴリ
--------------------------------- */
#pickup {
  margin: 64px 0 80px;
}

#pickup .container ul {
 display: flex;
  flex-wrap: wrap; 
  column-gap: 10px; /* 横方向の余白 */
  row-gap: 20px;    /* 上下の余白 */
  justify-content: space-between;
}

#pickup .container ul li {
  box-sizing: border-box;
  flex: 1 1 calc(30% - 5px);
  border-radius: 8px;
    border: 2px solid #D9D9D9;
}
#pickup .container ul li {
  text-decoration: none;
}

#pickup .container ul li img {
  width: 100%;
    display: block;
    border-radius: 7px 7px 0 0;
}
#pickup .container ul li div {
  padding: 10px;
}
#pickup .container ul li div h3{
  color: #1c1c1c;
  text-align: left;
  font-size: 12px;
  font-weight: 700;
}




@media (min-width:920px){
  #pickup {
  margin: 64px 0 120px;
}
  #pickup .container ul {
  column-gap:20px; /* 横方向の余白 */
  row-gap: 40px;    /* 上下の余白 */
}
  #pickup .container ul li {
  flex: 0 1 calc(20% - 20px); /* gap分を調整 */
  box-sizing: border-box;
}

/* #pickup .container ul li:hover a div p {
  color: #23B553; 
} */

  #pickup .container ul li div {
  padding: 14px 10px;
}
}

#more_case_btn {
  position: relative;
}
#more_case_btn::after {
  position: absolute;
  content: '';
  width: 14px;
  height: 14px;
  display: block;
  background-image: url(https://www.shinko-jp.com/cms/wp-content/themes/shinko/images/lp-offmeshi/icon_next_green.svg);
  top: 48%;
  transform: translateY(-50%);
  right: 20px;
}

/* ---------------------------------
TOPに戻る
--------------------------------- */
.side_top {
    position: fixed;
    right: 4px;
    bottom: 20px;
    margin-top: 6px;
    width: 40px;
    height: 40px;
    background-color: #44af35;
    border-radius: 80px;
    margin-right: 2px;
    /* padding:10px 12px 12px; */
    z-index: 1000;
    opacity: 0;
    transition: all 0.65s;
    border: none;
    border: 2px solid white;
    display: flex;              /* フレックスボックスを使う */
    align-items: center;        /* 縦方向中央揃え */
    justify-content: center; 
    padding: 0;
    }

    .side_top.isActive {
      opacity: 1;
      transition: all 0.65s;
    }
     .side_top img {
        width: 13px;
        transform: rotate(-90deg);
    }
    @media(min-width:768px){
      .side_top {
      right: 10px;
      bottom: 15px;
      width: 44px;
      height: 44px;
      /* padding:10px 12px; */
    }

    .side_top.isActive {
      opacity: 1;
      transition: all 0.65s;
    }
     .side_top img {
        width: 17px;
        transform: rotate(-90deg);
    }
    }
    @media(min-width:920px) {
      .side_top {
    bottom: 38px;
    width: 44px;
    height: 44px;
    margin-right: 4px;
    /* padding: 6px 13px 13px; */
    right: 15px;
    }
.side_top img {
        width: 13px;
    }
        .side_top:hover {
        filter: brightness(0.7);
        transition: 0.3s;
    }
    }


    /* ----------------------------
    form
    ------------------------------- */
    #form {
      margin-top: 80px;
    }

    /* ----------------------------
    footer
    ------------------------------- */
   .footer__simple {
  margin-top: auto;
}
.footer__simple .copyright{
  background: #44AF35;
  font-size: 14px;
    color: #fff;
    text-align: center;
    padding: 5px 0;
}