/*
Theme Name: Passlabo_school
Description: パスラボスクール
*/

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

body{
	background-color: black;
}
#main {
	background: fixed;
	background-image: url(../img/top_img.jpg);
	background-size: cover;
	background-position: center;
	font-family: 'Noto Sans JP';
}
ul,li{
	margin: 0;
	padding: 0;
}
.top_logo{
  overflow: hidden;
}
.menu{
	width: 960px;
	margin: 50px auto;
}
.menu ul{
	flex-wrap: wrap; /* 画面幅に合わせてカラム落ちさせる */
	display: flex;
	justify-content: space-between;
	align-items:flex-start;
}
.menu li{
	width: 23%;  /* お好みの幅で指定 */
    padding:16px;  /* お好みの幅で指定 */
	margin: 1% 0;
    /* paddingと合わせてbox-sizingも指定 */
    -moz-box-sizing: border-box;
    -webkit-box-sizing: border-box;
    -o-box-sizing: border-box;
    -ms-box-sizing: border-box
}
.menu ul:after {
    content: "";
    display: block;
    width: 23%;  /* .boxに指定したwidthと同じ幅を指定する */
    height: 0;
}
.menu li:hover{
    background-color: rgba(96 25 134);
}
.post-categories li ,
.post-categories a,
.con_home li ,
.con_home a{
	 list-style: none;
	text-decoration: none;
}
.eachTextAnime span{
	color: white;
	opacity: 0;
}
.eachTextAnime.appeartext span{
	animation:text_anime_on 1s ease-out forwards;
}
.box_menu{
	display: flex;
	flex-direction: column;
	justify-content: center;
	align-items: center;
	width: 200px;
	height: 200px;
	text-align: center;
	border: 2px solid #f08300;
}
.box_menu a,.nav_list li a{
	text-decoration: none;
	display: block;
}
.box_menu_txt01{
	color: white;
	font-size: 2rem;
	font-family: Anton;
}
.box_menu_txt02{
	color: #f08300;
	font-size: 1rem;
}
.menu2 a{
	text-decoration: none;
}
.box_menu_txt03{
	margin-top: 80px;
	text-align: center;
	display: block;
	color: #F08300;
	background-color: #601986;
	padding: 18px;
	margin-bottom: 28px;
}
.box_menu_txt03 span{
	margin: 0 10px;
	font-size: 1.2em;
}
.box_menu_txt03:hover{
	background-color: #8622BB;
}
.sns{
	margin: 0 auto;
	align-items: center;
}
.sns li{
	list-style-type: none;
	margin: 60px 1%;
}
.sns li:hover{
	opacity: 70%;
}
.sns_flex{
	flex-wrap: wrap;
	display: flex;
	justify-content:center;
}

h3 {
	color: #FFF;
  position: relative;
  margin: 1rem -10px;
  padding: 1rem 3rem;
  background: #601986;
}

.index_post h3:before,
.index_post h3:after {
  position: absolute;
  content: '';
}

.index_post h3:before {
  bottom: -10px;
  left: 0;
  width: 0;
  height: 0;
  border-top: 10px solid #853FAB;
  border-left: 10px solid transparent;
}
.index_post{
	margin:4% 22%;
}
.index_post ul{
	margin: 0 10px;
}
.index_post li{
	list-style-type:none;
	margin: 16px 0;
}
.index_post_contents a{
	display:block;
	font-size: 1.25rem;
	text-decoration: none;
	color: #fff;
	padding: 9px 0;
	border-bottom: #fff dotted 3px;
}
.post_btn{
	text-align: center;
}
.index_post a{
	display:block;
	font-size: 1.25rem;
	text-decoration: none;
	color: #fff;
}
.index_post a:hover{
	opacity: 70%;
}
/* ワイヴァンズアイコン */
.wyverns-hp_jump {
position: fixed;
    top: 10px;
    left: 20px;
    display: flex;
    height: 50px;
    width: 50px;
    justify-content: center;
    align-items: center;
    z-index: 100;
}
.wyverns-hp_jump a{
	height: 50px;
    width: 50px;
}
.wyverns-hp_jump img{
	max-height: 50px;
}
.wyverns-hp_jump :hover{
	opacity: 80%;
}
/* ここから下がハンバーガーメニューに関するCSS */
  
