@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
}

.yugo {
	font-family: "游ゴシック体", YuGothic, "游ゴシック Medium", "Yu Gothic Medium", "游ゴシック", "Yu Gothic", "メイリオ", sans-serif;
}

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

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


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

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


.page-head h1 {
	font-family: "游ゴシック体", YuGothic, "游ゴシック Medium", "Yu Gothic Medium", "游ゴシック", "Yu Gothic", "メイリオ", sans-serif;
	text-align: center;
}

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


#application {
	font-size: clamp(14px, 1.5vw, 16px);
	letter-spacing: 0;
	margin-bottom: clamp(60px, 7.0vw, 80px);
	counter-reset: number;
}
#application h4 {
	font-family: "游ゴシック体", YuGothic, "游ゴシック Medium", "Yu Gothic Medium", "游ゴシック", "Yu Gothic", "メイリオ", sans-serif;
}



#application a.underline {
	color: #000;
	text-decoration: underline;
	text-decoration-thickness: 1px;
	/*text-underline-offset: clamp(3px, 0.35vw, 4px);*/
}
#application a.underline:hover {
	text-decoration: none;
}
#application a.underline[target="_blank"]:after {
	content: "";
	display: inline-block;
	width: clamp(10px, 1.1vw, 12px);
	height: clamp(10px, 1.1vw, 12px);
	margin: 0 clamp(2px, 0.3vw, 4px);
	background: url(https://www.bunka-fc.ac.jp/_wp/wp-content/uploads/bfc-graduate_icon_blank.svg) no-repeat center center / contain;
}


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

#application .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;
}
#application section:nth-of-type(odd) .number:after {
	right: 0;
}
#application section:nth-of-type(even) .number:after {
	left: 0;
}

#application .head {
	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;
	display: flex;
	flex-direction: column;
}

#application .head b {
	font-size: clamp(28px, 3.8vw, 48px);
}
#application .head .yellow {
	color: #ffcc00;
}

#application .head .slash {
	display: flex;
	align-items: end;
	justify-content: center;
	margin-bottom: clamp(10px, 1.5vw, 20px);
}

#application .head .slash:before {
	content: "";
	width: 2px;
	height: 35px;
	transform: rotate(-20deg);
	background: #000;
	display: block;
	margin-right: 20px;
	position: relative;
	bottom: 10px;
}

#application .head .slash:after {
	content: "";
	width: 2px;
	height: 35px;
	transform: rotate(20deg);
	background: #000;
	display: block;
	margin-left: 20px;
	position: relative;
	bottom: 10px;
}


#application .head i {
	font-family: acumin-pro-extra-condensed, sans-serif;
	font-weight: 700;
	font-style: normal;
	font-size: clamp(30px, 3.5vw, 40px);
	letter-spacing: 0em;
	margin-right: 5px;
}

#application .description {
	line-height: 2;
	margin-bottom: clamp(60px, 7.0vw, 80px);
}
#application .description p + p {
	margin-top: clamp(30px, 3.5vw, 40px);
}



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

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


	#application .head .slash {
	}
	#application .head .slash:before {
		height: 24px;
		margin-right: 15px;
		bottom: 5px;
	}

	#application .head .slash:after {
		height: 24px;
		margin-left: 15px;
		bottom: 5px;
	}

}

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

@media screen and (min-width: 761px) {


	#application .pc-left {
		text-align: left!important;
	}
	#application .pc-center {
		text-align: center!important;
	}
	#application .pc-right {
		text-align: right!important;
	}

}

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

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

	#application .description {
		line-height: 1.5;
	}
	#application .sp-left {
		text-align: left!important;
	}
	#application .sp-center {
		text-align: center!important;
	}
	#application .sp-right {
		text-align: right!important;
	}

}


/*-------------------------------------------------------------------------
	indent
-------------------------------------------------------------------------*/

#application .indent {
	padding-left: 1em;
	text-indent: -1em;
}
#application .indent.level2 {
	padding-left: 2em;
	text-indent: -2em;
}
#application .indent li + li {
	margin-top: 16px;
}
#application table + .indent {
	margin-top: 16px;
}


/*-------------------------------------------------------------------------
	scroll
-------------------------------------------------------------------------*/

#application .scroll {
	overflow-y: hidden;
	margin: 0;
	/*margin-right: calc(0px - clamp(20px, 4.0vw, 60px));*/
	margin-top: calc(0px - clamp(30px, 3.5vw, 40px));
}
#application .scroll:before {
	content: '※各日程は横スクロールでご確認いただけます。';
	font-size: clamp(9px, 1.05vw, 12px);
}
#application .scroll + h4 {
	margin-top: clamp(30px, 4.5vw, 60px);
}
#application .scroll > div {
	margin-top: clamp(5px, 0.75vw, 10px);
	overflow-x: scroll;
	-webkit-overflow-scrolling: touch;
	overflow-scrolling: touch;
}
#application .scroll + .indent {
	margin-top: clamp(15px, 1.75vw, 20px);
}
#application .scroll + .indent li + li {
	margin-top: 0;
}

#application ::-webkit-scrollbar {
	height: clamp(10px, 1.25vw, 15px);
}
#application ::-webkit-scrollbar-track {
	background-color: #fff;
	border-radius: clamp(5px, 6.25vw, 7.5px);
}
#application ::-webkit-scrollbar-thumb {
	background: #888888;
	border-radius: clamp(5px, 6.25vw, 7.5px);
}


