@charset "utf-8";

html {
	overflow-y: scroll;
	overflow-x: hidden;
}

body {
	visibility: visible;
}

ul {
	list-style: none
}

img, iframe {
	vertical-align: top;
	max-width: 100%;
}

.font-acum {
  font-family: acumin-pro-extra-condensed, sans-serif;
  font-weight: 700;
  font-size: 36px
}

/*------------------------------------------------------------------------*/

@media screen and (min-width: 768px) {
	.sp {
		display: none!important;
	}
	a[href^="tel:"] {
		pointer-events: none;
	}
}


/*------------------------------------------------------------------------*/

@media screen and (max-width: 760px) {
	.pc {
		display: none!important;
	}
}


/* ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
	■bfc-graduate
━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ */


#bfc-graduate {
	font-size: clamp(14px, 1.5vw, 16px);
	letter-spacing: 0;
	margin-bottom: clamp(60px, 7.0vw, 80px);
	counter-reset: number;
}

#bfc-graduate .number {
	position: relative;
	text-align: center;
}

#bfc-graduate .number:after {
	position: absolute;
	top: 0;
	/*bottom: 0;
	margin: auto 0;*/
	font-size: clamp(150px, 18.0vw, 210px);
	font-family: acumin-pro-extra-condensed, sans-serif;
	font-weight: 700;
	letter-spacing: 0;
	line-height: 1;
	color: #ffcc00;
	counter-increment: number;
	content: counter(number, decimal-leading-zero);
	z-index: -1;
}
#bfc-graduate section:nth-of-type(odd) .number:after {
	right: 0;
}
#bfc-graduate section:nth-of-type(even) .number:after {
	left: 0;
}


#bfc-graduate .title {
	margin: 0;
	margin-bottom: clamp(30px, 4.5vw, 60px);
	padding: 0;
	font-size: clamp(18px, 2.4vw, 30px);
	font-family: "游ゴシック体", YuGothic, "游ゴシック Medium", "Yu Gothic Medium", "游ゴシック", "Yu Gothic", "メイリオ", sans-serif;
	line-height: 1.5;
}

#bfc-graduate .description {
	line-height: 2;
	margin-bottom: clamp(60px, 7.0vw, 80px);
}

/*------------------------------------------------------------------------*/

@media screen and (max-width: 760px) {

	#bfc-graduate .description {
		line-height: 1.5;
	}
	#bfc-graduate .sp-left {
		text-align: left;
	}

}

/* ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
	■kv
━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ */

#bfc-graduate #kv {
	margin-top: -40px;
	position: relative;
	border-radius: 30px;
	overflow: hidden;
	background: #000;
}
#bfc-graduate #kv img {
	opacity: 0.6;
}
#bfc-graduate #kv figcaption {
	width: 100%;
	height: 100%;
	position: absolute;
	left: 0;
	top: 0;
	display: flex;
	align-items: center;
	justify-content: center;
	font-size: clamp(21px, 3.45vw, 48px);
	font-weight: bold;
	font-family: "游ゴシック体", YuGothic, "游ゴシック Medium", "Yu Gothic Medium", "游ゴシック", "Yu Gothic", "メイリオ", sans-serif;
	color: #fff;
}

/*------------------------------------------------------------------------*/

@media screen and (max-width: 760px) {

	#bfc-graduate #kv {
		margin: -30px -24px 0 -24px;
		border-radius: 0;
	}

}



/* ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
	■レイアウト
━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ */


#bfc-graduate section {
	padding: clamp(30px, 5.5vw, 80px) 0;
	margin: 0;
}

#bfc-graduate section p,
#bfc-graduate section li,
#bfc-graduate section dt {
	line-height: 1.5;
}

#bfc-graduate section p + p {
	margin-top: 16px;
}
#bfc-graduate section ul,
#bfc-graduate section ol {
	margin: 0;
	padding: 0;
}

