@charset "utf-8";

:root {
	--radius-base: 10px;
	--color-pink1: #ff928a;
	--color-pink2: #ffeceb;
	--color-blue1: #66ccc5;
	--color-blue2: #c9f5f2;
}

.keyVisual_content .innerBox .figure{
	background: url("../img/keyvisual.jpg") no-repeat center 84% / cover;
}

.keyVisual_content .keyVisual_title span::before{
	background: url("../img/p_policeacademy_blue.png") no-repeat center top / contain;
	max-width: 350px;
	width: 100%;
	aspect-ratio: 699/215;
}

.cnt-flex{
	display: flex;
	justify-content: space-between;
	align-items: center;
}
.cnt-flex.reverse{
	flex-direction: row-reverse;
}

.slide-arrow,
.slick-dots li.slick-active button{
	background: #000;
}
.section-prev::before { content: '\f060'; }
.section-next::before { content: '\f061'; }

.slick-dots{
	flex-wrap: wrap;
}
.slick-list {
	margin: 0 -15px;
}
.slick-slide {
	margin: 0 15px;
}
.slide-arrow{
	flex-shrink: 0;
}

.youtubeLead {
	margin-bottom: 10px;
}

.youtubeWrap {
	width: 50vw;
	max-width: 560px;
	height: 28.125vw;
	max-height: 315px;
	margin: 0 auto;
}

@media screen and (max-width: 1024px){
	.keyVisual_content .keyVisual_title span{
		margin-left: 20px;
	}
	.keyVisual_content .keyVisual_title span::before{
		left: -0.2em;
	}

	.youtubeWrap {
		width: 70vw;
		height: 39.375vw;
	}
}
@media screen and (max-width: 768px){
	.keyVisual_content .keyVisual_title span{
		margin-left: 7.8125vw;
	}
	.keyVisual_content .keyVisual_title span::before{
		left: -5.599vw;
		width: 51%;
	}
	:root {
		--radius-base: 5px;
		--font-hd04: clamp(14px,7.5vw,31px);
	}
	.lead{
		text-align: left;
	}

	.youtubeWrap {
		width: calc(100vw - 20px);
		height: 56.25vw;
	}
}


@media screen and (max-width: 768px){
	.cnt-flex,
	.cnt-flex.reverse{
		flex-direction: column-reverse;
	}
}

@media screen and (max-width: 600px){
	.youtubeLead {
		text-align: left;
	}
}

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