/*-------------------------------------------------------------------------
	schedule
-------------------------------------------------------------------------*/

#application .schedule {
	table-layout: fixed;
	border-collapse: collapse;
	white-space: nowrap;
	margin: 0;
	margin-bottom: 15px;
}
#application .schedule.w1470 {
	width: calc(270px + 240px * 5);
}
#application .schedule.w1950 {
	width: calc(270px + 240px * 7);
}


#application .schedule + .schedule,
#application .schedule table + table {
	margin-top: clamp(30px, 4.5vw, 60px);
}

#application .schedule th {
	font-weight: normal;
}
#application .schedule thead {
	border: 1px solid #fff;
}
#application .schedule thead th {
	background: #999;
	color: #fff;
	font-weight: normal;
	text-align: center;
	border: 1px dashed #fff;
	padding: 5px;
}
#application .schedule thead > tr > th:first-of-type {
	border-right: 1px solid #fff;
}


#application .schedule tbody th {
	text-align: center;
	color: #fff;
}

#application .schedule tbody td {
}



#application .schedule tbody > tr > * {
	border: 1px solid #fff;
	padding: 10px;
}
#application .schedule tbody {
	border: 1px solid #fff;
}
#application .schedule tbody > tr > * {
	border: 1px dashed #fff;
}
#application .schedule tbody > tr > th:first-of-type {
	border-right: 1px solid #fff;
}
#application .schedule tbody td {
	vertical-align: top;
}
#application .schedule tbody td.va-middle {
	vertical-align: middle;
}
#application .schedule tbody td p {
	display: flex;
}
#application .schedule tbody td p + p {
	margin-top: 10px;
}
#application .schedule tbody td p span {
	padding: 5px;
	background: #c00;
	width: fit-content;
	line-height: 1.33;
}
#application .schedule tbody td p span + span {
	margin-left: auto;
}


#application .schedule tbody td p span.w100 {
	width: 100%;
}
#application .schedule tbody td p span.center {
	margin-left: auto;
	margin-right: auto;
	text-align: left;
}
#application .schedule tbody td p span.right {
	margin-left: auto;
	text-align: left;
}
#application .schedule tbody td p span.right-right {
	margin-right: -30px;
}


#application .schedule tbody.bg-0033cc th {
	background: #0033cc;
	color: #fff;
}
#application .schedule tbody.bg-0033cc td {
	background: #cdd5ec;
}

#application .schedule tbody.bg-0066cc th {
	background: #0066cc;
	color: #fff;
}
#application .schedule tbody.bg-0066cc td {
	background: #ffffcc;
}

#application .schedule tbody.bg-009999 th {
	background: #009999;
	color: #fff;
}
#application .schedule tbody.bg-009999 td {
	background: #dcece5;
}

#application .schedule tbody.bg-3399cc th {
	background: #3399cc;
	color: #fff;
}
#application .schedule tbody.bg-3399cc td {
	background: #dfecf9;
}

#application .schedule tbody td span {
	border-radius: 6px;
}

#application .schedule .p-ffcc00 {
	background: #ffcc00;
}
#application .schedule .p-0033cc {
	background: #0033cc;
	color: #fff;
}
#application .schedule .p-f8c567 {
	background: #f8c567;
}
#application .schedule .p-ff0000 {
	background: #ff0000;
	color: #fff;
}
#application .schedule .p-f0975b {
	background: #f0975b;
}
#application .schedule .p-229f2b {
	background: #229f2b;
	color: #fff;
}


#application .schedule thead th:nth-child(1) {
  width: 180px;
}

#application .schedule thead th:nth-child(2) {
  width: 90px;
}

#application .schedule thead th:nth-child(3) {
  width: 240px;
}

#application .schedule thead th:nth-child(4) {
  width: 240px;
}

#application .schedule thead th:nth-child(5) {
  width: 240px;
}

#application .schedule thead th:nth-child(6) {
  width: 240px;
}


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

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



	#application .schedule.w1470 {
		width: calc(68px + 180px * 5);
	}
	#application .schedule.w1950 {
		width: calc(68px + 180px * 7);
	}
	#application .schedule.w2 {
		width: calc(68px + 180px * 2);
	}

	#application .schedule thead th:nth-child(2) {
	  width: 68px;
	}

	#application .schedule thead th:nth-child(3) {
	  width: 180px;
	}

	#application .schedule thead th:nth-child(4) {
	  width: 180px;
	}

	#application .schedule thead th:nth-child(5) {
	  width: 180px;
	}

	#application .schedule thead th:nth-child(6) {
	  width: 180px;
	}


	#application .schedule thead > tr:first-of-type > th:first-of-type {
		display: none;
	}
	#application .schedule tbody > tr:first-of-type > th:first-of-type {
		display: none;
	}

}

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

#application #kv {
	margin-top: -40px;
	position: relative;
	border-radius: 30px;
	overflow: hidden;
	background: #000;
}
#application #kv img {
	opacity: 0.6;
}
#application #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) {

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

}



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


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


#application section .disabled {
	pointer-events: none
}

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

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

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

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

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

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




#application .small {
	font-size: clamp(11px, 1.25vw, 14px);
}
#application .x-small {
	font-size: clamp(10px, 1.1vw, 12px);
}

