@charset "UTF-8";

/*----------------------------------------------------------------------------------------------------------------index----------*/

.logo-mask{
    position:relative;
    width: 300px;
    height: 118px;
    left:50%;
    top:50%;
    transform: translate(-50%, -50%);
    
    -webkit-mask-image: url(../images/think_logo_b.svg);
    -webkit-mask-size: cover;
    mask-image: url(../images/think_logo_b.svg);



    mask-size: cover;
  mask-repeat: no-repeat;
  mask-position: 0 0;
  mask-size: 300px 118px;
  
}

#loadingbar {
    width: 300px;
    height: 118px;
    position:relative;
    mix-blend-mode: multiply;
  }








.loading {
    position: fixed;
    top: 0;
    left: 0;
    width: 100vw;
    height: 100vh;
    z-index: 1000;
    background-color: #000;
    display: flex;
    align-items: center;
    justify-content: center;
    animation: fadeOut 1.5s 2.5s forwards;
  }
  
  @keyframes fadeOut {
    0% {
      opacity: 1;
    }
  
    100% {
      opacity: 0;
      visibility: hidden;
    }
  }
  
  .loading__logo {
    opacity: 0;
    animation: logo_fade 2s 0.5s forwards;
    width: 175px;
  }
  
  @keyframes logo_fade {
    0% {
      opacity: 0;
      transform: translateY(20px);
    }
  
    60% {
      opacity: 1;
      transform: translateY(0);
    }
  
    100% {
      opacity: 0;
    }
  }





.contentbox {
    
    width:100%;
    
    margin-right:auto;
    margin-left:auto;
}



#mainarea .contentbox {
    overflow: hidden;
    position: relative;
}

.container-fluid {
    padding-right: 0px;
    padding-left: 0px;
}





.scrolldown2 {
    position: absolute;
    bottom: 120px;
    left: 50%;
    z-index: 30;
    display:none;
}

.scrolldown2 span {
    position: absolute;
    left: 10px;
    bottom: 10px;
    color: #fff;
    font-size: .7rem;
    letter-spacing: .05em;
    -ms-writing-mode: tb-rl;
    -webkit-writing-mode: vertical-rl;
    writing-mode: vertical-rl
}

.scrolldown2:before {
    content: "";
    position: absolute;
    bottom: 0;
    left: -2px;
    width: 5px;
    height: 10px;
    border-radius: 0%;
    background: #fff;
    animation: circlemove 1.6s ease-in-out infinite, cirlemovehide 1.6s ease-out infinite
}

@keyframes circlemove {
    0% {
        bottom: 45px
    }

    100% {
        bottom: -5px
    }
}

@keyframes cirlemovehide {
    0% {
        opacity: 0
    }

    50% {
        opacity: 1
    }

    80% {
        opacity: .9
    }

    100% {
        opacity: 0
    }
}

.scrolldown2:after {
    content: "";
    position: absolute;
    bottom: 0;
    left: 0;
    width: 1px;
    height: 50px;
    background: #fff
}







.hero_area{
    background:#00a75b;
    padding:80px 0 50px ;
    position:relative;
}


.imgarea.active {
    position: relative;
        width: 1000px;
        
        margin:0 auto;
}


.sub_img{
    margin-top:4rem;
    margin-bottom:4rem;
    width:100%;
    max-width:300px;
    margin-left:auto;
    margin-right:auto;
}



.kanda_logo{
    position:absolute;
    right:2rem;
    bottom:2rem;
    z-index:300;
}

.kanda_logo img{
    width:130px;
    height:25px;
}



.head_hero_title{
    
    position: absolute;
    top: 0;
  right: 0;
  bottom: 0;
  left: 0;
  margin: auto;
  width:100%;

  
}

.head_hero_title .inner{
    width: 100%;
    max-width:1200px;
    height: 800px;
    position:relative;
    margin-left:auto;
    margin-right:auto;
    min-width:1024px;
    z-index: 100;
    
    text-align: center;
    top:0px;
    margin-top:120px;
}





.head_hero_point{
    max-width: 320px;
    margin-left: auto;
        margin-right: auto;
}


.midashi_sp{
    display:block;
    z-index: 100;
    position:relative;

text-align: center;

}

.midashi_sp img{
    width:88%;
    max-width: 360px;;
    margin-left:auto;
    margin-right:auto;
}



.midashi01{
    z-index: 100;
    

}

.midashi01 img{
    width:auto;
    height:115px;

    height: calc(80vh / 7);
    max-height:115px;
}

.midashi02{
    
  
}

.midashi02 img{
    width:auto;
    height:229px;
    max-height:229px;
    height: calc(190vh / 7);
}

.midashi03{
    
}

.midashi03 img{
    width:auto;
    height:35px;
    height: calc(30vh / 7);
}

.midashi04{
    
}

.midashi04 img{
    width:auto;
    height:237px;

    height: calc(300vh / 7);
    max-height:237px;

    -webkit-filter: drop-shadow(0px 3px 6px rgba(29, 21, 93, 0.5)); /* SafariなどのWebkitブラウザ用 */
filter: drop-shadow(0px 3px 6px rgba(29, 21, 93, 0.5));
}

.hero_txt{
    
    z-index: 100;
    text-align:center;
}


.head_hero_point{
    
}


.head_hero_point img{
    width:100%;
    

    -webkit-filter: drop-shadow(0px 3px 10px rgba(29, 21, 93, 0.8)); /* SafariなどのWebkitブラウザ用 */
filter: drop-shadow(0px 3px 10px rgba(29, 21, 93, 0.8));
}






/*----------------------------------------------------------------------------------firefox fade対策----------*/
img,
x:-moz-any-link,
x:default {
    box-shadow: #000 0 0 0;
}



/*
追随ボタン
*/

#btn-contact {
    display: none;
    z-index:200;
}


#btn-contact {
    position: fixed;
    
}



#btn-contact a {
    width:130px;
    height:30px;
    padding:8px;

    font-weight: 700;
        font-size: 1.4rem;
    
    text-align: center;
    
    background: #00a75b;
    border:1px solid #00a75b;

    text-decoration: none;
    color: #fff;

    border-radius: 50px 0px 0px 50px;

    /* background color transition */
    -webkit-transition: 1s;
    -moz-transition: 1s;
    transition: 1s;

    display:inline-flex;
    justify-content: center;
    align-items: center;
    gap:8px;

}

#btn-contact a:hover {
    background-color: #fff;
    color: #00a75b;
}


#btn-contact  a:hover .icon--pink {
    opacity: 1;
}




/*
haed
*/
header {
    position: fixed;
    height: 70px;
    width: 100%;
    max-width:1280px;
    z-index: 999;
    display: flex;
    justify-content: center;
    align-items: center;
    
    margin-left:auto;
    margin-right:auto;
    padding: 20px 8px 20px 20px;
    gap:40px;

    -webkit-transition: 0.6s ease;
    -moz-transition: 0.6s ease;
    -o-transition: 0.6s ease;
    transition: 0.6s ease;
    background-color: rgba(255, 255, 255, 1);
}



header.scbg {
    background-color: rgba(255, 255, 255, 1);
    margin-top:0;
    
}




.logo h1 img {
    width: 100%;
    max-width: 150px;
    -webkit-transition: 0.8s ease;
    -moz-transition: 0.8s ease;
    -o-transition: 0.8s ease;
    transition: 0.8s ease;
}

.logo h1 img.mini {
    max-height: 30px;
}



@keyframes fadeInUpMin {
    from {
        opacity: 0;
        transform: translate3d(0, 8%, 0);
    }

    to {
        opacity: 1;
        transform: none;
    }
}

.fadeInUpMin {
    animation-name: fadeInUpMin;
}

@keyframes fadeInDownMin {
    from {
        opacity: 0;
        transform: translate3d(0, -8%, 0);
    }

    to {
        opacity: 1;
        transform: none;
    }
}

.fadeInDownMin {
    animation-name: fadeInDownMin;
}


@keyframes fadeInLeft {
    from {
        opacity: 0;

    }

    to {
        opacity: 1;
    }
}

.fadeInLeft {
    animation-name: fadeInLeft;
}


@keyframes fadeInRight {
    from {
        opacity: 0;
        transform: translate3d(-8%, 0, 0);
    }

    to {
        opacity: 1;
        transform: none;
    }
}

.fadeInRight {
    animation-name: fadeInRight;
}


@keyframes fadeInLeftMin {
    from {
        opacity: 0;
        transform: translate3d(-8%, 0, 0);
    }

    to {
        opacity: 1;
        transform: none;
    }
}

.fadeInLeftMin {
    animation-name: fadeInLeftMin;
}


@keyframes fadeInRightMin {
    from {
        opacity: 0;
        transform: translate3d(8%, 0, 0);
    }

    to {
        opacity: 1;
        transform: none;
    }
}