/*  リード文

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

#sec_school{
	padding: 100px 0 60px;
	border-bottom: solid 1px #000;
}

#sec_school .cnt-flex{
	gap: 60px;
}

#sec_school .cnt-flex + .cnt-flex{
	margin-top: 100px;
}

#sec_school .cnt-flex .txtBox{
	text-align: left;
	font-size: 18px;
	width: 55%;
}

#sec_school .txtBox p{
	line-height: 1.889;
}

#sec_school .txtBox p + p{
	margin-top: 1em;
}

#sec_school .cnt-flex figure{
	max-width: 542px;
	aspect-ratio: 540/340;
	overflow: hidden;
	border-radius: var(--radius-base);
	border: solid 1px #000;
	width: 45%;
}

#sec_school .cnt01 .txtBox{
	position: relative;
	z-index: 1;
}

#sec_school .cnt01 .deco{
	position: relative;
	z-index: 1;
}

#sec_school .cnt01 .txtBox::before,
#sec_school .cnt01 .deco::before,
#sec_school .cnt01 .deco::after{
	content: "";
	display: block;
	position: absolute;
}

#sec_school .cnt01 .txtBox::before{
	background: url("../img/icon_01_pc.png") no-repeat center / contain;
	aspect-ratio: 405/349;
	max-width: 203px;
	width: 27%;
	top: 40%;
	left: 80%;
}

#sec_school .cnt01 .deco::before{
	background: url("../img/icon_line.svg") no-repeat center top / contain;
	width: 100%;
	height: 8px;
	bottom: -4px;
	left: 0;
}
#sec_school .cnt01 .deco::after{
	background: url("../img/icon_hukidashi.svg") no-repeat center / contain;
	aspect-ratio: 242/150;
	max-width: 89px;
	width: 37%;
	right: -49px;
	bottom: 57%;
}

@media screen and (max-width: 1024px){
	#sec_school .cnt01 .txtBox::before{
		top: 80%;
	}
}

@media screen and (max-width: 768px){
	#sec_school{
		padding: 60px 0;
	}
	
	#sec_school .hd04{
		font-size: var(--font-hd04);
	}
	
	#sec_school .cnt-flex{
		gap: 40px;
	}
	
	#sec_school .cnt-flex + .cnt-flex{
		margin-top: 180px;
	}
	
	#sec_school .txtBox .ttl{
		font-size: clamp(14px,7.6vw,31px);
	}
	#sec_school .txtBox p{
		font-size: 15px;
	}
	
	#sec_school .cnt-flex .txtBox,
	#sec_school .cnt-flex figure{
		width: 100%;
	}
	
	#sec_school .cnt-flex .txtBox{
		max-width: 542px;
	}
	#sec_school .cnt01 .txtBox::before{
		background: url("../img/icon_01_sp.png") no-repeat center / contain;
		aspect-ratio: 935/434;
		max-width: 277px;
		width: 100%;
		top: 105%;
		left: 50%;
		transform: translate(-50%);
	}
	#sec_school .cnt01 .deco::after{
		right: -18%;
		bottom: 58%;
	}
}


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

/*  採用から卒業まで

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

#sec_from{
	background: #baf0a8 url("../img/bg_from.png") no-repeat center top;
	padding: 60px 0 40px;
	border-bottom: solid 1px #000;
	position: relative;
	z-index: 1;
	overflow: hidden;
}

#sec_from .slick-track{
	padding-bottom: 1px;
}

.slickFrom .section_cards {
	max-width: 860px;
	margin: 0 auto;
}

.slickFrom .section_cards li{
	background: #fff;
	border-radius: var(--radius-base);
	border: solid 1px #000;
	overflow: hidden;
	padding: 40px;
}

.slickFrom .section_cards li .cnt-flex{
	align-items: flex-start;
}

.slickFrom .section_cards li figure{
	border-radius: var(--radius-base);
	overflow: hidden;
	margin-right: 38px;
	max-width: 250px;
	aspect-ratio: 1/1;
	width: 33%;
}

.slickFrom .section_cards li .txtBox{
	padding-top: 20px;
	text-align: left;
	width: 63%;
}

.slickFrom .section_cards .txtBox .ttl{
	font-size: 30px;
	font-weight: 500;
	margin-bottom: 30px;
}

.slickFrom .section_cards .txtBox p{
	line-height: 1.75;
}

#sec_from .slick-dots li button{
	border-color: #000 !important;
	border-width: 2px !important;
	width: 10px !important;
	height: 10px !important;
}

@media screen and (max-width: 768px){
	#sec_from{
		background: #baf0a8 url("../img/bg_from_sp.png") no-repeat center top / contain;
	}
	.slickFrom .section_cards {
		max-width: 690px;
		margin: 0 auto;
	}
	
	.slickFrom .section_cards li{
		padding: 30px 2%;
	}
	
	.slickFrom .section_cards li .cnt-flex{
		flex-direction: column;
	}
	
	.slickFrom .section_cards li figure,
	.slickFrom .section_cards li .txtBox{
		width: 100%;
	}
	
	.slickFrom .section_cards li figure{
		margin: 0 auto;
	}
	
	.slickFrom .section_cards .txtBox .ttl{
		font-size: 23px;
		margin-bottom: 15px;
	}
	
	.slickFrom .section_cards .txtBox p{
		font-size: 15px;
	}
	
	#sec_from .slick-dots li button{
		border-width: 1px !important;
	}
}

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

/*  写真で見る

/* ------------------------------------------------------------------------ */
#sec_gallery{
	border-bottom: solid 1px #000;
}
#sec_gallery .cnt-flex{
	align-items: stretch;
}
#sec_gallery .cnt-flex .txtBox{
	display: flex;
	align-items: center;
	justify-content: flex-start;
	text-align: left;
	border-right: dashed 1px #000;
	padding: 39px;
	padding-left: 0;
	width: 38%;
}

