@charset "utf-8";

body::before{
	background: url(../img/oc/bg_pc.jpg) no-repeat center center / cover;		
}
	

/* Mv
-----------------------------------------------------------------*/
#Mv{
	position: relative;
	background: #F2F0EA;
	min-height: 1090px;
}
#Mv .logo{
	position: absolute;
	left: 15px;
	top: 10px;
	z-index: 10;
	opacity: 0;
	transition: 1s;
	transition-delay: .5s;
}
#Mv.start .logo{
	opacity: 1;
}

#Mv .pic{
	max-width: 550px;
	opacity: 0;
	transform: translateY(-50px);	
}
#Mv .pic img{
	border-radius: 0 0 60px 0;
}
#Mv .first.pic{
	transition: 1.5s;
}
#Mv .pic span img{
	border-radius: 0;
}
#Mv.start .pic{
	opacity: 1;
	transform: translateY(0);
}
#Mv .txt-area{
	position: absolute;
	left: 0;
	top: 516px;
	width: 100%;
}
#Mv .txt-area h1{
	text-align: center;
	opacity: 0;
	transition: 1s;
	transition-delay: 1s;
}
#Mv.start .txt-area h1{
	opacity: 1;
}

#Mv .txt-area .layout-box{
	position: relative;
	display: flex;
	margin: 30px 0;
	padding: 0 30px 0 18px;
}
#Mv .txt-area .layout-box .txt-mv{
	width: 62%;
	opacity: 0;
	transition: 1.5s;
	position: relative;
	max-width: 320px;
	z-index: 1;
}

#Mv.start .txt-area .layout-box .txt-mv{
	opacity: 1;
	z-index: 4;
}
#Mv .txt-area .layout-box .pic{
	position: absolute;
	z-index: 50;
	right: 30px;
	width: 37.5%;
	z-index: 1;
	opacity: 0;
	transition: 5s;
}
#Mv.start .txt-area .layout-box .pic{
	opacity: 1;
}
#Mv .txt-area .layout-box .badge{
	position: absolute;
	left: -100px;
    bottom: 34px;
	z-index: 10;
	transition: 5s;
}



/* schedule
-----------------------------------------------------------------*/
.schedule{
	padding: 135px 0 170px;
	background: #42C8CA;
	border-radius: 0 60px 0 0;
}
.schedule h2{
	text-align: left;
	margin-bottom: 35px;
	color: #fff;
}
.schedule h2 .en{
	font-size: 110px;
	margin-left: -10px;
	color: rgba(255, 255, 255, .2);
}
.schedule h2 b{
	position: relative;
	display: block;
	padding: 25px 40px 0;
	line-height: .9;
}
.schedule h2 b::before{
	content: "";
	position: absolute;
	top: 0;
	height: 1px;
	width: 35px;
	background: #fff;
}
.schedule h2.sec-ttl .ja{
	font-size: 4rem;
	margin-top: 0;
}
.schedule h2 span small{
	font-size: 1.8rem;
	font-family: "A1 Gothic R", "A1 Gothic M", "A1 Gothic L", "游ゴシック体", YuGothic, "Yu Gothic Medium", "ヒラギノ角ゴ Pro", "Hiragino Kaku Gothic Pro", "メイリオ", "Meiryo", "sans-serif";
}

.schedule .point{
	display: flex;
	justify-content: center;
	margin-bottom: 25px;
}
.schedule .point span{
	margin: 0 3px;
	padding: 3px 15px;
	background: #F2F0EA;
	border-radius: 10px;
	font-size: 1.4rem;
}
.schedule .campus-list{
	margin-bottom: 25px;
}
.schedule .campus-list > div{
	display: flex;
	padding: 18px 0;
	border-top: 1px dotted #D2D2D2;
	line-height: 1.3;
	font-size: 1.4rem;
}
.schedule .campus-list dt{
	display: flex;
	align-items: center;
	flex-shrink: 0;
	padding-right: 20px;
	border-right: 1px solid #D2D2D2;
}
.schedule .campus-list dt .ico-camp{
	flex-shrink: 0;
	margin-right: 10px;
}
.schedule .campus-list dd{
	padding-left: 20px;
}

.schedule .campus-list .department-list{
	display: flex;
	flex-wrap: wrap;
}
.schedule .campus-list .department-list li{
	margin: 3px 10px 3px 0;
}


