@charset "utf-8";
/* CSS Document */

.pc{
	display:block;
}
.sp{
	display:none;
}
/*
html, body {
  overflow: hidden;
}*/

body,html{
	width:100%;
	height:100%;
	padding:0;
	margin:0;
	line-height:normal;
	font-size:15px;
    position:inherit;
	}


*{
	font-family: "Hiragino Maru Gothic W4 JIS2004", "游ゴシック", YuGothic, "ヒラギノ角ゴ ProN W3", "Hiragino Kaku Gothic ProN", "メイリオ", Meiryo, "Helvetica Neue", Helvetica, Arial, sans-serif;	overflow-wrap: break-word;
	word-break: normal;

}


body > #wrapper {
    height: auto;
}

p{
	font-size:15px;
	line-height:180%;
font-weight:500;
}

.txt-center{
	text-align:center;
}
.txt-right{
	text-align:right;
}

#wrapper{
	width:100%;
	height:100%;
    overflow-x: hidden;
}

a:hover{
		 -webkit-transition: all 0.4s ease;
    -moz-transition: all 0.4s ease;
    -o-transition: all 0.4s ease;
    transition: all  0.4s ease;
}
a img:hover{
	opacity:0.7; 	
	 -webkit-transition: all 0.4s ease;
    -moz-transition: all 0.4s ease;
    -o-transition: all 0.4s ease;
    transition: all  0.4s ease;
}
/*
header
****************************/
#head{
        border:0px dotted #f00;

}
#header{
    padding:5px 15px 15px 15px!important;
    overflow: hidden;
    z-index: 10;
    width:100%;
    height:auto;
    vertical-align: top;
    background:#fff;
}

header h1{
    width:417px;
    height:50px;
    margin:10px 0 0 10px;
    vertical-align: top!important;
    float:left;
    padding:0px!important;
}
header h1 img{
    width:100%;
    height:auto;
    vertical-align: middle;
    display: block;
    margin:0px!important;
    padding:0px!important;
}
header ul{
    float:right;
    width:470px;
    text-align: right;
    padding:0px 0!important;
    vertical-align: middle!important;
        margin:12px 0 0 0;
}
header ul li{
    margin:0px 0px 0px 18px!important;
    padding:5px 0px 5px 18px!important;
    text-align: right;
    display: inline-block;
    border-left:0px solid #000;
    vertical-align: middle!important;
}
header ul li:last-child{
    border-left:1px solid #000;
}

/*
グローバルナビ
**************************/
.is-fixed {
  position: fixed;
  top: 0;
  left: 0;
  z-index: 12;
  width: 100%;
}
nav{
background:#e6001e;
	width:100%;
	position: relative;
	height:auto;
	z-index: 11!important;
}

nav ul{
	display: block;
	margin:0 auto;
	text-align: center;
}
nav li{
	display: inline-block!important;
}

nav li a{
	color:#fff;
	text-decoration: none;
	padding:15px 35px ;
	display: block;
    font-weight:bold;
}
nav li a:hover{
	text-decoration: underline;
}

/*
アンカーリンク
*******************************/

#header{

}
#secondSec,
#thirdSec,
#fourthSec,
#fifhtSec,
#sixthSec,
#seventhSec,
#eighthSec,
#ninthSec{
    padding-top:100px!important;
    margin-top:-100px!important;
}

/*
1stビュー
****************************/
.slider{
    margin:0px 0 0 0;

border:0px dotted #fff;
}
.fv01 .fvBox{
    background:url(../images/slide01.jpg) center top;
    background-size:cover;
  min-height: calc(100vh - 0px);
    
}
.fv02 .fvBox{
    background:url(../images/slide02.jpg) center center;
    background-size:cover;
      min-height: calc(100vh - 0px);
}
.fv01 .fvBox .sp{
    display:none!important;
    visibility: hidden!important;
    border:thick dotted #f00;
}
.fv03 .fvBox{
    background:url(../images/slide03.jpg) center center;
    background-size:cover;
  min-height: calc(110vh - 0px);
    padding:0px;
    margin:0px;
}
.fv04 .fvBox{
    background:url(../images/slide04.jpg) center center;
    background-size:cover;
  min-height: calc(100vh - 0px)!important;
  max-height: calc(100vh - 0px)!important;
    position: relative;
}
.fvBox {
  width: 100vw;
  height: auto;
      display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
        height:100%;


  /* 左右中央寄せ */
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;

  /* 上下中央寄せ */
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
    position: relative;
}
.custom-pager{
    position: absolute;
    bottom:0px;
    display: block;
    margin:0 auto;
    left:50%;
    z-index: 10;
    -webkit-transform: translate(-50%, 0%); /* Safari用 */
  transform: translate(-50%, 0%);
    width:60px;
    height:84px;
}