.fadeInRightMin {
    animation-name: fadeInRightMin;
}









.contents_title {
margin-left:auto;
margin-right:auto;
text-align: center;
position:relative;
}

.contents_title h3 {
    font-size: clamp(16px, (1rem + 4vw), 30px);
    margin-bottom:clamp(20px, 10 * (9vw + 1vh) / 2, 30px);
    font-weight:800;
}

.contents_title h3.about-title {
    font-size: clamp(16px, (1rem + 5vw), 38px);
    margin-bottom:clamp(16px, 10 * (9vw + 1vh) / 2, 16px);
}

.contents_title h3.about-title .unyo {
    font-size: clamp(18px, (1rem + 6vw), 53px);
    color:#e2007f;
}



.onayami_title {
    margin-left:auto;
    margin-right:auto;
    display:flex;
    justify-content: flex-start;
    flex-direction:column;
    align-items: center;
    width:100%;
    max-width:700px;
    }
    

    


    .onayami_title h3 {
        font-size: clamp(16px, (1rem + 4vw), 30px);
        margin-bottom:clamp(30px, 8vw, 50px);
        font-weight:800;
    }

    
    .onayami-teian{
        background: #00a75b;
        padding:40px 15px;
        text-align: center;
    }

    .onayami-teian inner{
        width:1000px;
        
    }




    .onayami-teian h4{
        color:#fff;
        margin:3.5rem 0 4rem 0;
        }



    




.emphasis {
    background: linear-gradient(transparent 75%, #ffef00 75%);
    background-position-y: -2px;
}


.onayami-txt-wrap{
    display:flex;
    align-items: flex-start;
    flex-direction:column;
justify-content: flex-start;
text-align: left;
margin-bottom:1rem;
}


.onayami-txt{
    margin-bottom:20px;
}


.onayami-txt img{
    width:100%;

    height:clamp(20px, 3.5vh, 26px);


}

.onayami-circle{
    display:flex;
    align-items:center;
justify-content: center;
gap:18px;
flex-wrap: wrap;
}

.circle_txt{
    width:calc(25% - 18px);
}


.contents_title p {
text-align: center;
}


.onayami-people{
    display:flex;
    align-items:center;
justify-content: center;
width:100%;
max-width: 450px;
margin-left:auto;
margin-right:auto;
margin-top:-3rem;
gap:18px;
height:100%;
max-height:128px;
}


.onayami-people img{    
height:100%;
max-height:128px
}



.sub-title{
    color:#333;
    position:relative;
    
}

.sub-title:before{
    background:#00a75b;
    position:absolute;
    width:120px;
    height:4px;
    content:"";
    left:calc(50% - 60px);
    bottom:-22px;
    
}


.sub-txt{
    color:#00a75b;
    padding-top:5px;
    margin-bottom:30px;
}


.tuiki_title {
    margin-left:auto;
    margin-right:auto;
    text-align: center;
    position:relative;
    
    }
    
    .tuiki_title h3 {
        font-size: clamp(16px, (1rem + 5vw), 40px);
        margin-bottom:min(5vw,30px);
        font-weight:800;
        color:#00a75b;
        position:relative;
        display:inline-block;
        line-height: 130%;
    }


    .tuiki_title h3 span {
        background: linear-gradient(transparent 80%, #ffef00 80%);
        background-position-y: -5px;
    }

    .tuiki_title h3:before {
        content: "";
        position:absolute;
        background: url(../images/06_otoshiana_05.svg) no-repeat left top;
        background-size: contain;
width:81px;
height:103px;
z-index: 10;
right:-85px;
bottom:0;

    }


.hole-tuiki-txt{
    color:#3b308c;
    padding-top:5px;
    margin-bottom:10px;
    font-size:2rem;
    text-align: center;

    align-items: center; /* 線を上下中央 */
  display: flex; /* 文字と線を横並び */
  justify-content: center; /* 文字を中央寄せ */

}

.hole-tuiki-txt::before,
.hole-tuiki-txt::after {
  background-color: #3b308c; /* 線の色 */
  border-radius: 2px; /* 線の両端を丸く */
  content: "";
  height: 2px; /* 線の高さ */
  width: 30px; /* 線の長さ */
}
.hole-tuiki-txt::before {
  margin-right: 0px; /* 文字との余白 */
  transform: rotate(60deg); /* 傾ける */
}
.hole-tuiki-txt::after {
  margin-left: 0px; /* 文字との余白 */
  transform: rotate(-60deg); /* 傾ける */
}





/*
content
*/


.page-wrap{
    

    padding-top:calc(80px + 80 * ((100vw - 320px) / 1120));

    padding-bottom:100px;
    width: 100%;
    background: #d9f2e6;
    
}



#section01 {
    width: 100%;
    
}

#about {
    padding-top:85px;
    padding-bottom:85px;
}


#section_onayami .inner {
    width: 1030px;
    margin: 0 auto;
    padding-left:15px;
    padding-right:15px;
}



#section01 .inner {
    width: 100%;
    max-width: 1100px;
    margin: 0 auto;
    padding-left:15px;
    padding-right:15px;
    
}


#service{
    padding-top:100px;
    
}


#service h3 {
    font-size: clamp(16px,(1rem + 4vw), 30px);
    margin-bottom: clamp(1.125rem, 0.331rem + 3.97vw, 2.813rem);
    font-weight: 800;
    text-align: center;
    background:#ccedde;
    border-radius:4rem;
    padding:1rem 2rem 1rem 2rem;
    margin-bottom:40px;
}


.daiko_wrap .inner {
    width: 1060px;
    margin: 0 auto;
    padding-left:30px;
    padding-right:30px;
    
    position:relative;
}

.daiko_wrap{
    position:relative;
margin-bottom:10rem;
    border-bottom:5px solid #00a75b;
}

#service .daiko_wrap:last-child{
margin-bottom:0rem;
    border-bottom:none;
}

.daiko01_image {
    position:absolute;
    width:100%;
    max-width:200px;
    right:5rem;
    top:2rem;
}

.daiko01_image_sp {
    text-align: center;
}

.daiko01_image_sp img{
    width:100%;
    max-width: 240px;
}




.daiko02_image {
    position:absolute;
    width:100%;
    max-width:265px;
    right:0;
    top:-3rem;
}

.daiko02_detail{
    display: flex;
    align-items:flex-start;
    justify-content:space-between;
    flex-wrap: wrap;
    gap:2rem;
}

.daiko02_detail_left, .daiko02_detail_right {
    width:calc(50% - 1rem);
}


.daiko02_detail_title{
    border-radius:2rem 2rem 0 0;
background:#00a75b;
padding:1rem 0;
font-size: clamp(1.6rem, 1.1728rem + 1.14vw, 2.6rem);
    font-weight: 800;
color:#fff;
text-align:center;
}


.daiko02_detail_body{
    padding:2rem 3rem;
    background:#ccedde;
   
    font-size:1.3rem;
    border-radius:0 0 2rem 2rem;
}

.daiko02_detail_body ul{
    display: flex;
    align-items:flex-start;
    justify-content:space-between;
    flex-wrap: wrap;
    gap:0 2rem ;
    position:relative;
    margin-top:3rem;
    margin-bottom:3rem;
}

.daiko02_detail_body li{
    width:calc(50% - 1rem);
    margin-bottom:1rem;
    position:relative;
    padding-left:20px;
}

.daiko02_detail_body li:before{
    content:"●";
    color:#00a75b;
    position:absolute;
    left:0;
    top:0;
    
}


.emphasis {
    background: linear-gradient(transparent 75%, #ffef00 75%);
    background-position-y: -2px;
}



.daiko02_sime{
padding:1rem 0;
font-size: clamp(1.8rem, 1.424rem + 1.18vw, 2.2rem);
    font-weight: 800;
text-align:center;
position:relative;
margin-top:2rem;
margin-bottom:8rem;
}


.daiko03_image {
    position:absolute;
    width:100%;
    max-width:265px;
    right:0;
    top:-1rem;
}

.daiko03_unyo{
    display: flex;
    align-items:flex-start;
    justify-content:space-between;
    flex-wrap: wrap;
    gap:0 1rem ;
    position:relative;
    margin-bottom:10rem;
}

.daiko03_unyo_box{
    width:calc(20% - 1rem);
}

.daiko03_unyo_txt{
    border-right:1px solid #aaa;
}


.daiko_title{
    display: flex;
    align-items: center;
    justify-content: flex-start;
    gap:2rem;
    margin-bottom:42px;
}

.daiko_no {
    
    border-right:1px solid #111;
    padding-right:2rem;
    padding-top:.5rem;
    padding-bottom:.5rem;
}

.daiko_no img {
    height:100%;
    max-height:60px;
    
}


.daiko_title_txt {
    font-size: clamp(2rem, 1.624rem + 1.18vw, 2.8rem);
    
    font-weight: 800;
    color:#00a75b;

    
}



.daiko_flow_pc {
    display: flex;
    align-items:flex-start;
    justify-content:center;
    flex-wrap: wrap;
    gap:0;
    position:relative;
    margin-bottom:10rem;
}

.daiko_flow_pc_box{
    width:20%;
}




.daiko_flow{
    margin-top:6.5rem;
    margin-bottom:9.5rem;
}

.flow_title{
   text-align:center;
   margin-top:5rem;
   margin-bottom:2rem;
}


.flow_title span{
    border:1px solid #ec6d74;
    color:#ec6d74;
    padding:.5rem 1rem;
    margin-left:auto;
    margin-right:auto;

}



#archive{
    background:#d9f2e6;
    padding: 8rem 0 10rem 0;
}


