@charset "UTF-8";
/* CSS Document */
*, *:before, *:after{margin:0;padding:0;border: 0;vertical-align:baseline;
-webkit-box-sizing: border-box;
-moz-box-sizing: border-box;
-o-box-sizing: border-box;
-ms-box-sizing: border-box;
box-sizing: border-box;
}
body {
font-family: "Zen Maru Gothic", sans-serif;
font-weight: 500;
font-style: normal;
font-size:15px;
line-height:1.8;
color:#4d4d4d;
letter-spacing:0.08em;
width:100%;
max-width: 1920px;
margin: 0 auto;
overflow-wrap: anywhere;
word-break: normal;
line-break: strict;
background: #f8f3ea;
}
body.search {
background: #fff;
}
.loading {width: 100vw;height: 100vh;transition: all .9s;background-color: #FFF;position: fixed;top: 0;left: 0;z-index: 9999;opacity: 1;visibility: visible;}
.loading.is-active {opacity: 0;visibility: hidden;}
.loading-animation {width: 100vw;height: 100vh;transition: all .2s;background-color: #fff;z-index: 9999;display: flex;align-items: center;justify-content: center;opacity: 0;visibility: hidden;padding: 0 0 60px;}
.loading-animation img {width: 100px;margin: 0 0 30px;}
.loading-animation.is-active {opacity: 1;visibility: visible;}


.loader {
width: 30px;
height: 30px;
--c:no-repeat linear-gradient(#005bac 0 0);
background: var(--c),var(--c),var(--c),var(--c);
background-size: 15px 15px;
animation: l5 1.5s infinite cubic-bezier(0.3,1,0,1);
}
@keyframes l5 {
0%   {background-position: 0    0,100% 0   ,100% 100%,0 100%}
33%  {background-position: 0    0,100% 0   ,100% 100%,0 100%;width:40px;height: 40px}
66%  {background-position: 100% 0,100% 100%,0    100%,0 0   ;width:40px;height: 40px}
100% {background-position: 100% 0,100% 100%,0    100%,0 0   }
}


html {
scroll-behavior: smooth;
scroll-padding-top: 50px;
}
.pc{}
.sp{display: none;}
ol, ul {
list-style: none;
list-style-type: none;
}
a:focus, *:focus { outline:none; }
a{
text-decoration: none;
color:#333;
}
a.link-ul{
text-decoration: underline;
color: #0000ff;
}
a.op07:hover{
opacity:0.7;
 transition: .4s opacity;
}
a:hover{
opacity:0.7;
transition: .4s opacity;
}
a.link-text{
text-decoration:underline;
}
img{
vertical-align:bottom;
}
img.w100{
width: 100%;
}
.sp-only{
display: none;
}
.menu-btn,
.menu-btn.active{
display: none;
}
.open{
overflow-y: hidden;
}
.add-entry{
display: none;
}
header{
position: fixed;
width: 100%;
top: 0;
left: 0;
z-index: 100;
}
header .inner{
width: 96%;
max-width: 1300px;
background: #fff;
margin: 0 auto;
position: relative;
border-radius: 0 0 16px 16px;
}
header .head-logo{
width: 220px;
height: 72px;
padding: 12px 0 0;
vertical-align: middle;
}
header .logo{
width: 220px;
vertical-align: middle;
padding: 0 0 0 20px;
position: relative;
top: -1px;
}
.head-site-info{
position: absolute;
top: 4px;
left: 230px;
font-family: "Poppins", sans-serif;
font-weight: 500;
line-height: 68px;
}
.nemu-wrap{
position: absolute;
top: 0;
right: 0;
padding: 0 20px 0 0;
}
.head-link-box{
position: relative;
letter-spacing: 0;
}
.head-link-box li{
display: inline-block;
position: relative;
letter-spacing: 0;
margin: 0 0 0 4px;
}
.head-link-box li ul{
position: absolute;
width: 0;
height: 0;
left: 50%;
margin-left: -200px;
padding:  10px 0 0;
opacity: 0;
transition:opacity 0.5s,height 0.5s ;
overflow: hidden;
border-radius: 0 0 20px 20px;
}
.head-link-box li:hover ul{
width: 400px;
height: auto;
opacity:1;
transition:opacity 0.5s ;
}
.head-link-box li ul li{
display: block;
}
.head-link-box li ul li:first-of-type{
border-radius: 14px 14px 0 0;
overflow: hidden;
}
.head-link-box li ul li:last-of-type{
border-radius: 0 0 14px 14px;
overflow: hidden;
}
.head-link-box li:nth-child(4) ul li:last-of-type{
border-radius: 14px;
}

.head-link-box li ul li a{
text-align: center;
display: block;
line-height: 68px;
color: #fff;
background: #4ebedf;
}
.head-link-box li ul li a:hover{
opacity: 1;
background: #31aed3;

}
.head-link-box li.for-entry {
line-height: 72px;
}
.head-link-box a{
font-size: 15px;
font-weight: 700;
line-height: 72px;
display: block;
padding: 0 12px;
}
.head-link-box a span{
font-weight: 500;
font-size: 12px;
}
.head-link-box a.to-rec-site{
line-height: 38px;
font-size: 15px;
font-weight: 700;
color: #fff;
background: #3dc588;
margin: 0 0 0 8px;
padding: 0 14px;
border-radius: 100px;
display: inline-block;
}
.head-link-box a.to-rec-site2{
line-height: 38px;
font-size: 15px;
font-weight: 700;
color: #fff;
background: #fbac0b;
margin: 0 0 0;
padding: 0 14px;
border-radius: 100px;
display: inline-block;
}
main{
max-width: 1300px;
margin: 0 auto;
overflow: hidden;
padding: 0 0 180px;
}
main.search-wrap{
max-width: 1400px;
margin: 110px auto 0;
overflow: visible;
padding: 0 0 80px;
}
main.person-contents{
max-width: 100%;
margin: 0 auto;
overflow: hidden;
padding: 0 0 150px;
}


section{
width: 100%;
margin: 0 auto;
}


.inner{
max-width: 1200px;
margin: 0 auto;
}



.page-main-about,
.page-main-support{
width: 100%;
max-width: 1400px;
margin: 0 auto;
position: relative;
}
.page-main-support{
width: 100%;
max-width: 1400px;
margin: 0 auto;
position: relative;
}
.page-main-about img{
border-radius: 0 0 30px 30px;
}
.page-main-about .ttl-box{
position: absolute;
width: 92%;
max-width: 1200px;
top: 30%;
left: 0;
right: 0;
margin: auto;
}
.page-main-message{
width: 92%;
max-width: 1400px;
margin: 0 auto;
position: relative;
}
.page-main-message .ttl-box{
width: 100%;
max-width: 1200px;
margin: 10% auto 0;
}
.page-main-support .ttl-box{
position: absolute;
width: 92%;
max-width: 1200px;
top: 40%;
left: 0;
right: 0;
margin: auto;
padding: 0;
}
.page-main-message .page-main-inner {
margin: 0 0 4%;
}
.page-main-inner{
margin: 0 0 7%;
}
.for-cat-support{
width: 50%;
position: relative;
left: 50%;
border-radius: 0 0 0 24px;
}

h1{
font-size: 25px;
font-weight: 700;
}
.page-cat-name{
font-family: "Montserrat", sans-serif;
font-weight: 400;
font-size: 94px;
line-height: 1.2;
}
.change-color-w h1,
.change-color-w .page-cat-name{
color: #fff;
}
.change-color-b h1,
.change-color-b .page-cat-name{
color: #333;
}
.page-main-business h1,
.page-main-business .page-cat-name{
color: #4ebedf;
}







.pege-block-ttl,
.support-block-ttl{
font-size: 17px;
font-weight: 700;
color: #fff;
background: #4ebedf;
margin: 0 0 4%;
padding: 4px 20px;
}



.page-top{
position: fixed;
width: 52px;
height: 52px;
bottom: 64px;
right: 2%;
cursor: pointer;
display: none;
z-index: 1000;
}




footer{

}
.foot-links{
background: #fff;
}
.foot-links .inner{
width: 92%;
max-width: 1300px;
margin: 0 auto;
}
.foot-links .cont-wrap{
padding: 5% 0 6%;
}
.foot-links-box{
max-width: 1100px;
margin: 0 auto;
display: flex;
justify-content: space-between;
}
.foot-links-1st{
}
.foot-links-2nd{
}
.foot-links-3rd{
}
.foot-links-4th{
position: relative;
}
.foot-links-box p{
font-size: 18px;
font-weight: 700;
color: #4ebedf;
margin: 0 0 12px;
}
.foot-links-box li a{
line-height: 2.1;
}
.foot-links-box li a span{
display: inline-block;
width: 44px;
}
.foot-links-box ul.with-mgb{
margin: 0 0 38px;
}
.foot-entry-links{
position: absolute;
width: 100%;
bottom: 0;
left: 0;
}
.foot-entry-links img{
width: 100%;
margin: 0 0 18px;
}
.foot-entry-links a.entry01 {
display: block;
line-height: 34px;
font-size: 16px;
font-weight: 700;
color: #fff;
background: #3dc588;
padding: 0 34px;
border-radius: 100px;
text-align: center;
margin: 0 0 6px;
}
.foot-entry-links a.entry02 {
display: block;
line-height: 34px;
font-size: 16px;
font-weight: 700;
color: #fff;
background: #fbac0b;
padding: 0 34px;
border-radius: 100px;
text-align: center;
}




.foot-under{
position: relative;
background: #f8f3ea;
}
.foot-under .inner{
width: 92%;
max-width: 1300px;
margin: 0 auto;
padding: 30px 0;
position: relative;
}
.foot-under-links a{
font-family: "Noto Sans JP", sans-serif;
font-size: 13px;
font-weight: 500;
}
.foot-under p{
position: absolute;
right: 0;
top: 30px;
font-family: "Noto Sans JP", sans-serif;
font-size: 12px;
font-weight: 500;
}


@media (max-width: 1200px) {
.nemu-wrap {
position: fixed;
width: 100%;
height: 100%;
left: -100%;
top: 0;
background: #4ebedf;
z-index: -1;
opacity: 1;
padding: 74px 0 0;
transition:left .6s;
}
.open .nemu-wrap {
visibility: visible;
opacity: 1;
transition:opacity .6s,left .6s;
left: 0;
}
.head-link-box li.for-entry{
display: none;
}


@keyframes fade-out {
  0% {
visibility: visible;
opacity: 1;
  }

  50% {
visibility: visible;
opacity: 0.5;
  }

  100% {
visibility: hidden;
opacity: 0;
  }
}



.head-link-box li.menu-for-entry{
display: none;
}
.head-link-box {
width: 100%;
text-align: left;
height: auto;
max-height: 100%;
overflow-y: scroll;
display: flex;
justify-content: space-between;
flex-wrap: wrap;
margin: 0 auto;
padding: 3% 9% 80px;
}
.head-link-box li {
width: 46%;
display: block;
position: relative;
line-height: 44px;
margin: 0 0 2%;
}
.head-link-box a {
font-size: 16px;
line-height: 54px;
padding: 0 ;
}
.head-link-box li ul {
position: relative;
width: auto;
height: auto;
left: 0;
margin-left: 0;
padding: 6px 0 0;
opacity: 1;
border-radius: 0;
border-top:1px dotted #fff;
}
.head-link-box li ul li a {
line-height: 1.6;
color: #fff;
text-align: left;
padding: 6px 0;
}
.head-link-box li ul li {
width: 100%;
display: block;
margin: 0;
}
.head-link-box li ul li a:hover {
background: #4ebedf;
}
.menu-btn,
.menu-btn.active{
display: block;
position: absolute;
top: 0;
z-index: 5000;
width: 72px;
height: 72px;
}
.menu-btn{
right: 0;
}
.menu-btn.active .close-overlay-menu-wrap {
display: block;
position: absolute;
top: 0;
right: 0;
width: 100%;
height: 100%;
z-index: 5001;
}
@media (hover: hover) {
.menu-btn.active .close-overlay-menu-wrap:hover {
cursor: pointer;
}
}
.menu-btn a{
position: relative;
display:block;
width:100%;
height:100%;
}
.menu-btn span{
display: inline-block;
transition: all .4s;
position: absolute;
left: 25%;
height: 1px;
background: #000;
width: 50%;
}
.menu-btn span:nth-of-type(1) {top:24px;}
.menu-btn span:nth-of-type(2) {top:36px;}
.menu-btn span:nth-of-type(3) {top:48px;}
.menu-btn.active span:nth-of-type(1) {
top: 28px;
left: 25%;
transform: translateY(10px) rotate(-45deg);
width: 50%;
}
.menu-btn.active span:nth-of-type(2) {
opacity: 0;
}
.menu-btn.active span:nth-of-type(3){
top: 48px;
left: 25%;
transform: translateY(-10px) rotate(45deg);
width: 50%;
}

}


@media (max-width: 1000px) {
body {
font-size:14px;
letter-spacing:0.08em;
line-height: 1.6;
}
.main-ill-pc {
width: 38%;
right: -5%;
bottom: 15%;
}
.page-main-about img {
position: relative;
width: 130%;
left: -15%;
border-radius: 0 0 30px 30px;
}
.page-main-about .page-main-inner {
margin: 0 0 7%;
border-radius: 0 0 30px 30px;
overflow: hidden;
}
.head-link-box {
padding: 3% 6% 80px;
}



}
@media (max-width: 767px) {
.pc{display: none;}
.sp{display: inline;}
main {
padding: 0 0 70px;
}
.menu-btn,
.menu-btn.active{
display: block;
position: absolute;
top: 4px;
right: 0;
z-index: 5000;
width: 64px;
height: 64px;
}
.menu-btn span:nth-of-type(1) {top:22px;}
.menu-btn span:nth-of-type(2) {top:32px;}
.menu-btn span:nth-of-type(3) {top:42px;}
.menu-btn.active span:nth-of-type(1) {
top: 26px;
left: 25%;
transform: translateY(6px) rotate(-45deg);
width: 50%;
}
.menu-btn.active span:nth-of-type(2) {
opacity: 0;
}
.menu-btn.active span:nth-of-type(3){
top: 38px;
left: 25%;
transform: translateY(-6px) rotate(45deg);
width: 50%;
}

.nemu-wrap {
padding: 72px 0 0;
}
.head-link-box li {
width: 100%;
line-height: 44px;
margin: 0 0 2%;
}
.head-link-box a {
font-size: 16px;
line-height: 44px;
}
.head-link-box li ul li a {
line-height: 1.5;
padding: 4px 0;
font-size: 14px;
}

header .inner {
width: 100%;
height: 72px;
background: #fff;
margin: 0 auto;
position: relative;
border-radius: 0 0 18px 18px;
}
header .head-logo {
width: 70%;
max-width: 190px;
padding: 10px 0 0;
}
header .logo {
width: 100%;
vertical-align: middle;
padding: 0 0 0 8px;
}
.head-site-info {
left: 196px;
font-size: min(3.4vw, 14px);
line-height: 58px;
}





.page-main-about, .page-main-support {
margin: 72px auto 0;
position: relative;
}


}









.fade-in{
opacity:0;
transition:opacity 1.2s;
}
.fade-in.scrolled,
.loaded .fade-in.ose{
opacity:1;
transition:opacity 1.2s;
}
.loaded .fade-in.ose{
transition:opacity 1s 0.8s;
}
.fade-in-late{
opacity:0;
transition:opacity 1s 1s;
}
.fade-in-late.scrolled,
.loaded .fade-in-late.ose{
opacity:1;
transition:opacity 1s 1s;
}
.loaded .fade-in-late.ose{
opacity:1;
transition:opacity 1s 1.2s;
}
.move-up{
opacity:0;
transform: translateY(40px);
transition:opacity 1s 0s,transform 1s 0s;
}
.move-up.scrolled,
.loaded .move-up.ose,
.move-up.is-active{
opacity:1;
transform: translateY(0);
transition:opacity 1s 0s,transform 1s 0s;
}
.loaded .move-up.ose{
transition:opacity 1s 0.4s,transform 1s 0.4s;
}
.move-up-late{
opacity:0;
transform: translateY(40px);
transition:opacity 1s 0.4s,transform 1s 0.4s;
}
.move-up-late.scrolled,
.loaded .move-up-late.ose,
.move-up-late.is-active{
opacity:1;
transform: translateY(0);
transition:opacity 1s 0.4s,transform 1s 0.4s;
}
.loaded .move-up-late.ose{
transition:opacity 1s 0.8s,transform 1s 0.8s;
}



.to-left{
opacity:0;
transform: translateX(60px);
transition:opacity 1s 0s,transform 1s 0s;
}
.to-left.scrolled,
.loaded .to-left.ose,
.to-left.is-active{
opacity:1;
transform: translateX(0);
transition:opacity 1s 0s,transform 1s 0s;
}
.loaded .to-left.ose{
transition:opacity 1s 0.5s,transform 1s 0.5s;
}


.to-right-late{
opacity:0;
transform: translateX(-60px);
transition:opacity 1s 0.4s,transform 1s 0.4s;
}
.to-right-late.scrolled,
.loaded .to-right-late.ose,
.to-right-late.is-active{
opacity:1;
transform: translateX(0);
transition:opacity 1s 0.4s,transform 1s 0.4s;
}
.loaded .to-right-late.ose{
transition:opacity 1.4s 0.6s,transform 1.4s 0.6s;
}


.to-right{
opacity:0;
transform: translateX(-60px);
transition:opacity 1s 0s,transform 1s 0s;
}
.to-right.scrolled,
.loaded .to-right.ose,
.to-right.is-active{
opacity:1;
transform: translateX(0);
transition:opacity 1s 0s,transform 1s 0s;
}
.loaded .to-right.ose{
transition:transform 1s 0.4s,opacity 1s 0.4s;
}




.to-big{
transform: scale(0.3);
opacity:0;
}
.to-big.scrolled,
.loaded .to-big.ose,
.to-big.is-active{
transform: scale(1);
opacity:1;
transition:transform 1s 0s,opacity 1s 0s;
}
.loaded .to-big.ose{
transition:transform 1s 0.4s,opacity 1s 0.4s;
}

.clip{
clip-path: inset(0 100% 0 0);
transition:clip-path 1.4s 0s;
}
.clip.scrolled,
.loaded .clip.ose{
clip-path: inset(0);
transition:clip-path 2.6s 0.2s;
}
.loaded .clip.ose{
transition:clip-path 1.8s 1s;
}






/*===================================================================*/
@media only screen and (max-width : 1200px) {

.page-cat-name {
font-size: 84px;
line-height: 1.2;
}
h1 {
font-size: 22px;
}
.add-entry{
display: block;
position: absolute;
top: 0;
right: 72px;
width: 160px;
}
.add-entry a{
display: block;
line-height: 36px;
font-size: 15px;
font-weight: 700;
color: #fff;
background: #fbac0b;
text-align: center;
}
.add-entry a:nth-child(1){
background: #3dc588;
}


}

/*===================================================================*/
@media only screen and (max-width : 1000px) {
.page-main-about .ttl-box {
top: 40%;
left: 0;
right: 0;
margin: auto;
}
.page-cat-name {
font-size: 64px;
line-height: 1.2;
}
header .head-logo {
width: 190px;
height: 72px;
padding: 16px 0 0;
}
header .logo {
width: 190px;
padding: 0 0 0 20px;
position: relative;
top: -1px;
}
.head-site-info {
top: 4px;
left: 210px;
font-family: "Poppins", sans-serif;
font-weight: 500;
line-height: 68px;
font-size: 12px;
}


h1 {
font-size: 20px;
}
.foot-links-box {
flex-wrap: wrap;
}
.foot-links-1st{
width: 100%;
}
.foot-under-links{
text-align: center;
}
.foot-under p {
position: relative;
right: 0;
top: 0;
font-size: 12px;
text-align: center;
padding: 20px 0 0;
}
.for-cat-support {
width: 64%;
left: 36%;
border-radius: 0 0 0 24px;
}


}









@media only screen and (max-width : 767px) {
.add-entry{
right: 64px;
width: 120px;
display: flex;
}
.add-entry a{
width: 60px;
height: 72px;
line-height: 1.4;
font-size: 14px;
padding: 16px 0 0;
}
header .head-logo {
width: 160px;
height: 34px;
padding: 4px 0 0;
}
header .logo {
width: 160px;
height: 44px;
padding: 0 0 0 12px;
}
.head-site-info {
clear: both;
top: 46px;
left: 62px;
line-height: 16px;
font-size: 10px;
letter-spacing: 0;
float: left;
}

.page-main-about .ttl-box {
top: 30%;
left: 0;
right: 0;
margin: auto;
}
.page-cat-name {
font-size: 40px;
line-height: 1.2;
}

h1 {
font-size: 18px;
}
.page-main-message .ttl-box {
margin: 108px auto 6%;
}
.foot-links-1st,
.foot-links-2nd,
.foot-links-3rd,
.foot-links-4th{
width: 100%;
}
.foot-links-box ul {
margin: 0 0 30px!important;
}
.foot-links-box p {
font-size: 16px;
margin: 0 0 10px;
}
.foot-entry-links {
position: relative;
width: 60%;
max-width: 170px;
bottom: 0;
left: 0;
margin: 0 auto;
}
.foot-links .cont-wrap {
padding: 8% 0 10%;
}
.foot-entry-links a {
line-height: 44px;
font-size: 16px;
background: #fbac0b;
padding: 0 34px;
border-radius: 100px;
text-align: center;
}
.page-top {
width: 44px;
height: 44px;
bottom: 100px;
right: 2%;
}
.inner {
width: 88%;
}
.for-cat-support {
width: 68%;
left: 32%;
border-radius: 0 0 0 3.4vw;
}
.page-main-support .ttl-box {
top: 30%;
padding: 0 0 0;
}
.pege-block-ttl, .support-block-ttl {
font-size: 16px;
margin: 0 0 7%;
padding: 4px 10px;
}
.foot-links .inner {
width: 88%;
max-width: 1300px;
margin: 0 auto;
}
.foot-under-links a {
font-size: 12px;
}
.foot-under p {
font-size: 10px;
}

}



@media only screen and (max-width : 350px) {
    .add-entry {
        right: 56px;
        width: 100px;
        display: flex;
    }
    .add-entry a {
        width: 50px;
        height: 72px;
        line-height: 1.4;
        font-size: 12px;
        padding: 18px 0 0;
    }
        .menu-btn, .menu-btn.active {
        top: 4px;
        right: -4px;
        width: 64px;
        height: 64px;
    }

}






@media print {
body {width:1000px;}
}