@import url('https://fonts.googleapis.com/css?family=Heebo:900');
body {
  font-family: 'Heebo', sans-serif;
  letter-spacing : .13rem;
  color : #777;
  background : #6AD9D9;
}
ul,li,p,h1,h2,h3,h4,dl,img,dd,dt{
	padding:0;
	margin:0;
	line-height:1.7em;
}
dl,dt,dd{
  line-height : 1;  
}
a{
	text-decoration:none;
	color:inherit;
}
.schedule{
	margin:50px auto;
}
.schedule p{
	font-size:150%;
	background:#84C91C;
	color:#fff;
	padding:2%;
}

.schedule p i{
	color:#fff;
	padding:0 2%;
}


.schedule table {
  border-collapse: collapse;
  border-spacing: 0;
  width:100%;
  margin:30px auto;
  border:1px solid 999;
  border-radius:2px;
}
.arrow{display:flex;
	justify-content:space-between;}
.arrow_box{
	position:relative;
	font-weight:900;
	font-size:140%;
	width:10em;
	height:32px;
	line-height:32px;
   background:#fff!important;
    padding:10px;
    text-align:center;
    color:#0099FF!important;
    border-radius:10px;
    -webkit-border-radius:10px;
    -moz-border-radius:10px;
	margin:30px 0 0;
}
.arrow_box:after{
    border: solid transparent;
    content:'';
    height:0;
    width:0;
    pointer-events:none;
    position:absolute;
    border-color: rgba(0, 153, 255, 0);
    border-top-width:10px;
    border-bottom-width:10px;
    border-left-width:10px;
    border-right-width:10px;
    margin-left: -10px;
    border-top-color:#fff;
    top:100%;
    left:50%;
}
.arrow_after{
	width:calc(100% - 14em);

}

.arrow_after p{
	background:transparent!important;
	padding:10px 0 0 10px;
	font-size:22px;
}

.schedule table th,.schedule table td{
  padding: 10px 0;
  text-align: center;
  font-size:140%;
  border:1px solid 999;
}
.schedule table th{
	border-right:1px solid #999;
}
.schedule table tr:nth-child(odd){
  background-color: #eee
}
.schedule table tr:nth-child(even){
	background:#fff;
}
.schedule table td:first-child{
	width:30%;
	letter-spacing:0.1em;
}
.schedule table td:nth-child(2){
	width:60%;
}

.schedule p span{
	margin:30px auto 50px
}

li{list-style:none;}
.container{
	max-width:1080px;
	margin:0 auto;
}
.title,.title_t2,.title_t3,.title_t4,.title_t5{
    position: relative;
    cursor: pointer;
    font-size:20px;
    font-weight: normal;
    padding: 3% 3% 3% 50px;
    transition: all .5s ease;
	border-radius:5px;
	color:#fff;
	margin:20px 0;
}
.t1,.title_t2,.title_t3,.title_t4,.title_t5{
	background:#13005A;
}
.title_t2,.title_t3,.title_t4,.title_t5{
	/* color: inherit; */
	text-decoration: none;
}
.title::before,
.title::after{
    position: absolute;
    content:'';
    width: 15px;
    height: 2px;
    background-color: #fff;
    
}
.title::before{
    top:48%;
    left: 15px;
    transform: rotate(0deg);
    
}
.title::after{    
    top:48%;
    left: 15px;
    transform: rotate(90deg);

}
.title.close::before{
  transform: rotate(45deg);
}

.title.close::after{
  transform: rotate(-45deg);
}

/*アコーディオンで現れるエリア*/
.box{
	display:none;}
.box li{
	line-height:1.7em;
	font-size:24px;
	background:#FFFEF6;
	margin:20px 0;
	padding:5px 0 5px 20px;
	border-radius:5px;
	color:inherit;
	align-items:baseline;
}
.box hr{
	width:90%;
	}

