@charset "UTF-8";

/*//////////////// 共通 //////////////////*/



/*//////////////// セクション1 /////////////////*/
.sec1 h2 {
	color: #005584;
	text-align: center;
	font-size: 1.35rem;
}


@media (min-width: 768px) {
	.sec1 h2 {
		font-size: 1.5rem;
	}
}


@media (min-width: 992px) {
	.sec1 .container, .sec2 .container {
		max-width: 880px;
	}
}


@media (min-width: 1200px) {
	.sec1 .container, .sec2 .container {
		max-width: 1000px;
	}
}


/*//////////////// セクション2 /////////////////*/
.sec2 h1 {
	font-family: 'Noto Serif JP', serif;
	font-size: 1.55rem;
	font-weight: 700;
	letter-spacing: 0.1rem;
	color: #fff;
	background-color: #203864;
	padding: 0.7rem;
	margin-bottom: 0;
}

.sec2 .box {
	padding: 2rem 0;
}

.sec2 h2 {
	font-family: 'Noto Serif JP', serif;
	font-size: 1.4rem;
	text-align: center;
	font-weight: 600;
	color: #203864; 
	border: 1px solid #203864;
	padding: 0.7rem;
}

.sec2 h2 span, .sec2 h3 span {
	font-size: 1rem;
}

.sec2 .title {
	border-left: 10px solid #203864;
	padding-left: 0.5rem;
}

.sec2 h3 {
	color: #203864;
	font-size: 1.3rem;
	font-weight: 700;
	display: inline-block;
	margin: 0 0.5rem 0 0;
}

.sec2 .maker {
	color: #203864; 
	font-size: 0.9rem;
}

.sec2 h4 {
	color: #203864;
	font-size: 1.1rem;
	display: block;
	margin-top: 0.25rem;
}

.sec2 ul {
	padding: 0;
	margin-left: -0.25rem;
	list-style: none;
}

.sec2 ul li {
	display: inline-block;
	margin-right: 0.5rem;
}

.sec2 .fac .row {
	padding: 1.6rem 0;
	border-bottom: 1px solid #A6A6A6;
}

.sec2 .fac .row:last-child {
	border-bottom: none;
	padding-bottom: 0.8rem;
}

.sec2 .fac img {
	display: block;
	margin-left: auto;
	margin-right: auto;
}

.sec2 h5 {
	font-size: 1.15rem;
	font-size: 600;
	margin: 0.5rem;
	text-align: center;
}

.sec2 table {
	width: 100%;
}

.sec2 table th {
	background-color: #879cb2;
	color: #fff;
	font-weight: 400;
	text-align: center;
	padding: 0.5rem 0;
	width: 100%;
	display: block;
}

.sec2 table td {
	padding: 0.8rem 0;
	text-align: center;	
	width: 100%;
	display: block;
}

.sec2 table tr td:last-child {
	padding-bottom: 2rem;
}

.sec2 .w-65 {
	width: 65%;
}

.sec2 .w-90 {
	width: 90%;
}



@media (min-width: 768px) {
	.sec2 h1 {
		font-size: 1.7rem;
		padding: 0.8rem;
	}

	.sec2 .box {
		padding: 2.6rem 0;
	}
	
	.sec2 h2 {
		font-size: 1.5rem;
		width: 50%;
		display: block;
		margin-left: auto;
		margin-right: auto;
	}

	.sec2 h3 {
		font-size: 1.3rem;
		line-height: 1.4em;
	}

	.sec2 .maker {
		font-size: 1rem;
	}

	.sec2 h4 {
		font-size: 1.2rem;
	}

	.sec2 ul li {
		display: block;
		margin-right: 0;
	}

	.sec2 .fac .row {
		padding: 2rem 0;
	}

	.sec2 h5 {
		text-align: left;
	}
	
	.sec2 table {
		width: 100%;
		border: 2px solid #b3b3b3;
	}

	.sec2 table th {
		padding: 0.7rem;
		width: auto;
		display: table-cell;
		border: 1px solid #b3b3b3;
	}

	.sec2 table th:first-child {
		background-color: #879cb2;
	}

	.sec2 table td {
		padding: 0.7rem;
		width: auto;
		display: table-cell;
		border: 1px solid #b3b3b3;
	}
	
	.sec2 table tr td:last-child {
		padding-bottom: 0.7rem;
	}
	
	.sec2 .w-45 {
		width: 45%;
	}
	
	.sec2 .w-md-70 {
		width: 70%;
	}	
}