.fv02 div{
    color:#fff!important;
    font-size:3.5rem;
    font-weight:bold;
    text-align: center;
}
.fv04{
        height:100%;

}
.fv04 .txtBox{
    display: block;
    max-width:800px;
    margin:0 auto;

    color:#e6001e;
    position: absolute;
    left:50%;
    top:45%;
   -webkit-transform: translate(-50%, -50%); /* Safari用 */
     transform: translate(-50%, -50%);
}
.fv04 .txtBox h2{
    font-size:38px;
    text-align: center;
    border-bottom:2px solid #e6001e;
    padding:0 0 5px 0;
    margin:0 0 20px 0;
    font-weight:bold;
}
.fv04 .txtBox p{
    font-size:25px;
    line-height: 180%;
     text-align: center;
    margin:0px auto 20px;
    display: block;
}
.btn{

    display: block;
    margin:40px auto 0px;
}
.btn a{
    color:#fff;    font-size:17px;
    background:#e6001e;
    border-radius:300px;
    padding:20px 0px;
    text-align: center;
    text-decoration: none;
    display: block;
    margin:0px auto;
    max-width:240px;
    font-weight:bold;
}
.btn a:hover{
    background:#a5001c;
        -webkit-transform: scale(1.08);
    -moz-transform: scale(1.08);
    -o-transform: scale(1.08);
    -ms-transform: scale(1.08);
    transform: scale(1.08);
}
/*
アニメーション
***************************/
.fukidashi01{
    position: absolute;
    left:15%;
    bottom:40%;
    margin-top:100px;
    width:20%;
    height:auto;
}
.fukidashi01 img,
.fukidashi02 img,
.fukidashi03 img{
    width:100%;
    height:auto;
        min-width:260px!important;

}
.fukidashi02{
    position: absolute;
    left:35%;
    bottom:65%;
    margin-left:-50px;
        width:20%;
    height:auto;

}
.fukidashi03{
    position: absolute;
    right:8%;
    bottom:40%;
        width:20%;
    height:auto;

}

.box4{
    position:absolute;
    top:50%;
    left:50%;
        	  -webkit-transform: translate(-50%, 0%); /* Safari用 */
  transform: translate(-50%, 0%);
        color: #fff;

}
strong{
        color: #fff;
    text-decoration: none;
    border-bottom:7px solid #fff;
    background: linear-gradient(rgba(255, 255, 255,0) 60%, rgba(255, 255, 255,1) 40%);
    background-repeat: no-repeat;
    background-size: 0% 150%;
    transition: background-size 5.5s;
    padding-bottom:5px;
}

/*
SecondSec
**************************/

#secondSec{
}
#secondSec h2{
    text-align: center;
    color:#e6001e;
    font-size:38px;
    font-weight:bold;
    background:url(../images/bgHeadinmg01.svg) no-repeat center top;
    width:100%;
    max-width:800px;
    padding:5% 0 17%;
    margin:0 auto;
}
#secondSec .inner{
    width:95%;
    max-width:1000px;
    margin:0 auto;
    display: block;
    padding:100px 0 100px;

}

#secondSec .divBox01{
    overflow: hidden;
    z-index: auto;
    width:1000px;
    margin:0 0px 0 0!important;
    background: url(../images/Number01.svg) no-repeat right 110px top 40px;
    background-size:114px 114px;
    padding:0 0 70px 0;
}
#secondSec .divBox02{
    overflow: hidden;
    z-index: auto;
    width:1000px;
    margin:40px 0 0 0px;
    background: url(../images/Number02.svg) no-repeat right 510px top 40px;
    background-size:150px 113px;
    padding:0 0 70px 0;
}
#secondSec .divBox03{
    overflow: hidden;
    z-index: auto;
    width:1000px;
    margin:40px 0px 0 0!important;
    background: url(../images/Number03.svg) no-repeat right 60px top 40px;
    background-size:146px 116px;
}
#secondSec .hr01{
    max-width:800px;
    width:100%;
    display: block;
    margin:0 auto;
    border-width: 1px 0px 0px 0px; /* 太さ */
   border-style: solid; /* 線種 */
   border-color: #dcdddd;   /* 線色 */
   height: 1px;         /* 高さ(※古いIE用) */
    border: 1 none;
}
#secondSec .divBox01 img,
#secondSec .divBox03 img{
    float:left;
    max-width:385px;
    height:auto;
}
#secondSec .divBox02 img{
    float:right;
    max-width:385px;
    height:auto;
}
#secondSec .divBox01 div,
#secondSec .divBox03 div{
    float:right;
    width:530px;
    margin-right:30px;
}
#secondSec .divBox02 div{
    float:left;
    width:540px;
}