#archive h3{
    font-size: clamp(2.2rem, 1.824rem + 1.18vw, 3rem);
    font-weight: 800;
text-align:center;
position:relative;
margin-top:2rem;
margin-bottom:7.2rem;
}

#archive h3 span{
padding-bottom:1rem;
border-bottom:4px solid #00a75b;
padding-left:1rem;
padding-right:1rem;
}


#archive .inner {
    width: 1060px;
    margin: 0 auto;
    padding-left:30px;
    padding-right:30px;
    
    position:relative;
}

.archive_img01{
    
    width: 100%;
    max-width: 900px;
    margin: 0 auto 4.8rem auto;
}

.archive_img01_sp{
    width:100%;
    max-width: 250px;
    margin:0 auto 5rem auto;
    display:flex;
    flex-direction:column;
    align-items:center;
    gap:1rem;
}

.jisseki_01{
    background:#fff;
    border-radius:2rem;
    border:3px solid #00a75b;
    padding:3rem 3rem;
    text-align:center;
}

.jisseki_01 img{
    width:100%;
    max-width:170px;
}

.jisseki_02{
    background:#fff;
    border-radius:2rem;
    padding:2rem 3rem;
    text-align:center;
}

.jisseki_02 img{
    width:100%;
    max-width:160px;
}

.jisseki_03{
    background:#fff;
    border-radius:2rem;
    border:3px solid #ec6d74;
    padding:3rem 3rem;
    text-align:center;
}

.jisseki_03 img{
    width:100%;
    max-width:160px;
}


.archive_img02{
    
    width: 100%;
    max-width: 900px;
    margin: 0 auto 0 auto;
}



#price {
    width: 100%;
    
    

    background: url(../images/price_bg.png) repeat left top;

    padding-bottom:10rem;
}




#price h3{
    font-size: clamp(2.2rem, 1.824rem + 1.18vw, 3rem);
    font-weight: 800;
text-align:center;
position:relative;
margin-top:2rem;
margin-bottom:9rem;
}

#price h3 span{
padding-bottom:1rem;
border-bottom:4px solid #00a75b;
padding-left:1rem;
padding-right:1rem;
}




#price .inner {
   width: 1060px;
    margin: 0 auto;
    
    padding-left: 30px;
    padding-right: 30px;

    padding-top: 8rem;
    
}


.price_wrap{
    display: flex;
    align-items: flex-start;
    justify-content: flex-start;
    flex-wrap: wrap;
    gap:2rem;
    margin-bottom:3rem;
    position:relative;
}

.plan_img{
    position:absolute;
    right:7rem;
    bottom:20rem;
    width:123px;
}



.plan03table{
    width:750px;
}


.js-scrollable td{
    padding-top:1rem;
    padding-bottom:1rem;
}






.price_img01{
    width:30%;
}

.price_img02{
    width:calc(70% - 2rem);
    margin-top:-10.5rem;
}

.price_img02 img{
   
    margin-bottom:1rem;
}

.plice_shoki{
    border:5px solid #ec6d74;
    background:#fff;
    border-radius:2rem;
    padding:3.5rem 2rem;

}


#price h3.support_title{
    border-left:8px solid #00a75b;
    padding-left:1.5rem;
    text-align: left;
    margin-bottom:0rem;
}

.support_caution p{
    font-size:1.1rem;
}

.support_caution p span{
    color:#00a75b;
    font-weight:700;
}

.support_img{
    margin-bottom:1rem;
}


.tuika{
    display:flex;
    justify-content: flex-start;
    align-items: center;
    flex-wrap: wrap;
}

.tuika_title{
    color:#fff;
    background:#88a3d4;
    font-size:2.2rem;
    padding:0rem 2rem 0rem 3rem;
    border-radius:3rem 0 0 3rem;
    width:200px;
    display:flex;
    align-items: center;
    justify-content: center;
}

.tuika_price{
    background:#ffffff;
    width:calc(100% - 200px);
    padding:.5rem 3rem .5rem 2rem;
    border-radius:0 3rem 3rem 0;
    display:flex;
    align-items: center;
    justify-content: center;
}






#section02 {
    width: 100%;
    background: linear-gradient(-20deg, rgba(251, 208, 62, .1), rgba(232, 85, 50, .1) 22%, rgba(226, 0, 127, .1) 60%, rgba(59, 48, 141, .1) 78%, rgba(59, 48, 141, .1) 90%, rgba(226, 0, 127, .1));
}

#section02 #dekirukoto.inner{
    margin-top:30px;
}

#section02 .inner {
    width: 100%;
    max-width: 1100px;
    margin: 0 auto;
    padding:0 15px;
    
    padding: clamp(3rem, 6vmax, 13rem) 15px 0 15px;
}


#section02 .inner.part04{
    padding-bottom:120px
}

#dekirukoto {
    width: 100%;
    background: linear-gradient( rgba(252, 235, 242, 1), rgba(234, 239, 249, 1)30% );
}

#section02 #dekirukoto .inner {
    padding-top: 3.5rem;
    padding-bottom: 2rem;
}


#section02 #service-wrap {
    width: 100%;
    background: linear-gradient( rgba(252, 235, 242, 1), rgba(234, 239, 249, 1)30% );
}

#section02 #jisseki-wrap {
    width: 100%;
    background: linear-gradient( rgba(252, 235, 242, 1), rgba(234, 239, 249, 1)30% );
}


#section02 #nagare {
    width: 100%;
    background: linear-gradient( rgba(252, 235, 242, 1), rgba(234, 239, 249, 1)30% );
}

#section02 #nagare .inner {
    padding-top: 3rem;
    padding-bottom: 3rem;
}


#section02 #hole {
    width: 100%;
    background: linear-gradient( rgba(252, 235, 242, 1), rgba(234, 239, 249, 1)30% );
}

#section02 #hole .inner {
    padding-top: 3rem;
    padding-bottom: 3rem;
}





.price-pc{
margin-top:5rem;
}


.price-table{
    display:flex;
    justify-content:space-between;
    align-items: flex-start;
    flex-wrap: wrap;
    gap:1rem;
    
}

.plan_cell-pc{
    width:calc(25% - 1rem);
}


.plan_detail_wrap {
    text-align: left;
}

.plan_mark {
    width: 100%;
    max-width: 20px;
}

.plan_mark{
    width:100%;
    max-width:20px;
    }
    
    .pdt{
    width:100%;
    
    }


    .plan_detail_text{
        padding:10px 0;
        position:relative;
        display:flex;
        justify-content: flex-start;
        align-items: flex-start;
        gap:1rem;
        }




/**************************
 slick スライダー
***************************/

    .slide-dots {
        margin: 2rem 0 0 0;
        padding: 0;
        text-align: center;
      }
      .slide-dots li {
        display: inline-block;
        margin: 0 8px;
      }
      .slide-dots li button {
        position: relative;
        text-indent: -9999px;
        width:11px;
        height:11px;
        border-radius: 8px;
        margin:0;
        padding:0;
      }
      .slide-dots li button::before {
        background:none;
        content: "";
        cursor: pointer;
        height: 13.5px;
        left: 0;
        margin: auto;
        position: absolute;
        right: 0;
        top: 24px;
        width: 13.5px;
      }
      .slide-dots li.slick-active button::before {
        background: none;
      }
      button {
        background: none;
        border: none;
        outline: none;
        padding: 0 7px;
      }

      .slick-list{
        background:#fff;
      }

.slick-active button{
    background:#111;
    border-color: #111;
}