.box li img{
	width:34px;height:34px;padding-right:10px;
}
aside{
	margin:100px auto;
	overflow:hidden;
}
.t4{
	background:#FF6947;
	/**color:#333;**/
	display:flex;
	justify-content:space-between;
	flex-wrap:nowrap;
	align-items:center;
	font-size:24px;
	font-weight:800;
}
.t4 img{
	width:100px;height:auto;
}
.t4,.t5,.t6{
	font-weight:900;
	text-shadow:/**   0px -6px 0 #212121,  
                 0px -6px 0 #212121,
                 0px  6px 0 #212121,
                 0px  6px 0 #212121,
                -6px  0px 0 #212121,  
                 6px  0px 0 #212121,
                -6px  0px 0 #212121,
                 6px  0px 0 #212121,
                -6px -6px 0 #212121,  
                 6px -6px 0 #212121,
                -6px  6px 0 #212121,
                 6px  6px 0 #212121,
                -6px  18px 0 #212121,
                 0px  18px 0 #212121,
                 6px  18px 0 #212121,**/
                 0 19px 1px rgba(0,0,0,.1),
                 0 0 6px rgba(0,0,0,.1),
                 0 6px 3px rgba(0,0,0,.3),
                 0 12px 6px rgba(0,0,0,.2),
                 0 18px 18px rgba(0,0,0,.25),
                 0 24px 24px rgba(0,0,0,.2),
                 0 36px 36px rgba(0,0,0,.15);
}


.t5{
	background:url("../img/shinrosoudan.jpg") no-repeat center center/cover;
	margin:50px auto 0;
}

.t6{
	background:url("../img/benkyou.jpg") no-repeat center center/cover;
	margin:100px auto;
}
.box>.ask{
	display:flex;
	justify-content:space-between;
	flex-wrap:nowrap;
	width:100%;
}
.box>.ask li{
	width:30%;
	border-radius:5px;
	background:transparent;
	text-align:center;
}
.box>.ask li img,.box>.ask li div{
	width:100%;
}
.box>.ask li img{
	width:180px;height:180px;
}
.box>.ask li div p.a{
	color:#008f95;
	font-weight:900;}

.box>.ask li div p:nth-of-type(2){
	text-align:left;
}
/**
tr{
	display:flex;
	justify-content:space-between;
	width:90%;
	flex-wrap:nowrap;
}
th{width:33%;
	text-align:center;**/
th img{
	display:block;
	width:80px;height:80px;
	margin:0 auto;
}
td{width:30%;}
td span{
	display:block;
	text-align:center;
}
.box span{
	padding-right:10px;
	font-family: 'Dela Gothic One', cursive;
}
.box span.q{
	color:#e24e42;
}
.box span.a{
	color:#008f95;
}
main{
	margin:50px auto;
}
/*.flexcontainer{
	display:flex;
	flex-wrap: wrap;
    justify-content: space-between;
    max-width: 1080px;
    background-color: #d32ca1;
    overflow: auto;
    flex-direction: row;
	margin:10px auto;
	padding:10px 0;
}**/
.school {
    width: 90%;
	margin:0 auto 10px;
	padding:10px;
	background-color:#FFFEF6;
	}
.pickup{
	width:88%;
	position:relative;
	margin:10px auto 40px;
    background: #fcfdfe;
	border:double 15px #FF9000;
    box-shadow: 0 3px 6px rgba(0, 0, 0, 0.25);
    border-radius: 9px;
	z-index:0;
}
.pickup>img{
	position:absolute;
	left:-25px;
	top:-25px;
	width:120px;height:120px;
	z-index:999;
}
.nokeyword{
	text-align: center;
}