#application .right {
	text-align: right;
}



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

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

	#application .inner {
		margin: 0 24px;
	}
}


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

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

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


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

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


/*-------------------------------------------------------------------------
	select
-------------------------------------------------------------------------*/

#application .exam-systems {
	display: flex;
	flex-wrap: wrap;
	align-items: start;
	margin: 0 calc(0px - clamp(5px, 1.25vw, 20px));
}
#application .exam-systems li {
	width: calc(100% / 2 - clamp(10px, 2.5vw, 40px));
	margin: 0 clamp(5px, 1.25vw, 20px);
	border-radius: clamp(24px, 2.7vw, 30px);
	box-sizing: border-box;
	padding: clamp(20px, 2.5vw, 30px);
	position: relative;
	color: #fff;
	box-shadow: 5px 5px 5px 0 rgba(0, 0, 0, .25);

}
#application .exam-systems li + li {
	margin-top: clamp(30px, 3.5vw, 40px);
}

#application .exam-systems dl {
	position: relative;
}
#application .exam-systems dd h4 img {
	width: clamp(64px, 8.2vw, 100px);
	position: absolute;
	left: 0;
	top: 0;
}

#application .exam-systems dd {
	text-align: center;
	position: relative;
}
#application .exam-systems dd h4 {
	font-size: clamp(16px, 2.0vw, 24px);
	min-height: 3em;
	display: flex;
	align-items: center;
	justify-content: center;
	margin-top: 20px;
	position: relative;
}
#application .exam-systems dd p:first-of-type {
	font-size: clamp(11px, 1.35vw, 16px);
	font-weight: bold;
}
#application .exam-systems dd .link {
	margin-top: 20px;
}

#application .exam-systems dd i {
	width: clamp(50px, 6.25vw, 75px);
	height: clamp(50px, 6.25vw, 75px);
	border-radius: 50%;
	font-size: clamp(10px, 1.2vw, 14px);
	font-weight: bold;
	font-style: normal;
	display: flex;
	align-items: center;
	justify-content: center;
	position: absolute;
	right: 0;
	top: 0;
	background: #fff;
}

#application .exam-systems .exam-ao {
	background: #0033cc;
}
#application .exam-systems .exam-ao dd i {
	color: #0033cc;
}
#application .exam-systems .exam-ao .link > * {
	color: #0033cc;
	background-image: url(/_wp/wp-content/uploads/application_icon_arrow_exam-ao.svg);
}

#application .exam-systems .exam-shiteikou {
	background: #0066cc;
}
#application .exam-systems .exam-shiteikou dd i {
	color: #0066cc;
}
#application .exam-systems .exam-shiteikou .link > * {
	color: #0066cc;
	background-image: url(/_wp/wp-content/uploads/application_icon_arrow_exam-shiteikou.svg);
}

#application .exam-systems .exam-jiko {
	background: #009999;
}
#application .exam-systems .exam-jiko dd i {
	color: #009999;
}
#application .exam-systems .exam-jiko .link > * {
	color: #009999;
	background-image: url(/_wp/wp-content/uploads/application_icon_arrow_exam-jiko.svg);
}

#application .exam-systems .exam-ippan {
	background: #3399cc;
}
#application .exam-systems .exam-ippan dd i {
	color: #3399cc;
}
#application .exam-systems .exam-ippan .link > * {
	color: #3399cc;
	background-image: url(/_wp/wp-content/uploads/application_icon_arrow_exam-ippan.svg);
}

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

@media screen and (min-width: 761px) {

	#application .exam-systems li:nth-child(3) {
		margin-top: 0;
	}

}

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

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

	#application .exam-systems {
		display: block;
		margin: 0;
	}
	#application .exam-systems li {
		width: 100%;
		margin: 0;
	}
	#application .exam-systems li + li {
		margin-top: 30px;
	}

}

/*-------------------------------------------------------------------------
	box
-------------------------------------------------------------------------*/

#application .box {
	padding: clamp(30px, 4.5vw, 60px) clamp(20px, 4.0vw, 60px);
	border-radius: clamp(24px, 2.7vw, 30px);
}
#application .box.gray {
	background: #eee;
}

#application .box h3 {
	margin: 0;
	margin-bottom: clamp(30px, 4.5vw, 60px);
	padding: 0;
	font-size: clamp(12px, 1.4vw, 16px);
	font-family: "游ゴシック体", YuGothic, "游ゴシック Medium", "Yu Gothic Medium", "游ゴシック", "Yu Gothic", "メイリオ", sans-serif;
	line-height: 1.5;
	display: flex;
	align-items: center;
	flex-direction: column;
	text-align: center;
}

#application .box h3 b {
	width: 100%;
	font-size: clamp(18px, 2.4vw, 30px);
	display: flex;
	align-items: center;
	justify-content: center;
	position: relative;
}
#application .box h3 b img {
	width: clamp(60px, 8.0vw, 100px);
	margin: auto 0;
	position: absolute;
	left: 0;
	top: 0;
	bottom: 0;
}

#application .box h3 .slash {
	display: flex;
	align-items: end;
	justify-content: center;
	margin-bottom: clamp(20px, 3.0vw, 40px);
}

#application .box h3 .slash:before {
	content: "";
	width: 2px;
	height: 30px;
	transform: rotate(-20deg);
	display: block;
	margin-right: 20px;
	position: relative;
}

