@charset "UTF-8";
/*----------------------------------
Pages：functional
----------------------------------*/


/*  functionalここから  */

/* functional index */
.fcn-wrap{
  margin: 0 auto;
  padding: 0;
}
.fcn-wrap .picture{
  max-width: 100%;
  display: block;
}
.fcn-wrap .picture img {
  width: 100vw;
}

/*seckv*/
.fcn-wrap__seckv{
  margin: 0 auto;
  padding: 0;
}
/* @media only screen and (max-width: 768px) {
  .fcn-wrap__seckv{
    margin: 0 auto;
    padding: 20px 0 0 0;
  }
} */


.fcn-wrap__seckv-wrap{
  margin: 0 auto;
  padding: 0;
  text-align: center;
}

.fcn-wrap__sec-wrap{
  max-width: 1120px;
  margin: 0 auto;
  padding: 0;
}

/*sec01*/
.fcn-wrap__sec01{
  margin: 0 auto 0 auto;
  padding: 50px 0 100px 0;
}
@media only screen and (max-width: 768px) {
  .fcn-wrap__sec01{
    margin: 0 auto;
    padding: 20px 0 0 0;
  }
}

.fcn-wrap__sec01-tit{
  margin: 0 auto 30px auto;
  padding: 0;
  font-size: 3.6rem;
  font-weight: bold;
  line-height: 1.8;
  text-align: center;
}
.fcn-wrap__sec01-tit > .txtb{
  color: #000;
  /* border-bottom: 7px solid #FFF0C9; */
}
@media only screen and (max-width: 768px) {
  .fcn-wrap__sec01-tit{
    font-size: 2.4rem;
  }
}


.fcn-wrap__sec01-txt{
  margin: 0 auto 80px auto;
  padding: 0;
  font-size: 1.6rem;
  line-height: 1.8;
  text-align: center;
}
@media only screen and (max-width: 768px) {
  .fcn-wrap__sec01-txt{
    width: calc( 320 / 375 * 100% );
    margin: 0 auto 70px auto;
    font-size: 1.2rem;
  }
}

.fcn-wrap__sec01-webcm{
  margin: 50px auto 50px auto;
  padding: 0 24px 0 24px;
}
@media only screen and (max-width: 768px) {
  .fcn-wrap__sec01-webcm{
    margin: 50px auto 50px auto;
    padding: 0 14px 0 14px; 
  }
}

.fcn-wrap__sec01-txt{
  margin: -40px auto 40px auto;
  padding: 0;
  text-align: center;
}
@media only screen and (max-width: 768px) {
  .fcn-wrap__sec01-txt{
    margin: -24px auto 40px auto;
    padding: 0;
    text-align: center;
  }
}

.fcn-wrap__iframe{
  max-width: 560px;
  height: 315px;
  margin: 0 auto 0 auto;
  padding: 0;
  box-sizing: border-box;
}
@media only screen and (max-width: 768px) {
  .fcn-wrap__iframe{
    max-width: 750px;
    height: 210px;
    margin: 0 auto 0 auto;
    padding: 0;
    box-sizing: border-box;
  }
}
.fcn-wrap__iframe iframe{
  width: 100%;
  height: 100%;
}


.fcn-wrap__sec01-expand{
  margin: 0 auto;
  padding: 0;
  background: url(../img/top/img_sec02_03@2x.jpg) no-repeat center center / cover;
}
@media only screen and (max-width: 768px) {
  .fcn-wrap__sec01-expand{
    margin: 0 auto;
    padding: 0;
    background: url(../img/top/img_sec02_03_sp@2x.jpg) no-repeat center center / cover;
  }
}

.fcn-wrap__sec01-catch{
  margin: 0 auto;
  padding: 80px 0 80px 0;
  text-align: center;
  display: block;
}
@media only screen and (max-width: 768px) {
  .fcn-wrap__sec01-catch{
    width: calc( 320 / 375 * 100% );
    padding: 60px 10px 60px 10px;
  }
}

.fcn-wrap__sec01-utxt{
  margin: 30px auto 0 auto;
  padding: 0;
  text-align: center;
}
@media only screen and (max-width: 768px) {
  .fcn-wrap__sec01-utxt{
    width: calc( 320 / 375 * 100% );
    margin: 30px auto 60px auto;
    font-size: 1.2rem;
  }
}


/*sec02*/
.fcn-wrap__sec02{
  margin: 0 auto;
  padding: 0 0 130px 0; 
}
@media only screen and (max-width: 768px) {
  .fcn-wrap__sec02{
    padding: 0 0 75px 0;
  }
}

.fcn-wrap__sec02-undertxt{
  margin: 0 auto 40px auto;
  padding: 0;
  text-align: center;
}