/**************************
 タブ PC 切り替え
***************************/
/* 全体を囲むdiv（親要素）*/
.tab-wrap {
    --tab-color:#f9deb9; /*タブの色*/
    --active-tab-color:#f39800; /*選択したタブの色*/
    display: flex;
    flex-wrap: wrap;
    justify-content:space-between;
    align-items: center;
    gap:0 1rem; /*タブ間の余白*/
  }
  
 

  .tab-btn{
    width:calc(50% - 1rem)% !important;

  }

  /*タブ(label)のスタイル*/
  .tab-label {
    
    color:#f39800;
    background-color:var(--tab-color);
    text-align: center;
    padding: 1.5rem 1rem 1rem 1rem;
    border-radius:14px;
    cursor: pointer;
    flex-grow: 1;/*flexアイテムの比率を指定*/
    order: -1; /*タブを上段に表示する*/

    font-size:1.8rem;
    position:relative;
    box-shadow: rgba(0, 0, 0, 0.15) 1.95px 1.95px 2.6px;

    -webkit-transition: .5s;
    -moz-transition: .5s;
    transition: .5s;
  }

  .tab-label::before {
    position:absolute;
    left:5px;
    top:5px;
    content:"";
    background: url(../images/btn_shadow_left.png) no-repeat left top;
    background-size:contain;
    width:120px;
    height:80px;
  }



  

  .tab-label span {
    color:#f39800;
    background-color:#fff;
    border-radius:8px;
    padding:.5rem 1rem;
    font-size:2rem;
    display:inline-flex;
    align-items: center;
  }

  .tab-label img {
    width:22px;
  }


   
  /* タブのコンテンツ部分*/
  .tab-content {
    width: 100%;
    visibility: hidden;
 height:0;
}
  
  /*選択されていることがわかるように、選択されているタブの色を変える*/
  .tab-switch:checked+.tab-label {
    color:white;
    background-color:var(--active-tab-color);
    box-shadow: rgba(50, 50, 93, 0.25) 0px 13px 27px -5px, rgba(0, 0, 0, 0.3) 0px 8px 16px -8px;
  }
  
  /* 選択されているタブのコンテンツを表示させる */
  .tab-switch:checked+.tab-label+.tab-content {
    visibility: visible;
    margin-top:1em;
    height:100%;
  }
  

  .tab-switch:checked+.tab-label span {
    color:var(--active-tab-color);
  }

  .tab-switch:checked+.tab-label span.icon_1 .st0 {
    fill:#F39800;
  }


  .st0{fill:#f39800;}
  .st1{fill:none;}
  

  
  
  /* input（ラジオボタン）は仕組みだけ利用するため非表示 */
  .tab-switch {
    display: none !important;
  }
  
  
  
















/* タブ */

.tab-group {
    display:block;
    margin-top: 20px;
    /* タブ全体の幅 */
    width: 100%;
    list-style: none;
    
    
}

.tab-button {
    display: flex;
    justify-content:space-between;
    list-style: none;
    /* カーソル形状を指先にする */
    cursor: pointer;
    text-align: center;
    align-items: center;
    gap:16px;
    margin-bottom:30px;
    max-width:400px;
    margin-left:auto;
    margin-right:auto;
}



.tab.tab-01, .tab.tab-02 {
    width: calc(100% / 2);
    padding: 8px;
    border-bottom: none;
    text-align: center;
    border-radius:12px 12px 12px 12px;
    position: relative;
    z-index: 0;
    -webkit-transition: .5s;
    -moz-transition: .5s;
    transition: .5s;
    background: linear-gradient( rgba(160, 160, 160, 1)50%, rgba(160, 160, 160, 1) 50%);
}


.tab.tab-01:after, .tab.tab-02:after {
    content: "";
    width: 100%;
    height: 100%;
    display: block;
    position: absolute;
    top: 0;
    left: 0;
    color: #FFF;
    z-index: -1;
    opacity: 0;
    -webkit-transition: .5s;
    -moz-transition: .5s;
    transition: .5s;
    border-radius:8px 8px 8px 8px;
}

.tab.tab-01.is-active:after {
    content: "";
    width: 100%;
    height: 100%;
    display: block;
    position: absolute;
    top: 0;
    left: 0;
    background: rgba(243, 152, 0, 1);
    color: #FFF;
    z-index: -1;
    opacity: 1;
    
}

.tab.tab-02.is-active:after {
    content: "";
    width: 100%;
    height: 100%;
    display: block;
    position: absolute;
    top: 0;
    left: 0;
    background: rgba(243, 152, 0, 1);
    color: #FFF;
    z-index: -1;
    opacity: 1;
}



















#faq {
    width: 100%;
    background: linear-gradient( rgba(252, 235, 242, 1), rgba(234, 239, 249, 1)30% );
}



#faq .inner {
    width: 100%;
    max-width: 1100px;
    margin-left:auto;
    margin-right:auto;
    padding-top: 3rem;
    padding-left: 15px;
    padding-right: 15px;
    padding-bottom:120px;
}

#section03 {
    width: 100%;
    padding:50px 0;
}


#section03 .inner {
    width: 100%;
    max-width: 1200px;
    margin: 0 auto;
    padding: clamp(2rem, 8vmax, 8rem) 15px 90px 15px;

}






#section04 {
    width: 100%;
    background: linear-gradient(-30deg, rgba(251, 208, 62, .1), rgba(232, 85, 50, .1) 22%, rgba(226, 0, 127, .1) 60%, rgba(59, 48, 141, .1));
}


#section04 .inner {
    width: 100%;
    max-width: 1200px;
    margin: 0 auto;
    padding:0 15px;
    padding: 4rem 15px;
    padding: clamp(2rem, 8vmax, 8rem) 15px 90px 15px;
}







#section {
    position:relative;
    width: 100%;
}


#section04 .inner {
    width: 100%;
    max-width: 1200px;
    margin: 0 auto;

}


.codebox {
    padding-top: 0px;
    padding-bottom: 50px;
    padding-left: 0px;
    padding-right: 0px;
    margin-top: 0px;
    position: relative;
}


.code-title{
    width: calc(280px + 350 * ((100vw - 320px) / 1120));
    margin:0 auto 0 auto;
}


/*
top page section01
*/

.about-intro-txt{
    margin-bottom: 2rem;
    font-size: clamp(17px, (1rem + 1vw), 21px);
}


.problem_wrap{
    display:flex;
    flex-wrap: wrap;
    align-items: center;
    justify-content: center;
}

.probrem-left, .probrem-right{
    width:33%;
    z-index:3;
    height:100%;
    position:relative;
    
}

.probrem-left{
    margin-right:-4rem;
    
}

.probrem-right{
    margin-left:-4rem;
}


.probrem-center{
    width:40%;
}

.probrem-list{
    flex-grow:1;
    }

.probrem-list ul{
margin:0 auto;
padding:0;
position:relative;
height:100%;
display:-webkit-box;
  display:-ms-flexbox;
  display:flex;
  flex-flow: column;
  
  -ms-flex-pack:distribute;
  justify-content:space-around;
  width:100%;
  max-width:480px;

}

.probrem-list li{
    border:1px solid #3b308c;
    border-radius:1.2rem;
    padding:10px 18px;
    text-align:left;
    font-weight:700;
    
    background:#fff;
    margin-bottom:17px;
    min-height:64px;

    display: flex;
  align-items: center;
  justify-content: flex-start;
    
}


.probrem-list .emphasis{
    font-size:2rem;
    
}



.probrem-list-sp{
    display:none;
}






.probrem-list li:last-child{
    margin-bottom:0px;
}

.check-mark {
    width:25px;
    margin-right:8px;
}

.plusmark{
    display:none;
}


.color-pink{
color:#e2007f;
}



.ruled-line {
    position: relative;
    border-bottom: 2px solid #3b308d;
    background: #fff;
    color: #000;
    text-align: right;
    font-size: 24px;
    
    padding-right: calc(1px + 80 * ((100vw - 320px) / 1120));
    margin: 20px 0 40px 0;

}
    /* 下三角 */ 
    .ruled-line:before{
        content: "";
        position: absolute;
        bottom: -36px;
        
        left: calc(50% - 18px);
        margin-left: 2px;
        border: 18px solid transparent;
        border-top: 18px solid #fff;
        z-index: 2;
    }
    .ruled-line:after {
        position: absolute;
        border: 21px solid transparent;
        border-top-color: #3b308d;
        border-bottom-width: 0;
        bottom: -21px;
        
        content: "";
        left: calc(50% - 19px);
        z-index: 1;
    }


    .ruled-line img {
        width: calc(135px + 100 * ((100vw - 320px) / 1120));
        margin-bottom:-7px;
    }

    .correct-wrap{
        display:flex;
        flex-wrap: wrap;
        margin-bottom:65px;
    }

    .correct-box h4{
        font-size:21px;
        line-height:140%;
        
        
    }
    .correct-box{
        display:flex;
        flex-direction: column;
        align-items: center;
        text-align: center;
        width:50%;
    }

    .correct_title{
        display:flex;
        flex-direction: column;
        align-items: center;
        text-align: center;
        margin-bottom:12px;
    }


    .correct_illust img {
        width:100%;
        max-width:350px;
    }


    
    .correct_icon{
        width:60px;
        
    }
   .correct_txt {
        flex-grow: 1;
        
        width: calc(100% - 76px);
    }
    .correct h4 {
        color:#e2007f;
    }
    .incorrect h4 {
        
        color:#3b308d;
    }

    