#sec_gallery .cnt-flex .figBox{
	display: flex;
	justify-content: center;
	align-items: stretch;
	padding: 39px;
	padding-right: 0;
	width: 62%;
	gap: 20px;
}
	#sec_gallery .cnt-flex .figBox > li{
		border: solid 1px #000;
		border-radius: var(--radius-base);
		cursor: pointer;
		width: calc(50% - 10px);
		overflow: hidden;
	}
		#sec_gallery .cnt-flex .figBox > li .fig{
			display: block;
			background: url("../img/img_seephotos_01.jpg") no-repeat center -1px / 101%;
			width: 100%;
			aspect-ratio: 403/184;
			overflow: hidden;
			transition: 0.3s;
		}
		#sec_gallery .cnt-flex .figBox > li .ttl{
			text-align: left;
			font-size: 24px;
			font-weight: 500;
			padding: 14px 20px;
			border-top: solid 1px #000;
			position: relative;
		}
			#sec_gallery .cnt-flex .figBox > li .ttl::after{
				content: "\2b";
				font-family: "Font Awesome 6 Free";
				font-weight: 700;
				background: #000;
				border-radius: 50%;
				width: 30px;
				height: 30px;
				display: flex;
				justify-content: center;
				align-items: center;
				color: #fff;
				font-size: 12px;
				position: absolute;
				right: 20px;
				top: calc(100% / 2 - 15px);
			}
				#sec_gallery .cnt-flex .figBox > li .ttl br{
					display: none;
				}

#sec_gallery .cnt-flex .figBox > li:hover .fig{
	opacity: 0.7;
}

#sec_gallery .cnt-flex .figBox > li:first-child{
	background: #dac4f5;
}

#sec_gallery .cnt-flex .figBox > li:last-child{
	background: #ffe66b;
}
	#sec_gallery .cnt-flex .figBox > li:last-child .fig{
		background-image: url("../img/img_seephotos_02.jpg");
	}


@media screen and (max-width: 1440px){
	#sec_gallery .cnt-flex .figBox > li .ttl{
		font-size: clamp(12px,1.6vw,24px);
	}
}

@media screen and (max-width: 1023px){
	#sec_gallery .cnt-flex{
		flex-direction: column;
		margin: 0 -10px;
	}
	#sec_gallery .cnt-flex .txtBox{
		border-right: none;
		border-bottom: dashed 1px #000;
		justify-content: center;
		text-align: center;
		width: 100%;
		padding: 39px 10px;
	}
	#sec_gallery .cnt-flex .figBox{
		flex-direction: column;
		padding: 39px 10px;
		width: 100%;
	}
	#sec_gallery .cnt-flex .figBox > li{
		display: flex;
		justify-content: flex-start;
		align-items: stretch;
		margin: 0 auto;
		max-width: 690px;
		width: 100%;
	}
	#sec_gallery .cnt-flex .figBox > li .fig{
		border-right: solid 1px #000;
		background-image: url("../img/img_seephotos_sp_01.jpg");
		background-size: 103%;
		background-position: center -2px;
		aspect-ratio: 642 / 500;
		max-width: 321px;
		width: 100%;
	}
	#sec_gallery .cnt-flex .figBox > li:last-child .fig{
		background-image: url("../img/img_seephotos_sp_02.jpg");
	}
	#sec_gallery .cnt-flex .figBox > li .ttl{
		font-size: 24px;
		border: none;
		padding-top: 30px;
		width: 100%;
	}
	#sec_gallery .cnt-flex .figBox > li .ttl::after{
		top: auto;
		right: 15px;
		bottom: 15px;
	}
	#sec_gallery .cnt-flex .figBox > li .ttl br{
		display: inherit;
	}
}

@media screen and (max-width: 768px){
	#sec_gallery .cnt-flex .figBox > li .ttl{
		font-size: clamp(14px,4.5vw,24px)
	}
}


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

/*  モーダル

/* ------------------------------------------------------------------------ */
.remodal{
	max-height: 400px;
}
.remodal.remodal-is-opened{
	max-height: inherit;
}
.remodal .section_cards {
	opacity: 0;
}

.remodal.remodal-is-opened .section_cards {
	opacity: 1;
	transition: opacity .2s ease;
}
.remodal{
	border: solid 1px #000;
	border-radius: 10px;
	padding: 30px 98px 45px;
	margin-bottom: 0;
	max-width: 860px;
	width: 100%;
}
.remodal-facility{
	background: #dac4f5;
}
.remodal-class{
	background: #ffe66b;
}

.remodal figure{
	border: solid 1px #000;
	border-radius: 10px;
	aspect-ratio: 660/410;
	width: 100%;
	overflow: hidden;
}
	.remodal figure img{
		width: 100%;
		height: 100%;
		object-fit: cover;
	}

