/* CSS Document */

#boysGirls {
}




#fv {
}
#fv dl {
	display: flex;
	flex-direction: row-reverse;
	margin: 0 0 40px;
}
#fv dl dt {
	width: 50%;
	position: relative;
  top: -40px;
}
#fv dl dt img {
	max-width: 680px;
}
#fv dl dt.feather::after {
	left: -50px;
	bottom: -50px;
}
#fv dl dd {
	width: 50%;
	display: flex;
  justify-content: flex-end;
}
#fv dl dd .block {
	max-width: 520px;
	margin: 60px 0 0;
	padding: 0 80px 0 0;
  box-sizing: border-box;
}
#fv dl dd .block h2 {
	margin: 0 0 40px;
}
#fv dl dd .block p {
	text-align: justify;
}




#whats {
	padding: 80px 0 40px;
}
#whats .box {
	text-align: justify;
	padding: 40px 70px;
	padding-right: 230px;
	border: 1px solid #000;
	position: relative;
}
#whats .box h3 {
	background: #f2f2e9;
	position: absolute;
	top: -18px;
  left: -5px;
	padding: 0 30px 15px 0;
}
#whats .box h3::after {
	content: url("../module/img/line_end.svg");
	width: 23px;
  position: absolute;
  right: -7px;
  top: 5px;
}
#whats .box .boyGirl {
	position: absolute;
  width: 180px;
  right: 20px;
  bottom: -50px;
}




#example {
	padding: 80px 0;
}
#example .block {
	margin: 30px 0;
	display: flex;
	gap: 40px;
}
#example .block dl {
	padding: 0 0 30px;
	position: relative;
}
#example .block dl::before,
#example .block dl::after {
	position: absolute;
}
#example .block dl::before {
	content: url("../module/img/tokyo_green_feather.svg");
	width: 130px;
	bottom: 10px;
	right: 0;
	line-height: 0;
}
#example .block dl::after {
	content: '';
	width: 100%;
	border: solid #000;
	border-width: 1px 0;
	height: 5px;
	bottom: 0;
}
#example .block dl dt {
	position: relative;
}
#example .block dl dt img {
	clip-path: polygon(0 50px, 70px 0, 100% 0px, 100% 100%, 0px 100%);
}
#example .block dl dt em {
	font-family: 'Geometos Rounded';
  font-size: 300%;
  font-weight: 400;
  color: #51AB51;
	position: absolute;
	top: -5px;
	left: -10px;
	z-index: 1;
}
#example .block dl dd {
	padding: 10px;
}
#example .block dl dd h4 {
	font-size: 110%;
	font-weight: 600;
	margin: 10px 0;
}
#example .block dl dd ul {
	list-style: disc;
	padding-left: 1em;
	margin: 15px 0;
}
#example .block dl dd ul li {
	line-height: 1.2em;
  margin: 8px 0;
}




#grants {
	padding: 80px 0 40px;
	background: #fff;
}
#grants h2 {
	align-items: center;
}
#grants .block {
	max-width: 680px;
	margin: 40px auto;
}
#grants .block h3 {
	font-size: 110%;
	font-weight: 600;
	line-height: 1.4em;
  padding: 10px 0;
	margin: 0 0 15px;
	border-bottom: 1px solid #000;
	display: flex;
	justify-content: center;
	align-items: center;
	gap: 5px;
	position: relative;
}
#grants .block h3::before {
	content: url("../module/img/i_feather.svg");
	width: 20px;
	line-height: 0;
	flex-shrink: 0;
}
#grants .block p {
	text-align: center;
	margin: 0 0 20px;
}
#grants .block ol {
	list-style: none;
	margin: 0 40px;
	line-height: 1.6em;
}
#grants #grants01.block ol > li {
	text-indent: -2.8em;
  padding: 0 0 0 2.8em;
	margin: 5px 0;
}
#grants #grants01.block ol li ul {
	list-style: disc;
	padding: 0 0 0 1em;
}
#grants #grants01.block ol li ul li {
	text-indent: 0;
  padding: 0;
}


#grants #grants02.block ol li {
	margin: 5px 0;
	display: flex;
	gap: 20px;
}
#grants #grants02.block ol li em {
	width: 140px;
}
#grants #grants02.block ol li a:hover {
	text-decoration: underline;
}
#grants #grants02.block ol li address {
	text-indent: 0;
}



#formation {
	padding: 80px 0 200px;
	background: #fff;
}
#formation h2 {
	align-items: center;
}
#formation .block {
	text-align: center;
	max-width: 760px;
	margin: 40px auto;
}
#formation .block address {
	text-align: center;
	max-width: 600px;
	margin: 20px auto;
	border-top: 1px solid #000;
	padding: 20px;
}
#formation .block address strong {
	display: flex;
  justify-content: center;
  gap: 10px;
}
#formation .block address strong em {
	font-size: 120%;
}







@media screen and (max-width: 480px) {
  
	#boysGirls {
		padding: 40px 0;
	}
	#fv dl {
		flex-direction: column-reverse;
		margin: 0 30px 40px;
	}
	#fv dl dt {
		width: auto;
		top: 0;
		margin: 30px 0 0;
	}
	#fv dl dt.feather::after {
		width: 40px;
		left: -20px;
		bottom: -20px;
	}
	#fv dl dt img {
		max-width: 100%;
	}
	#fv dl dd {
		width: auto;
	}
	#fv dl dd .block {
		margin: 0;
		padding: 0;
	}
	#fv dl dd .block h2 {
		margin: 0 0 30px;
	}
	
	
	#whats {
		padding: 40px 0;
	}
	#whats .box {
		padding: 30px 20px 60px;
	}
	#whats .box h3 {
		top: -15px;
		padding: 0 30px 10px 0;
	}
	#whats .box .boyGirl {
		width: 80px;
		right: 10px;
		bottom: -30px;
	}
	
	
	#example {
		padding: 40px 0;
	}
	#example .block {
		margin: 40px 0 0;
		flex-direction: column;
		gap: 60px;
	}
	#example .block dl dd h4 {
		margin: 5px 0;
	}
	#example .block dl dd ul {
		margin: 10px 0;
	}
	#example .block dl dd ul li {
		margin: 5px 0;
	}
	
	
	#grants {
		padding: 40px 0;
	}
	#grants .block {
		margin: 30px 0 50px;
	}
	#grants .block p {
		text-align: left;
		margin: 0 0 30px;
	}
	#grants .block ol {
		margin: 0;
	}
	#grants #grants02.block ol li {
		margin: 20px 0;
		flex-direction: column;
		align-items: flex-start;
		gap: 5px;
	}
	#grants #grants01.block ol > li {
		margin: 20px 0;
	}
	#grants #grants02.block ol li a {
		margin-left: 2.8em;
		align-items: flex-end;
	}
	#grants #grants02.block ol li a::after {
		top: -3px;
	}
	#grants #grants02.block ol li address {
		margin-left: 2.8em;
	}
	
	
	#formation {
		padding: 40px 0 160px;
	}
	#formation .block {
		text-align: left;
		margin: 30px auto;
	}
	#formation .block address {
		text-align: left;
		padding: 15px 0;
	}
	#formation .block address strong {
		justify-content: flex-start;
	}
	
	
	
	
	
}
