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

#project-base{
	margin-top: 5%;
	padding-left: 7%;
	padding-right: 7%;
	font-size: 1.7vw;
	min-height: 60vw;
	line-height: 2.5;
}


h2{
	font-size: 4.5vw;
	margin: 1% 0% 5% 0%;
	color: #1962A3;
	text-align: center;
}
@media screen and (max-width: 480px) {
	h2{
	font-size: 5.5vw;
}
}


h3{
	font-size: 2.8vw;
	margin-left: 4%;
}

main p{
	color: #010A4F;
}

.project{
	margin-bottom: 15%;
	align-content: center;
}
@media screen and (max-width: 480px) {
	.project{
	align-content: left;
}
	
	
	.project p{
	font-size: 3vw;
	align-content: left;
}
}


.lead-text{
	margin-bottom: 10vw;
	text-align: center;
}
@media screen and (max-width: 480px) {
	.lead-text{
	text-align: left;
}
}

.chu{
	color: #47763c;
	text-decoration-line: underline;
}

.ppb-block{
	display:flex;
	margin-bottom: 10%;
}

.mini-contents{
	flex: 2;
	align-content: center;
	line-height: 1.5;
	color: white;
}

.cabinet-page-bottun{
	display:flex;
	font-size: 1.8vw;
	justify-content: center;
	align-items: center;
	padding: 1% 3%;
	width: 100%;
	height: 70%;
	margin: 0 4%;
	color: white;
	position: relative;
	background-color: #1962A3;
	z-index: 1;
	transition: 0.5s;
}
@media screen and (max-width: 480px) {
	.cabinet-page-bottun{
	font-size: 2vw;
}
}


.cabinet-page-bottun::before{
	content: "";
	display: block;
	position: absolute;
		top:0;
		left:0;
		width: 100%;
		height: 100%;
	background-color: #47763c;
	z-index: -1;
	transition: 0.4s ease-out;
	
}

.mini-contents:hover .cabinet-page-bottun::before{
	height: 0%;
	transition: 0.4s ease-in;
}

.cabinet-page-bottun2{
	display: flex;
	font-size: 1.8vw;
	justify-content: center;
	align-items: center;
	width: 100%;
	height: 40%;
	margin: 3% 4%;
	padding: 2%;
	color: white;
	position: relative;
	background-color: #1962A3;
	z-index: 1;
	transition: 0.5s;
}


.cabinet-page-bottun2::before{
	content: "";
	display: block;
	position: absolute;
		top:0;
		left:0;
		width: 100%;
		height: 100%;
	background-color: #47763c;
	z-index: -1;
	transition: 0.4s ease-out;
	
}

.mini-contents:hover .cabinet-page-bottun2::before{
	height: 0%;
	transition: 0.4s ease-in;
}

.ccc{
	width: 50%;
	margin: 0% 1%;
}




.explane{
	color: #47763c;
	font-size: 1.5vw;
	padding: 4% 15%;
	width: 100%;
	height: 80%;
	margin: 0 4%;
	background-color: #F6ECC6;
	transition: 0.5s;
}



.attention{
	font-size: 80%;
	width: 100%;
	padding: 1%;
	align-content: center;
	border-width: medium;
	border-style: dashed;
}




.ac-menu:last-child {
  margin-bottom: 60px; /* 最後の要素の下にだけ余白 */
}
.ac-menu input {
  display: none;
}
.ac-menu label {
  color: #fff; /* 文字色 */
  line-height: 2; /* 行間 */
  background-color: #47763c; 
  width: 100%;
  margin-bottom: 3%;
  padding-left: 1%; /* 内側の余白 */
  cursor: pointer;
  position: relative;
  display: block;
  font-size: 1.3em;
}
.ac-menu label:after {
  position: absolute;
  right: 20px; /* 左からの距離 */
  top: 50%; /* 上下中央配置 */
  -webkit-transform : translateY(-50%);
  transform : translateY(-50%);
  content: "＋"; /* アイコン */
}
.ac-menu input:checked ~ label::after {
  content: "?"; /* クリック後のアイコン */
}
.ac-menu .ac-menu-inside {
  height: 0;
  overflow: hidden;
  opacity: 0;
  transition: 0.3s; /* 開閉スピード */
}
.ac-menu input:checked ~ .ac-menu-inside{
  height: auto;
  opacity: 1;
  padding: 20px; /* 中身の枠内の余白 */
  margin-bottom: 5%;
}


.inside-lead{
	padding: 0% 3% 3% 3%;
	margin-bottom: 2%;
}


.inside-lead h3{
	font-size: 1.5em;
	text-align: center;
	margin:2% 0% 4%;
}

.paragraph{
	background-color: #F6ECC6;
	padding: 3%;
	margin-bottom: 5%;
}

.paragraph h4{
	color: #1962A3;
	font-size: 1.2em;
	margin-bottom: 2%;
}

.paragraph p{
	font-size: 90%;
}

.ListBlock{
	padding: 5%;
}

.image-position{
	text-align: center;
}

.image-flex{
	display: flex;
}

.image_02{
	margin: 5%;
}

.number{
	margin-right: 1.5%;
}

h5{
	text-align: center;
	margin-top: 5%;
	margin-bottom: 3%;
}

.atogaki{
	padding: 5%;
	margin-bottom: 5%;
	border-width: medium;
	border-style: solid;
}