#bfc-graduate .inner {
	max-width: 1040px;
	margin: 0 auto;
	position: relative;
	z-index: 1;
}

#bfc-graduate * + .inner {
	padding-top: clamp(30px, 5.5vw, 80px);
}

#bfc-graduate .ratio16_9 {
	width: 100%;
	aspect-ratio: 16 / 9;
	object-fit: cover;
	object-position: center center;
}

#bfc-graduate .ratio1_1 {
	width: 100%;
	aspect-ratio: 1 / 1;
	object-fit: cover;
	object-position: center center;
}

/*------------------------------------------------------------------------*/

@media screen and (max-width: 760px) {

	#bfc-graduate .inner {
		margin: 0 24px;
	}
}

/*-------------------------------------------------------------------------
	links
-------------------------------------------------------------------------*/

#bfc-graduate .links {
	padding: clamp(20px, 4.0vw, 60px) 0;
	background: #eee;
}




/*-------------------------------------------------------------------------
	slide
-------------------------------------------------------------------------*/

#bfc-graduate .archives {
	overflow: hidden;
	position: relative;
}

#bfc-graduate .archives ul {
	display: flex;
	justify-content: center;
	margin: 0 -20px;
}

#bfc-graduate .archives li {
	flex: none;
	width: calc(360px - 40px)!important;
	margin: 0 20px;
}


#bfc-graduate .archives li > a {
	height: 100%;
	display: flex;
	position: relative;
}
#bfc-graduate .archives li.new a:before {
	content: "NEW";
	width: 40px;
	height: 20px;
	position: absolute;
	top: 10px;
	left: 0;
	background: #ffcc00;
	font-family: acumin-pro-extra-condensed, sans-serif;
	font-weight: 700;
	font-size: 16px;
	letter-spacing: .05em;
	color: #000;
	display: flex;
	align-items: center;
	justify-content: center;
	z-index: 1;
}

#bfc-graduate .archives dl {
	display: flex;
	flex-direction: column;
}

#bfc-graduate .archives dt {
	overflow: hidden;
	position: relative;
}


#bfc-graduate .archives li dt img {
	width: 100%;
	/*aspect-ratio: 16 / 9;*/
	object-fit: cover;
	object-position: center center;
	transition: all 1s ease;
}
#bfc-graduate .archives li > a:hover dt img {
	transform: scale(1.05);
}

#bfc-graduate .archives.youtube li dt:after {
	content: "";
	width: 48px;
	height: 34px;
	display: block;
	position: absolute;
	top: 0;
	left: 0;
	right: 0;
	bottom: 0;
	margin: auto;
	background: url(https://www.bunka-fc.ac.jp/_wp/wp-content/uploads/bfc-graduate_icon_youtube.svg) no-repeat center center / cover;
	transition: all 1s ease;
}

#bfc-graduate .archives dd {
	margin-top: clamp(10px, 1.5vw, 20px);
	position: relative;
}

#bfc-graduate .archives dd p {
	font-weight: bold;
	line-height: 1.3125;
	color: #000;
	display: flex;
	justify-content: center;
	flex-direction: column;
}
#bfc-graduate .archives dd p b {
	font-size: clamp(11px, 1.45vw, 18px);
	font-family: "游ゴシック体", YuGothic, "游ゴシック Medium", "Yu Gothic Medium", "游ゴシック", "Yu Gothic", "メイリオ", sans-serif;
}
#bfc-graduate .archives dd p span {
	font-size: clamp(12px, 1.4vw, 16px);
	font-family: "游ゴシック体", YuGothic, "游ゴシック Medium", "Yu Gothic Medium", "游ゴシック", "Yu Gothic", "メイリオ", sans-serif;
}
#bfc-graduate .archives dd p small {
	font-size: clamp(10px, 1.1vw, 12px);
	font-weight: normal;
	margin-bottom: 5px;
}