#application .box h3 .slash:after {
	content: "";
	width: 2px;
	height: 30px;
	transform: rotate(20deg);
	display: block;
	margin-left: 20px;
	position: relative;
}



#application .box h4 {
	font-size: clamp(16px, 2.0vw, 24px);
	margin-bottom: clamp(30px, 4.5vw, 60px);
}
#application .box h4 small {
	font-size: clamp(12px, 1.5vw, 18px);
	margin-left: 10px;
}
#application .box h5 {
	font-size: clamp(14px, 1.6vw, 18px);
	margin: 30px 0;
}


#application .box h4 + .small {
	margin-top: calc(0px - clamp(10px, 2.5vw, 40px));
}


#application .box .link {
	margin-top: clamp(30px, 3.5vw, 40px);
}
#application .box li {
	list-style: none;
}
#application .box li + li {
	margin-top: 0;
}

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

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


	#application .box h4 small {
		margin-left: 0;
	}
	#application .box h4 + h5 {
		margin-top: 0;
	}

}


/*-------------------------------------------------------------------------
	separate
-------------------------------------------------------------------------*/


#application .separate {
	display: flex;
	flex-wrap: wrap;
	justify-content: center;
	list-style: none;
}

#application .separate.center {
	align-items: center;
	text-align: start;
}
#application .separate li img {
	width: 100%;
}

#application .separate > li + li {}


#application .separate .subtitle {
	margin-bottom: clamp(24px, 2.8vw, 32px);
}

#application .separate .link {
	margin-top: 0;
}
#application .separate + p {
	font-size: clamp(12px, 1.4vw, 16px);
}

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

@media screen and (min-width: 761px) {

	#application .separate {
		margin: 0 calc(0px - clamp(15px, 1.75vw, 20px)) calc(0px - clamp(30px, 3.5vw, 40px)) calc(0px - clamp(15px, 1.75vw, 20px));
	}
	#application .separate > li {
		margin: 0 clamp(15px, 1.75vw, 20px) clamp(30px, 3.5vw, 40px) clamp(15px, 1.75vw, 20px);
	}

	#application .separate > li.order1 {
		order: 1;
	}
	#application .separate li.w50 {
		width: calc(100% / 2 - clamp(30px, 3.5vw, 40px));
	}
	#application .separate li.w100 {
		width: calc(100% / 1 - clamp(30px, 3.5vw, 40px));
	}

	#application .separate + p {
		margin: clamp(30px, 3.5vw, 40px) 0;
	}
}

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

@media screen and (max-width: 760px) {
	#application .separate {
		margin: 0;
		display: block;
	}
	#application .separate > li + li {
		margin: 0;
		margin-top: 30px;
	}

	#application .separate + p {
		margin: 30px 0 60px 0;
	}
}

/*-------------------------------------------------------------------------
	ul
-------------------------------------------------------------------------*/


#application ul.disc {
	list-style-type: disc;
	padding-left: 1.4em;
}
#application ol.decimal {
	list-style-type: decimal;
	padding-left: 1.4em;
}



/*-------------------------------------------------------------------------
	flow
-------------------------------------------------------------------------*/

#application .flow {
	display: flex;
	justify-content: center;
	counter-reset: number;
	list-style: none;
	position: relative;
}

#application .flow li {
	display: flex;
}

#application .flow li p {
	background: #fff;
	border: 1px solid #ffcc00;
	box-sizing: border-box;
	position: relative;
	display: flex;
	align-items: center;
}

#application .flow li:last-child p {
	background: #ffcc00;
}

#application .flow li p span {
	font-weight: bold;
}

#application .flow li p:before {
	flex: none;
	font-size: clamp(14px, 1.5vw, 16px);
	font-weight: bold;
	letter-spacing: 0;
	line-height: 1;
	counter-increment: number;
	content: counter(number, decimal-leading-zero);
}

#application .flow li p small {
	font-size: 12px;
	font-weight: bold;
	text-align: center;
	position: absolute;
}


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

@media screen and (min-width: 761px) {


	#application .flow li:not(:last-child):after {
		content: "";
		flex: none;
		width: 10px;
		max-width: 100%;
		height: 1px;
		background: #ffcc00;
		margin: auto 0;
		display: block;
	}
	#application .flow li p {
		width: 83px;
		max-width: 100%;
		height: 240px;
		flex-direction: column;
	}

	#application .flow li p:before {
		margin: 15px 0 10px 0;
	}


	#application .flow li p span {
		writing-mode: vertical-rl;
	}
	#application .flow li p small {
		left: 0;
		right: 0;
		bottom: 10px;
		margin: 0 auto;
	}

}

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

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


	#application .flow {
		flex-direction: column;
		background: linear-gradient(to top, #ffcc00, #ffcc00) repeat-y center/1px;
	}

	/*#application .flow li:not(:last-child):after {
		content: "";
		flex: none;
		width: 1px;
		height: 100%;
		background: #ffcc00;
		margin: 0 auto;
		display: block;
	}*/
	#application .flow li {
		width: 100%;
	}
	#application .flow li + li {
		margin-top: 10px;
	}
	#application .flow li p {
		width: 100%;
		height: 64px;
		justify-content: center;
		text-align: center;
	}


	#application .flow li p:before {
		position: absolute;
		left: 15px;
		top: 0;
		display: flex;
		align-items: center;
		height: 100%;
	}


	#application .flow li p small {
		right: 10px;
		display: flex;
		align-items: center;
		height: 100%;
	}



}