.fcn-wrap__sec02-list{
  margin: 0 auto 80px auto;
  padding: 0;
  display: flex;
  justify-content: center;
  align-items: flex-start;
  flex-wrap: wrap;
}
@media only screen and (max-width: 768px) {
  .fcn-wrap__sec02-list{
    max-width: auto;
    width: calc( 316 / 375 * 100% );
    margin: 0 auto 0 auto;
    flex-direction: column;
  }
}


.fcn-wrap__sec02-li{
  /* width: calc( 100% / 3 ); */
  width: calc(50% - 20px);
  margin: 0;
  padding: 0 0 35px 0;
  padding-left: calc( 20 / 1120 * 100% );
  padding-right: calc( 20 / 1120 * 100% );
  box-sizing: border-box;
}
@media only screen and (max-width: 768px) {
  .fcn-wrap__sec02-li{
    width: calc( 100% / 1 );
    padding: 0 0 50px 0;
  }
}


.fcn-wrap__sec02-li > a{
  margin: 0;
  padding: 0;
  display: block;
}
.fcn-wrap__sec02-li figure{
  max-width: 380px;
  height: auto;
  margin: 0 auto 20px auto;
  padding: 0;
}
.fcn-wrap__sec02-li img{
  width: 100%;
  height: auto;
}
.fcn-wrap__sec02-caption{
  margin: 0 auto;
  padding: 0;
  text-align: center;
}
.fcn-wrap__sec02-caption > span{
  display: block;
}
.fcn-wrap__sec02-caption > span:nth-child(1){
  font-size: 1.6rem;
  font-weight: bold;
  line-height: 1.2;
  color: #FF651A;
}
.fcn-wrap__sec02-caption > span:nth-child(2){
  font-size: 1.8rem;
  line-height: 1.8;
  color: #000000;
}
@media only screen and (max-width: 768px) {
  .fcn-wrap__sec02-caption > span:nth-child(2){
    font-size: 1.6rem;
  }
}


.fcn-wrap__sec02expand{
  margin: 0 auto;
  padding: 0;
}
.fcn-wrap__sec02expand-about{
  width: 100%;
  height: auto;
  margin: 0 auto;
  padding: 100px 30px 0 30px;
  text-align: center;
  display: flex;
  justify-content: center;
  flex-direction: column;
  align-items: center;
  box-sizing: border-box;
  background: url(../img/top/img_sec02_03@2x.jpg) no-repeat center center / cover;
}
@media only screen and (max-width: 768px) {
  .fcn-wrap__sec02expand-about{
    border-top:1px solid #C4C4C4;
    padding: 100px 30px 0 30px;
  }
}


.fcn-wrap__sec02expand-list{
  max-width: 1060px;
  margin: 0 auto 100px auto;
  padding: 0;
  display: flex;
  justify-content: center;
  align-items: center;
  text-align: center;
}
@media only screen and (max-width: 768px) {
  .fcn-wrap__sec02expand-list{
    max-width: 100%; 
    margin: 0 auto 80px auto;
    flex-direction: column;
  }
}

.fcn-wrap__sec02expand-tit{
  position: relative;
  z-index: 2;
  width: 340px;
  height: 340px;
  min-width: 340px;
  min-height: 340px;
  margin: 0;
  padding: 0;
  box-sizing: border-box;
  border: 10px solid #FFB300;
  background: url(../img/top/icon_qmark.svg) no-repeat center center / 150px auto;
  background-color: #FAF3E8;
  border-radius: 50%;
  display: flex;
  justify-content: center;
  align-items: center;
  font-size: 3rem;
  font-weight: bold;
  line-height: 1.6;
  color: #000000;
  box-sizing: border-box;
}

@media only screen and (max-width: 768px) {
  .fcn-wrap__sec02expand-tit{
    width: 250px;
    height: 250px;
    min-width: 250px;
    min-height: 250px;
    border: 5px solid #FFB300;
    margin: 0 auto -30px auto;
    background-size: 110px auto;
    font-size: 2.4rem;
  }
}

.fcn-wrap__sec02expand-txt{
  position: relative;
  z-index: 1;
  max-width: 760px;
  margin: 0 0 0 -40px;
  padding: 60px 70px 60px 70px;
  border-radius: 10px;
  background-color: #FCF9F4;
  box-sizing: border-box;
  text-align: left;
}

@media only screen and (max-width: 768px) {
  .fcn-wrap__sec02expand-txt{
    margin: 0 auto;
    padding: 50px 30px 50px 30px;
  }
}
.fcn-wrap__sec02expand-txt > .tit{
  margin: 0 0 10px 0;
  padding: 0;
  display: block;
  font-size: 2.1rem;
  line-height: 1.4;
  font-weight: bold;
}
.fcn-wrap__sec02expand-txt > .txt{
  margin: 0 0 10px 0;
  padding: 0;
  display: block;
  font-size: 1.6rem;
}
.fcn-wrap__sec02expand-txt > .auth{
  margin: 0;
  padding: 0;
  display: block;
  font-size: 1.2rem;
}