/*------------------------------------------------------------------------*/
@media screen and (max-width:760px) {

	#bfc-graduate .archives ul {
		margin: 0 -5px;
	}
	#bfc-graduate .archives li {
		width: calc(160px - 10px)!important;
		margin: 0 5px;
	}


	#bfc-graduate .archives li.new a:before {
		width: 30px;
		height: 15px;
		font-size: 12px;
		top: 0;
	}
	#bfc-graduate .archives dl {}
	#bfc-graduate .archives dt {
	}


	#bfc-graduate .archives.youtube li dt:after {
		width: 24px;
		height: 17px;
	}


}
/*-------------------------------------------------------------------------
	local
-------------------------------------------------------------------------*/

#bfc-graduate #local {
}
#bfc-graduate #local ol {
	display: flex;
	flex-wrap: wrap;
	margin: 0 -10px;
	counter-reset: number;
	list-style: none;
}
#bfc-graduate #local li {
	width: calc(100% / 4 - 20px);
	margin: 0 10px;
	padding: 0;
}

#bfc-graduate #local li a {
	width: 100%;
	height: 100%;
	aspect-ratio: 2 / 1;
	border-radius: 24px;
	display: flex;
	align-items: center;
	justify-content: center;
	position: relative;
	background-color: #eee;
	font-size: 14px;
	font-weight: bold;
	font-family: "游ゴシック体", YuGothic, "游ゴシック Medium", "Yu Gothic Medium", "游ゴシック", "Yu Gothic", "メイリオ", sans-serif;
	line-height: 1.5;
	color: #000;
	text-align: center;
	position: relative;
}
#bfc-graduate #local li a:before {
	position: absolute;
	left: 12px;
	top: 0;
	/*bottom: 0;
	margin: auto 0;*/
	font-size: 96px;
	letter-spacing: 0;
	line-height: 1;
	color: #ffcc00;
	font-family: acumin-pro-extra-condensed, sans-serif;
	font-weight: 700;
	counter-increment: number;
	content: counter(number, decimal-leading-zero);
}
#bfc-graduate #local li a:after {
	content: "";
	width: clamp(20px, 2.5vw, 30px);
	height: clamp(20px, 2.5vw, 30px);
	display: block;
	position: absolute;
	left: 0;
	right: 0;
	bottom: calc(0px - clamp(10px, 1.25vw, 15px));
	margin: 0 auto;
	background: url(https://www.bunka-fc.ac.jp/_wp/wp-content/uploads/bfc-graduate_icon_arrow_bottom.svg) no-repeat center center / cover;
	transition: all 1s ease;
}

#bfc-graduate #local li a:hover:after {
	bottom: calc(0px - clamp(15px, 2.0vw, 25px));
}

#bfc-graduate #local li a span {
	position: relative;
}

/*------------------------------------------------------------------------*/

@media screen and (max-width: 760px) {

	#bfc-graduate #local ol {
		margin: 0 -5px -20px -5px;
	}
	#bfc-graduate #local li {
		width: calc(100% / 2 - 10px);
		margin: 0 5px 20px 5px;
	}
	#bfc-graduate #local li a {
		aspect-ratio: 16 / 9;
		border-radius: 15px;
		font-size: 10px;
		line-height: 1.25;
	}
	#bfc-graduate #local li a:before {
		left: 10px;
		font-size: 72px;
	}

}

/*-------------------------------------------------------------------------
	iframe
-------------------------------------------------------------------------*/

#bfc-graduate .iframe {
	width: 100%;
	position: relative;
	/*box-shadow: 8px -8px 0 #000;*/
}

#bfc-graduate .iframe iframe {
	position: absolute;
	top: 0;
	right: 0;
	width: 100% !important;
	height: 100% !important;
}


/*-------------------------------------------------------------------------
	thumbnail
-------------------------------------------------------------------------*/

#bfc-graduate .thumbnail {
	margin-bottom: clamp(30px, 3.5vw, 40px);
}



/*-------------------------------------------------------------------------
	link
-------------------------------------------------------------------------*/

