/* ---------------------------
PAGE AD
----------------------------*/
.page-aa h2 {
	position: absolute;
	bottom: 5.7vw;
	left: 9%;
	line-height: 1;
	letter-spacing: .1em;
	font-family: 'Oswald', sans-serif;
	font-size: 3vw;
}
.page-aa h2 span {
	display: block;
	margin-top: 1vw;
	letter-spacing: 0;
	font-family: "Yu Gothic Medium", sans-serif;
	font-size: 1vw;
	font-weight: normal;
}
.page-ad-text {
	margin: 9% 9%;
}
.page-ad-text h2 {
	text-indent: -.5em;
	font-size: 1.8vw;
}
.page-ad-text p {
	margin-top: 4%;
	font-size: .8vw;
}

/*contents*/
.page-aa-contents {
	overflow: hidden;
	padding-bottom: 5%;
}
.page-ad-01 {
	display: flex;
	position: relative;
	padding: 9% 0 9% 9%;
	background: linear-gradient(90deg, #f5f5f5 0 91%, #ffffff00 9% 100%);
}
.page-ad-01 h2 {
	margin-bottom: 6%;
	font-size: 1.8vw;
}
.page-ad-01 p {
	line-height: 2;
	font-size: .8vw;
}
.page-ad-01 div {
	width: 40%;
}
.page-ad-01-img {
	position: absolute;
	bottom: -18%;
	right: 0;
	width: 50%;
	height: 100%;
	object-fit: cover;
}
.page-ad-01-bg {
	position: absolute;
	top: 5%;
	left: 5%;
	width: 18.5%;
	opacity: .7;
}

.page-ad-02 {
	display: flex;
	flex-direction: row-reverse;
	position: relative;
	margin: 12% auto 0;
	padding: 9% 9% 9% 0;
	background: linear-gradient(90deg, #ffffff00 0 10%, #f5f5f5 9% 100%);
}
.page-ad-02 h2 {
	margin-bottom: 6%;
	font-size: 1.8vw;
}
.page-ad-02 p {
	line-height: 2;
	font-size: .8vw;
}
.page-ad-02 div {
	width: 40%;
}
.page-ad-02-img {
	position: absolute;
	bottom: -18%;
	left: 0;
	width: 50%;
	height: 100%;
	object-fit: cover;
}

/*solution*/
.solution {
	margin: 13% auto 12%;
	padding: 0 9%;
}
.solution h2 {
	margin-bottom: 4%;
	font-family: 'Oswald', sans-serif;
	font-size: 2vw;
	letter-spacing: .1em;
}
.solution-block-01,
.solution-block-02 {
	display: flex;
	justify-content: space-between;
}
.solution-block-01 {
	margin-bottom: 3%;
}
.solution-block {
	margin-right: 3%;
	padding: 4% 2.8% 0;
	width: 42%;
	border: 5px solid #d8d8d8;
}
.solution-block img {
	margin: 0 auto;
	width: 12%;
}
.solution-block h3 {
	margin: 4% auto 4%;
	text-align: center;
	font-size: 1.3vw;
}
.solution-block p {
	line-height: 2;
	font-size: .8vw;
}
.solution-text-top {
	margin: 0 auto 5%;
	padding: 0 0 5%;
	border-bottom: 2px solid #d8d8d8;
}
.solution-block-01 .solution-block p:last-of-type {
	letter-spacing: -.03em;
}
.solution-block-02 .solution-block {
	padding: 4% 2.8% 4%;
}
.solution-block-02 .solution-block:last-of-type {
	margin-right: 0;
}
.solution-block-02 .solution-block img {
	width: auto;
	height: 6.5vw;
}
.solution-block-ad {
	display: flex;
	justify-content: center;
}
.solution-block-02 .solution-block .solution-block-ad p {
	margin: 0;
	padding: 0;
}
.solution-block-02 .solution-block .solution-block-ad p:first-of-type {
	margin-right: 8%;
	border: none;
}
.solution-text-btm {
	margin: 0 auto;
	width: fit-content;
}
.solution-award {
	padding: 5% 4% 5% 5%;
	width: 55%;
	background: #fffbf2;
}
.solution-award-flex {
	display: flex;
	align-items: center;
	justify-content: flex-start;
}
.solution-award-badge {
	margin-right: 6%;
	width: 24.5%;
}
.solution-img-text {
	line-height: 2.2;
	font-size: .8vw;
	color: #b1913a;
}
.solution-award-icon {
	margin: 8% auto 0;
	width: 100%;
}

/*client*/
.client {
	margin: 10% auto 12%;
	padding: 0 9%;
}
.client h2 {
	font-family: 'Oswald', sans-serif;
	font-size: 2vw;
	letter-spacing: .1em;
	margin-bottom: 4%;
}
.client ul {
	display: flex;
	align-items: center;
	justify-content: space-between;
}
.client ul li {
	width: 10%;
}
.client ul li:nth-child(1) {
	width: 7%;
}
.client ul li:nth-child(2) {
	width: 14%;
}
.client ul li:nth-child(3) {
	width: 8%;
}
.client ul li:nth-child(4) {
	width: 12%;
}
.client ul li:nth-child(6) {
	display: none;
}

@media screen and (max-width: 559px) {
	.page-aa h2 {
		bottom: 20vw;
		left: 7%;
		letter-spacing: .0em;
		font-size: 7.5vw;
	}
	.page-aa h2 span {
		margin-top: .5em;
		letter-spacing: .05em;
		font-size: 3.5vw;
	}
	.page-ad-text {
		margin: 15% 7%;
	}
	.page-ad-text h2 {
		margin-left: -.4em;
		line-height: 1.8;
		text-indent: 0;
		font-size: 4vw;
	}
	.page-ad-text p {
		margin-top: 5%;
		line-height: 2;
		font-size: 3.1vw;
	}

	/*contents*/
	.page-ad-01 {
		flex-wrap: wrap;
		flex-direction: column-reverse;
		padding: 15% 0 15% 7%;
		background: #f5f5f5;
		overflow: hidden;
	}
	.page-ad-01 h2 {
		margin-bottom: 8%;
		line-height: 1.8;
		letter-spacing: .1em;
		font-size: 4vw;
	}
	.page-ad-01 p {
		text-align: justify;
		font-size: 3.1vw;
	}
	.page-ad-01 div {
		margin-top: 10%;
		width: 93%;
	}
	.page-ad-01-img {
		position: inherit;
		bottom: 0;
		width: 100%;
	}
	.page-ad-01-bg {
		display: none;
	}

	.page-ad-02 {
		flex-wrap: wrap;
		flex-direction: column-reverse;
		margin: 12% auto 0;
		padding: 15% 7% 15% 0;
		background: #f5f5f5;
		overflow: hidden;
	}
	.page-ad-02 h2 {
		margin-bottom: 8%;
		line-height: 1.8;
		letter-spacing: .1em;
		font-size: 4vw;
	}
	.page-ad-02 p {
		text-align: justify;
		font-size: 3.1vw;
	}
	.page-ad-02 div {
		margin-top: 10%;
		margin-left: 7%;
		width: 93%;
	}
	.page-ad-02-img {
		position: inherit;
		bottom: 0;
		width: 100%;
	}

	/*solution*/
	.solution {
		margin: 20% auto 0;
		padding: 0 7%;
	}
	.solution h2 {
		margin-bottom: 10%;
		font-size: 5vw;
		letter-spacing: .05em;
	}
	.solution-block-01,
	.solution-block-02 {
		display: block;
	}
	.solution-block-01 {
		margin-bottom: 15%;
	}
	.solution-block {
		margin-right: 0;
		margin-bottom: 13%;
		padding: 13% 8% 10%;
		width: 100%;
		border: 3px solid #d8d8d8;
	}
	.solution-block img {
		margin: 0 auto;
		width: 18%;
	}
	.solution-block h3 {
		margin: 7% auto;
		text-align: center;
		font-size: 4vw;
	}
	.solution-block p {
		text-align: justify;
		line-height: 1.8;
		font-size: 3.1vw;
	}
	.solution-text-top {
		border-bottom: 1px solid #d8d8d8;
	}

	.solution-block-02 .solution-block {
		margin-bottom: 10%;
		padding: 13% 8% 12%;
	}
	.solution-block-02 .solution-block img {
		width: auto;
		height: 20vw;
	}
	.solution-block-02 .solution-block:last-of-type .solution-text-btm {
		width: 100%;
		letter-spacing: -.05em;
	}
	.solution-award {
		padding: 13% 10%;
		width: 100%;
	}
	.solution-award-flex {
		display: block;
	}
	.solution-award-badge {
		margin: 0 auto;
		width: 50%;
	}
	.solution-img-text {
		margin: 5% auto 0;
		width: 100%;
		text-align: center;
		line-height: 2;
		font-size: 3.1vw;
		color: #b1913a;
	}
	.solution-award-icon {
		margin: 10% auto 0;
	}

	/*client*/
	.client {
		margin: 20% auto 0;
		padding: 0 7%;
	}
	.client h2 {
		font-size: 5vw;
		letter-spacing: .05em;
		margin-bottom: 4%;
	}
	.client ul {
		flex-wrap: wrap;
		justify-content: space-between;
	}
	.client ul li {
		display: flex;
		align-items: center;
		width: 30% !important;
		height: 20vw;
	}
	.client ul li:nth-child(1) img {
		width: 50%;
	}
	.client ul li:nth-child(2) img {
		width: 100%;
	}
	.client ul li:nth-child(3) img {
		width: 65%;
	}
	.client ul li:nth-child(4) img {
		width: 90%;
	}
	.client ul li:nth-child(5) img {
		width: 80%;
	}
	.client ul li:nth-child(6) {
		display: block;
	}
	.client ul li img {
		margin: 0 auto;
	}
}