/*
top page section02
*/

.logical_title{
    width:100%;
    max-width:clamp(370px, 10 * (10vw + 2vh) / 2, 680px);
    margin-bottom:35px;
}

.logical_subtext{
    display:none;
}


.logical_wrap {
    display:flex;
    justify-content: center;
    flex-wrap: wrap;
    padding-bottom:40px;
}

.logic_circle{
    display:flex;
    
    justify-content: flex-start;
    align-items: center;
    flex-direction: column;
    text-align: center;

    width:50%;
    background: #fff;

    width:clamp(360px, 10 * (10vw + 2vh) / 2, 400px);

    height:clamp(360px, 10 * (10vw + 2vh) / 2, 400px);

    border-radius: 50%;
    -moz-border-radius: 50%;
    -webkit-border-radius: 50%;
    padding:40px;
    text-align: center;
}

.left{
    margin-right:-20px;
}

.right{
    margin-left:-20px;
}

.logic_area{
    position:relative;
    top:50px;
}
.emotion_area{
    position:relative;
    top:50px;
}

.logic_circle img{
    height:clamp(20px, 10 * (10vw + 2vh) / 2, 40px);

}

.logic_title{
    margin-bottom:20px;
    
}

.logic_txt{
    
}


.logic_subject{
    color:#3b308c;
    margin-bottom:35px;
    font-weight:700;
    
}






@keyframes slide_img {
    100% {
        background-position: -10000px 0;
    }
}

.jp_slide_img_wrapper.sp {
    display:none;
}






.wecan_wrap {
    position:relative;
    display:flex;
    gap:22px;
    flex-wrap: wrap;
    margin-bottom:50px;
    margin-top:50px;
}

.wecan_circle{
    width:calc(25% - 17px);
    background: #fff;
    
    background: url(../images/bg_circle.png) no-repeat center center;
    background-size: contain;
    padding:50px 30px;
    text-align: center;
    display:flex;
    justify-content: center;
    align-items: center;
    flex-direction: column;
    margin-bottom:calc(1px + 5 * ((100vw - 320px) / 1120));
}

.wecan_circle img{
    height:100%;
    max-height:100px;
}

.small_cap{
    display:block;
    font-size:80%;
    
}

.wecan_txt{
    min-height:43px;
}






.tab-group {
    display:none;
}

.carousel_slider{
    display:none;
}




.tsuyomi_wrap{
    display:flex;
    position:relative;
    flex-wrap: wrap;
    gap:32px;
    margin-bottom:50px;
}

.tsuyomi_box{
    width:calc(50% - 16px);
    
}

.tsuyomi_box img{
    border-radius:18px 18px 0 0;

}



.tsuyomi_txt{
    background:#fff;
    padding:40px 40px 30px 40px;
    border-radius:0 0 18px 18px;
}

.tsuyomi_title{
    font-size:2.3rem;
    margin-bottom:18px;
}

.tsuyomi-intro{margin-bottom:50px;}



.tsuyomi_lastbox{
    width:100%;
    display:flex;
    
}


.lastbox-img{
    border-radius:18px 0 0 18px;
    width:53%;

    background: url(../images/04_tsuyomi_05.jpg) no-repeat center center;
    background-size: cover;

}

.lastbox-txt{
    width:47%;
    border-radius:0 18px 18px 0;
}




.flow-wrap{
    position:relative;
    display:flex;
    flex-wrap: wrap;
    align-items: center;
    justify-content: space-between;
    width:100%;
    max-width:800px;
    margin-left:auto;
    margin-right:auto;
    margin-bottom:54px;
}

.flow-box{
    display:flex;
    justify-content: center;
    align-items: center;
    width:100%;
    max-width:67px;
    height:246px;
    color:#fff;
    padding:0;
    border-radius:20px;
    font-size:2rem;
}

.flow-box span{
    -ms-writing-mode: tb-rl;
    writing-mode: vertical-rl;
    white-space: pre;
    display: inline-block;
}


.flow-box:first-child{
  color:#111;
  background:#fff;
  border:1px solid #333;
}

.flow-wrap > div:nth-child(3){
    background:#f19500;
    
  }

  .flow-wrap > div:nth-child(5){
    background:#e85532;
    
  }

  .flow-wrap > div:nth-child(7){
    background:#e2007f;
    
  }

  .flow-wrap > div:nth-child(9){
    background:#9a0181;
    
  }

  .flow-wrap > div:nth-child(11){
    background:#3b308d;
    
  }

  .flow-arrow{
    width:100%;
    max-width:78px;
  }


  



  .flow-detail-wrap{
    position:relative;
    display:flex;
    flex-wrap: wrap;
    align-items: center;
    justify-content: space-between;
    margin-bottom:55px;
    gap:32px;
  }

  .flow-detail{
    background:#fff;
    border-radius:20px;

    width:calc(50% - 16px);
    padding:30px 30px 10px 30px;
    display:flex;
    align-items: center;
    justify-content: space-between;
    flex-wrap: wrap;
    gap:10px;
  }

  .flow-detail-subject{
    border-radius:20px;
    font-size:2rem;
    padding:8px 30px;
    color:#fff;
    display:inline-block;
    margin-bottom:25px;
  }


.sub-first{
    background:#e85532;
  }

  .title-kikaku {
    color:#e85532;
  }

  
.sub-second{
    background:#e2007f;
  }
  
  .title-seisaku{
    color:#e2007f;
  }


.sub-third{
    background:#9a0181;
  }

  .title-bunseki{
    color:#9a0181;
  }

  
.sub-forth{
    background:#3b308d;
  }

  .title-kaizen{
    color:#3b308d;
  }



  .flow-detail-txt{
    width:calc(50% - 13px);
  }

  .flow-detail-txt p{
    margin-bottom:0px;
  }

.flow-detail-img{
    width:calc(50% - 5px);
    
}


.flow-detail-title {
    font-size:2.3rem;
    margin-bottom:16px;

}





.teian-detail-wrap{
    position:relative;
    display:flex;
    flex-wrap: wrap;
    align-items: center;
    justify-content: space-between;
    margin-bottom:55px;
    gap:32px;
    width:100%;
    max-width: 1100px;
    margin: 0 auto 2rem auto;
    padding-left: 15px;
    padding-right: 15px;

    margin-top: clamp(30px, 3vh, 60px);

  }

  .teian-detail{
    width:calc(33% - 19px);
    background:#fff;
    border-radius:20px;
    padding:30px 15px 0px 15px;

    display:flex;
    align-items: flex-start;
    justify-content: center;
    flex-wrap: wrap;
    gap:10px;
    
  }



  .teian-detail-subject{
    border-radius:20px;
    font-size:2rem;
    padding:8px 30px;
    color:#fff;
    display:inline-block;
    margin-bottom:25px;
  }

  .teian-detail-txt{
    
  }

  .teian-detail-txt p{
    margin-bottom:0px;
  }

.teian-detail-img{
    
}




.slide-flow{
    position:relative;
    margin-top:3rem;
    margin-bottom:8rem;
}


.slide-wrap{
    position:relative;
    margin-top:clamp(30px, 3vh, 60px);
    margin-bottom:6rem;
}


  .teian-detail-subject{
    border-radius:20px;
    font-size:2rem;
    padding:8px 30px;
    color:#fff;
    display:inline-block;
    margin-bottom:25px;
  }

  .teian-detail-title {
    font-size:2.3rem;
    text-align:center;
}

.teian-detail-title span.strong {
    color:#e2007f;
    font-size:3.2rem;
    line-height:4rem;
    display:inline-block;
}


.line-yellow {
  display: inline;
    background: -webkit-linear-gradient(transparent 74%, rgba(255, 250, 125, 0.9) 0%);
    background: linear-gradient(transparent 74%, rgba(255, 250, 125, 0.9) 0%);
}





.hole-wrap{
    position:relative;
    display:flex;
    flex-wrap: wrap;
    align-items: center;
    justify-content: space-between;
    margin-bottom:45px;
    gap:32px;
    margin-top:60px;
  }


.hole-detail{
    background:#fff;
    border-radius:20px;
    border:1px dashed #3b308c;
    width:calc(50% - 16px);
    padding:30px;
    display:flex;
    align-items: center;
    justify-content:center;
    flex-wrap: wrap;
    
    gap:26px;
  }

  .hole-detail-title {
    font-size:2.3rem;
    margin-bottom:16px;
    color:#3b308d;
    text-align:center;
}

.hole-img{
    display:flex;
    align-items:flex-end;
}


.adjust01 img{
    max-width:290px;
}

.adjust02 img{
    max-width:260px;
}

.adjust03 img{
    max-width:200px;
}

.adjust04 img{
    max-width:214px;
}


#section02 #service-wrap .inner {
    padding-top: 4rem;
    padding-bottom: 3.5rem;
}

