@charset "UTF-8";
@import url(cmn.css);
@import url(base.css);

/*----------------------------outline--------------------------------*/
#outline{
    position:relative;
    background:url("../images/index/outline-illust.png");
    background-repeat:no-repeat;
    background-position: 50% 100%;
}
#outline:before{
    content:"";
    background:url("../images/cmn/garland.png") no-repeat;
    width:100%;
    height:100px;
    position:absolute;
    background-position: center top;
}

#outline p.outline-txt{
    font-size:2.4rem;
    text-align: center;
    font-weight: 700;
}
#outline p.kikan{
    margin:30px 0;
    font-size:3.0rem;
    font-weight: 700;
}
#outline p.kikan span{
    background:#036EB8;
    border-radius: 230px;
    padding:10px 30px;
    color:#fad151 !important;
}
.blue{
    color:#036eb8;
}

.orange{
    color:#db2e1b;
}

.outline-date{
    text-align: center;
}
.outline-date2{
    max-width:720px;
    margin:  20px auto 0 auto;
    width:100%;
    border:2px solid #391903;
    padding:15px;
    background:rgba(255,255,255,.8)
}
@media screen and (max-width: 1190px){
    #outline{
        background-size:100% auto;
        padding-bottom:15vw;
    }
}
@media screen and (max-width: 950px){
    #outline p{
    font-size:4.0vw;
    }
    #outline p.kikan{
    font-size:4.0vw;
    }
    #outline p.kikan span{
    padding:10px 20px;
    }
}
@media screen and (max-width: 600px){
    #outline p{
    font-size:4.5vw;
    text-align: left;
    }
    #outline p.kikan{
    text-align: center;
    }
    #outline p.kikan span{
    width:calc(100% - 40px);
    }
}
/*---slider---*/
.slider{
    padding-bottom:30px;
}
.slider .slick-list{
	position: relative;
	display: block;
	overflow: hidden;
}
.slider{
	position: relative;
	/*cursor: pointer;*/
}
.slider .slick-track{
	position: relative;
	top: 0;
	left: 0;
	display: flex;
	justify-content: center;
    -webkit-box-align: end;
    -webkit-align-items: flex-end;
    -ms-flex-align: end;
    align-items: flex-end;
    
}
.slider figure img{
    margin:auto;
    display:block;
    width:85%;
    height:auto;
}
.slider figure{
    position:relative;
    
}
.slider figure:after{
    position:absolute;
    top:calc(50% - 25px);
    right:-25px;
    width:50px;
    height:50px;
    content:"";
    background:url("../images/index/outline-img04.png") no-repeat;
    background-size:cover;
}
.slider figure:last-child:after{
    display:none;
}

.slider .slick-arrow{
	display: block;
	text-indent: -10000px;
	outline:none;
	line-height:1px;
	font-size:1px;
	height: 40px;
	width: 30px;
	cursor: pointer;
	position: absolute;
	top: calc(50% - 20px);
	left: 0;
	z-index: 1;
	border: none;
}
.slider .slick-next{
	left: auto;
	right: 0;
}
.slider .slick-arrow:before{
	content: "";
	display: block;
	width: 15px;
	height: 15px;
	position: absolute;
	top: calc(50% - 7px);
	border-top: 1px solid #222;
	border-left: 1px solid #222;
}
.slider .slick-prev:before{
	transform: rotate(-45deg);
	left: calc(50% - 4px);
}
.slider .slick-next:before{
	transform: rotate(135deg);
	left: calc(50% - 12px);
}

.slider .pointer{
	display: table;
	margin: 20px auto 0;
}
.slider .pointer li{
	display: table-cell;
	padding: 0 3px;
}
.slider .pointer li button{
	display: block;
	text-indent: -10000px;
	outline:none;
	line-height:1px;
	font-size:1px;
	background-color: #ccc;
	width: 7px;
	height: 7px;
	border-radius: 100%;
	border: none;
	cursor: pointer;
}
.slider .pointer .slick-active button{
	background-color: #E61673;
}

@media screen and (max-width: 950px){
    .slider{
    padding-bottom:15px;
    }
    .slider figure img{
    width:100%;
    height:auto;
    }
    .slider figure:after{
        display:none;
    }
}

/*----------------------------lesson--------------------------------*/
#lesson{
    background:#fefbeb;
}

#menu{
    background:#fff;
    border-radius: 24px;
    margin-top:50px;
}

#menu .inner{
    padding:3vw;
}

main #menu h3{
    padding-bottom:5px;
    border-bottom:4px solid #db2e1b;
    margin-bottom:15px;
}

#menu .flex>div:first-child{
    width:45%;

    }
#menu .img figure:last-child{
    display: -webkit-box;
    display: -webkit-flex;
    display: -ms-flexbox;
    display: flex;
}
#menu .flex>div:last-child{
    width:52%;

    }
#menu .date{
    margin-bottom:10px;
}
#menu .date span{
    background:#f84600;
    padding:5px 10px;
    color:#fff;
    font-weight: 900;
    font-size:1.8rem;
}
#menu h4{
    margin-bottom:0;
    line-height: 1.2;
}
@media screen and (max-width: 600px){
    #menu{
        border-radius:6px;
        margin-top:20px;
    }

    #menu .inner{
        padding:20px;
    }
}