.remodal .txtBox{
	margin-top: 30px;
	text-align: left;
	color: #000;
}
	.remodal .txtBox p{
		line-height: 1.75;
		margin-top: 12px;
	}
	.remodal .txtBox .ttl{
		font-size: 26px;
		font-weight: 500;
		margin-top: 0;
	}

.remodal-close{
	max-width: 200px;
	background: #000;
	border-radius: 25px;
	color: #fff;
	line-height: 50px;
	position: absolute;
	top: auto;
	bottom: -25px;
	left: calc(100% / 2 - 100px);
	height: auto;
	width: 100%;
	transition: 0.3s;
}
	.remodal-close:before{
		content: "\f00d";
		font-size: 16px;
		font-family: "Font Awesome 6 Free" !important;
		font-weight: 700;
		top: calc(100% / 2 - 18px);
		right: 10px;
		left: auto;
	}

.remodal-close:hover,
.remodal-close:focus{
	color: #fff;
	background: #555;
}


@media screen and (max-width: 768px){
	.remodal{
		padding: 30px 10% 45px;
	}
	.remodal .txtBox{
		margin-top: 20px;
	}
	.remodal .txtBox .ttl{
		font-size: 20px;
	}
}

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

/*  警察学校の一日

/* ------------------------------------------------------------------------ */
#sec_day{
	background: url("../img/bg_check.png");
	background-size: 20px 20px;
	padding: 60px 0;
	border-bottom: solid 1px #000;
}

#sec_day > .content{
	max-width: 860px;
}

#sec_day .list-day{
	margin-top: 30px;
}

#sec_day .list-day .cnt-flex{
	display: flex;
	align-items: flex-start;
	justify-content: flex-start;
	flex-direction: row;
	padding-top: 20px;
}
#sec_day .list-day .cnt-flex.not-box + .cnt-flex.not-box{
	padding-top: 3px;
}

#sec_day .list-day .timeBox{
	display: flex;
	justify-content: space-between;
	align-items: center;
	width: 172px;
	flex-shrink: 0;
	margin-right: 18px;
	position: relative;
	z-index: 6;
}

#sec_day .list-day .timeBox .time{
	font-size: 18px;
	font-weight: 500;
}

#sec_day .list-day .circle{
	display: flex;
	justify-content: center;
	align-items: center;
	flex-direction: column;
	width: 100px;
}
	#sec_day .circle .in{
		background: #fff;
		border: solid 2px #00aeef;
		border-radius: 50%;
		width: 20px;
		height: 20px;
	}
	#sec_day .circle.txt .in{
		display: flex;
		justify-content: center;
		align-items: center;
		flex-direction: column;
		background: #00aeef;
		border: none;
		color: #fff;
		font-size: 22px;
		font-weight: 900;
		line-height: 1;
		width: 100px;
		height: 100px;
	}
		#sec_day .circle.txt .in::before,
		#sec_day .circle.txt .in::after{
			font-family: "Font Awesome 6 Free";
			font-size: 18px;
		}
		#sec_day .circle.txt .in::before{
			content: "\f062";
			margin-bottom: 0.6em;
			color: #00aeef;
		}
		#sec_day .circle.txt .in::after{
			content: "\f063";
			margin-top: 0.6em;
		}
		#sec_day .list-day li:last-child .circle.txt .in::after{
			color: #00aeef;
		}


#sec_day .list-day .txtBox {
	background: #fff;
	border: solid 1px #000;
	border-radius: var(--radius-base);
	padding: 20px;
}
	#sec_day .list-day .txtBox figure{
		border-radius: var(--radius-base);
		overflow: hidden;
		margin-right: 20px;
		max-width: 220px;
		width: calc(60% - 20px);
	}

	#sec_day .list-day .txtBox p{
		text-align: left;
		padding-top: 0.8em;
		line-height: 1.75;
		width: 60%;
	}

#sec_day .list-day .line{
	position: relative;
	z-index: 5;
}

#sec_day .list-day .line::before{
	content: "";
	display: block;
	width: 6px;
	height: calc(100% + 46px);
	position: absolute;
	top: -24px;
	left: -72px;
	background: #91d3eb;
	z-index: -1;
}
#sec_day .list-day .txt.line::before{
	left: -71px;
}
#sec_day .list-day li:first-child .line::before{
	content: none;
}