/* チェックボックスを非表示にする */
.drawer_hidden {
  display: none;
}

/* ハンバーガーアイコンの設置スペース */
.drawer_open {
    position: fixed;
    top: 10px;
    right: 10px;
    display: flex;
    height: 60px;
    width: 60px;
    justify-content: center;
    align-items: center;
    z-index: 100;
}

/* ハンバーガーメニューのアイコン */
.drawer_open span,
.drawer_open span:before,
.drawer_open span:after {
    content: '';
    display: block;
    height: 3px;
    width: 25px;
    border-radius: 3px;
    background-color: #ffffff;
    position: absolute;
}

/* 三本線の一番上の棒の位置調整 */
.drawer_open span:before {
  bottom: 8px;
}

/* 三本線の一番下の棒の位置調整 */
.drawer_open span:after {
  top: 8px;
}

/* アイコンがクリックされたら真ん中の線を透明にする */
#drawer_input:checked ~ .drawer_open span {
  background: rgba(255, 255, 255, 0);
}

/* アイコンがクリックされたらアイコンが×印になように上下の線を回転 */
#drawer_input:checked ~ .drawer_open span::before {
  bottom: 0;
  transform: rotate(45deg);
}

#drawer_input:checked ~ .drawer_open span::after {
  top: 0;
  transform: rotate(-45deg);
}
  
/* メニューのデザイン*/
.nav_content {
	margin-top:10px;
  width: 100%;
  height: 100%;
  position: fixed;
  top: 0%;
  left: 100%; /* メニューを画面の外に飛ばす */
  z-index: 99;
  background: rgb(0, 0, 0, 0.7);
  transition: .5s;
  text-align: center;
  padding-top: 20px;
	overflow: scroll;
}

/* メニュー黒ポチを消す */
.nav_list {
  list-style: none;
	display: flex;
    flex-wrap: wrap;
    justify-content: center;
	max-width: 960px;
	margin: 0 auto;
}

.nav_item a {
  color: #fff;
  text-decoration: none;
}
.nav_list li{
	margin: 30px 0;
	width: 50%;
	position: relative;
	overflow: hidden;
	padding: 2%;
}
.nav_list li::before{
	position: absolute;
	top: 0;
	right: 0;
	bottom: 0;
	left: 0;
	z-index: -1;
	background: rgb(40,174,201);
	background: linear-gradient(45deg, rgb(81 6 149) 0%,rgba(126,93,173,1) 100%);
	transition: transform .3s;
	content: "";
	transform-origin: right top;
	transform: skewX(45deg) scale(0, 1);
}
.nav_list li::after{
	position: absolute;
	top: 0;
	right: 0;
	bottom: 0;
	left: 0;
	z-index: -2;
	background: #000;
	content: "";
}
.nav_list li:hover:before{
	transform-origin: left bottom;
	transform: skewX(30deg) scale(2, 2);
	content: "";
}

/* アイコンがクリックされたらメニューを表示 */
#drawer_input:checked ~ .nav_content {
  left: 0;/* メニューを画面に入れる */
  
}

footer{
    position: sticky;
	top: 100vh;
	width: 100%;
	text-align: center;
	color: white;
	font-size: small;
	padding: 5%;
}
/*下層ページ*/

/*タイプライター*/
.textSplitLoad {
	display: none;
}
.split {
	visibility: hidden;
}