#bfc-graduate .link {
	margin-top: clamp(30px, 4.5vw, 60px);
}

#bfc-graduate .link a {
	margin: 0 auto;
	width: clamp(270px, 31.5vw, 360px);
	height: clamp(60px, 7.0vw, 80px);
	border: 0;
	border-radius: clamp(30px, 3.5vw, 40px);
	font-size: clamp(12px, 1.4vw, 16px);
	font-weight: bold;
	font-family: "游ゴシック体", YuGothic, "游ゴシック Medium", "Yu Gothic Medium", "游ゴシック", "Yu Gothic", "メイリオ", sans-serif;
	text-decoration: none;
	letter-spacing: .05em;
	line-height: 1.5;
	color: #000;
	display: flex;
	align-items: center;
	justify-content: center;
	text-align: center;
	background-color: #ffcc00;
	background-repeat: no-repeat;
	background-position: right clamp(15px, 1.75vw, 20px) center;
	background-image: url(https://www.bunka-fc.ac.jp/_wp/wp-content/uploads/bfc-graduate_icon_blank.svg);
	background-size: clamp(15px, 1.75vw, 20px) auto;
	transition: all 1s ease;
}
#bfc-graduate .link a:hover {
	transform: scale(1.05);
}




/*-------------------------------------------------------------------------
	list
-------------------------------------------------------------------------*/



/*inputを非表示 & 閉じた時の位置調整*/
#bfc-graduate .open-box{
  position: relative;
}
#bfc-graduate input[type="checkbox"].on-off{
  position: absolute;
  top: 20%;
  display: block;
  opacity: 0;
}

/*ラベル（「開く」ボタン）*/
#bfc-graduate .open-label{
	display: flex;
	align-items: center;
	justify-content: center;
	text-align: center;
	margin: 0 auto;
	z-index: 2;
	background-color: #eee;
	width: clamp(160px, 18.7vw, 214px);
	height: clamp(40px, 4.5vw, 50px);
	border-radius: clamp(20px, 2.25vw, 25px);
	font-size: clamp(10px, 1.2vw, 14px);
	letter-spacing: .05em;
	cursor: pointer;
}
/*ボタンっぽい効果*/
#bfc-graduate .open-label:active{
}
#bfc-graduate .open-label:hover{
	/*background: #fcbe11;*/
	opacity: 0.5;
}
/*ラベルに表示するテキスト*/
#bfc-graduate .open-label::after{
  content: "リストをもっとみる"; 
}
#bfc-graduate .on-off:checked ~ .open-label::after{
  content: "リストをとじる";
}

#bfc-graduate .on-off:checked ~ .open-label {
	margin-top: clamp(20px, 3.0vw, 40px); 
  }



/*開閉エリア*/
#bfc-graduate .open{
  height: 200px;
  overflow: hidden;
  /*transition: 1s;*/
  position: relative;




  /* animation: yourAnimation 0s ease-in-out; */
  transition: height 0.3s ease-out; 


}
#bfc-graduate .on-off:checked ~ .open{
    min-height: 200px;
	/* padding-bottom: clamp(20px, 3.0vw, 40px); */
}
/* #bfc-graduate .open.expanded {
	height: auto;
	padding-bottom: clamp(20px, 3.0vw, 40px);
  } */
/*開閉エリアにぼかしを乗せる*/
#bfc-graduate .open::before{
  content:'';
  background: linear-gradient(to bottom, transparent,rgba(255,255,255,1)100%);
  position: absolute;
  top:0;
  left:0;
  right:0;
  bottom:0;
  z-index: 3;
}
/*開いたらぼかしを消す*/
#bfc-graduate .on-off:checked ~ .open::before{
  background: none;
  z-index: -1;
}




