@charset "utf-8";
.flex {
	display: flex;
	justify-content: space-between;
	flex-wrap: wrap;
}
#kv img{ min-height: 610px;}
#detail {
	margin-top: 60px;
	padding: 25px;
	background: #eaeff9;
}
#detail .flex > div {
	width: calc(100% / 2 - 12.5px);
	height: 680px;
	margin: 0 0 25px 0;
	padding: 20px 0;
	background: #ffffff;
}
#detail .flex > div .type {
	padding: 10px 20px;
	font-size: 2.2rem;
	color: #ffffff;
	font-weight: bold;
	line-height: 1;
	letter-spacing: 0.1em;
	border-radius: 0 50px 50px 0;
	background: #003279;
	display: inline-block;
}
#detail .flex > div > .cont {
	display: flex;
	flex-flow: column;
	height: calc(100% - 40px);
}
#detail .flex > div > .cont h3 {
	margin-top: 40px;
	padding: 0 25px;
	font-size: 3.4rem;
	font-weight: bold;
	line-height: 1.2;
	display: flex;
	align-items: center;
}
#detail .flex > div > .cont h3 span {
	margin-left: 10px;
}
#detail .flex > div:first-of-type > .cont h3 {
	color: #ca824c;
}
#detail .flex > div:nth-of-type(2) > .cont h3 {
	color: #687b92;
}
#detail .flex > div:nth-of-type(3) > .cont h3 {
	color: #dd5162;
}
#detail .flex > div:nth-of-type(4) > .cont h3 {
	color: #009f87;
}
#detail .flex > div > .cont h4 {
	margin-top: 40px;
	padding: 10px 0;
	font-size: 2.2rem;
	color: #ffffff;
	text-align: center;
	background: #eaeff9;
}
#detail .flex > div:first-of-type > .cont h4 {
	background: #ca824c;
}
#detail .flex > div:nth-of-type(2) > .cont h4 {
	background: #687b92;
}
#detail .flex > div:nth-of-type(3) > .cont h4 {
	letter-spacing: -0.025em;
	background: #dd5162;
}
#detail .flex > div:nth-of-type(4) > .cont h4 {
	background: #009f87;
}
#detail .flex > div > .cont p {
	margin-top: 20px;
	padding: 0 25px;
}
#detail .flex > div > .cont p .note {
	font-size: 1.2rem;
	line-height: 1.5;
	display: block;
}
#detail .flex > div > .cont .img {
	text-align: center;
	margin-top: auto;
}
#detail .flex > a {
	margin: 0 auto;
	display: block;
}
#awd {
	margin-top: 60px;
}
#awd .flex > div {
	width: calc(100% / 4 - 13px);
}
#awd .flex > div .note {
	margin-top: 10px;
	font-size: 1.2rem;
}
#awd .flex > div > div {
	padding: 30px 0 25px;
	text-align: center;
	background: #eeeeee;
	position: relative;
}
#awd .flex > div > div h3 {
	min-width: 230px;
	padding: 10px 25px;
	font-size: 2.2rem;
	color: #ffffff;
	text-align: center;
	font-weight: bold;
	line-height: 1;
	white-space: nowrap;
	border-radius: 50px;
	display: inline-block;
	background: #003279;
	position: absolute;
	top: -20px;
	left: 50%;
	transform: translateX(-50%);
}
#awd .flex > div > div .img {
	margin-top: 20px;
}
#awd .flex > div > div > p {
	font-size: 2rem;
	font-weight: bold;
}
#system {
	margin-top: 60px;
}
#system h2 {
	font-size: 4rem;
	color: #003279;
	text-align: center;
	font-weight: bold;
	line-height: 1.25;
}
#system p {
	margin-top: 25px;
	font-size: 2rem;
	color: #003279;
	text-align: center;
	font-weight: bold;
	line-height: 1;
}
#system img {
	margin: 0 auto;
}
#voice {
	margin-top: 60px;
	padding: 40px 20px 20px;
	text-align: center;
	background: #eeeeee;
}
#voice h2 {
	font-size: 3rem;
	text-align: left;
	font-weight: bold;
	display: flex;
	align-items: center;
}
#voice h2 span {
	margin-left: 1em;
	font-size: 2.4rem;
	line-height: 1.25;
}
#voice .flex {
	margin-top: 40px;
}
#voice .flex .img {
	width: calc(100% / 4 - 12px);
}
#voice a {
	margin: 40px auto 0;
	display: inline-block;
}

@media screen and (max-width: 767px) {
.listType-notes01 > li {
	padding-left: 0;
}
#kv img{min-height: calc(94vw / 1.836);}
#detail {
	margin-top: 30px;
	padding: 10px;
}
#detail .flex {
	display: block;
}
#detail .flex > div {
	width: 100%;
	height: auto;
	margin: 0 0 15px 0;
	padding: 10px 0;
}
#detail .flex > div .type {
	padding: 5px 10px;
	font-size: 1.2rem;
}
#detail .flex > div > .cont {
	display: flex;
	height: auto;
}
#detail .flex > div > .cont h3 {
	margin-top: 20px;
	padding: 0 10px;
	font-size: 1.8rem;
	justify-content: center;
}
#detail .flex > div > .cont h3 span {
	margin-left: 10px;
}
#detail .flex > div > .cont h3 img {
	width: 12vw;
}
#detail .flex > div > .cont h4 {
	margin-top: 20px;
	padding: 5px 0;
	font-size: 1.3rem;
}
#detail .flex > div > .cont p {
	margin-top: 10px;
	padding: 0 10px;
}
#detail .flex > div > .cont p .note {
	font-size: 1.2rem;
	line-height: 1.5;
	display: block;
}
#detail .flex > div > .cont .img {
	padding: 0 10px;
	margin-top: 10px;
}
#awd {
	margin-top: 60px;
}
#awd .flex > div {
	width: calc(100% / 2 - 5px);
	margin: 0 0 30px 0;
}
#awd .flex > div .note {
	margin-top: 5px;
	font-size: 1rem;
}
#awd .flex > div > div {
	padding: 15px 0 10px;
}
#awd .flex > div > div h3 {
	min-width: 160px;
	padding: 5px 10px;
	font-size: 1.5rem;
	top: -12px;
}
#awd .flex > div > div .img {
	margin-top: 10px;
	padding: 0 20px;
}
#awd .flex > div > div > p {
	font-size: 1.2rem;
	font-weight: bold;
}
#system {
	margin-top: 20px;
}
#system h2 {
	font-size: 2rem;
}
#system p {
	margin-top: 12px;
	font-size: 1.2rem;
	line-height: 1.2;
}
#system img {
	margin: 0 auto;
}
#voice {
	margin-top: 30px;
	padding: 20px 10px 10px;
}
#voice h2 {
	font-size: 1.8rem;
	white-space: nowrap;
}
#voice h2 span {
	font-size: 1.2rem;
}
#voice .flex {
	margin-top: 20px;
}
#voice .flex .img {
	width: calc(100% / 4 - 5px);
}
#voice a {
	margin: 20px auto 0;
}
}