#profile{
  background:#fff;
}

#profile h3{
    text-align: center;
    margin-bottom:30px;
    padding-bottom:10px
}

#profile h3 i{
    border-bottom:1px dotted #432008;
}
#profile .flex > figure{
	width: auto;
	margin-bottom:15px;
}
#profile .flex > div{
	width: calc(100% - 280px);
	
}
#profile .flex{
	margin-bottom:30px;
	border-top:1px dotted #432008;
	padding-top:30px;
	align-items: flex-start;
}
#profile .flex:first-of-type{
	border:none!important;
	padding-top:0px;
}
#profile .flex:last-child{
	margin-bottom:0;
}
#profile figure img{
	width:250px;
	height:250px;
	object-fit:cover;
	border-radius:50%;
}

main #profile h4 span{
	font-size: 1.6rem;
	margin-right: 10px;
	font-weight: 900;
}
@media screen and (max-width: 950px){
	#profile{
		margin-top:30px;
	}
	#profile figure img{
	width:200px;
	height:200px;
	object-fit:cover;
	border-radius:50%;
    margin:auto;
    display:block;
	}
}
/*----------------------------flow--------------------------------*/

#flow{
    background: #fefbeb;
    
}
#flow dl {
    display: -webkit-box;
    display: -webkit-flex;
    display: -ms-flexbox;
    display: flex;
    margin-bottom:30px;
}
#flow dt{
    width:100px;
    background:url("../images/index/flow.png") no-repeat;
    background-position:  50% 100%;
}
#flow dt span{
    background:#db2e1b;
    border-radius: 50%;
    width: 70px;
    height: 70px;
    padding: 0;
    margin: 0;
    padding-top: 20px;
    text-align: center;
    display: inline-block;
    font-weight: 900;
    line-height: 1;
    margin:auto;
    display:block;
    color:#fff;

}
#flow dt span i{
    display:block;
}
#flow dd{
    width:calc(100% - 120px);
    padding-bottom:50px;
}
main #flow h4{
    border-bottom:4px solid #db2e1b;

}
@media screen and (max-width: 950px){
    #flow dl{
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -webkit-flex-direction: column;
    -ms-flex-direction: column;
    flex-direction: column;
    position:relative;
    margin-bottom:100px;
    }
    #flow dl:after{
    content:"";
    background:url("../images/index/flow.png") no-repeat;
    width:20px;
    height:60px;
    background-size:100% auto;
    position:absolute;
    left:calc(50% - 10px);
    bottom:-80px;
    background-position: bottom;
    }
    #flow dt,
    #flow dd{
        width:100%;
        background:none;
        padding-bottom:0;
    }
}


/**/


.large-image-wrap {
  /*max-width: 400px;*/
  border: 6px solid transparent;
}

.large-image-wrap{
    position: relative;
    z-index: 1;
    overflow: hidden;
    padding-top: 100%;
}
.large-image-wrap img{
	position: absolute;
	display: block;
	max-width: none;
	width: 100%;
	top: 50%;
	left: 50%;
	transform: translate(-50%, -50%);
	object-fit: cover;
	object-position: 50% 50%;
	font-family: 'object-fit: cover; object-position: 50% 50%;';
	transition: 0.5s;
	height: 100%;
}

.thumb-list {
    box-sizing: border-box;
    margin: 10px -5px 10px;
    padding: 0;
    list-style-type: none;
    text-align: center;
    display: flex;
    justify-content: space-between;
}

.thumb-list::after {
  display: block;
  clear: both;
  content: '';
}

.thumb-list-wrap {
  box-sizing: border-box;
  width: 33%;
  margin-bottom: 10px;
  padding: 0 5px;
}
.thumb-list-img{
    position: relative;
    z-index: 1;
    overflow: hidden;
    padding-top: 100%;
    border: 2px solid transparent;
    cursor: pointer;
}
.thumb-list-img img{
	position: absolute;
	display: block;
	max-width: none;
	width: 100%;
	top: 50%;
	left: 50%;
	transform: translate(-50%, -50%);
	object-fit: cover;
	object-position: 50% 50%;
	font-family: 'object-fit: cover; object-position: 50% 50%;';
	transition: 0.5s;
	height: 100%;
}

.thumb-list-img.is-current {
  border-color: #fad151;
  background: #fad151;
}


/*delayZoomm*/

.delayZoom{
	opacity: 0;
	transition: 0.8s ease-in-out;
	transform: scale(0);
}
.delayZoomActive{
	opacity: 1.0;
	transform: scale(1);
	transition: 0.8s ease-in-out;
}


/*youtube*/

.youtube-flex{
    display: -webkit-box;
    display: -webkit-flex;
    display: -ms-flexbox;
    display: flex;
}
.youtube-wrap{
  max-width:680px;
  margin:auto;
  width:auto;
  margin-bottom:15px;
}
#youtube{
  max-width:680px;
  margin:auto;
  width:auto;
  margin-bottom:15px;
}
.youtube {
  position: relative;
  width: 100%;
  padding-top: 56.25%;
}
.youtube iframe {
  position: absolute;
  top: 0;
  right: 0;
  width: 100%;
  height: 100%;
}