/*sec03*/
.fcn-wrap__sec03{
  margin: 0 auto 150px auto;
  padding: 0 30px 0 30px;
  box-sizing: border-box;
}
@media only screen and (max-width: 768px) {
  .fcn-wrap__sec03{
    max-width: 100%;
    margin: 0 auto 90px auto;
    padding: 0;
  }
}

.fcn-wrap__sec03-acdwrap{
  max-width: 960px;
  margin: 0 auto;
  padding: 0;
  text-align: center;
}
.fcn-wrap__sec03-acdlist{
  margin: 0 auto 40px auto;
  padding: 0;
}

@media only screen and (max-width: 768px) {
  .fcn-wrap__sec03-acdlist{
    margin: 0 auto 0 auto;
    padding: 0 10px 0 20px;
    border-bottom:1px solid #C4C4C4;
  }
}


.fcn-wrap__sec03-acdtit{
  position: relative;
  margin: 0;
  padding: 0 0 0 65px;
  text-align: left;
  font-size: 2.4rem;
  font-weight: bold;
  background: url(../img/top/icon_faq@2x.jpg) no-repeat left center / 48px 48px;
  box-sizing: border-box;
}
@media only screen and (max-width: 768px) {
  .fcn-wrap__sec03-acdtit{
    width: calc( 360 / 375 * 100% );
    margin: 0 auto;
    padding: 1.2em 30px 1.2em 55px;
    font-size: 1.8rem;
    line-height: 1.4;
    background-position: left center;
  }
}

.fcn-wrap__sec03-acdtit:before{
  display: none;
}
@media only screen and (max-width: 768px) {
  .fcn-wrap__sec03-acdtit{
    font-size: 1.8rem;
  }
}


@media only screen and (max-width: 768px) {
  .fcn-wrap__sec03-acdtit:before{
    content: " ";
    display: block;
    width: 10px;
    height: 10px;
    border-right: 3px solid #FFB300;
    border-bottom: 3px solid #FFB300;
    transition: .4s;
    position: absolute;
    top: 50%;
    right: 15px;
    transform: translateY(-50%) rotate(45deg);
    -ms-transform: translateY(-50%) rotate(45deg);
    display: block;
  }
  
  .fcn-wrap__sec03-acdtit.is-active:before {
    transform: translateY(-50%) rotate(225deg);
    -ms-transform: translateY(-50%) rotate(225deg);
  }
}

.fcn-wrap__sec03-acdtxt{
  margin: 0;
  padding: 30px 0 30px 0;
  font-size: 1.6rem;
  line-height: 1.8;
  text-align: left;
  box-sizing: border-box;
}
@media only screen and (max-width: 768px) {
  .fcn-wrap__sec03-acdtxt{
    width: calc( 345 / 375 * 100% );
    margin: 0 auto;
    padding: 20px 0 20px 0;
    display: none;
  }
}


.fcn-wrap__sec03-acdtxt > .txt-u{
  text-decoration: underline;
}

.fcn-wrap__sec02expand-txt .og{
  color: #FF651A;
}


.fcn-wrap__sec03aten{
  max-width: 1120px;
  margin: 0 auto;
  padding: 50px 55px 50px 50px;
  border: 6px solid #FEF0CB;
  background-color: #fff;
  box-sizing: border-box;
}
@media only screen and (max-width: 768px) {
  .fcn-wrap__sec03aten{
    width: calc( 340 / 375 * 100% );
    margin: 30px auto 0 auto;
    padding: 20px 12px 10px 12px;
  }
}


.fcn-wrap__sec03aten-txt{
  margin: 0 auto 30px auto;
  padding: 0;
  font-size: 1.6rem;
  line-height: 1.8;
}
@media only screen and (max-width: 768px) {
  .fcn-wrap__sec03aten-txt{
    width: 100%;
    margin: 0 auto 30px auto;
  }
}



.fcn-wrap__sec03aten-tit{
  margin: 0 auto 10px auto;
  padding: 0;
  font-size: 2.0rem;
  line-height: 1.2;
  color: #FF651A;
  font-weight: bold;
}
.fcn-wrap__sec03aten-list{
  margin: 0 auto;
  padding: 0;
  font-size: 1.6rem;
  line-height: 2.0;
}
@media only screen and (max-width: 768px) {
  .fcn-wrap__sec03aten-list{
    margin: 0 auto 30px auto;
  }
}



/* functional detail */


.fcn-detail{
  margin: 0 auto;
  padding: 0;
}
.fcn-detail__wrap{
  max-width: 1130px;
  margin: 0 auto 90px auto;
  padding: 20px 60px 50px 60px;
  border-radius: 7px;
  border: 6px solid #FEF0CB;
  box-sizing: border-box;
}