.schedule-list{
	display: flex;
	justify-content: space-between;
	flex-wrap: wrap;
}
.schedule-list li{
	width: calc(50% - 10px);
	padding: 15px 30px 20px;
    background: #fff;
    border-radius: 10px;
    text-align: center;
}
.schedule-list li:nth-child(n+3){
	margin-top: 20px;
}
.schedule-list .year{
	display: block;
	margin-bottom: 5px;
	line-height: 1;
	font-size: 1.3rem;
}
.schedule-list .date{
	width: calc(100% + 20px);
	margin-left: -10px;
	line-height: 1;
}
.schedule-list .date.blankLine::before {
	display: block;
	content: '';
	height: calc(1.3rem + 5px);
}
.schedule-list .date .en{
	font-size: 7.6rem;
	letter-spacing: .2rem;
}
.schedule-list .date .en small{
	font-size: 3.8rem;
}
.schedule-list .date .day{
	font-size: 1.6rem;
}
.schedule-list .date .day._sat{
	color: #004FC7;
}
.schedule-list .date .day._sun{
	color: #B92525;
}
.schedule-list .time{
	margin: 10px 0 20px;
	font-size: 1.6rem;
	line-height: 1;
	letter-spacing: .05em;
	font-family: "A1 Gothic R", "A1 Gothic M", "A1 Gothic L", "游ゴシック体", YuGothic, "Yu Gothic Medium", "ヒラギノ角ゴ Pro", "Hiragino Kaku Gothic Pro", "メイリオ", "Meiryo", "sans-serif";
}
.schedule-list .time span{
	font-size: 1.4rem;
	padding-right: 10px;
	vertical-align: middle;
}
.schedule-list .time span:after{
	content: "";
	width: 1px;
	height: 1.3rem;
	background:  #434548;
	display: inline-block;
    margin-left: 1rem;
}

/*modal*/
.schedule-modal .schedule-list li{
	padding:  15px 20px;
}
.schedule-modal .schedule-list .date .en{
	font-size: 5.6rem;
	letter-spacing: .2rem;
}
.schedule-modal .schedule-list .date .en small{
	font-size: 2.8rem;
}
.schedule-modal .schedule-list .date .day{
	font-size: 1.3rem;
}
.schedule-modal .time span{
	display: none;
}





.schedule-list .btn-schedule{
	display: none;
}
.schedule-list .btn-schedule.on{
	display: block;
}
.schedule-list .btn-schedule a{
	position: relative;
	display: flex;
	justify-content: center;
	align-items: center;
	height: 42px;
	margin: 0 auto;
	padding-top: 2px;
	background:url(../img/common/arw_btn.svg) no-repeat right 10px center #F4EFDE;
	background-size: 4px auto;
	border-radius: 30px;
	font-size: 1.6rem;
	transition: .3s;
}

@media (hover: hover) and (pointer: fine) {
.schedule-list .btn-schedule a:hover{
	background-image:url(../img/common/arw_btn.svg);
	background-color: #fff;
	color: #434548;
	border: 1px solid #434548;
}
}
.schedule-list .btn-schedule a span {
	position: absolute;
	top: 50%;
	transform: translateY(-50%);
	left: 8px;
	width: 15px;
	height: 15px;
	color: #fff;
	font-size: 1rem;
	line-height: 15px;
	border-radius: 50%;
}

.schedule-list .btn-reserve{
	margin: 8px auto;
}
.schedule-list .btn-reserve a{
	background:url(../img/common/arw_btn_w.svg) no-repeat right 10px center #42C8CA;
	background-size: 4px auto;
	font-size: 1.6rem; 
}
.schedule-list li.oc-close {
	position: relative;
	background-color: unset;
}
.schedule-list li.oc-close:before {
	position: absolute;
	display: block;
	width: 100%;
	height: 100%;
	top: 0;
	left: 0;
	background: rgba(255,255,255,.5);
	border-radius: 10px;
	content: '';
	z-index: 1;
}
.schedule-list li.oc-close .btn-schedule a {
	color: #aaa;
	background-image: url(../img/common/arw_btn_gy.svg);
	border-color: #aaa;
	pointer-events: none;
}
.schedule-list li.oc-close .btn-schedule a span {
	background: #aaa;
}
.schedule-list li.oc-close .btn-reserve a {
	background-color: #aaa;
	border-color: #aaa;
	pointer-events: none;
}
.schedule-list li.oc-comming .btn-reserve a {
	background-color: #aaa;
	border-color: #aaa;
	pointer-events: none;
}
.schedule-list li.oc-comming {
	position: relative;
	background: #fff;
}
/* .schedule-list li.oc-comming:before {
	position: absolute;
	display: block;
	width: 100%;
	height: 100%;
	top: 0;
	left: 0;
	background: rgba(255,255,255,.5);
	border-radius: 10px;
	content: '';
	z-index: 1;
} */
.schedule-list li.oc-comming .btn-schedule a {
	color: #434548;
	background-image: url(../img/common/arw_btn.svg);
	border-color: #434548;
	/* pointer-events: none; */
}
.schedule-list li.oc-comming .btn-schedule a span {
	background: #aaa;
}
.schedule-list li.oc-comming .btn-reserve a {
	background-color: #e0e0e0;
	border-color: #e0e0e0;
	/* pointer-events: none; */
}
.schedule-box h3{
	margin: 25px 0 0;
	padding: 7px 0;
	background: url(../img/common/ico_plus_circle.svg) no-repeat right center;
	background-size: 30px auto;
	border-bottom: 1px solid #42C8CA;
	font-size: 1.8rem;
	line-height: 1;
	letter-spacing: .05em;
	font-weight: normal;
	cursor: pointer;
}
.schedule-box h3.open{
	background-image: url(../img/common/ico_minus_circle.svg);
}
.schedule-box h3 strong{
	display: inline-block;
	transform: translateY(2px);
	font-size: 2.8rem;
	font-weight: normal;
}
.schedule-box .schedule-acc-cont{
	display: none;
	margin-top: 20px;
}
.takarazuka_ap{
	margin: 60px 0 100px;
	padding: 60px 0;
	border-top: 1px solid #fff;
	border-bottom: 1px solid #fff;
}
.takarazuka_ap h3{
	margin-bottom: 36px;
	text-align: center;
	font-size: 3.8rem;
	line-height: 1.4;
	letter-spacing: .05em;
	color: #fff;
}
.takarazuka_ap h3 span{
	display: block;
	font-size: 1.8rem;
	font-family: "A1 Gothic R", "A1 Gothic M", "A1 Gothic L", "游ゴシック体", YuGothic, "Yu Gothic Medium", "ヒラギノ角ゴ Pro", "Hiragino Kaku Gothic Pro", "メイリオ", "Meiryo", "sans-serif";

}
.takarazuka_ap .viewmore{
	max-width: 320px;
	margin: 0 auto;
}
.takarazuka_ap .viewmore a{
	background:url(../img/common/arw_btn_bl.svg) no-repeat right 24px center #fff;
	position: relative;
	display: flex;
	justify-content: center;
	align-items: center;
	height: 74px;
	margin: 0 auto;
	padding-top: 2px;
	background-size: 6px auto;
	border-radius: 70px;
	font-size: 1.5rem;
	color: #42C8CA;
	border: 1px solid #fff;
	transition: .3s;
}
@media (hover: hover) and (pointer: fine) {
.takarazuka_ap .viewmore a:hover{
	background:url(../img/common/arw_btn_w.svg) no-repeat right 24px center #42C8CA;
	background-size: 6px auto;
	color: #fff;
	border: 1px solid #fff;
}
}
.schedule .gift{
  position: relative;
  margin: 0 auto;  
}