.contents{
	background-color: black;
	color: white;
	font-family: 'Noto Sans JP';
	height: 100%;
}
header{
	text-align: center;
	margin: 0 0 20px;
	padding: 10px 0;
	border-bottom: 1px solid #f08300;
}
.contents h1,.contents .title{
	font-family: Anton;
	font-weight: normal;
	font-size: 2rem;
    line-height: 2rem;
}
.contents .title{
	font-size: 6rem;
	line-height: 6rem;
}
.contents .box_title_txt{
	padding: 40px;
}
.contents h1 a{
	color: white;
	text-decoration: none;
}
.contents h1 a:hover{
	color: #601986;
}
.contents h2{
	font-size: 0.5rem;
}
.con_title{
	display: flex;
	max-height: 300px;
	align-items: center;
}
.box_title_img{
	background-image: url("../img/title/image8.jpg");
	background-size: cover;
	background-position: center;
	width: 30%;
	height: 300px;
	border-radius: 0 10px 10px 0;
}
#bgimg_point{
	background-image: url("../img/title/image17.jpg");
}
#bgimg_policy{
	background-image: url("../img/title/image11.jpg");
}
#bgimg_staff{
	background-image: url("../img/title/image4.jpg");
}
#bgimg_system{
	background-image: url("../img/title/image16.jpg");
}
#bgimg_join{
	background-image: url("../img/title/image12.jpg");
}
#bgimg_achievement{
	background-image: url("../img/title/image9.jpg");
}
#bgimg_calendar{
	background-image: url("../img/title/image7.jpg");
}
#bgimg_category{
	background-image: url("../img/title/image10.jpg");
	background-position:top;
}
.sub_title{
	color: #f08300;
}
.con_vision,.con_policy,.con_point,.con_join,.con_calendar{
	max-width: 960px;
	margin: 150px auto;
	text-align: center;
	font-size: 	1.5rem;
}
.con_staff,.con_system,.con_category,.con_school{
	max-width: 960px;
	margin: 150px auto;
	font-size: 	1.5rem;
}
.con_achievement{
	max-width: 960px;
	margin: 150px auto;
	font-size: 	1.5rem;
}
.con_point_txt p{
	border-bottom:1px dashed #FCEE21;
	margin: 5%;
    padding: 2% 0;
}
.con_policy_txtbox{
	margin-bottom: 100px;
}
.con_policy_txt01{
	margin-bottom: 60px;
}
.con_policy_txt01 span,.con_join_txt01 span{
	margin-right: 25px;
}
.txt_yellow{
	color: #FCEE21;
}
.con_policy_txt02{
	font-weight:100;
	font-size: 0.855em;
	max-width: 980px;
	line-height: 4em;
}
.flex{
	display: flex;
}
.con_staff_box{
	margin-bottom:52px;
}
.con_staff_img img{
	max-width: 228px;
}
.con_staff_img{
		margin-right: 20px;
}
.con_staff_txt01,.con_staff_txt03{
	font-size: 1rem;
}
.con_staff_txt02{
	color: #F08300;
	font-size: 1.3rem;
	margin-bottom: 10px!important;
}
.con_system_img01 img{
	margin: 0 auto 88px;
}
.con_system_box{
	align-items: center;
	margin-bottom: 50px;
}
.con_system_icon{
	align-items: center;
	width: 110px;
	height: 110px;
	max-height: 5em;
	max-width: 5em;
	font-size: 0.85em;
	padding-top: 1.72em;
	text-align: center;
	border: 2px solid #FCEE21;
	border-radius: 50%;
	-moz-border-radius: 50%;
	-webkit-border-radius: 50%;
	margin-right: 4%;
}
.con_system_txt01{
	width: 810px;
	font-size: 0.92em;
}
.con_system_txt02{
	margin: 130px 0 120px;
	max-width:810px;
}
.con_system_img02 li{
	list-style:  none;
	margin-right: 20px;
}
.con_join a{
	color: inherit;
	text-decoration: none;
}
.con_join_txtbox{
	margin-bottom: 80px;
}
.con_join_txt01{
	margin-bottom: 32px;
	text-align: center;
}
.con_join_txt02{
	text-align: center;
}
.con_join_txt02,.con_join_txt04,.con_achievement_txt02,.con_achievement_txt04{
	font-weight:100;
	line-height: 57px;
	font-size: 0.855em;
	max-width: 980px;
	margin-bottom: 55px;
}
.con_join_buttonbox{
	margin-bottom: 55px;
}
.con_join_button{
	width:340px;
	height: 75px;
	margin: 0 auto 20px;
	border: 4px solid #601986;
}
.con_join_button:hover{
	background-color: #1B1B1B;
}
.con_join_button a{
	display: block;
	padding-top: 1.1em;
	font-size: 0.7em;
}
.con_join_addressbox{
	text-align: left;
	border: 2px solid #fff;
	padding: 25px;
}
.con_join_address01{
	font-weight: normal;
	font-size: 0.7em;
	margin-bottom: 28px;
}
.con_join_address02{
	font-weight:100;
	font-size: 0.855em;
	max-width: 980px;
	margin-bottom: 28px;
}
.con_join_address03{
	font-weight:100;
	font-size: 0.7em;
	max-width: 980px;
}
.con_join_txt02_linebox{
	border: 2px solid #fff;
	padding: 5px 10px;
}
.con_join_freetry_txtbox{
	text-align: left;
}
.con_join_txt03{
	display: block;
	color: #F08300;
	background-color: #601986;
	padding: 10px;
	margin-bottom: 28px;
}
.con_join_txt04,.con_achievement_txt04,.con_achievement_txt02{
	padding: 0 1em;
}
.con_achievement_txt01{
	font-family: Anton;
	font-weight: normal;
	font-size: 1.55em;
}
.con_achievement_txt02 li{
	list-style-position: inside;
	line-height: 1.5rem;
}
.con_achievement_txt04 p{
	line-height: 1.5rem;
}
.con_achievement_img{
	margin-bottom: 100px;
}
.con_achievement_txt03{
	display: block;
	color: #000000;
	background-color: #FFFFFF;
	padding: 10px;
	margin-bottom: 28px;
}
.con_category_table,.con_school_table{
	margin-top: 80px;
	display: block;
	color: #F08300;
	background-color: #601986;
	padding: 10px;
	margin-bottom: 28px;
}
.con_school_table2{
	margin-top: 80px;
	display: block;
	background-color: #601986;
	padding: 10px;
	margin-bottom: 28px;
}
.con_category_box table,.con_category_txt01,
.con_school_box table,.con_school_txt01{
	padding: 1em;
}
.con_category_box table,.con_school_box table{
	line-height: 40px;
}
table span,
.con_category_txt01,
.con_school_txt01{
	font-weight: lighter;
	font-size: 1rem;
}
.con_category_box table,
.con_school_box table{
	width: 100%;
}
.con_category_box tbody,
.con_school_box tbody{
	width: 100%;
}
.txt_red{
	color: #CB1818;
}
.con_category_box th,.con_school_box th{
	width: 13vw;
	font-weight: normal;
	vertical-align: text-top;
	text-align: left;
	padding: 10px 4px 10px 7px;
	background-color: #6B3787;
	font-size: 1rem;
}
.con_category_box td,.con_school_box td{
	padding:10px 20px;
	font-size: 1rem;
	background-color: #2E2E2E;
}
.bgc_purple td{
	background-color: #533787;
	text-align: center;
}
.con_school_box .bgc_black{
	background-color: black;
}
.con_school_box2 table{
	margin: 5% auto 0 ;
}
.con_school_box2 th{
	font-weight: normal;
	vertical-align: text-top;
	background-color: #6B3787;
}
.con_school_box2 td{
	font-size: 1rem;
	padding: 30px 22px;
	text-align: center;
	color: black;
	background-color: #EDEDED;
}
.con_school_txt01 a{
	text-decoration: none;
	color: #F08300;
}
.con_school_txt01 a:hover{
	opacity: 70%;
}
.home_left{
	width: 70%;
}
.con_home{
	margin: 0 4%;
}
.con_news{
	display: flex;
	justify-content: space-between;
	margin-bottom: 60px;
}
.con_news .article {
	border-bottom: 2px solid #fff;
	padding:  0 0.8em 20px;
	margin: 18px 0;
	margin-right: 4%;
}
.home_right{
	width:23%;
	margin: 18px 0;
}
.home_right a{
	color: #fff;
}
.cat_name{
	font-size: 1.5em;
  position: relative;
  padding: 0.5rem 1rem;
   border: 3px solid #d8d8d8;
  border-radius: 10px;
  background: #000;
}
.cat_name:before {
  position: absolute;
  bottom: -15px;
  left: 1em;
  width: 0;
  height: 0;
  content: '';
  border-width: 14px 12px 0 12px;
  border-style: solid;
  border-color: #d8d8d8 transparent transparent transparent;
}
.cat_name:after {
position: absolute;
  bottom: -10px;
  left: 1em;
  width: 0;
  height: 0;
  content: '';
  border-width: 14px 12px 0 12px;
  border-style: solid;
  border-color: #000 transparent transparent transparent;
}
.con_news h5{
	display: block;
	font-size: 1.63rem;
	line-height: 1.82rem;
	margin-block-start: 12px;
    margin-block-end: 7px;
	margin-bottom: 16px;
}
.con_news h5 a,
.con_news h5 a:visited,
.con_news h5 a:link{
	text-decoration: none;
	color: #f08300;
}
.con_news h5 a:hover{
	opacity: 70%;
}
.right_cat{
	display: flex;
	flex-wrap: wrap;
	padding: 10px 2%;
}
.right_cat li{
	margin-right: 15px;
	margin-top: 6px;
}
.date{
	margin-top: 0.5em;
}
.article{
	display: flex;
	align-items: center;
	align-content: space-between;
}
.at_img{
	width: 15%;
	vertical-align: middle;
}
.at_img img{
  width: 15vh;
  height: 15vh;
  object-fit: cover; /* この一行を追加するだけ！ */
}
.at_contents{
	width: 85%;
	padding-left: 20px;
}
.category a,
.category a:link,
.category a:visited{
	color: #fff;
	border-radius: 7px;
}
.category a:hover,
.right_cat a:hover{
	opacity: 70%;
}
.post-categories{
	display: flex;
	align-items: flex-start;
	flex-direction: row;
}
.post-categories li{
	margin-right: 15px;
  position: relative;
  display: inline-block;
  padding: 0.5rem 1rem 0.5rem 2rem;
  color: #fff;
  border-radius: 100vh 0 0 100vh;
	background-color: #551A8B;
}