#secondSec .divBox01 div h3,
#secondSec .divBox02 div h3,
#secondSec .divBox03 div h3{
    color:#e6001e;
font-size:24px;
line-height:40px;
margin:90px 0 20px 0;
}
#secondSec .divBox01 div h4,
#secondSec .divBox02 div h4,
#secondSec .divBox03 div h4{
    color:#000;
font-size:17px;
line-height:40px;
margin:0 0 20px 0;
}
/*
thirdSec
**************************/
#thirdSec{
    padding:100px 0;
}
#thirdSec .bgRed{
    background:#e6001e;
    padding:60px 0;
    color:#fff;
    text-align: center;
}
#thirdSec .bgRed h3{
 font-size:24px;
    line-height:160%;
    margin:0 0 30px 0;
}

#thirdSec .bgRed h4{
 font-size:30px;
    line-height:160%;
    background: url(../images/bgHeading02.svg) no-repeat center top;
    background-size:cover;
    padding:45px 0px 55px!important;
    max-width:800px;
    margin:0 auto;
}
#thirdSec .redTriangle{
    display: none;
}
#thirdSec .bgPic{
    background: url(../images/bg_thirdSec.jpg) no-repeat center center;
    background-size:cover;
    padding:80px 0;
    text-align: center;
}
#thirdSec .bgPic .bgPicSp p:nth-of-type(1){
    font-size:20px;
    line-height: 250%;
    font-weight: 500;
}

#thirdSec .bgPic p:nth-of-type(1){
    font-size:33px;
    line-height: 180%;
    font-weight: 700;
    padding:20px ;
}
#thirdSec .bgPic p:nth-of-type(2){
    font-size:18px;
    line-height: 180%;
    font-weight: 500;
}
/*
fourthSec
**************************/
#fourthSec{
    background:#f5f5f5;
}
#fourthSec .inner{
    width:95%;
    max-width:1000px;
    margin:0 auto;
    padding:60px 0 60px;
}

#fourthSec .inner h2{
    margin:0 auto 80px;
    text-align: center;
    width:30%;
    max-width:230px;
}
#fourthSec .inner h2 img{
    width:100%;
    height:auto;
}
#fourthSec .inner h3{
    margin:0 auto 5px;
    text-align: center;
    font-size:18px;
    line-height:180%;
    font-weight:500;
}
#fourthSec .inner h4{
    margin:0 auto 90px;
    text-align: center;
    font-size:26px;
    line-height:180%;
    background: url(../images/bgHeading_underline_blk.gif) no-repeat center bottom;
    padding:0 0 25px 0;
}
#fourthSec .inner h5{
    color:#e6001e;
    margin:0 auto 10px;
    text-align: center;
    font-size:26px;
    line-height:130%;
    background: url(../images/bgHeading_underRed.gif) no-repeat center bottom;
    padding:0 0 10px 0;
}
#fourthSec ul{
display: flex;
    flex-wrap: wrap;
    text-align: center;
}
#fourthSec ul li{
    display: block;
    width:33.33333333333333%!important;
    text-align: center;
    font-size:14px;
    margin: 0 0 80px 0;
}
#fourthSec ul li img{
    display: block;
    margin:0 auto 20px;
    max-width:216px;
    height:auto;
}
#fourthSec ul li p:nth-of-type(1){
    font-weight:bold!important;
}
#fourthSec ul li p:nth-of-type(2){
    font-weight:normal;
    line-height:160%;
}

/*
fifthSec
**************************/
#fifthSec{
    background:#fff;
}
#fifthSec .inner{
    width:95%;
    max-width:1000px;
    margin:0 auto;
    padding:150px 0 100px;
}

#fifthSec .inner h2{
    margin:0 auto 80px;
    text-align: center;
    width:30%;
    max-width:230px;
}
#fifthSec .inner h2 img{
    width:100%;
    height:auto;
}
#fifthSec .inner h3{
    margin:0 auto 5px;
    text-align: center;
    font-size:18px;
    line-height:180%;
    font-weight:500;
}
#fifthSec .inner h4{
    margin:0 auto 90px;
    text-align: center;
    font-size:26px;
    line-height:180%;
    background: url(../images/bgHeading_underline_blk.gif) no-repeat center bottom;
    padding:0 0 15px 0;
}
#fifthSec .inner .planTable{
    width:100%;
    height:auto;
    margin:0 0 25px 0;
}
#fifthSec .planSp{
    display:none;
}
.txtSmall{
    font-size:13px;
    line-height:160%;
}