#bfc-graduate .list dl {
}
#bfc-graduate .list dt {
	height: clamp(40px, 4.5vw, 50px);
	border-radius: clamp(20px, 2.25vw, 25px);
	font-size: clamp(12px, 1.4vw, 16px);
	font-weight: bold;
	font-family: "游ゴシック体", YuGothic, "游ゴシック Medium", "Yu Gothic Medium", "游ゴシック", "Yu Gothic", "メイリオ", sans-serif;
	letter-spacing: .05em;
	color: #000;
	display: flex;
	align-items: center;
	justify-content: center;
	text-align: center;
	background-color: #ffcc00;
}
#bfc-graduate .list dd {
	padding: 20px 40px 0 40px;
}

#bfc-graduate .list dd ul {
	display: flex;
	flex-wrap: wrap;
	margin: 0 -10px;
	counter-reset: number;
	list-style: none;
}
#bfc-graduate .list dd li {
	width: calc(100% / 4 - 20px);
	margin: 20px 10px 0 10px;
	padding: 0;
}
#bfc-graduate .list dd li a {
	display: flex;
	align-items: center;
	color: #000;
}
#bfc-graduate .list dd li a:before {
	flex: none;
	content: "●";
	color: #ffcc00;
	margin-right: 5px;
}
#bfc-graduate .list dd li p {
	display: flex;
	flex-direction: column;
}
#bfc-graduate .list dd li small {
	font-size: 12px;
}
#bfc-graduate .list dd li i {
	font-style: normal;
	white-space: nowrap
}
#bfc-graduate .list dd li span {
	font-size: 14px;
}


/*------------------------------------------------------------------------*/

@media screen and (max-width: 760px) {

	#bfc-graduate .list dd {
		padding: 10px 0 0 0;
	}

	#bfc-graduate .list dd ul {
		margin: 0 -5px;
	}
	#bfc-graduate .list dd li {
		width: calc(100% / 2 - 10px);
		margin: 10px 5px 0 5px;
	}
	#bfc-graduate .on-off:checked ~ .open {
		min-height: 250px;
	  }

}

/* ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
	■scroll
━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ */

.scroll-up {
  opacity: .5; 
  visibility: hidden;
  transform: translateY(80px);
  transition: all .5s;
}
.scroll-up.is-show {
  opacity: 1;
  visibility: visible;
  transform: translateY(0px);
}


/*------------------------------------------------------------------------*/

@media screen and (max-width: 760px) {

	.scroll-up {
	  transform: translateY(30px);
	}


}

/* スライダー */
  .splide {
	position: relative;
}
  .splide-track{
	/*padding-left: 200px;
	padding-right: 200px;*/
  }
  .splide__slide{
	transition: all 1.8s ease-out;
  }
  /*.splide__slide img {
	width: 100%;
	height: auto;
  }*/

/*#bfc-graduate .splide__list ul {
	display: flex;
	justify-content: center!important;
	margin: 0 -20px!important;
}*/

#bfc-graduate .splide__list li {
	flex: none;
	width: calc(360px - 40px)!important;
	/*margin: 0 20px;*/
	margin: 0 40px 0 0;
}


#bfc-graduate .splide__list li > a {
	height: 100%;
	display: flex;
	position: relative;
}

#bfc-graduate .splide__list li.new a:before {
	content: "NEW";
	width: 40px;
	height: 20px;
	position: absolute;
	top: 10px;
	left: 0;
	background: #ffcc00;
	font-family: acumin-pro-extra-condensed, sans-serif;
	font-weight: 700;
	font-size: 16px;
	letter-spacing: .05em;
	color: #000;
	display: flex;
	align-items: center;
	justify-content: center;
	z-index: 1;
}

#bfc-graduate .splide__list dl {
	display: flex;
	flex-direction: column;
}

#bfc-graduate .splide__list dt {
	overflow: hidden;
	position: relative;
}


#bfc-graduate .splide__list li dt img {
	width: 100%;
	/*aspect-ratio: 16 / 9;*/
	object-fit: cover;
	object-position: center center;
	transition: all 1s ease;
}
#bfc-graduate .splide__list li > a:hover dt img {
	transform: scale(1.05);
}