#sec_day .list-day .cnt-flex.not-box .line::before{
	top: -6px;
}

#sec_day .list-day .last-none .line::before{
	height: 120px;
}

#sec_day .pointContainer{
	background: #baf0a8;
	border: solid 1px #000;
	border-radius: var(--radius-base);
	overflow: hidden;
	padding: 20px;
	padding-left: 40px;
	margin-top: 60px;
	display: flex;
	justify-content: space-between;
	align-items: center;
}

#sec_day .pointContainer figure{
	max-width: 290px;
	width: 100%;
	aspect-ratio: 290/180;
	border-radius: var(--radius-base);
	overflow: hidden;
	margin-left: 35px;
}

#sec_day .pointContainer .txtBox{
	text-align: left;
}

#sec_day .pointContainer .lead{
	font-size: 26px;
	font-weight: 500;
	margin-bottom: 25px;
	position: relative;
	z-index: 5;
}
	#sec_day .pointContainer .lead::before{
		content: "";
		display: block;
		background: url("../img/p_point.png") no-repeat center / contain;
		max-width: 101.5px;
		aspect-ratio: 203/130;
		width: 100%;
		position: absolute;
		top: -40px;
		left: -30px;
		z-index: -1;
	}

@media screen and (max-width: 767px){
	#sec_day{
		background-size: 10px;
	}
	#sec_day .list-day,
	#sec_day .list-day .timeBox .time{
		font-size: 14px;
	}
	
	#sec_day .list-day .cnt-flex{
		padding-top: 10px;
	}
	#sec_day .list-day .timeBox{
		margin-right: 10px;
		width: 122px;
	}
	#sec_day .list-day .circle{
		width: 72px;
	}
	#sec_day .circle .in{
		width: 12px;
		height: 12px;
		border-width: 1px;
	}
	#sec_day .circle.txt .in{
		font-size: 16px;
		font-weight: 700;
		width: 72px;
		height: 72px;
	}
	#sec_day .circle.txt .in::before,
	#sec_day .circle.txt .in::after{
		font-size: 13px;
	}
	#sec_day .list-day .line::before{
		top: -15px;
		left: -50px;
	}
	#sec_day .list-day .txt.line::before {
		left: -49px;
	}
	#sec_day .list-day .last-none .line::before{
		height: 75px;
	}
	
	#sec_day .list-day .txtBox{
		flex-direction: column;
		padding: 15px;
	}
		#sec_day .list-day .txtBox figure{
			width: 100%;
			max-width: 241px;
			margin: 0 auto;
		}
		#sec_day .list-day .txtBox p{
			line-height: 1.4;
			width: 100%;
		}
	
	#sec_day .pointContainer{
		flex-direction: column;
		padding: 30px 15px 15px;
	}
	#sec_day .pointContainer .lead{
		font-size: 20px;
		margin-bottom: 10px;
	}
	#sec_day .pointContainer p{
		font-size: 14px;
	}
	#sec_day .pointContainer figure{
		margin: 15px auto 0;
		max-width: 430px;
	}
	
	#sec_day .pointContainer .lead::before{
		max-width: 81px;
		top: -34px;
		left: -15px;
	}
}



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