.service-detail-wrap{
    display:flex;
    align-items: flex-start;
    justify-content:space-between;
    gap:2.4rem;
    flex-wrap: wrap;
}


.service-detail{
    background:#fff;
    border-radius:10px;
    width:calc(33% - 1.3rem);
    padding:40px 40px 10px 40px;
    display:flex;
    align-items: flex-start;
    justify-content: center;
    flex-wrap: wrap;
  }

  .service-detail img{
    width:70%;
    
  }

  .service-detail-midashi {
    font-size:2.2rem;
    text-align:center;
    position:relative;
    margin-top:4.5rem;
    margin-bottom:2.8rem;
}
.service-detail-midashi span {
    color:#e2007f;
}



  .service-detail-subject{
    border-radius:20px;
    font-size:2rem;
    padding:8px 30px;
    color:#fff;
    display:inline-block;
    margin-bottom:25px;
  }



  .service-detail-title {
    font-size:2rem;
    text-align:center;
    position:relative;
    border-radius:20px;
    
    padding:8px 30px;
    margin-bottom:15px;
    
    background:#3b308c;
    color:#fff;
}






.service-detail-title span {
    color:#e2007f;
}

.service-detail ul{
    margin-bottom:1rem;
    margin-left:2rem;
}
.service-detail li{
    list-style-type:disc;
    font-size:1.6rem;
    margin-bottom:.8rem;
}


#section02 #jisseki-wrap .inner {
    padding-top: 4rem;
    padding-bottom: .8rem;
}


.jisseki-wrap-pc{
    display:flex;
    align-items: center;
    flex-wrap: wrap;
    justify-content: space-between;
    gap:2rem;
    margin-top:6rem;
    margin-bottom:4rem;
}



.jisseki-wrap{
    margin-top:50px;
}

.jisseki-detail{
    background:#fff;
    border-radius:20px;

    width:calc(33% - 19px);
    padding:30px 10px 25px 10px;
    display:flex;
    align-items: center;
    
    flex-wrap: wrap;

    flex-direction:column;

    
  }

  .jisseki-text{
font-size:1.5rem;
text-align:center;
margin-bottom:1.7rem;
  }

.jisseki-text span.big{
font-size:2.4rem;
  }

  .jisseki-text span.deco-txt{
    background:linear-gradient(transparent 64%, rgba(255, 250, 125, 1) 0%);
    
}


.jisseki-detail-title {
    font-size:2.2rem;
    text-align:center;
    position:relative;
    padding-bottom:8px;
    margin-bottom:24px;
    width:100%;
}

.jisseki-detail-title:before {
    position:absolute;
    background:#111;
    height:1px;
    content:"";
    width:80%;
    bottom:0;
    left:calc(10%);
}

.jisseki-detail-title span {
    font-size:1.5rem;
    display:block;
}

.jisseki-kekka{
    color:#e52880;
    text-align:center;
    margin-bottom:22px;
}



.insta-link{
    display:flex;
    justify-content: center;
    
}

.insta-link a{
    text-decoration: none;
    display:inline-flex;
    justify-content: center;
    align-items: center;
background:#3b308c;
border:1px solid #3b308c;
border-radius:30px;
width:100%;
max-width:200px;
margin-left:auto;
margin-right:auto;
text-align: center;

-webkit-transition: all .3s;
    -moz-transition: all .3s;
    transition: all .3s;

}


.insta-link .button {
    position: relative;
    width: 100%;
    height: 40px;
}


.jisseki-wrap-pc .insta-link a:hover{
background:#fff;
border:1px solid #3b308c;
}


.jisseki-wrap-pc .insta-link a:hover .icon--pink {
    opacity: 1;
}






.insta_contents-link{
    display:flex;
    justify-content: center;
    margin-bottom:2rem;
    
}

.insta_contents-link a{
    text-decoration: none;
    display:flex;
    font-size:1.8rem;
    justify-content: center;
    align-items: center;
background:#3b308c;
border:1px solid #3b308c;
border-radius:50px;
padding:1rem 2rem 1rem 4rem;

color:#fff;

margin-left:auto;
margin-right:auto;
text-align: center;

-webkit-transition: all .3s;
    -moz-transition: all .3s;
    transition: all .3s;

    position:relative;

}

.insta_contents-link a:before{
    
font-size:1.5rem;
    position:absolute;
    content:"▶︎";
    left:12px;
}



.insta_contents-link a:hover{
    background:#fff;
    color:#3b308c;
    border:1px solid #3b308c;
    }


.insta_img{
    margin-bottom:1rem;
width:100%;
max-width:800px;
}


.insta_think_logo{
    width:100%;
    margin-bottom:4rem;
    text-align:center;
}

.insta_think_logo img{
    width:100%;
    max-width:350px;
}


.policy-wrap section{
    margin-bottom:10rem;
}




.insta-intro-line {
    position: relative;
    border-bottom: 1.5px solid #aaa;
    background: #fff;
    color: #aaa;
    
    padding-bottom:4rem;
}


    /* 下三角 */ 
    .insta-intro-line:before{
        content: "";
        position: absolute;
        bottom: -18px;
        
        left: calc(50% - 6px);
        margin-left: 0px;
        border: 10px solid transparent;
        border-top: 10px solid #fff;
        z-index: 2;
    }
    .insta-intro-line:after {
        position: absolute;
        border: 8px solid transparent;
        border-top-color: #aaa;
        border-bottom-width: 0;
        bottom: -8px;
        
        content: "";
        left: calc(50% - 6px);
        z-index: 1;
    }







/*
top page section03
*/

.fukidashi-01-06 {
    position: relative;
    width: fit-content;
    padding: 8px 8px;
    border: 2px dotted #333333;
    background-color: #ffffff;
    border-radius: 4px;
    width:100%;
    max-width: 500px;
    margin-left:auto;
    margin-right:auto;
  }
  .fukidashi-01-06::before {
    content: "";
    position: absolute;
    bottom: -5px;
    left: 50%;
    width: 15px;
    height: 15px;
    box-sizing: border-box;
    background-color: #ffffff; /* 背景色と同じ色を指定 */
    rotate: 135deg;
    translate: -50%;
  }
  .fukidashi-01-06::after {
    content: "";
    position: absolute;
    bottom: -8px;
    left: 50%;
    width: 15px;
    height: 15px;
    box-sizing: border-box;
    border: 2px dotted;
    border-color: #333333 #333333 transparent transparent;
    rotate: 135deg;
    translate: -50%;
  }


  .fukidashi-01-06 p{
    margin:0;
    padding:0;
  }

  .fukidashi-01-06 span {
    color: #e4007f;
  }




.ichiran_head{
    
    border-radius: 20px 20px 0 0;
}


.plan_subject{
    border: 3px solid #f9edea;
    -webkit-transition: .5s;
    -moz-transition: .5s;
    transition: .5s;
}

.plan_line {
    display:flex;
    align-items: center;
    justify-content: center;
    background:#ffffff;
    padding:1rem 1rem 1rem 1rem;
    text-align: center;
    width:100%;

}



.plan_test{
    -webkit-transition: .5s;
    -moz-transition: .5s;
    transition: .5s;
    border:3px solid #f9edea;
    border-radius:24px 24px 0 0;
    will-change:transform;
    isolation: isolate;
}

.plan_test:hover{
    border:3px solid #f39800;
    border-radius:24px 24px 0 0;
}

.plan_test .point_dot{
    color: #f39800;
}



.plan_start {
    -webkit-transition: .2s;
    -moz-transition: .2s;
    transition: .2s;
    border:3px solid #f9edea;
    border-radius:24px 24px 0 0;
    will-change:transform;
    isolation: isolate;
}

.plan_start:hover{
    border:3px solid #e95504;
    border-radius:24px 24px 0 0;
}

.plan_start .point_dot{
    color: #e95504;
}



.plan_basic{
    -webkit-transition: .5s;
    -moz-transition: .5s;
    transition: .5s;
    border:3px solid #f9edea;
    border-radius:24px 24px 0 0;
    will-change:transform;
    isolation: isolate;
    
}

.plan_basic:hover{
    border:3px solid #e4007f;
    border-radius:24px 24px 0 0;
}

.plan_basic .point_dot{
    color: #e4007f;
}


.test_head{
    background:#f39800;
    
    border-radius:20px 20px 0 0;
}

.start_head{
    background:#e95504;
    
    border-radius:20px 20px 0 0;
}

.basic_head{
    background:#e4007f;
    
    border-radius:20px 20px 0 0;
}

.continue_head{
    background:#009e40;
    
    border-radius:20px 20px 0 0;
}




.test_head img, .start_head img, .basic_head img, .continue_head img {
    
    
}

.test_text img, .start_text img, .basic_text img, .continue_text img {
    
    max-height:50px;
}