#bfc-graduate .splide__list.youtube li dt:after {
	content: "";
	width: 48px;
	height: 34px;
	display: block;
	position: absolute;
	top: 0;
	left: 0;
	right: 0;
	bottom: 0;
	margin: auto;
	background: url(https://www.bunka-fc.ac.jp/_wp/wp-content/uploads/bfc-graduate_icon_youtube.svg) no-repeat center center / cover;
	transition: all 1s ease;
}

#bfc-graduate .splide__list dd {
	margin-top: clamp(10px, 1.5vw, 20px);
	position: relative;
}

#bfc-graduate .splide__list dd p {
	font-weight: bold;
	line-height: 1.3125;
	color: #000;
	display: flex;
	justify-content: center;
	flex-direction: column;
}
#bfc-graduate .splide__list dd p b {
	font-size: clamp(11px, 1.45vw, 18px);
	font-family: "游ゴシック体", YuGothic, "游ゴシック Medium", "Yu Gothic Medium", "游ゴシック", "Yu Gothic", "メイリオ", sans-serif;
}
#bfc-graduate .splide__list dd p span {
	font-size: clamp(12px, 1.4vw, 16px);
	font-family: "游ゴシック体", YuGothic, "游ゴシック Medium", "Yu Gothic Medium", "游ゴシック", "Yu Gothic", "メイリオ", sans-serif;
}
#bfc-graduate .splide__list dd p small {
	font-size: clamp(10px, 1.1vw, 12px);
	font-weight: normal;
	margin-bottom: 5px;
}



/*------------------------------------------------------------------------*/
@media screen and (max-width:760px) {

	/*#bfc-graduate .splide__list ul {
		margin: 0 -5px;
	}*/
	#bfc-graduate .splide__list li {
		width: calc(100% / 2 - 29px)!important;
		margin: 0 10px 0 0;
	}


	#bfc-graduate .splide__list li.new a:before {
		width: 30px;
		height: 15px;
		font-size: 12px;
		top: 0;
	}
	#bfc-graduate .splide__list dl {}
	#bfc-graduate .splide__list dt {
	}


	#bfc-graduate .splide__list.youtube li dt:after {
		width: 24px;
		height: 17px;
	}


}




#bfc-graduate .splide__arrow {
	opacity: 1;
	top: 0;
	bottom: 0;
	transform: unset;
}
#bfc-graduate .arrow.prev {
	content: "";
	width: clamp(20px, 3.0vw, 40px);
	height: clamp(20px, 3.0vw, 40px);
	display: block;
	position: absolute;
	top: 0;
	left: clamp(10px, 2.0vw, 30px);
	bottom: 0;
	margin: auto 0;
	background: url(https://www.bunka-fc.ac.jp/_wp/wp-content/uploads/bfc-graduate_icon_arrow_left.svg) no-repeat center center / cover;
	z-index: 3;
	transition: all 1s ease;
}
#bfc-graduate .arrow.prev:hover {
	/*transform: scale(1.25);*/
	left: clamp(5px, 1.0vw, 15px);
}


#bfc-graduate .arrow.next {
	content: "";
	width: clamp(20px, 3.0vw, 40px);
	height: clamp(20px, 3.0vw, 40px);
	display: block;
	position: absolute;
	top: 0;
	right: clamp(10px, 2.0vw, 30px);
	bottom: 0;
	margin: auto 0;
	background: url(https://www.bunka-fc.ac.jp/_wp/wp-content/uploads/bfc-graduate_icon_arrow_right.svg) no-repeat center center / cover;
	z-index: 3;
	transition: all 1s ease;
}
#bfc-graduate .arrow.next:hover {
	/*transform: scale(1.25);*/
	right: clamp(5px, 1.0vw, 15px);
}




.fadein {
	opacity : 0;
	transition:all 1s;
	transform : translate(0, 40px);
}
.fadein.scrollin {
	opacity : 1;
	transform : translate(0, 0);
}