/*-------------------------------------------------------------------------
	table
-------------------------------------------------------------------------*/

#application .table2 .caption {
	width: 100%;
	height: clamp(45px, 5.25vw, 60px);
	border-radius: 30px;
	background: #eee;
	font-size: clamp(14px, 1.75vw, 21px);
	font-weight: bold;
	line-height: clamp(45px, 5.25vw, 60px);
	margin-bottom: clamp(30px, 3.5vw, 40px);
	text-align: center;
}


#application .table2 + .table2,
#application .table2 table + table {
	margin-top: clamp(30px, 4.5vw, 60px);
}
#application .table2 table {
	width: 100%;
	border-collapse: collapse;
}

#application .table2 th {
	font-weight: normal;
}


#application .table2 thead th {
	background: #000;
	color: #fff;
	font-weight: normal;
	text-align: center;
	border: 1px solid #fff;
	padding: 12px;
}
#application .table2 tbody > tr > * {
	border: 1px solid #fff;
	padding: 12px;
}
#application .table2 tbody p {
	text-align: center;
}
#application .table2 tfoot td {
	background: #eee;
	text-align: center;
	padding: 12px;
}
#application .table2 tfoot.total td {
	background: #ddd;
}



#application .bg-a7c67a {
	background: #a7c67a;
}
#application .bg-8ac1e5 {
	background: #8ac1e5;
}
#application .bg-bfa6ca {
	background: #bfa6ca;
}
#application .bg-f0b653 {
	background: #f0b653;
}
#application .bg-e78494 {
	background: #e78494;
}


/*-------------------------------------------------------------------------
	exam-ao
-------------------------------------------------------------------------*/


#application .bg-cdd5ec#exam-ao {
	background: #cdd5ec;
	color: #0033cc;
}

#application .bg-cdd5ec#exam-ao h3 .slash:before {
	background: #0033cc;
}

#application .bg-cdd5ec#exam-ao h3 .slash:after {
	background: #0033cc;
}

#application .bg-cdd5ec#exam-ao hr {
	border-top: 1px solid #0033cc;
}

#application .bg-cdd5ec#exam-ao .target {
	background: #0033cc;
}
#application .bg-cdd5ec#exam-ao .point dd {
}
#application .bg-cdd5ec#exam-ao .accordion label {
	background-color: #0033cc;
	color: #fff;
}
#application .bg-cdd5ec#exam-ao .outline dt {
	background: #0033cc;
}
#application .bg-cdd5ec#exam-ao a.underline {
	color: #0033cc;
}



/*-------------------------------------------------------------------------
	exam-shiteikou
-------------------------------------------------------------------------*/

#application .bg-ffffcc#exam-shiteikou {
	background: #ffffcc;
	color: #0066cc;
}

#application .bg-ffffcc#exam-shiteikou h3 .slash:before {
	background: #0066cc;
}

#application .bg-ffffcc#exam-shiteikou h3 .slash:after {
	background: #0066cc;
}

#application .bg-ffffcc#exam-shiteikou hr {
	border-top: 1px solid #0066cc;
}
#application .bg-ffffcc#exam-shiteikou hr.type2 {
	border-top: 1px dashed #0066cc;
}

#application .bg-ffffcc#exam-shiteikou .target {
	background: #0066cc;
}
#application .bg-ffffcc#exam-shiteikou .point dd {
	background: #0066cc;
	color: #fff;
}
#application .bg-ffffcc#exam-shiteikou .accordion label {
	background-color: #0066cc;
	color: #fff;
}
#application .bg-ffffcc#exam-shiteikou .outline dt {
	background: #0066cc;
}
#application .bg-ffffcc#exam-shiteikou a.underline {
	color: #0066cc;
}


/*-------------------------------------------------------------------------
	exam-jiko
-------------------------------------------------------------------------*/


#application .bg-dcece5#exam-jiko {
	background: #dcece5;
	color: #009999;
}

#application .bg-dcece5#exam-jiko h3 .slash:before {
	background: #009999;
}

#application .bg-dcece5#exam-jiko h3 .slash:after {
	background: #009999;
}

#application .bg-dcece5#exam-jiko hr {
	border-top: 1px solid #009999;
}

#application .bg-dcece5#exam-jiko .target {
	background: #009999;
}
#application .bg-dcece5#exam-jiko .point dd {
}
#application .bg-dcece5#exam-jiko .accordion label {
	background-color: #009999;
	color: #fff;
}
#application .bg-dcece5#exam-jiko .outline dt {
	background: #009999;
}
#application .bg-dcece5#exam-jiko a.underline {
	color: #009999;
}




/*-------------------------------------------------------------------------
	exam-ippan
-------------------------------------------------------------------------*/



#application .bg-dfecf9#exam-ippan {
	background: #dfecf9;
	color: #3399cc;
}

#application .bg-dfecf9#exam-ippan h3 .slash:before {
	background: #3399cc;
}

#application .bg-dfecf9#exam-ippan h3 .slash:after {
	background: #3399cc;
}

#application .bg-dfecf9#exam-ippan hr {
	border-top: 1px solid #3399cc;
}