/*  一人前の警察官になるまで

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

#sec_until{
	padding: 60px 0;
	border-bottom: solid 1px #000;
}

#sec_until > .content{
	max-width: 860px;
}

#sec_until .lead{
	font-size: 18px;
	line-height: 1.889;
}

#sec_until .gridContainer{
	display: grid;
	grid-template-columns: 1fr 1fr;
	grid-template-rows: 1fr auto;
	gap: 0 40px;
	margin-top: 40px;
}
	#sec_until .gridContainer .end{
		grid-column: 1/3;
		background: #00aeef;
		color: #fff;
		border: solid 1px #000;
		font-size: 28px;
		font-weight: 900;
		border-radius: var(--radius-base);
		padding: 18px 10px;
	}

#sec_until .grid-cnt__box{
	display: grid;
	grid-template-columns: 60px 1fr;
	grid-template-rows: 60px 1fr;
	gap: 20px 17px;
}
	#sec_until .grid-cnt__box .hd-top{
		font-size: 28px;
		font-weight: 900;
		color: #fff;
		border: solid 1px #000;
		border-radius: var(--radius-base);
		grid-column: 1/3;
		place-content: center;
	}
		#sec_until .grid-cnt__box .hd-top br{
			display: none;
		}

	#sec_until .grid-cnt__box .months{
		font-weight: 900;
		position: relative;
		z-index: 1;
	}
	#sec_until .grid-cnt__box .months::before,
	#sec_until .grid-cnt__box .months::after{
		content: "";
		display: block;
		position: absolute;
	}
		#sec_until .grid-cnt__box .months::before{
			width: 2px;
			height: calc(100% - 33px);
			bottom: 3px;
			left: calc(100% / 2 - 1px);
		}
		#sec_until .grid-cnt__box .months::after{
			width: 0;
			height: 0;
			border-style: solid;
			border-right: 8px solid transparent;
			border-left: 8px solid transparent;
			border-top: 19px solid transparent;
			border-bottom: 0;
			bottom: 0;
			left: calc(100% / 2 - 8px);
		}

#sec_until .grid-cnt__box ul{
	display: grid;
	grid-template-columns: 1fr;
	grid-template-rows: 1fr 1fr 1fr 1fr;
	gap: 30px 0;
	margin-bottom: 40px;
}
	#sec_until .grid-cnt__box li{
		border-radius: var(--radius-base);
		font-size: 18px;
		font-weight: 500;
		padding: 15px 20px 28px;
		text-align: left;
		position: relative;
		z-index: 1;
	}
		#sec_until .grid-cnt__box li::before{
			content: "\f107";
			font-family: "Font Awesome 6 Free";
			font-weight: 700;
			font-size: 26px;
			line-height: 1.3;
			display: block;
			position: absolute;
			top: 100%;
			left: 50%;
			transform: translateX(-50%);
		}
		#sec_until .grid-cnt__box li .label{
			display: block;
			font-size: 14px;
			font-weight: 500;
			text-align: center;
			position: absolute;
			right: 0;
			bottom: 10px;
			line-height: 24px;
			padding: 0 10px;
		}


/* BOX毎の色 */
#sec_until .grid-cnt__box.box-1 .hd-top,
#sec_until .grid-cnt__box.box-1 li .label,
#sec_until .grid-cnt__box.box-1 .months::before{
	background: var(--color-blue1);
}
#sec_until .grid-cnt__box.box-2 .hd-top,
#sec_until .grid-cnt__box.box-2 li .label,
#sec_until .grid-cnt__box.box-2 .months::before{
	background: var(--color-pink1);
}
#sec_until .grid-cnt__box.box-1 li{
	background: var(--color-blue2);
}
#sec_until .grid-cnt__box.box-2 li{
	background: var(--color-pink2);
}
#sec_until .grid-cnt__box.box-1 .months::after{
	border-top-color: var(--color-blue1);
}
#sec_until .grid-cnt__box.box-2 .months::after{
	border-top-color: var(--color-pink1);
}
#sec_until .grid-cnt__box.box-1 li::before{
	color: var(--color-blue1);
}
#sec_until .grid-cnt__box.box-2 li::before{
	color: var(--color-pink1);
}

#sec_until .list{
	display: flex;
	justify-content: space-between;
	align-items: stretch;
	gap: 20px;
	margin-top: 20px;
	text-align: left;
}
	#sec_until .list li{
		background: #e6facd;
		border-radius: var(--radius-base);
		padding: 32px 16px 25px;
		width: calc(100% / 4);
	}
		#sec_until .list .ttl{
			font-size: 18px;
			font-weight: 500;
			margin-bottom: 10px;
		}
		#sec_until .list p{
			font-size: 14px;
		}