@media only screen and (max-width: 768px) {
  .fcn-detail__wrap{
    max-width: auto;
    width: calc( 330 / 375 * 100% );
    padding: 0 0 30px 0;
  }
}

.fcn-detail__colwrap{
  margin: 0 auto;
  padding: 40px 0 0 0;
  display: flex;
  justify-content: flex-start;
  align-items: flex-start;
  flex-wrap: wrap;
}
@media only screen and (max-width: 768px) {
  .fcn-detail__colwrap{
    flex-direction: column;
    justify-content: center;
    margin: 0 20px 0 20px;
    padding: 20px 0 20px 0;
  }
}

.fcn-detail__colwrap.line{
  border-bottom: 2px dotted #FFDC8B;
}


.fcn-detail__col{
  margin: 0;
  padding: 0 0 50px 0;
  display: block;
}
@media only screen and (max-width: 768px) {
  .fcn-detail__col{
    padding: 0 0 20px 0;
  }
}

.fcn-detail__col.fullsize{
  width: 100%;
}
.fcn-detail__col.halfsize{
  width: 50%;
}
@media only screen and (max-width: 768px) {
  .fcn-detail__col.halfsize{
    width: 100%;
  }
}


.fcn-detail__idnum{
  max-width: 273px;
  height: 40px;
  margin: 0 0 15px 0;
  padding: 0;
  border: 1px solid #FF651A;
  border-radius: 40px;
  box-sizing: border-box;
  font-size: 1.6rem;
  font-weight: bold;
  line-height: 40px;
  text-align: center;
  color: #FF651A;
}
@media only screen and (max-width: 768px) {
  .fcn-detail__idnum{
    max-width: auto;
    width: calc( 300 / 375 * 100% );
    margin: 0 auto 25px auto;
  }
}

.fcn-detail__photo{
  position: relative;
  max-width: 560px;
  height: 560px;
  margin: 0;
  padding: 0;
  box-sizing: border-box;
  overflow: hidden;
}

@media only screen and (max-width: 768px) {
  .fcn-detail__photo{
    max-width: calc( 320 / 375 * 100% );
    height: calc( 320 / 375 * 100% );
    margin: -20px auto 0 auto;
  }
}


.fcn-detail__photo > img{
  position: absolute;
  left: 50%;
  top: 50%;
  transform: translate(-50%,-50%);
  margin: 0 auto;
  padding: 0;
  width: 100%;
  height: auto;
  object-fit:contain;
}
@media only screen and (max-width: 768px) {
  .fcn-detail__photo > img{
    position: static;
    transform: none;
  }
}

.fcn-detail__tit{
  font-size: 1.6rem;
  line-height: 1.4;
  font-weight: bold;
}
.fcn-detail__tit.og{
  margin-bottom: 10px;
  font-size: 2.0rem;
  color: #FF651A;
}
@media only screen and (max-width: 768px) {
  .fcn-detail__tit.og{
    font-size: 1.6rem;
    margin-bottom: 10px;
  }
}

.fcn-detail__tit.mg{
  margin-bottom: 20px;
}
.fcn-detail__txt{
  margin: 0 0 1em 0;
  font-size: 1.6rem;
  line-height: 1.6;
}
@media only screen and (max-width: 768px) {
  .fcn-detail__txt{
    font-size: 1.5rem;
  }
}

.fcn-detail__txtwrap{
  margin: 0 auto;
  padding: 0 20px 0 20px;
}
@media only screen and (max-width: 768px) {
  .fcn-detail__txtwrap{
    padding: 0;
  }
}

.fcn-detail__spacer{
  height: 3.2em;
}
@media only screen and (max-width: 768px) {
  .fcn-detail__spacer{
    display: none;
  }
}

.fcn-detail__list{
  margin: 0 0 20px 0;
  padding: 0;
}
@media only screen and (max-width: 768px) {
  .fcn-detail__list{
    margin-bottom: 20px;
  }
}

.fcn-detail__list-li{
  margin: 0;
  padding: 0;
  font-size: 1.6rem;
  line-height: 2.0;
  list-style: none;
}
@media only screen and (max-width: 768px) {
  .fcn-detail__list-li{
    font-size: 1.4rem;
  }
}

a.fcn-detail__link{
  text-decoration: underline;
}
a.fcn-detail__link:hover{
  text-decoration: none;
}

@media only screen and (max-width: 768px) {
  .fcn-detail__button{
    margin: 0 auto;

  }
  .btn01 a{
    padding-left: 20px;
    padding-right: 20px;
  }
  .btn01 a>span{
    padding-right: 15px;
  }
}


.fcn-detail__link{
  margin-top: 20px;
  display: inline-block;
}




/*  functionalここまで  */