#application .bg-dfecf9#exam-ippan .target {
	background: #3399cc;
}
#application .bg-dfecf9#exam-ippan .point dd {
}
#application .bg-dfecf9#exam-ippan .accordion label {
	background-color: #3399cc;
	color: #fff;
}
#application .bg-dfecf9#exam-ippan .outline dt {
	background: #3399cc;
}
#application .bg-dfecf9#exam-ippan a.underline {
	color: #3399cc;
}

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

@media screen and (min-width: 761px) {




	#application .table2 thead th:nth-child(1) {
	  width: 25%;
	}

	#application .table2 thead th:nth-child(2) {
	  width: 25%;
	}

	#application .table2 thead th:nth-child(3) {
	  width: 12.5%;
	}

	#application .table2 thead th:nth-child(4) {
	  width: 12.5%;
	}

	#application .table2 thead th:nth-child(5) {
	  width: 25%;
	}


}

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

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

	#application hr {
		display: block;
		height: 30px;
		border: 0;
		background: none;
		margin: 0;
		padding: 0
	}

	#application .table2 table {
		font-size: 11px;
	}

	#application .table2 + .table2,
	#application .table2 table + table {
		margin-top: 15px;
	}


	#application .table2 caption {
		width: 100%;
		height: 30px;
		border-radius: 15px;
		font-size: 12px;
		font-weight: bold;
		line-height: 30px;
		margin-bottom: 15px;
		text-align: center;
	}

	#application tbody + tbody {
		 border-spacing: 0 0 15px 0;
	}
	#application tbody th {
		width: 20%;
		background: #000;
		text-align: center;
		color: #fff;
		padding: 8px;
	}
	#application tbody tr + tr {
		border-top: 1px solid #fff;
	}
	#application tbody td {
		width: 30%;
	}
	#application .table2 tbody > tr > * {
		border: 0;
		padding: 8px;
	}
	#application .table2 tfoot td {
		padding: 8px;
	}



}


/*-------------------------------------------------------------------------
	exam-schedule
-------------------------------------------------------------------------*/

#application .exam-schedule {
}


#application .box hr {
	height: 0;
	margin: 0;
}
#application .box hr.type2 {
	margin-bottom: 60px;
}

#application .bullet {
	margin: 30px 0;
	font-weight: bold;
}
#application .bullet li {
	display: flex;
	align-items: center;
}
#application .bullet li:before {
	flex: none;
	content: "";
	width: 24px;
	height: 24px;
	border: 1px solid #8097ce;
	background: url(/_wp/wp-content/uploads/application_icon_bullet.svg) no-repeat center center / 16px auto #fff;
	box-sizing: border-box;
	display: flex;
	align-items: center;
	justify-content: center;
	margin-right: 10px;
}
#application .bullet li + li {
	margin-top: 15px;
}
#application .bullet li p {
	font-size: clamp(12px, 1.4vw, 16px);
}
#application .target {
	margin: 30px 0;
	display: flex;
	align-items: center;
	font-size: clamp(11px, 1.25vw, 14px);
}

#application .target dt {
	flex: none;
	font-weight: bold;
	color: #fff;
	padding: clamp(12px, 1.4vw, 16px);
}

#application .target dd {
	flex: 1;
	background: #fff;
	padding: clamp(12px, 1.4vw, 16px);
}
#application .target dd p {
	margin-top: 0;
}

#application .point {
	margin: 30px 0;
	font-weight: bold;
}
#application .point dt {
	width: fit-content;
	background: #ffcc00;
	padding: 10px clamp(12px, 1.4vw, 16px);
	font-size: clamp(11px, 1.25vw, 14px);
}
#application .point dd {
	flex: 3;
	background: #fff;
	padding: clamp(10px, 1.5vw, 20px);
}


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

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


	#application .box hr.type2 {
		margin-bottom: 30px;
	}

}

/*-------------------------------------------------------------------------
	accordion
-------------------------------------------------------------------------*/


#application .accordion {
}
#application .accordion.mb60 {
	margin-bottom: 60px;
}

#application .accordion label {
	height: 60px;
	border-radius: 30px;
	font-weight: bold;
	background: #0033cc;
	display: flex;
	align-items: center;
	justify-content: center;
	text-align: center;
	line-height: 1.5;
	color: #fff;
	margin-top: clamp(30px, 4.5vw, 60px);
	background-repeat: no-repeat;
	background-position: right clamp(15px, 1.75vw, 20px) center;
	background-image: url(/_wp/wp-content/uploads/application_icon_arrow_bottom_white.svg);
	background-size: auto clamp(8px, 0.9vw, 10px);
	cursor: pointer;
}
#application .accordion label:hover {
	opacity: 0.5;
}

#application .acd-check:checked + label {
	background-image: url(/_wp/wp-content/uploads/application_icon_arrow_top_white.svg);
}


#application .acd-check{
	display: none;
}
#application .acd-content{
	height: 0;
	transition: 0.5s;
	overflow: hidden;
}
#application .acd-check:checked + .acd-label + .acd-content{ 
	height: auto;
	margin-top: clamp(30px, 4.5vw, 60px);
}


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

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

	#application .accordion.mb60 {
		margin-bottom: 30px;
	}

}



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

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

#application .link > * {
	margin: 0 auto;
	max-width: 100%;
	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;
	text-decoration: none;
	letter-spacing: .05em;
	line-height: 1.5;
	color: #000;
	display: flex;
	align-items: center;
	justify-content: center;
	text-align: center;
	background-repeat: no-repeat;
	background-position: right clamp(15px, 1.75vw, 20px) center;
	transition: all 1s ease;
}
#application .link > *:hover {
	transform: scale(1.05);
}