.schoolname {
	display: flex;
	align-items: center;
	color: #fff;
	width: 88%;
	margin: 10px auto;
	background:#1C82AD;
	border-radius: 5px;
	overflow: hidden;
  }
  
  .schoolname-image {
	flex: 0 0 auto;
	margin-right: 10px;
	margin-left: 10px;
	width: 16%;
  }
  
  .schoolname-image img {
	width: 90%;
	border-radius: 5px;
  }
  
  .schoolname-text {
	flex: 1 1 0;
	display: flex;
	flex-direction: column;
	justify-content: center;
  }
  
  .schoolname-text h4 {
	/* margin: 0; */
	margin-top: 10px;
	font-size: 24px;
	font-weight: bold;
  }
  
  .schoolname-text p {
	margin: 0;
	font-size: 18px;
	padding-left: 0;
  }

.schoolname .cls-1{
	fill:#fff;
}
.innerschool{
	width:90%;
	display:flex;
	flex-wrap:nowrap;
	justify-content:space-between;
}
.no-video {
    width: 60%;
    height: 0;
    padding-bottom: 33.75%; /* 16:9 アスペクト比から縦幅を短く調整 */
    position: relative;
    background-color: #ccc;
    text-align: center;
    margin-left: 20%;
}

.no-video-text {
    position: absolute;
    top: 50%;
    left: 0;
    width: 100%;
    transform: translateY(-50%);
    font-size: 1.2em;
    font-weight: bold;
    color: #fff;
}

.video-frame {
	width: 100%;
	height: 0;
	padding-bottom: 56.25%; /* 16:9 アスペクト比を維持 */
}
.youtube {
    cursor : pointer;
	margin:8px auto;
	padding:5px;
	text-align:center;
	width:60%!important;
}

div.youtube p {
	text-align: justify;
	margin-left: 30%;
}	

.rightside{
	width:40%;
}
iframe {
  aspect-ratio: 16 / 9;
  text-align:center;
 }

/* .youtube img {
	border-radius : 3px;
	align-self: flex-start;
	width:80%!important;
} */
.youtube img {
	border-radius: 3px;
	align-self: flex-start;
	width: 80%;
	height: 80%;
	max-height: 300px;
	object-fit: contain;
  }
  
.faculty{
	width:100%;
	display:grid;
	grid-template-columns:50px 50px 50px 50px 50px 50px;
	grid-template-rows: 50px 50px;
	gap:10px;
}
.faculty img{
	padding:10px 20px;
	width:40px;height:40px;
}

.school p{
	text-align:left;
	padding:3px 0 3px 0;
	font-size:12px;
	display: -webkit-box;
	overflow: hidden;
	-webkit-line-clamp: 2;
	-webkit-box-orient: vertical;
}
.theme{
	display:flex;
	flex-wrap:wrap;
	margin:10px auto;
	width:90%;
}
.theme p{
	padding:3px;
	color:#fff;
	background:#ec3472;
	border-radius:5px;
	margin:5px;
	font-size:16px;
}


h1 {
  margin : 0;
  text-indent:100%;
  white-space:nowrap;
  overflow:hidden;
 background:url("../img/20250523_topA3-2.svg") no-repeat center center/cover;
  width:100%;
  padding-top:71.9%;
  object-fit:cover;
}
h2 {
  text-indent:100%;
  white-space: nowrap;
  overflow: hidden;
  /* background:url(https://placehold.jp/1200x450.png) no-repeat center center/cover;
  width:100%;
  padding-top:37.5%;
  object-fit:cover; */
}

.eventapply{
	margin:10px auto 50px;
	text-align:center;
}
button{
	background:#fa4141;
	font-weight:+900;
	font-size:32px;
	padding:15px;
	border-radius:10px;
	color:#fff;
	border:none;
}

/* ここから川崎追加　20230302 
学校名検索で該当のものがなかった場合の処理のため追加*/
.text-center {
	text-align: center;
}
.nokeyword {
	margin-top: 20px;
}
  
.button-container {
	display: flex;
	justify-content: center;
}

.small-button {
	font-size: 20px;
	padding: 4px 8px;
}
/* ここまで川崎追加　20230302 */

.access{
  width:92%;
 margin:30px auto!important;
  text-align:center;
}