@media (min-width: 992px) {
	.sec2 h1 {
		padding: 1rem;
	}

	.sec2 .box {
		padding: 3rem 0;
	}
	
	.sec2 h2 {
		font-size: 1.55rem;
		width: 40%;
		display: block;
		margin: 0 auto 1.5rem;
	}

	.sec2 .fac .row {
		padding: 2.4rem 0;
	}

	.sec2 table th {
		padding: 1rem;
	}

	.sec2 table td {
		padding: 1rem;
	}
	
	.sec2 table tr td:last-child {
		padding-bottom: 1rem;
	}
}


/*//////////////// アコーディオン /////////////////*/
.s_04 .accordion_one {
  width: 100%;
  margin: 0 auto;
}

.s_04 .accordion_one .accordion_header {
  background-color: #224F7F;
  color: #fff;
	border-bottom: 1px solid #F2F2F2;
  text-align: center;
	padding: 0.75rem 0;
  position: relative;
  z-index: +1;
  cursor: pointer;
  transition-duration: 0.2s;
}

.s_04 .accordion_one .accordion_header:hover {
  background-color: #2493BA;
}

.s_04 .accordion_one .accordion_header .i_box {
  display: flex;
  justify-content: center;
  align-items: center;
  position: absolute;
  top: 50%;
  right: 3%;
  width: 40px;
  height: 40px;
  margin-top: -20px;
  box-sizing: border-box;
  -webkit-transform: rotate(45deg);
  transform: rotate(45deg);
  transform-origin: center center;
  transition-duration: 0.2s;
}

.s_04 .accordion_one .accordion_header.stay .i_box {
  -webkit-transform: rotate(0deg);
  transform: rotate(0deg);
}

.s_04 .accordion_one .accordion_header .i_box .one_i {
  display: block;
  width: 18px;
  height: 18px;
  -webkit-transform: rotate(45deg);
  transform: rotate(45deg);
  transform-origin: center center;
  transition-duration: 0.2s;
  position: relative;
}

.s_04 .accordion_one .accordion_header.stay .i_box .one_i {
  -webkit-transform: rotate(0deg);
  transform: rotate(0deg);
}

.s_04 .accordion_one .accordion_header.stay.open .i_box .one_i {
  -webkit-transform: rotate(45deg);
  transform: rotate(45deg);
}

.s_04 .accordion_one .accordion_header.open .i_box {
  -webkit-transform: rotate(-360deg);
  transform: rotate(-360deg);
}

.s_04 .accordion_one .accordion_header.stay.open .i_box {
  -webkit-transform: rotate(315eg);
  transform: rotate(315deg);
}

.s_04 .accordion_one .accordion_header .i_box .one_i:before, .s_04 .accordion_one .accordion_header .i_box .one_i:after {
  display: flex;
  content: '';
  background-color: #fff;
  border-radius: 10px;
  width: 18px;
  height: 4px;
  position: absolute;
  top: 7px;
  left: 0;
  -webkit-transform: rotate(0deg);
  transform: rotate(0deg);
  transform-origin: center center;
}

.s_04 .accordion_one .accordion_header .i_box .one_i:before {
  width: 4px;
  height: 18px;
  top: 0;
  left: 7px;
}

.s_04 .accordion_one .accordion_header.stay .i_box .one_i:before {
  content: none;
}

.s_04 .accordion_one .accordion_header.open .i_box .one_i:before {
  content: none;
}

.s_04 .accordion_one .accordion_header.stay.open .i_box .one_i:before {
  content: "";
}

.s_04 .accordion_one .accordion_header.open .i_box .one_i:after {
  -webkit-transform: rotate(-45deg);
  transform: rotate(-45deg);
}

.s_04 .accordion_one .accordion_header.stay.open .i_box .one_i:after {
  -webkit-transform: rotate(0deg);
  transform: rotate(0deg);
}

.s_04 .accordion_one .accordion_inner {
  display: none;
  box-sizing: border-box;
}

.s_04 .accordion_one .accordion_inner.stay {
  display: block;
}

.s_04 .accordion_one .accordion_inner .box_one {
  height: auto;
}

.s_04 .accordion_one .accordion_inner p.txt_a_ac {
  margin: 0;
}