#fifthSec dl{
display: flex;
    text-align: center;
    background:#fef2f4;
    padding:10px 8%;
    border-radius:15px;
    margin:25px 0 0 0;
}
#fifthSec dl dt{
    display: inline-block;
    width:25%;
    text-align: right;
    margin: 0 0px 0px 0;
}
#fifthSec dl dt img{
    width:100%;
    height:auto;
    min-width:203px;
}
#fifthSec dl dd{
    display: inline-block;
    width:75%;
    text-align: left;
    margin: 0 0px 0px 0;
    padding:10px 0 0 20px;
    font-size:16px;
    line-height:140%;
    font-weight:bold;
}
#fifthSec ul li img{
    display: block;
    margin:0 auto 20px;
    max-width:216px;
    height:auto;
}
#fifthSec ul li p:nth-of-type(1){
    font-weight:bold!important;
}
#fifthSec ul li p:nth-of-type(2){
    font-weight:normal;
    line-height:160%;
}
#fifthSec .bgPazzle{
    background: url(../images/bg_plan.jpg)no-repeat center bottom;
    background-size: cover;
    padding:190px 0 250px;
    text-align: center;
    color:#fff;
}
#fifthSec .bgPazzle h3{
 font-size:33px;
    line-height:160%;
    margin:0 0 30px 0;
}

#fifthSec .bgPazzle h4{
 font-size:20px;
    line-height:200%;
    margin:0 0 0px 0;
    padding:0 0 40px 0;
    font-weight:500;
}

/*
sixthSec
**************************/
#sixthSec{
    background:#fff;
}
#sixthSec .inner{
    width:95%;
    max-width:1000px;
    margin:0 auto;
    padding:60px 0 60px;
}

#sixthSec .inner h2{
    margin:0 auto 80px;
    text-align: center;
    width:30%;
    max-width:230px;
}
#sixthSec .inner h2 img{
    width:100%;
    height:auto;
}
#sixthSec .inner h3{
    margin:0 auto 5px;
    text-align: center;
    font-size:18px;
    line-height:180%;
    font-weight:500;
}
#sixthSec .inner h4{
    margin:0 auto 40px;
    text-align: center;
    font-size:26px;
    line-height:180%;
    background: url(../images/bgHeading_underline_blk.gif) no-repeat center bottom;
    padding:0 0 15px 0;
}
#sixthSec .inner h5{
    color:#434a54;
    margin:0 auto 15px;
    text-align: left;
    font-size:23px;
    line-height:100%;
    padding:0 0 0px 0;
}
#sixthSec .inner .pnkBox{
    background:#fef2f4;
    border-radius:15px;
    width:95%;
    max-width:650px;
    margin:0 auto;
    padding:70px 20px 50px;
}
#sixthSec .inner .pnkBox li::after{
    width:100%!important;
    height:14px;
    content:"";
    background-image: url(../images/underline_fukidashi_red.svg);
  background-size: contain;
    background-position:center ;
  vertical-align: middle;
    display: block;
    margin: 20px 0 20px 0;
}
#sixthSec .inner .pnkBox li:last-child::after{
    width:100%!important;
    height:1px;
    content:"";
    background-image: url(parents);
  background-size: contain;
  vertical-align: middle;
    display: block;
    margin: 20px 0 0px 0;
}
#sixthSec .inner .pnkBox li p{
    line-height: 130%
    
}
#sixthSec .inner .pnkBox img{
    display: block;
    margin:0 auto;
}
#sixthSec .inner .pnkBox dl{
    padding:20px 0 0 60px ;
    vertical-align: top;
}
#sixthSec .inner .pnkBox dt{
    width:122px;
    height:auto;
    display: inline-block;
    vertical-align: top;
}
#sixthSec .inner .pnkBox dt img{
    width:100%;
    height:auto;
}
#sixthSec .inner .pnkBox dd{
    display: inline-block;
    width:330px;
    vertical-align: top;
    padding:0 0 0 15px;
}
#sixthSec .inner .pnkBox dd p{
    line-height:160%;
}
/*
sevenhSec
**************************/
#seventhSec{
    background:#fff;
}
#seventhSec .inner{
    width:95%;
    max-width:1000px;
    margin:0 auto;
    padding:100px 0 160px;
}