@media screen and (max-width: 768px){
	#sec_until .hd04{
		font-size: var(--font-hd04);
	}
	
	#sec_until .lead{
		font-size: 16px;
	}
	
	#sec_until .gridContainer{
		gap: 0 20px;
	}
	#sec_until .grid-cnt__box{
		grid-template-columns: 50px 1fr;
		grid-template-rows: auto 1fr;
		gap: 15px 3px;
	}
	#sec_until .grid-cnt__box .hd-top{
		font-size: clamp(14px,4.5vw,20px);
		font-weight: 600;
		padding: 8px 10px;
	}
		#sec_until .grid-cnt__box .hd-top br{
			display: inherit;
		}
	
	#sec_until .grid-cnt__box .months{
		font-size: 14px;
	}
		#sec_until .grid-cnt__box .months::before{
			width: 1px;
			height: calc(100% - 25px);
			left: calc(100% / 2);
		}
		#sec_until .grid-cnt__box .months::after{
			border-right-width: 6px;
			border-left-width: 6px;
			border-top-width: 14px;
			left: calc(100% / 2 - 6px);
		}
	
	#sec_until .grid-cnt__box ul{
		gap: 20px 0;
	}
		#sec_until .grid-cnt__box li{
			font-size: clamp(10px,3.3vw,14px);
			text-align: center;
			padding: 10px 10px 35px;
		}
			#sec_until .grid-cnt__box li::before{
				font-size: 20px;
			}
	
	#sec_until .grid-cnt__box li .label{
		font-size: 12px;
		font-weight: 400;
		bottom: 0;
		left: 0;
		width: 100%;
		border-bottom-right-radius: var(--radius-base);
		border-bottom-left-radius: var(--radius-base);
	}
	
	#sec_until .gridContainer .end{
		font-size: clamp(14px,5vw,22px);
	}
	
	#sec_until .list{
		flex-wrap: wrap;
		gap: 5px;
	}
		#sec_until .list li{
			padding: 20px;
			width: calc(100% / 2 - 2.5px);
		}
	#sec_until .list .ttl{
		font-size: 15px;
	}
	#sec_until .list p{
		font-size: 12px;
	}
}


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

/*  入校生の声

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

#sec_voice .hd04{
	margin: 0;
	padding: 35px 10px;
	border-bottom: 1px solid #000;
}

.voiceTop{
	border-bottom: 1px solid #000;
}

.voiceTop_flex{
	display: flex;
	justify-content: flex-start;
	align-items: center;
	border-right: solid 1px #000;
}
.voiceTop1 .voiceTop_flex{
	background: #fad2a5;
}
.voiceTop2 .voiceTop_flex{
	background: #c9f5f2;
}

.voiceTop_title{
	padding-left: 40px;
}
.voiceTop .voiceTop_title{
	max-width: 430px;
	width: 100%;
}
.voiceTop1 .voiceTop_title figure{
	max-width: 369px;
	width: 100%;
}
.voiceTop2 .voiceTop_title figure{
	max-width: 385px;
	width: 100%;
}

.voiceTop_title .time{
	font-size: 26px;
	font-weight: 900;
	text-align: right;
	margin-top: 60px;
}
	.voiceTop_title .time span{
		font-size: 28px;
		font-weight: 900;
	}

.voiceTop_image img{
	width: 702px;
	height: auto;
	aspect-ratio: 700 / 400;
	object-fit: cover;
	border-inline: 1px solid #000;
}

.voice_content{
	background-color: #fff;
	border-right: 1px solid #000;
	border-left: 1px solid #000;
	padding: 60px;
}

.voice_content + .voiceTop{
	border-top: 1px solid #000;
}

.voice_flex{
	margin-top: 60px;
	display: flex;
	gap: 40px;
}
.voice_flex.flex_reverse{
	flex-direction: row-reverse;
}
.voice_flex .voice_image{
	max-width: 550px;
	width: 100%;
	flex: 1;
}

.voice_flex img{
	width: 100%;
	height: 100%;
	object-fit: cover;
	border-radius: 10px;
}

.voice_text{
	margin-top: 27px;
	display: block;
	flex: 1;
	width: auto;
	text-align: left;
}
	.voice_text h3{
		font-size: 40px;
	}
	.voice_text p{
		font-size: 18px;
		line-height: 1.889;
		margin-top: 1em;
	}


@media screen and (max-width: 1100px) {
	.voiceTop_title{
		width: 100%;
		border-right: none;
		padding-top: 50px;
		padding-inline: 20px;
		padding-bottom: 20px;
		margin: 0 auto;
	}
	.voiceTop_flex{
		flex-direction: column-reverse;
		border-left: solid 1px #000;
	}
	.voiceTop_image img{
		border: none;
		margin: 0 auto;
		width: 100%;
	}
	.voiceTop_image{
		border-top: solid 1px #000;
		width: 100%;
	}
}

@media screen and (max-width: 1000px) {
	.voice_flex{
		flex-direction: column;
		gap: 0px;
	}
	.voice_flex.flex_reverse{
		flex-direction: column;
	}
	.voice_flex .voice_image{
		width: 100%;
		margin-inline: auto;
	}
}
@media screen and (max-width: 768px) {
	.voice_content{
		padding: 40px 20px 50px;
	}
	.voice_flex img{
		border-radius: 5px;
	}
	.voice_text{
		margin-top: 30px;
	}
	.voice_text h3{
		font-size: 27px;
	}
	.voice_text p{
		font-size: 14px;
		line-height: 23px;
	}
	.voiceTop .voiceTop_title figure{
		margin: 0 auto;
	}
	.voiceTop1 .voiceTop_title figure{
		width: 70%;
	}
	.voiceTop2 .voiceTop_title figure{
		width: 80%;
	}
	.voiceTop_title .time{
		text-align: center;
		margin-top: 20px;
	}
}



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

/*  教官からのメッセージ

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

#sec_message{
	border-top: solid 1px #000;
	border-bottom: solid 1px #000;
}

#sec_message .hd04{
	text-align: left;
	font-size: 48px;
	font-weight: 900;
	color: #fff;
	-webkit-text-stroke: 1.5px #000;
}

#sec_message > .content{
	background: #eee0ff;
	border-right: solid 1px #000;
	border-left: solid 1px #000;
	padding: 60px;
}

#sec_message .messageBox{
	display: flex;
	justify-content: flex-start;
	align-items: flex-start;
	text-align: left;
}

#sec_message .messageBox figure{
	aspect-ratio: 1/1;
	border-radius: 50%;
	border: solid 1px #000;
	overflow: hidden;
	margin-right: 40px;
	max-width: 302px;
	width: 40%;
}

#sec_message .messageBox .txtBox{
	font-size: 18px;
	line-height: 1.889;
	position: relative;
	background: #fff;
	border: solid 1px #000;
	border-radius: var(--radius-base);
	padding: 30px;
	width: calc(100% - 302px);
}
#sec_message .messageBox .txtBox::before,
#sec_message .messageBox .txtBox::after{
	content: "";
	position: absolute;
	border-style: solid;
}

/* 左向き */
#sec_message .messageBox .txtBox::before{
	top: 29px;
	right: 100%;
	border-width: 9px 21px 9px 0;
	border-color: transparent #000 transparent transparent;
}
#sec_message .messageBox .txtBox::after{
	top: 30px;
	right: 100%;
	margin-right: -1px;
	border-width: 8px 20px 8px 0;
	border-color: transparent #fff transparent transparent;
}