.post-categories li:before {
  position: absolute;
  top: calc(50% - 5px);
  left: 10px;
  width: 10px;
  height: 10px;
  content: '';
  border-radius: 50%;
  background: #000;
}
.tag{margin-top: 16px;}
.tag a,
.tag a:link,
.tag a:visited{
	text-decoration: none;
	margin-top: 16px;
	margin-right: 15px;
	color: #fff;
}
.tag a:hover{
	opacity: 70%;
}
.article_box{
	margin-bottom: 30px;
}
.pager{
	margin: 0 4%;
	display: flex;
	justify-content: center;
}

.next_btn1 a,
.next_btn1 a:visited,
.next_btn2 a,
.next_btn2 a:visited{
	font-size: 1.3rem;
	color: #fff;
	padding: 0.43em;
	text-decoration: none;
	background-color: #551A8B;
	height: 100%;
	border-radius: 5px;
	margin-right: 20px;
}
.next_btn1 a:hover,
.next_btn2 a:hover{
	opacity: 70%;
}
.randombg{
	width: 100%;
	height: 500px;
	background-position: center center;
	background-repeat: no-repeat;
	background-size: cover;
	background-attachment: fixed;
}
.randombg .w_text{
	display: inline-block;
	padding: 5px 10px;
	background-color: rgba(255,255,255,0.7);
}
@keyframes text_anime_on {
  0% {opacity:0;}
  100% {opacity:1;}
}
figure {
  display: flex;
  align-items: center;
  justify-content: center;
  height: auto;
  width: 100vw;
}