/* timetable
-----------------------------------------------------------------*/

.timetable{
  position: relative;
  padding: 80px 0 0;
  background: #F2F0EA;
  border-radius: 60px 0 0 0;
  margin-top: -60px;
  z-index: 1;
}
.timetable::after{
	content: "Open Campus Time Schedule.";
	position: absolute;
	left: -390px;
    rotate: -90deg;
    top: 30%;
	z-index: -1;
	width: 400vh;
	font-size: 105px;
	color: rgba(255, 255, 255, .8);
	font-family: "本明朝-Book 新小がな", "HonMinSKok-Book", "HonMinSKok-L", "YuMincho","Yu Mincho","HG明朝E", "ＭＳ Ｐ明朝", "ＭＳ 明朝", serif;
	text-transform: uppercase;
}


.timetable h2{
  position: relative;
  color: #5FC8CA;
  text-align: right;
}
.timetable h2 .en{
	font-size: 120px;
	line-height: .9;
}
.timetable h2 .ja{
	font-size: 4.4rem;
	letter-spacing: .3rem;
	line-height: 1.4;
}
.timetable h2 .ja.middle{
	font-size: 3.2rem;
	letter-spacing: .3rem;
	line-height: 1.4;
}
.timetable h2 .ja small{
	display: block;
	font-size: 1.8rem;
	letter-spacing: 0;
	font-family: "A1 Gothic R", "A1 Gothic M", "A1 Gothic L", "游ゴシック体", YuGothic, "Yu Gothic Medium", "ヒラギノ角ゴ Pro", "Hiragino Kaku Gothic Pro", "メイリオ", "Meiryo", "sans-serif";
}

.timetable h2 b{
	position: relative;
	display: block;
	padding: 5px 0 0;
    line-height: .9;
    margin-top: 20px;
}
.timetable h2 b::before{
	content: "";
	position: absolute;
	top: 0;
	right: 5px;
	height: 1px;
	width: 35px;
	background: #5FC8CA;
}

.time-line > li{
  position: relative;
  width: 100%;
  padding: 0 0 60px 30px; 
}
.time-line > li:last-child{
  padding-bottom: 140px;  
}
.time-line > li::before{
  position:absolute;
  left: -10px;
  top: 20px;
  z-index: 5;
  display: block;
  content: "";
  width: 38px;
  height: 1px;
  border-radius: 50%;
  background: #5FC8CA;    
}
.time-line > li::after{
  position:absolute;
  left: 5px;
  top: 0px;
  display: block;
  content: "";
  width: 1px;
  height: 100%;
  background: #5FC8CA;  
}
.time-line h3{
  color: #5FC8CA;
  font-size: 2rem;
}
.time-line h3 small{
  font-size: 1.3rem;  
}
.time-line .time{
  position:absolute;
  left: 28px;
  top: 28px;
  transform: translateY(-70%);
  display: flex;
  justify-content: center;
  align-items: center;
  color: #fff;
  background: #5FC8CA;
  line-height: 1;
  font-size: 3rem;
  padding: 5px 10px;
}
.time-line .time .en{
	padding-left: .8rem;
}
.time-line .time small{
  font-size: 80%;  
}