#application .link.small > * {
	width: clamp(160px, 18.75vw, 215px);
	height: clamp(36px, 4.3vw, 50px);
	border-radius: clamp(18px, 2.15vw, 25px);
	font-size: clamp(11px, 1.25vw, 14px);
}
#application .link.big > * {
}
#application .link.yellow > * {
	background-color: #ffcc00;
}
#application .link.gray > * {
	background-color: #eee;
}


#application .link.blank > * {
	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;
}


#application .link.right > * {
	background-image: url(/_wp/wp-content/uploads/application_icon_arrow_right_black.svg);
	background-size: clamp(4px, 0.45vw, 5px) auto;
}
#application .link.bottom > * {
	background-image: url(/_wp/wp-content/uploads/application_icon_arrow_bottom_black.svg);
	background-size: auto clamp(4px, 0.45vw, 5px);
}

#application .link.shadow > * {
	box-shadow: 5px 5px 5px 0 rgba(0, 0, 0, .25);
}




/*-------------------------------------------------------------------------
	outline
-------------------------------------------------------------------------*/

.exam-schedule {
}
.exam-schedule {
}

/*-------------------------------------------------------------------------
	outline
-------------------------------------------------------------------------*/
#application .outline {}
#application .outline > li {
}
#application .outline > li + li {
	border-top: 1px solid #eee;
}

#application .outline dl {
	display: flex;
	font-size: clamp(11px, 1.25vw, 14px);
}

#application .outline dt {
	flex: 1;
	font-weight: bold;
	color: #fff;
	background: #0033cc;
	padding: clamp(12px, 1.4vw, 16px);
}

#application .outline dd {
	flex: 3;
	background: #fff;
	padding: clamp(12px, 1.4vw, 16px);
}

#application .outline dd p {
	margin-top: 0;
}
#application .outline dd * + p {
	margin-top: clamp(5px, 0.75vw, 10px);
}
#application .outline dd ul {
	list-style: disc;
	padding-left: 1.25em;
}

#application .outline * + .indent {
	margin-top: clamp(5px, 0.75vw, 10px);
}

#application sup {
	font-size: clamp(8px, 0.9vw, 10px);
	vertical-align: super;
}

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



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

/*ラベル（「開く」ボタン）*/
#application .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;
}
/*ボタンっぽい効果*/
#application .open-label:active{
}
#application .open-label:hover{
	/*background: #fcbe11;*/
	opacity: 0.5;
}
/*ラベルに表示するテキスト*/
#application .open-label::after{
  content: "リストをもっとみる"; 
}
#application .on-off:checked ~ .open-label::after{
  content: "リストをとじる";
}

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



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

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


}
#application .on-off:checked ~ .open{
    min-height: 200px;
	/* padding-bottom: clamp(20px, 3.0vw, 40px); */
}
/* #application .open.expanded {
	height: auto;
	padding-bottom: clamp(20px, 3.0vw, 40px);
  } */
/*開閉エリアにぼかしを乗せる*/
#application .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;
}
/*開いたらぼかしを消す*/
#application .on-off:checked ~ .open::before{
  background: none;
  z-index: -1;
}




#application .list dl {
}
#application .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;
}
#application .list dd {
	padding: 20px 40px 0 40px;
}

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


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

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

	#application .list dd {
		padding: 10px 0 0 0;
	}

	#application .list dd ul {
		margin: 0 -5px;
	}
	#application .list dd li {
		width: calc(100% / 2 - 10px);
		margin: 10px 5px 0 5px;
	}
	#application .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;
  }*/

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

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


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

#application .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;
}

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

#application .splide__list dt {
	overflow: hidden;
	position: relative;
}


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

#application .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;
}

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

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



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

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


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


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


}




#application .splide__arrow {
	opacity: 1;
	top: 0;
	bottom: 0;
	transform: unset;
}
#application .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;
}
#application .arrow.prev:hover {
	/*transform: scale(1.25);*/
	left: clamp(5px, 1.0vw, 15px);
}


#application .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;
}
#application .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);
}


/*-------------------------------------------------------------------------
	banner
-------------------------------------------------------------------------*/

#application .banner {
}
#application .banner a {
	height: 100%;
	display: flex;
	overflow: hidden;
	position: relative;
	border-radius: clamp(12px, 2.1vw, 30px);
	display: block;
}
#application .banner a img {
	width: 100%;
	/*aspect-ratio: 1 / 1;*/
	object-fit: cover;
	object-position: center center;
	transition: all 0.75s ease;
}

#application .banner a:hover img {
	transform: scale(1.05);
}

/*-------------------------------------------------------------------------
	index
-------------------------------------------------------------------------*/

#application .index {
}


#application .index {
	display: flex;
	flex-wrap: wrap;
	margin: 0 calc(0px - clamp(5px, 1.25vw, 20px)) calc(0px - clamp(30px, 4.5vw, 60px)) calc(0px - clamp(5px, 1.25vw, 20px));
}

#application .index li {
	width: calc(100% / 3 - clamp(10px, 2.5vw, 40px));
	margin: 0 clamp(5px, 1.25vw, 20px) clamp(30px, 4.5vw, 60px) clamp(5px, 1.25vw, 20px);
}


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