svg {
  padding: 5vw;
  width: 90vw;
}

svg > * {
  fill: #fff;
  stroke: #fff;
  stroke-width: 0.85px;
}

@-moz-keyframes tip {
  0%,
  100% {
    opacity: 0;
  }
  10%,
  80% {
    opacity: 1;
  }
}
@-webkit-keyframes tip {
  0%,
  100% {
    opacity: 0;
  }
  10%,
  80% {
    opacity: 1;
  }
}
@keyframes tip {
  0%,
  100% {
    opacity: 0;
  }
  10%,
  80% {
    opacity: 1;
  }
}

@media only screen and (max-width:960px) {
	#main {}
	.menu{
		display: none;
	}
	.box_menu_txt03{
	font-size: 0.9rem;
	padding: 10px;
	margin-bottom: 28px;
	}
	.box_menu_txt03 span{
	font-size: 0.8em;
	}
	.top_logo{
		padding-top: 30%;
	}
	.contents .box_title_txt{
		padding: 12px;
	}
	.contents .title{
		font-size: 4rem;
	}
	.box_title_img{
		width: 40%;
	}
	body{
		height: 100%;
	}	.con_vision,.con_policy,.con_point,.con_staff,.con_system,.con_join,.con_achievement,.con_category,.con_calendar,.con_school{
		font-size: 1rem;
		padding: 0 3.2%;
	}
	.index_post ul{
	padding: 0.7rem 0;
}
	.con_point_txt span{
		line-height: 52px;
	}
	.con_staff .flex{
		flex-direction: column;
	}
	.con_staff p{
		margin: 0;
	}
	.con_staff_img{
		margin-bottom: 13px;
	}
	.con_system_icon{
		max-height: 5em;
		max-width: 5em;
		font-size: 0.68em;
		padding-top: 1.5em;
	}
	.con_system_txt01{
		width: 80%;
	}
	.con_system_txt02{
		width: 88%;
		margin: 0 auto 50px;
	}
	.con_system_img01 img{
		max-width: 100%;
	}
	.con_system_img02 ul{
		flex-direction: column;
		align-items: center;
		margin: 0 auto;
	}
	.con_system_img02 li{
		margin-bottom: 20px;
	}
	.con_join_button a{
		font-size: 1em;
	}
	.con_join_txt02_linebox{
		font-size: 0.95em;
		padding: 3px 7px;
	}
	.con_calendar{
		margin-right: auto;
		margin-left: auto;
	}
	.con_calendar iframe {
		display: inline-block;
		width: 100%;
		height: 500px;
	}
	.con_category_box th,
	.con_school_box th,
	.con_school_box2 th{
	width: auto;
	}
	.con_category_box td,
	.con_school_box td{
	padding: 10px 10px;
	}
	.con_school_box2 td{
		font-size: 0.98rem;
		padding: 7px
	}
	.index_post{
	margin:4% 10%;
	}
	.index_post li{
	font-size:1rem; 
	}
	.con_news{
	flex-direction: column;
	}
	.home_left,.home_right{
		width: 100%;
	}
	.home_right{
		margin-top: 60px;
	}
}
@media only screen and (max-width:600px) {
	.con_category_box table,.con_category_txt01,
	.con_school_box table,.con_school_txt01{
		padding: 0;
	}
	.con_policy_txt02{
		line-height: 2em;
	}
	.contents .title{
		font-size: 3rem;
	}
	.con_category_box table,
	.con_school_box table{
		line-height: 1.5rem;
	}
	.con_staff_box{
		text-align: left;
	}
	.con_staff_img{
		margin: 0 auto;
	}
	.con_join{
		text-align: left;
	}
	.con_join_button{
		text-align: center;
	}
	.con_staff_txtbox{
		margin: 20px;
	}
	.con_policy_txtbox,.con_vision{
		text-align: left;
	}
	.con_point_txt p{
		margin: 0;
		padding: 5% 0;
	}
	.index_post{
	margin:4% 5%;
	}	
	.index_post li{
		font-size:1rem;
	}
	.post-categories a{
	font-size: 0.8rem;
}
	.randombg{
	height: 200px;
	background-size: cover;
	background-attachment: inherit;
}
}
@media screen and (min-width: 768px){
.br-sp {display: none; }
}@media screen and (max-width: 768px){
.br-pc {display: none; }
}