.map{
	background:#fff;
	color:#03C988;
	padding:10px 0;
	margin:20px auto;
	border-radius:5px;
	font-size:24px;
	max-width:800px;
}
.map i{
	color:#03C988;
	padding-right:10px;
	font-weight:700;
}

footer{text-align:center;
color:#333;}

.scroll-top {
  position: fixed;
  right: 25%;
  bottom: 5%;
  z-index: 100;
  background-color: #1f640a;
  width: 50px;
  height: 50px;
  border-radius: 50%;
  color: #fff;
  line-height: 50px;
  text-align: center;
}
.scroll-top:hover {
  cursor: pointer;
  opacity: 0.7;
}
h3{
  position: relative;
  display: inline-block;
  padding: 1rem 2rem 1rem 4rem;
  color: #fff;
  border-radius: 100vh 0 0 100vh;
  background: #fa4141;
  text-align:left;
}
h3:before {
  position: absolute;
  top: calc(50% - 7px);
  left: 10px;
  width: 14px;
  height: 14px;
  content: '';
  border-radius: 50%;
  background: #fff;
}
.sp{display:none;}

.search_container{
  box-sizing: border-box;
  border-radius:20px;
  margin:30px 0;
}
.search_container input[type="text"]{
  background: #ccddf5;
  border: none;
  height: 45px;
font-size:20px;
}
.search_container input[type="text"]:focus {
  outline: 0;
}
.search_container input[type="submit"]{
  cursor: pointer;
  font-family: FontAwesome;
  border: none;
  background: #3879D9;
  color: #fff;
  outline : none;
  width: 6.0em;
  height: 49px;
}
.schedule_br{display:none;}
@media (max-width: 768px) {
.innerschool {display:block;
	width:98%;}
/**	.school {width:96%;}**/
.youtube,.rightside{
	width:100%!important;
	}
h4{
	justify-content:flex-start;
	align-items:flex-start;
	font-size:24px;
	}
.schoolname h4 img{
	width:24%}
.faculty{
	margin:0 auto 20px;
	width:100%;
	grid-template-columns:42px 42px 42px 42px 42px 42px;
	grid-template-rows: 42px 42px 42px;
	gap:10px;
	}
.faculty img{
	width:38px;height:38px;
	}
.t4{
	display:block;
	}
.t4 img:first-of-type{
	display:none;
	width:20%;
	}
.sp{display:block;}
.t4 img:nth-of-type(2){
	display:block;text-align:right;width:32%;margin-left:auto;	
	}
.t5{
	margin:30px auto 0;}
.t6{
	margin:30px auto;
	}
.box>.ask{
	display:block;
	}
.box>.ask li{
	width:100%;
	display:flex;
	justify-content:space-between;
	flex-wrap:nowrap;
	align-items:center;
	}
.box>.ask li img{
	width:30%
	}
	
.box>.ask li div{
	width:68%;
	}
.box>.ask li div p{
	text-align:left;
	font-size:14px;
	padding:5px;
	}
.box>.ask li div p.a{
	font-size:20px!important;
	}
.pickup{
	margin:5px auto 40px;
    
	}
	
.pickup>img{
	position:absolute;
	left:-22px;
	top:-22px;
	width:70px;height:70px;
	z-index:999;
	}
.theme{font-size:12px;}
	
.schedule table th,.schedule table td{
	font-size:100%;
  }
	  iframe{width:100%;}	
.box li{
	line-height:1.6em;
	font-size:18px;
}
.box li img{
	width:30px;height:30px;padding-right:10px;
}
	
button{
	font-weight:+900;
	font-size:26px;
	padding:12px;
}
h3{ padding: 1rem 1rem 1rem 3rem;}
.schedule_br{display:block;}
.arrow{display:block;}
.arrow_after{
	width:100%;
	}
.arrow_after p{
	background:transparent!important;
	width:98%;
	margin:0 auto;
	font-size:18px;
	}

}