#application .index dl {
	display: flex;
	flex-direction: column;
	height: 100%;
}

#application .index dt {
}
#application .index dt a {
	height: 100%;
	display: flex;
	overflow: hidden;
	position: relative;
	border-radius: clamp(12px, 1.8vw, 24px);
	display: block;
}

#application .index li dt img {
	width: 100%;
	/*aspect-ratio: 1 / 1;*/
	object-fit: cover;
	object-position: center center;
	transition: all 0.75s ease;
}

#application .index li dt a:hover img {
	transform: scale(1.05);
}

#application .index dd {
	margin-top: clamp(16px, 2.4vw, 32px);
	display: flex;
	flex-direction: column;
	flex-grow: 1;
}
/*
#application .index dd span {
	display: flex;
	align-items: center;
	background: rgba(0, 0, 0, .2);
	background: #c0c6c9;
	font-size: clamp(10px, 1.1vw, 12px);
	font-weight: bold;
	color: #fff;
	width: fit-content;
	padding: clamp(4px, 0.6vw, 8px);
}*/

#application .index dd h4 {
	font-size: clamp(11px, 1.45vw, 18px);
	text-align: center;
}

#application .index dd h4 + p {
	font-size: clamp(11px, 1.25vw, 14px);
	margin-bottom: auto;
}
#application .index dd * + * {
	margin-top: clamp(9px, 1.5vw, 21px);
}


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

@media screen and (max-width:760px) {
	#application .index {
		margin: 0;
	}
	#application .index li {
		width: calc(100% / 2 - clamp(10px, 2.5vw, 40px));
	}
}




/*-------------------------------------------------------------------------
	contents
-------------------------------------------------------------------------*/

#application .contents {
	margin-top: calc(0px - clamp(30px, 5.5vw, 80px));
}
#application .contents .main .box {
	margin-top: clamp(30px, 5.5vw, 80px);
}

#application .contents .sidebar {
	width: 245px;
	margin-left: 39px;
	position: sticky;
	left: 0;
}
#application .contents .sidebar .color-0033cc {
	color: #0033cc;
}
#application .contents .sidebar .color-0066cc {
	color: #0066cc;
}
#application .contents .sidebar .color-009999 {
	color: #009999;
}
#application .contents .sidebar .color-3399cc {
	color: #3399cc;
}

#application .contents .sidebar .check {
	position: relative;
	display: flex;
	align-items: center;
	justify-content: center;
}

#application .contents .sidebar .check:before {
	flex: none;
	content: "";
	width: 24px;
	height: 24px;
	border: 1px solid #8097ce;
	background: url(/_wp/wp-content/uploads/application_icon_bullet.svg) no-repeat center center / 16px auto #fff;
	box-sizing: border-box;
	display: flex;
	align-items: center;
	justify-content: center;
	margin-right: 10px;
	position: absolute;
	left: 0;
	top: 0;
	bottom: 0;
	margin: auto 0;
}
#application .contents .sidebar .check.current:before {
	background-image: url(/_wp/wp-content/uploads/application_icon_bullet_current.svg);
}

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

@media screen and (min-width:761px) {

	#application .contents {
		display: flex;
		align-items: start;
	}
	#application .contents .main {
		width: 100%;
		max-width: 756px;
	}
	#application .contents .sidebar {
		width: 245px;
		margin-left: 39px;
		top: clamp(30px, 5.5vw, 80px);
		margin-top: clamp(30px, 5.5vw, 80px);
	}

}


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

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


	#application .contents .sidebar {
		display: none;
	}


}


#application .contents .sidebar ul {
	background: #eee;
	padding: 30px;
	border-radius: 30px;
	text-align: center;
}
#application .contents .sidebar li {
	font-weight: bold;
}
#application .contents .sidebar li + li {
	margin-top: 12px;
	padding-top: 12px;
	border-top: 1px dashed #999;
}
#application .contents .sidebar li a {
	color: #000;
}

#application .contents .sidebar .link {
	margin-top: 30px;
}
#application .contents .sidebar .link a {
	height: 100px;
	border-radius: 30px;
}


/*-------------------------------------------------------------------------
	web-appli
-------------------------------------------------------------------------*/

#application #web-appli .box dl {
	display: flex;
	align-items: center;
}
#application #web-appli .box dt {
	width: clamp(120px, 14.75vw, 175px);
}
#application #web-appli .box dt img {
	width: 100%;
}
#application #web-appli .box dd {
	flex: 1;
	margin-left: clamp(21px, 4.05vw, 60px);
}
#application #web-appli .box dd .indent {
	margin-top: 16px;
}

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

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


	#application #web-appli .box dl {
		flex-direction: column;
	}
	#application #web-appli .box dt {
	}
	#application #web-appli .box dd {
		margin-left: 0;
		margin-top: 30px;
	}

}


/*-------------------------------------------------------------------------
	qualification
-------------------------------------------------------------------------*/

#application #qualification .box ul.disc li + li,
#application #qualification .box ol.decimal li + li {
	margin-top: clamp(16px, 1.8vw, 20px);
}
#application #qualification .box ul.disc li {
	list-style: disc!important;
}
#application #qualification .box ol.decimal li {
	list-style: decimal!important;
}
#application #qualification .box * + .indent {
	margin-top: clamp(16px, 1.8vw, 20px);
}