.test_price img, .start_price img, .basic_price img, .continue_price img {  
    max-height:46px;
}



.plan_ichiran_text img {
    max-height:95px;
}

.clousel_text img {
    max-height: 50px;
}

.price_text img{  
    max-height:46px;
}

.other_text{  
    max-height:46px;
    height:46px;
}
.other_text img{  
    max-height:46px;
}

.caution-wrap{
    display:flex;
    justify-content: space-between;
    align-items: center;
    flex-wrap: wrap;
    margin-top:16px;
    margin-bottom:63px;
}

.ps-txt{
    border:1px solid #231815;
    display:inline-block;
    padding:4px 14px;
    border-radius: 1.6rem;
    
}
.caution-txt {
    font-size: 1.3rem;
    text-align: right;
}

.shooting-wrap{
    display:flex;
    justify-content: space-between;
    flex-wrap: wrap;
    background:#fff;
    margin-bottom:12px;
    border-radius:8px 8px 0 0;
    align-items: center;

    border: 3px solid #f9edea;
    -webkit-transition: .4s;
    -moz-transition: .4s;
    transition: .4s;
    will-change: transform;
    isolation: isolate;

}


.shooting-wrap:hover{
    border:3px solid #0dac67;
    border-radius:12px 12px 0 0;
}



.shooting-intro{
    display:flex;
    justify-content: center;
    align-items: center;
    flex-direction: column;
    width:35%;
}

.option-title{
    background:#0dac67;
    color:#fff;
    width:100%;
    text-align: center;
    padding:17px 8px;
    border-radius:8px 0 0 0;
}

.option-title h3{
    font-size:2.4rem;
    font-weight:700;
}

.option-text{
    font-size:1.4rem;
}


.option-desc{
    padding:3rem 2.5rem;
}


.shooting-select{
    display:flex;
    justify-content:space-around;
    
    width:65%;
    gap:4.5rem;
    padding:0 3rem;
}

.shooting-block{
    display:flex;
    justify-content: center;
    align-items: center;
    flex-direction: column;
}

.shoot-box{
    display:flex;
    justify-content: center;
    align-items: center;
    flex-direction: column;
}

.shoot-br{
    display:none;
}

.shoot-name{
    border:1px solid #231815;
    display:inline-block;
    padding:3px 14px;
    border-radius: 1.6rem;
    font-size:1.4rem;
    margin-bottom:1.6rem;
}

.shoot-proviso {
    font-size:1.3rem;
    padding-top:1.5rem;
    border-top:1px solid #040000;
    margin-top:1rem;
    width:100%;
}


.shooting-block .shoot-proviso{
    flex-grow: 1;
}


.slider-cell {
    width: 90%;
    height: 200px;
    background: #8C8;
    margin: 0 5px;
  }
  


  

/*
top page section04
*/
  
.ct-intro{
    margin-top:50px;
    margin-bottom:20px;
}

.ct-intro.with_subtitle{
    margin-top:0px;
}




.policy-wrap{
    background:#fff;
    border-radius:20px;

    width:100%;
    padding:100px 30px;
    
  }


  .policy-txt{
    width:100%;
    max-width:800px;
    margin:0 auto;
    
  }

  .policy-txt p{
   margin-bottom:40px;
  }



  .policy-title {
    font-size:2.3rem;
    margin-bottom:50px;

}

.policy-txt li {
    font-size:1.6rem;
    margin-bottom:20px;

}

.mail-coation{
    width:100%;
    max-width:600px;
    margin:0 auto;
    margin-top:4rem;
    border:1px solid #ccc;
    padding:2rem 2rem 1rem 2rem;
    border-radius:1rem;
}
.mail-coation h3{
    margin-bottom:2rem;
    font-size:16px;
    border-bottom:1px solid #cc0000;
    padding-bottom:1rem;
}
.mail-coation p{
    font-size:14px;
}
.mail-coation span{
    color:#cc0000;
    padding:0 1rem;
}








.insta-wrap{
    background:#fff;
    border-radius:20px;

    width:100%;
    padding:100px 0px;
    
  }


  .insta-txt{
    width:100%;
    max-width:800px;
    margin:0 auto;
    
  }

  .insta-txt h3 {
    font-size:2.3rem;
    margin-bottom:3rem;
  }

  .insta-txt p{
   margin-bottom:40px;
  }



  .insta-title {
    font-size:2.3rem;
    margin-bottom:50px;

}

.insta-txt li {
    font-size:1.6rem;
    margin-bottom:20px;

}


.insta_content-title{
    font-size:2.8rem;
    font-weight:600;
    color:#3b308c;
    margin-bottom:3rem;
    border-bottom:1px solid #3b308c;
}

.insta-txt section{
    margin-bottom:10rem;
}


.insta-table{
    margin-bottom:5rem;
}


.insta-table table{
    border:1px solid #333;
    width:100%;
}




.insta-table th{
    border:1px solid #111;
    background:#c9c3f8;
    text-align:center;
    padding:1rem 1rem;
}

.insta-table td{
    border:1px solid #333;
    padding:1rem 1rem;
    text-align:center;
}












/* ===================================================================
 * # forms
 *
 * ------------------------------------------------------------------- */

 .form-area {
    width: 100%;
    max-width: 1200px;
    padding: 2rem 5rem 2rem 5rem;
    background: #fff;
    margin: -2rem auto 0 auto;
}



form#mailformpro {
    width: 100%;
    max-width: 800px;
    overflow: hidden;


}



fieldset {
    border: none;
}

input[type="email"],
input[type="number"],
input[type="search"],
input[type="text"],
input[type="tel"],
input[type="url"],
input[type="password"],
textarea,
select {

    height: 6.8rem;
    padding: 1.8rem 1.5rem 1.5rem;
    border: 0;
    outline: none;
    color: #000000;
    font-family: "Gothic A1", sans-serif;
    font-size: 1.6rem;
    line-height: 3.2rem;
    max-width: 100%;
    background: #fff;
    border-bottom: 1px solid #d3d3d3;
    -webkit-transition: all .3s ease-in-out;
    transition: all .3s ease-in-out;
}

.ss-custom-select {
    position: relative;
    padding: 0;
}

.ss-custom-select select {
    -webkit-appearance: none;
    -moz-appearance: none;
    appearance: none;
    text-indent: 0.01px;
    text-overflow: '';
    margin: 0;
    line-height: 3rem;
    vertical-align: middle;
}

.ss-custom-select select option {
    padding-left: 2rem;
    padding-right: 2rem;
}

.ss-custom-select select::-ms-expand {
    display: none;
}

.ss-custom-select::after {
    border-bottom: 2px solid #000000;
    border-right: 2px solid #000000;
    content: '';
    display: block;
    height: 8px;
    width: 8px;
    margin-top: -7px;
    pointer-events: none;
    position: absolute;
    right: 2.4rem;
    top: 50%;
    -webkit-transition: all 0.15s ease-in-out;
    transition: all 0.15s ease-in-out;
    -webkit-transform-origin: 66% 66%;
    transform-origin: 66% 66%;
    -webkit-transform: rotate(45deg);
    transform: rotate(45deg);
}

textarea {
    min-height: 25.6rem;
}

input[type="email"]:focus,
input[type="number"]:focus,
input[type="search"]:focus,
input[type="text"]:focus,
input[type="tel"]:focus,
input[type="url"]:focus,
input[type="password"]:focus,
textarea:focus,
select:focus {
    color: #000000;
    border-bottom: 1px solid #000000;
}

label,
legend {
    font-family: "Gothic A1", sans-serif;

    font-size: 1.6rem;
    margin-bottom: .8rem;
    line-height: 1.714;
    color: #000000;
    display: block;
}

input[type="checkbox"],
input[type="radio"] {
    display: inline;
}

label>.label-text {
    display: inline-block;
    margin-left: 1rem;
    font-family: "Gothic A1", sans-serif;
    line-height: inherit;
}

label>input[type="checkbox"],
label>input[type="radio"] {
    margin: 0;
    position: relative;
    top: .2rem;

}


.kakunin-check {}



.kakunin-check .mfp_err {

    bottom: .5em !important;
}


.modal-header {
    position: relative;
}

.modal-header .close {
    position: absolute;
    right: 0;
    top: -4rem;
}

.mailform dt{
    font-weight:500;
}

/* ------------------------------------------------------------------- 
 * ## Style Placeholder Text
 * ------------------------------------------------------------------- */
::-webkit-input-placeholder {

    /* WebKit, Blink, Edge */
    color: #8c8c8c;
}

:-ms-input-placeholder {

    /* Internet Explorer 10-11 */
    color: #8c8c8c;
}

::-ms-input-placeholder {

    /* Microsoft Edge */
    color: #8c8c8c;
}

::placeholder {

    /* Most modern browsers support this now. */
    color: #8c8c8c;
}

.placeholder {
    color: #8c8c8c !important;
}