#seventhSec .inner h2{
    margin:0 auto 80px;
    text-align: center;
    width:30%;
    max-width:230px;
}
#seventhSec .inner h2 img{
    width:100%;
    height:auto;
}
#seventhSec .inner h3{
    margin:0 auto 5px;
    text-align: center;
    font-size:18px;
    line-height:180%;
    font-weight:500;
}
#seventhSec .inner h4{
    margin:0 auto 40px;
    text-align: center;
    font-size:26px;
    line-height:180%;
    background: url(../images/bgHeading_underline_blk.gif) no-repeat center bottom;
    padding:0 0 15px 0;
}
#seventhSec .inner dl.faqBox{
    border-radius:25px;
    background:#f5f5f5;
    padding:30px;
    margin:0 0 50px 0;
}
#seventhSec .inner dl.faqBox dt{
    padding:0px 0 0px 0px;
    vertical-align: middle;
    border-bottom:1px dotted #000;
    margin:0 0 10px 0;
    min-height:65px;
    text-align: left;
    overflow: hidden;
    z-index: auto;
}
#seventhSec .inner dl.faqBox dt img{
    vertical-align: middle!important;
    padding:0px;
    margin:0px 20px 20px 0;
    display: block;
    float:left;
    width:62px;
    height:62px;
}
#seventhSec .inner dl.faqBox dd img{
    vertical-align: middle!important;
    padding:0px;
    margin:0px 20px 0px 0;
    display: block;
    float:left;
    width:62px;
    height:62px;
}
#seventhSec .inner dl.faqBox dt p{
    font-size:17px;
    line-height:21px;
    font-weight:600;
    display: block;
    width:calc(100% - 2px);
    vertical-align: middle!important;
}
#seventhSec .inner dl.faqBox dt span{
    background:#ffe500;
}
#seventhSec .inner dl.faqBox dd{
    padding:0px 0 0 0px;
    font-size:17px;
    line-height:21px;
    min-height:65px;
    font-weight:600;
    vertical-align: middle;
    overflow: hidden;
    z-index: auto;
}
#seventhSec .inner dl.faqBox dd p{
    font-size:15px;
    line-height:29px;
    font-weight:500;
    padding:10px 0 0 0 ;
    display: block;
    width:calc(100% - 82px);
    float:right;
}
/*
eighthSec
*********************************/

#eighthSec{
    background:url(../images/bg_contact.jpg);
    background-size:cover;
    color:#fff;
}
#eighthSec .inner{
    width:95%;
    max-width:1000px;
    margin:0 auto;
    padding:100px 0 150px;
    text-align: center;
}

#eighthSec .inner h2{
    margin:0 auto 80px;
    text-align: center;
    width:30%;
    max-width:230px;
}
#eighthSec .inner h2 img{
    width:100%;
    height:auto;
}
#eighthSec .inner h3{
    margin:0 auto 40px;
    text-align: center;
    font-size:26px;
    line-height:180%;
    background: url(../images/bgHeading_underline.gif) no-repeat center bottom;
    padding:0 0 15px 0;
    color:#fff;
}
#eighthSec .inner p{
    font-size:20px;
    line-height:41px;
}


#eighthSec .inner .btn{

    display: block;
    margin:40px auto 0px;
}
#eighthSec .inner .btn a{
    color:#fff;    font-size:25px;
    background:#e6001e url(../images/ico_mail.png) no-repeat left 65px center;
    border-radius:300px;
    padding:30px 0px;
    text-align: center;
    text-decoration: none;
    display: block;
    margin:0px auto 65px;
    max-width:680px;
    font-weight:bold;
}
#eighthSec .inner .btn a:hover{
    background:#a5001c url(../images/ico_mail.png) no-repeat left 65px center;
}
#eighthSec .inner .telContact{
    max-width:340px;
    height:auto;
    display: block;
    margin:0 auto;
}

/*
ninth
***************************/

#ninth{
    background:#f0f0f0;
    text-align: center;
    padding:64px 15px;
}
#ninth img{
    max-width:133px;
    height:auto;
}

.btnLogo{

}

.gototop{
    width:100%;
    padding:30px;
    text-align: center;
}
.gototop a{
    display: block;
    margin:0 auto;
}


/*
footer
************************/
footer{
    background:#e6001e;
    color:#fff;
    text-align: center;
    padding:20px;
    font-weight:normal!important;
}
footer p{
        font-weight:normal!important;
    font-size:13px;
}

/*
padding/margin
*****************************/
.pt5{padding-top:5px;}
.pt10{padding-top:10px;}
.pt15{padding-top:15px;}
.pt20{padding-top:20px;}

.mt5{margin-top:5px;}
.mt10{margin-top:10px;}
.mt15{margin-top:15px;}
.mt20{margin-top:20px;}