#sec_message .messageBox .txtBox p + p{
	margin-top: 1em;
}

@media screen and (max-width: 768px){
	#sec_message > .content{
		padding: 50px 15px;
	}
	#sec_message .hd04{
		text-align: center;
		font-size: clamp(14px,8vw,48px);
		-webkit-text-stroke: 1px #000;
	}
	#sec_message .messageBox{
		flex-direction: column;
	}
	#sec_message .messageBox figure{
		margin: 0 auto 20px;
		width: 58%;
	}
	#sec_message .messageBox .txtBox{
		border-radius: var(--radius-base);
		font-size: 14px;
		padding: 15px;
		width: 100%;
	}
	#sec_message .messageBox .txtBox::before{
		border-width: 0 7px 17px 7px;
		border-color: transparent transparent #000 transparent;
		top: auto;
		right: auto;
		bottom: 100%;
		left: calc(100% / 2 - 8.5px);
	}
	#sec_message .messageBox .txtBox::after{
		border-width: 0 6px 16px 6px;
		border-color: transparent transparent #fff transparent;
		top: auto;
		right: auto;
		bottom: 100%;
		left: calc(100% / 2 - 7px);
		margin: 0px;
	}
}




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

/*  関連リンク

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

#sec_link{
	padding: 60px 0;
}
#sec_link > .content{
	max-width: 560px;
}

#sec_link .btn{
	max-width: 260px;
	height: 50px;
	background-color: #000;
	color: #fff;
	font-size: 16px;
	margin: 0 auto;
}
#sec_link .cnt-flex{
	gap: 40px;
}
#sec_link .cnt-flex li{
	width: calc(100% / 2);
}

@media screen and (max-width: 768px){
	#sec_link .cnt-flex{
		gap: 20px;
	}
	#sec_link .cnt-flex li{
		width: 100%;
	}
}