.time-line .slick-list{
  overflow: visible;  
}
.time-line .slider-item{
	padding: 60px 0 0;
}
.time-line  .slider-item h3{
	font-size: 3.8rem;
	letter-spacing: .05em;
	line-height: 1.2; 
  }
.time-line .slider-item h3 small{
	font-size: 1.8rem;
	font-family: "A1 Gothic R", "A1 Gothic M", "A1 Gothic L", "游ゴシック体", YuGothic, "Yu Gothic Medium", "ヒラギノ角ゴ Pro", "Hiragino Kaku Gothic Pro", "メイリオ", "Meiryo", "sans-serif";
}

.time-line .txt{
  font-size: 2rem;
  line-height: 1.7;
  text-align: justify;
  margin: 10px 0 20px;
}
.time-line .pic img{
	border-radius: 0 0 60px 0;
}

.time-line > li:last-child h3 small{
	display: block;
}
.time-line .txt.notes{
	font-size: 1.8rem;
	margin: 30px 0 0;
}


/* lesson
-----------------------------------------------------------------*/

.lesson{
	position: relative;
	background: #fff;
	border-radius: 0 60px 0 0;
	margin: -60px 0 0;
	padding: 100px 0 95px;
	z-index: 1;
}
.lesson h2{
	margin-bottom: 60px
}
.lesson .txt{
	margin: 4rem 0;
}
.lesson .txt p{
	text-align: justify;
	margin: 4rem 0;
	font-size: 2rem;
}
.lesson .txt h3{
	font-size: 36px;
	display: inline;
	padding: 0 0 10px;
	background: linear-gradient(transparent 96%, #5FC8CA 100% );
}
.clr{
	color: #5FC8CA;
}
.clm2{
	display: flex;
	gap: 34px;
	margin: 50px 0;
}
.clm2 .pic{
	width: calc(50% - 34px);
}
.clm2 .txt{
	width: calc(50% - 34px);
	margin: 0;
}
.lesson .clm2 .txt h3{
	font-size: 2.8rem;
	line-height: 2;
}
.lesson .clm2 .txt p{
	margin: 3rem 0 0;
}
.lesson .pic img{
	border-radius: 0 0 60px 0;
}


/* pickup
-----------------------------------------------------------------*/
.pickup{
	padding: 0 0 135px;	
	background: #fff;
}
.pickup h2{
	margin-bottom: 60px;
}
.pickup .modal.qa{
	position: relative;
	background: #26BFC2;
	margin-bottom: 30px;
	border-radius: 10px;
	padding: 60px 30px;
	display: flex;
	align-items: center;
    justify-content: center;
	text-align: center;
}
.pickup .modal.qa:last-child{
	margin-bottom: 0;
}
.pickup .modal.qa::before{
	position: absolute;
	content: "";
	width: 100%;
	height: 100%;
	background: #5FC8CA;
	border-radius: 300px 10px 300px 10px;
}
.pickup .modal.qa ._inner{
	width: 100%;
	color: #fff;
	z-index: 3;
}
.pickup .modal.qa ._inner h3{
	font-size: 42px;
	line-height: 1.4;
	letter-spacing: .05em;
}
.pickup .modal.qa ._inner h3 small{
	font-size: 28px;
}
.pickup .modal.qa .btn{
	display: flex;
	justify-content: center;
	align-items: center;
	margin: 30px auto 0;
	max-width: 320px;
	width: 100%;
	height: 74px;
	background:url(../img/common/arw_btn_bl.svg) no-repeat right 20px center #fff;
	background-size: 6px auto;
	border-radius: 100px;
	font-size: 1.8rem; 
	color: #5FC8CA;
	transition: .3s; 		
	border: 1px solid #5FC8CA;
}
@media (hover: hover) and (pointer: fine) {
.pickup .modal.qa .btn:hover{
	background-image:url(../img/common/arw_btn_w.svg);
	background-color: #5FC8CA;
	color: #fff;
	border: 1px solid #fff;
}
}



/* futurecourse
-----------------------------------------------------------------*/

.futurecourse{
	background: #F2F0EA;
	border-radius: 60px 0 0 0;
	padding: 140px 0 180px;
}



/* access
-----------------------------------------------------------------*/

.access{
	background: #F2F0EA;
	border-radius: 60px 0 0 0;
	padding: 140px 0 180px;
	margin-top: -60px;
}
.access h2{
	position: relative;
	color: #5FC8CA;
	text-align: right;
	margin-bottom: 5rem;
}
.access h2 .en{
	font-size: 120px;
	line-height: .9;
}
.access h2 .ja{
	font-size: 4.4rem;
	letter-spacing: .3rem;
	line-height: 1.4;
}
.access h2 .ja small{
	display: block;
	font-size: 1.8rem;
	letter-spacing: 0;
	font-family: "A1 Gothic R", "A1 Gothic M", "A1 Gothic L", "游ゴシック体", YuGothic, "Yu Gothic Medium", "ヒラギノ角ゴ Pro", "Hiragino Kaku Gothic Pro", "メイリオ", "Meiryo", "sans-serif";
}

.access h2 b{
	position: relative;
	display: block;
	padding: 5px 0 0;
	line-height: .9;
	margin-top: 20px;
}
.access h2 b::before{
	content: "";
	position: absolute;
	top: 0;
	right: 5px;
	height: 1px;
	width: 35px;
	background: #5FC8CA;
}
.access .traffic{
	margin-bottom: 8rem;
}
.access .traffic p{
	font-size: 3.2rem;
	letter-spacing: 0;
	line-height: 1;
	margin-bottom: 3rem;
}
.access .traffic p span{
	line-height: 1;
}
.access .traffic p small{
	font-size: 2.7rem;
}
.access .traffic p small.line{
	display: block;
	font-size: 1.8rem;
	line-height: .5;
}
.access .traffic p .clr{
	font-size: 5.2rem;
}

.access .tab-nav{
	position: relative;
	padding-right: 4%;
	display: flex;
	align-items: flex-end;
	justify-content: space-between;
	margin-bottom: 4.6rem;
}
.access .tab-nav::after{
    content: "";
    position: absolute;
    background: #5FC8CA;
    right: 0;
    bottom: 0;
    width: 4%;
    height: 2px;
}
.access .tab-nav li{
	width: 44%;
	display: block;
	background: #5FC8CA;
	color: #FFF;
	font-size: 3rem;
	line-height:1.2;
	padding: 2rem 3.5rem 1.5rem;
	border-top: 2px solid #5FC8CA;
	border-right: 2px solid #5FC8CA;
	border-radius: 0 30px 0 0;
	cursor:pointer;	
	letter-spacing: 0.15rem;
	border-collapse: collapse;
    box-sizing: border-box;
	transition: .3s; 		
}
.access .tab-nav li:first-child{
	border-radius: 0;
}
.tab-nav li small{
	display: block;
	font-size: 1.6rem;
}
.access .tab-nav li.active{
	width: 57%;
	background: #F2F0EA;
	color: #5FC8CA;
	font-size: 4rem;
	padding: 3rem 4rem 1.5rem;
	cursor: default;	
}
.access .tab-nav li.active small{
	font-size: 2rem;
}
@media (hover: hover) and (pointer: fine) {
.access .tab-nav li:not(.active):hover{
	background: #F2F0EA;
	color: #5FC8CA;
}
}
.access .tab-nav li.active:first-child{
	border-radius: 0 30px 0 0;
	border-right: 2px solid #5FC8CA;
}
.access .tab-nav li:first-child{
	border-right: none;
}
.access .tab-nav li.active:last-child{
	border-left: 2px solid #5FC8CA;
}

.routebox{
	display: none;
	transition: .3s;
	padding-bottom: 9rem;
}
.routebox.active{
	display:block;
	transform: translateY(0);
}
.routebox ul{
	display: flex;
	gap: 30px;
	flex-wrap: wrap;
    justify-content: space-between;
}
.routebox ul li{
	width: calc(50% - 15px);
	font-size: 1.8rem;
}
.routebox ul li img{
	margin: 0 0 1.6rem;
}

.access .map-area{
	position: relative;
	padding-bottom: 100%;	
}
.access .map-area iframe{
	position: absolute;
	left: 0;
	top: 0;
	width: 100%;
	height: 100%;
}
.access .btn-googlemap{
	margin-top: 5rem;
}
.access .btn-googlemap a{
	display: flex;
	justify-content: center;
	align-items: center;
	max-width: 320px;
	height: 74px;
	margin: 0 auto;
	border-radius: 100px;
	background: url(../img/common/ico_blank.svg) no-repeat right 26px center #fff;
	background-size: 16px auto;
	font-size: 1.8rem;
	line-height: 1;
	text-transform: uppercase;
	letter-spacing: .15em;
	color: #5FC8CA;
	cursor: pointer;
	transition: .3s;	
}
@media (hover: hover) and (pointer: fine) {
.access .btn-googlemap a:hover{
	background: url(../img/common/ico_blank_w.svg) no-repeat right 26px center #5FC8CA;
	background-size: 16px auto;
	color: #fff;
}
}




/* question
-----------------------------------------------------------------*/
.question{
	position: relative;
	background: #fff;
	border-radius: 0 60px 0 0;
	margin: -60px 0 0;
	padding: 160px 0 95px;
	z-index: 1;
}
.question h2{
	position: relative;
	color: #5FC8CA;
	text-align: left;
	margin-bottom: 7rem;
}
.question h2 .en{
	font-size: 95px;
	line-height: .9;
}
.question h2 .ja{
	font-size: 4rem;
	letter-spacing: .3rem;
	line-height: 1.4;
}
.question h2 b{
		position: relative;
		display: block;
		padding: 5px 0 0;
		line-height: .9;
		margin-top: 20px;
}
.question h2 b::before{
		content: "";
		position: absolute;
		top: 0;
		height: 1px;
		width: 35px;
		background: #5FC8CA;
}
.question dl{
	margin: 0 0 1.6rem;
	border-radius: 10px;
}
.question dt{
	position: relative;
	background: #5FC8CA;
	background-size: 15px auto;
	border-radius: 10px;
	font-size: 3rem;
	line-height: 1.3;
	letter-spacing: .15em;
	padding: 3rem 7rem 3rem 3rem;
	color: #fff;
	cursor: pointer;
	transition: .3s;
}
.question dt::after{
	position: absolute;
	right: 3rem;
    top: 50%;
	content: "";
	width: 42px;
	height: 42px;
	background: url(../img/common/arw_circle.svg) no-repeat center center;
	transform: rotate(0deg) translateY(-50%);
}
@media (hover: hover) and (pointer: fine) {
.question dt:hover{
	opacity: .8;
}
}
.question dt.is-active{
	border-radius: 10px 10px 0 0;
}
.question dt.is-active::after{
	background: url(../img/common/arw_circle.svg) no-repeat center center;
	transform: rotate(180deg) translateY(50%);
}

.question dd{
	display: none;
	background: #5FC8CA;
	border-radius: 0 0 10px 10px;
	padding: 0 3rem 3rem;
	color: #fff;
	font-size: 2rem;
}
.question dd a{
	color: #fff;
	text-decoration: underline;
}

.question .open dd{
	display: block;
}



/* bnr
-----------------------------------------------------------------*/

.bnr{
	background: #fff;
	position: relative;
	margin: 0 auto; 
	padding: 0 0 80px;
}

.bnr .totop a{
	background:url(../img/common/arw_btn_bl.svg) no-repeat right 30px center #F2F0EA;
	position: relative;
	display: flex;
	justify-content: center;
	align-items: center;
	text-align: center;
	line-height: 1.3;
	height: 100px;
	margin: 0 auto;
	background-size: 12px auto;
	border-radius: 70px;
	font-size: 2rem;
	color: #42C8CA;
	border: 1px solid #F2F0EA;
	transition: .3s;
}
@media (hover: hover) and (pointer: fine) {
.bnr .totop a:hover{
	background:url(../img/common/arw_btn_w.svg) no-repeat right 30px center var(--maincolor);
	background-size: 12px auto;
	color: #fff;
	border: 1px solid var(--maincolor);
}
}




/*--------------------------------------------------------------------------
   mobile
---------------------------------------------------------------------------*/

@media screen and (max-width: 580px) {
		
	/* Mv
	-----------------------------------------------------------------*/
	#Mv{
		padding-bottom: 20px;
		min-height: 100%;
        height: 173vw;
	}
	#Mv .logo{
		position: absolute;
		left: 15px;
		top: 10px;
		z-index: 10;
	}
	
	#Mv .pic{
		width: 93vw;
	}
	#Mv .txt-area{
		top: 85vw;
		width: 93vw;
		padding-left: 3vw;
	}

	#Mv .txt-area .layout-box{
		position: relative;
		display: flex;
		margin: 30px 0;
		padding: 0 0 0 5px;
	}
	#Mv.start .txt-area .layout-box .txt-mv{
		width: 68%;
		z-index: 7;
	}
	#Mv .txt-area .layout-box h2{
		position: relative;
		max-width: 320px;
		z-index: 7;
	}
	#Mv .txt-area .layout-box .pic{
		position: absolute;
		z-index: 5;
		right: 0;
		width: 32%;
	}
	#Mv .txt-area .layout-box .badge{
		width: 20vw;
        position: absolute;
        left: -14vw;
        bottom: 5vw;
	}
	
	
	
	/* schedule
	-----------------------------------------------------------------*/
	.schedule{
		padding: 85px 0 140px;
	}

	.schedule h2 .en{
		font-size: 19vw;
	}
	.schedule h2 b{
		padding: 25px 20px 0;
		line-height: 1.4;
	}
	.schedule h2.sec-ttl .ja{
		font-size: 3.5rem;
		margin-top: 0;
	}
	.schedule h2 span small{
		font-size: 1.6rem;
	}
	
	
	.schedule-list li{
		width: calc(50% - 5px);
		padding: 15px 5vw 20px;
	}
	.schedule-list li:nth-child(n+3){
		margin-top: 10px;
	}
	.schedule-list .year{
		display: block;
		margin-bottom: 5px;
		line-height: 1;
		font-size: 1.3rem;
	}
	.schedule-list .date{
		width: calc(100% + 20px);
		margin-left: -10px;
		line-height: 1;
	}
	.schedule-list .date.blankLine::before {
		display: block;
		content: '';
		height: calc(1.3rem + 5px);
	}
	.schedule-list .date .en{
		font-size: 15vw;
		letter-spacing: .2rem;
	}
	.schedule-list .date .en small{
		font-size: 7vw;
	}
	.schedule-list .date .day{
		font-size: 1.4rem;
	}

	.schedule-list .time{
		margin: 12px 0 4vw;
		font-size: 3vw;
	}
	.schedule-list .time span{
		font-size: 1.4rem;
		padding-right: 7px;
	}
	.schedule-list .time span:after{
		height: 1.1rem;
		margin-left: 7px;
	}
	
	
	/*modal*/
	.schedule-modal .schedule-list li{
		padding:  15px 20px;
	}
	.schedule-modal .schedule-list .date .en{
		font-size: 5.6rem;
		letter-spacing: .2rem;
	}
	.schedule-modal .schedule-list .date .en small{
		font-size: 2.8rem;
	}
	.schedule-modal .schedule-list .date .day{
		font-size: 1.3rem;
	}
	.schedule-modal .time span{
		display: none;
	}
	.modal-cont.schedule .schedule-box{
		padding: 20px 10px;
		height: calc(100svh - 25svh);
	}
	
	
	.schedule-list .btn-schedule a{
		position: relative;
		display: flex;
		justify-content: center;
		align-items: center;
		height: 42px;
		margin: 0 auto;
		padding-top: 2px;
		background:url(../img/common/arw_btn.svg) no-repeat right 10px center #F4EFDE;
		background-size: 4px auto;
		border-radius: 30px;
		font-size: 1.5rem;
		transition: .3s;
	}
	.schedule-list .btn-schedule a span {
		position: absolute;
		top: 50%;
		transform: translateY(-50%);
		left: 8px;
		width: 15px;
		height: 15px;
		font-size: 1rem;
		line-height: 15px;
		border-radius: 50%;
	}
	
	.schedule-list .btn-reserve{
		margin: 8px auto;
	}
	.schedule-list .btn-reserve a{
		background:url(../img/common/arw_btn_w.svg) no-repeat right 10px center #42C8CA;
		background-size: 4px auto;
		font-size: 1.5rem; 
	}
	.schedule-box h3{
		margin: 25px 0 0;
		padding: 7px 0;
		background: url(../img/common/ico_plus_circle.svg) no-repeat right center;
		background-size: 30px auto;
		border-bottom: 1px solid #42C8CA;
		font-size: 1.8rem;
		line-height: 1;
		letter-spacing: .05em;
		font-weight: normal;
		cursor: pointer;
	}
	.schedule-box h3 strong{
		display: inline-block;
		transform: translateY(2px);
		font-size: 2.8rem;
		font-weight: normal;
	}
	.takarazuka_ap{
		margin: 40px 0 60px;
		padding: 40px 0;
	}
	.takarazuka_ap h3{
		margin-bottom: 26px;
		font-size: 7.5vw;
		line-height: 1.2;
	}
	.takarazuka_ap h3 span{
		font-size: 4vw;
		padding-bottom: 1vw;
	}
	.takarazuka_ap .viewmore a{
		height: 64px;
		border-radius: 70px;
		font-size: 4vw;
	}
	
	
	/* timetable
	-----------------------------------------------------------------*/
	
	.timetable{
	  position: relative;
	  padding: 100px 0 0;
	  margin-top: -60px;
	  z-index: 1;
	}
	.timetable::after{
		content: "Open Campus Time Schedule.";
		position: absolute;
		right: 0px;
        rotate: -90deg;
        top: 1280px;
        z-index: -1;
        width: 1800px;
        font-size: 100px;
        text-align: right;
        min-width: 700px;
	}
	
	
	.timetable h2 .en{
		font-size: 24vw;
	}
	.timetable h2 .ja{
		font-size: 11vw;
	}
	.timetable h2 .ja.middle{
		font-size: 9vw;
	}
	.timetable h2 .ja small{
		display: inline;
		font-size: 4.5vw;
		letter-spacing: 0;
		font-family: "A1 Gothic R", "A1 Gothic M", "A1 Gothic L", "游ゴシック体", YuGothic, "Yu Gothic Medium", "ヒラギノ角ゴ Pro", "Hiragino Kaku Gothic Pro", "メイリオ", "Meiryo", "sans-serif";
	}
	
	.time-line h3{
	  font-size: 8vw;
	}
	.time-line h3 small{
	  font-size: 1.3rem;  
	}
	.time-line .time{
	  font-size: 7vw;
	}
	.time-line .slider-item{
		padding: 60px 0 0;
	}
	.time-line  .slider-item h3{
		font-size: 9vw;
	}
	.time-line .slider-item h3 small{
		font-size: 4.2vw;
		display: block;
		line-height: 2;
	}
	
	.time-line .txt{
	  font-size: 1.5rem;
	  line-height: 1.7;
	  text-align: justify;
	  margin: 10px 0 20px;
	}
	.time-line .pic img{
		border-radius: 0 0 60px 0;
	}
	
	.time-line > li:last-child h3 small{
		display: block;
	}
	.time-line .txt.notes{
		font-size: 1.5rem;
		margin: 30px 0 0;
	}
	
	
	/* lesson
	-----------------------------------------------------------------*/
	
	.lesson{
		position: relative;
		background: #fff;
		border-radius: 0 60px 0 0;
		margin: -60px 0 0;
		padding: 100px 0 15px;
		z-index: 1;
	}
	.lesson h2{
		margin-bottom: 4rem;
	}
	.lesson .txt{
		margin: 3rem 0;
	}
	.lesson .txt p{
		font-size: 1.5rem;
	}
	.lesson .txt h3{
		font-size: 6vw;
		padding: 0 0 8px;
		line-height: 1.8;
	}
	.lesson .pic img {
		width: 100%;
		height: 360px;
		object-fit: cover;
		object-position: 20% 0%;
	}
	.clm2{
		gap: 14px;
        flex-direction: column;
		padding: 0 20px;
        width: 100%;
	}
	.clm2 .pic{
		width: 100%;
	}
	.clm2 .pic img{
		width: 100%;
		height: 356px;
		object-fit: cover;
		object-position: 0 16%;
	}

	.clm2 .txt{
		width: 100%;
		margin-top: 1rem;
	}
	.lesson .clm2 .txt h3{
		font-size: 6vw;
		line-height: 1.8;
	}
	
	
	/* pickup
	-----------------------------------------------------------------*/
	.pickup{
		padding: 0 0 95px;	
	}
	.pickup h2{
		margin-bottom: 30px;
	}
	.pickup h2.sec-ttl{
		padding-left: 20px;
		margin-bottom: 40px;
	}
	.pickup .modal.qa{
		margin-bottom: 20px;
		padding: 35px 20px;
	}
	.pickup .modal.qa::before{
		position: absolute;
		content: "";
		width: 100%;
		height: 100%;
		background: #5FC8CA;
		border-radius: 180px 10px 180px 10px;
	}
	.pickup .modal.qa ._inner h3{
		font-size: 8vw;
	}
	.pickup .modal.qa ._inner h3 small{
		font-size: 5.6vw;
	}
	.pickup .modal.qa .btn{
		margin: 20px auto 0;
		height: 64px;
		border-radius: 100px;
		font-size: 1.7rem;
	}
	
	
	/* futurecourse
	-----------------------------------------------------------------*/
	
	.futurecourse{
		padding: 120px 0 160px;
	}
	
	
	/* access
	-----------------------------------------------------------------*/
	
	.access{
		padding: 120px 0 160px;
		margin-top: -60px;
	}
	.access h2{
		margin-bottom: 5rem;
	}
	.access h2 .en{
		font-size: 23vw;
	}
	.access h2 .ja{
		font-size: 11vw;
	}
	.access h2 .ja small{
		font-size: 4.5vw;
	}
	
	.access .traffic{
		margin-bottom: 6rem;
	}
	.access .traffic p{
		font-size: 6vw;
		margin-bottom: 3rem;
	}
	.access .traffic p span {
		line-height: .8;
	}
	.access .traffic p small{
		font-size: 4.5vw;
	}
	.access .traffic p small.line{
		font-size: 1.6rem;
		line-height: .2;
	}
	.access .traffic p .clr{
		font-size: 14vw;
		padding: 0 4px;
		vertical-align: sub;
	}
	
	.access .tab-nav{
		position: relative;
		padding-right: 5%;
		margin-bottom: 4rem;
	}
	.access .tab-nav::after{
		width: 5%;
	}
	.access .tab-nav li{
		width: 44%;
		display: block;
		font-size: 5.8vw;
		padding: 1.6rem 1.8rem 1.5rem;
	}
	.tab-nav li small{
		font-size: 1.4rem;
	}
	.access .tab-nav li.active{
		width: 56%;
		font-size: 8vw;
		padding: 2.8rem 1.8rem 1.5rem;
	}
	.access .tab-nav li.active small{
		font-size: 1.8rem;
	}
	
	.routebox{
		padding-bottom: 7rem;
	}
	.routebox ul{
		gap: 30px 10px;
	}
	.routebox ul li{
		width: calc(50% - 8px);
		font-size: 1.4rem;
		line-height: 1.4;
	}
	.routebox ul li img{
		margin: 0 0 1.6rem;
	}

	.access .btn-googlemap a{
		font-size: 1.7rem;
	}
	
	
	
	/* question
	-----------------------------------------------------------------*/
	.question{
		padding: 120px 0 95px;
	}
	.question h2{
		margin-bottom: 5rem;
	}
	.question h2 .en{
		font-size: 17vw;
	}
	.question h2 .ja{
		font-size: 8vw;
	}
	.question dl{
		margin: 0 0 1.6rem;
	}
	.question dt{
		font-size: 6vw;
		padding: 3rem 7rem 3rem 2.5rem;
		color: #fff;
		cursor: pointer;
		transition: .3s;
	}
	.question dt::after{
		right: 2.5rem;
		width: 42px;
		height: 42px;
		background: url(../img/common/arw_circle.svg) no-repeat center center;
	}
	.question dd{
		padding: 0 2.5rem 3rem;
		font-size: 1.5rem;
	}



/* bnr
-----------------------------------------------------------------*/

	.bnr{
		padding: 0 0 80px;
	}

	.bnr .totop a{
		background:url(../img/common/arw_btn_bl.svg) no-repeat right 20px center #F2F0EA;
		height: 90px;
		margin: 0 auto;
		background-size: 9px auto;
		border-radius: 70px;
		font-size: 1.7rem;
	}
	 	
}