/* ------------------------------------------------------------------- 
 * ## Change Autocomplete styles in Chrome
 * ------------------------------------------------------------------- */
input:-webkit-autofill,
input:-webkit-autofill:hover,
input:-webkit-autofill:focus input:-webkit-autofill,
textarea:-webkit-autofill,
textarea:-webkit-autofill:hover textarea:-webkit-autofill:focus,
select:-webkit-autofill,
select:-webkit-autofill:hover,
select:-webkit-autofill:focus {
    -webkit-text-fill-color: #111;
    -webkit-transition: background-color 5000s ease-in-out 0s;
    transition: background-color 5000s ease-in-out 0s;
}



/* ===================================================================
 * # buttons
 *
 * ------------------------------------------------------------------- */
.btn,
button,
input[type="submit"],
input[type="reset"],
input[type="button"] {
    display: inline-block;
    font-family: "Work Sans", sans-serif;
    font-weight: 600;
    font-size: 1.6rem;
    text-transform: uppercase;
    letter-spacing: .6rem;
    height: 6rem;
    line-height: 5.6rem;
    padding: 0 3.2rem;
    margin: 0 .4rem 1.6rem 0;
    color: #000000;
    text-decoration: none;
    text-align: center;
    white-space: nowrap;
    cursor: pointer;
    -webkit-transition: all .3s;
    transition: all .3s;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
    background-color: #d3d3d3;
    border: 0.2rem solid #d3d3d3;
}

.btn:hover,
button:hover,
input[type="submit"]:hover,
input[type="reset"]:hover,
input[type="button"]:hover,
.btn:focus,
button:focus,
input[type="submit"]:focus,
input[type="reset"]:focus,
input[type="button"]:focus {
    background-color: #000000;
    border-color: #000000;
    color: #ffffff;
    outline: 0;
}

/* button primary
 * ------------------------------------------------- */
.btn.btn--primary,
button.btn--primary,
input[type="submit"].btn--primary,
input[type="reset"].btn--primary,
input[type="button"].btn--primary {
    background: #f9861a;
    border-color: #f9861a;
    color: #ffffff;
}

.btn.btn--primary:hover,
button.btn--primary:hover,
input[type="submit"].btn--primary:hover,
input[type="reset"].btn--primary:hover,
input[type="button"].btn--primary:hover,
.btn.btn--primary:focus,
button.btn--primary:focus,
input[type="submit"].btn--primary:focus,
input[type="reset"].btn--primary:focus,
input[type="button"].btn--primary:focus {
    background: #fff;
    border-color: #000000;
    color: #000;
}

/* button modifiers
 * ------------------------------------------------- */
.btn.h-full-width,
button.h-full-width {
    width: 100%;
    margin-right: 0;
}

.btn--small,
button.btn--small {
    height: 5.6rem !important;
    line-height: 5.2rem !important;
}

.btn--medium,
button.btn--medium {
    height: 6.4rem !important;
    line-height: 6rem !important;
}

.btn--large,
button.btn--large {
    height: 6.8rem !important;
    line-height: 6.4rem !important;
}

.btn--stroke,
button.btn--stroke {
    background: transparent !important;
    border: 0.2rem solid #000000;
    color: #000000;
}

.btn--stroke:hover,
button.btn--stroke:hover {
    background: #000000 !important;
    border: 0.2rem solid #000000;
    color: #ffffff;
}

.btn--pill,
button.btn--pill {
    padding-left: 3.2rem !important;
    padding-right: 3.2rem !important;
    border-radius: 1000px !important;
}

button::-moz-focus-inner,
input::-moz-focus-inner {
    border: 0;
    padding: 0;
}

div.mfp_buttons button.submit {
    margin: 0 2rem;
}




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

    .brpc {
        display: none;
    }


    form#mailformpro dl dt {
        width: 100%;
        text-align: left;
    }


    form#mailformpro dl dd {
        margin: 0px;
        padding: 10px 5px 10px 0px;
        font-size: 1.6rem;
        line-height: 1.5em;
        text-align: left;
    }

}


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

div.mfp_buttons button.submit {
    margin: 15px 10px;
    width: 50%;
}

div.mfp_buttons button.submit.reset {
    margin: 15px 10px;
    width: 32%;
}



div.mfp_buttons button.submit {
    padding: 0px 10px;
}

button{
    height:5rem;
}



.form-area {
    padding: 0rem 0rem 0rem 0rem;
}

}






/*
footer
*/
.footer-bg{
    background:#00a75b;
}


.footer-wrap{
    display:flex;
    justify-content:center;
    align-items: center;
    width:1060px;
    margin:0 auto;
    flex-wrap: wrap;
    gap:20px;
    padding:65px 30px 65px 30px;
    
}



.copywright-wrap{
    display:flex;
    justify-content:space-between;
    align-items: flex-end;
    width:1060px;
    margin:0 auto;
    flex-wrap: wrap;
    gap:20px;
    padding:0px 30px 0px 30px;
}





.footer_logo{
    width:100%;
    max-width: 140px;
}




.foot-intro-line {
    position: relative;
    border-bottom: 1.5px solid #e1007f;
    background: #fff;
    color: #e1007f;
    text-align: right;
    font-size: 20px;
    padding-bottom:18px;
}


    /* 下三角 */ 
    .foot-intro-line:before{
        content: "";
        position: absolute;
        bottom: -18px;
        
        left: calc(50% - 6px);
        margin-left: 0px;
        border: 10px solid transparent;
        border-top: 10px solid #fff;
        z-index: 2;
    }
    .foot-intro-line:after {
        position: absolute;
        border: 8px solid transparent;
        border-top-color: #e1007f;
        border-bottom-width: 0;
        bottom: -8px;
        
        content: "";
        left: calc(50% - 6px);
        z-index: 1;
    }




    


.contact_intro {
    font-size:1.8rem;
    margin-bottom:20px;
}


.contact_intro span {
    color:#fff;
}

.foot_contact_btn {
display:flex;
justify-content: center;
}


.foot_contact_btn a {
    
    text-decoration: none;
    color: #111;
    padding: 1.4rem 2.8rem;
    transition: all .3s;
    font-weight: 700;
    font-size: 1.6rem;
    color:#00a75b;
    background: #fff;
    border:1px solid #fff;
    border-radius: 5rem;
    text-align: center;
    -webkit-transition: .5s;
    -moz-transition: .5s;
    transition: .5s;

display:inline-flex;
justify-content: center;
align-items: center;
gap:8px;
}


.foot_contact_btn a:hover {
    background-color: #00a75b;
    border:1px solid #fff;
    color: #fff;
}

.button {
    position: relative;
    width: 19px;
    height: 13px;
}

.icon {
    position: absolute;
    inset: 0;
    object-fit: contain;
    transition: opacity 0.5s;
}

.icon--pink {
    opacity: 0;
}

.foot_contact_btn a:hover .icon--pink {
    opacity: 1;
}



.arrow-right {
    display: inline-block;
    vertical-align: middle;
    color: #3b308c;
    line-height: 1;
    width: 1rem;
    height: 1rem;
    border: 1.5px solid currentColor;
    border-left: 0;
    border-bottom: 0;
    box-sizing: border-box;
    transform: translateX(-25%) rotate(45deg);
    margin-right:8px;
  }

.copywright{
    background: #fff;
    font-size:1.2rem;
    padding:12px 0;
    text-align: center;
}





/* ------------------------------------------------------------------- 
 * ## go top
 * ------------------------------------------------------------------- */
 .ss-go-top {
    z-index: 100;
    opacity: 0;
    visibility: hidden;
    -webkit-transform: translate3d(0, 200%, 0);
    transform: translate3d(0, 200%, 0);
    -webkit-transition: all 0.5s cubic-bezier(0.215, 0.61, 0.355, 1);
    transition: all 0.5s cubic-bezier(0.215, 0.61, 0.355, 1);
    position: fixed;
    bottom: 8.4rem;
    right: 8rem;
}

.ss-go-top a {
    text-decoration: none;
    border: 0 none;
    display: block;
    height: 6.4rem;
    width: 6.4rem;
    border-radius: 50%;
    background-color: #888888;
    -webkit-transition: all .3s;
    transition: all .3s;
    position: relative;
}

.ss-go-top a:hover,
.ss-go-top a:focus {
    background-color: #f9861a;
}

.ss-go-top svg {
    height: 1.2rem;
    width: 1.2rem;
    position: absolute;
    -webkit-transform: translate3d(-50%, -50%, 0);
    transform: translate3d(-50%, -50%, 0);
    left: 50%;
    top: 50%;
}

.ss-go-top svg path {
    fill: #ffffff;
}

.ss-go-top.link-is-visible {
    opacity: 1;
    visibility: visible;
    -webkit-transform: translate3d(0, 0, 0);
    transform: translate3d(0, 0, 0);
}


