/* --------------------------------------------------------------------------------------
   TOPページ
--------------------------------------------------------------------------------------- */

.key-top {
	background:
		url(../img/key_top.png) no-repeat center center,
		#fff7f4 url(../img/key_cloud.png) no-repeat center center;
}

.key-top > .box { min-height: 430px; }

.key-top .key-top-inner {
	bottom: 0;
	position: absolute;
	right: 56px;
	text-align: center;
}

.key-top-inner article h2 {
	display: inline-block;
	font-size: 1.8rem;
	font-weight: bold;
	margin-bottom: 24px;
	text-align: center;
	vertical-align: middle;
}

.key-top-inner article h2::before,
.key-top-inner article h2::after {
	background: url(../img/key_deco.png) no-repeat;
	content: '';
	display: inline-block;
	height: 27px;
	vertical-align: middle;
	width: 27px;
}

.key-top-inner article h2::before { margin-right: 14px; }

.key-top-inner article h2::after {
	margin-left: 14px;
	transform: scale(1,-1);
}

.key-top-inner article .logo {
	display: flex;
	justify-content: space-between;
}

.key-top-inner article .logo div:nth-child(1) {
	margin-right: 15px;
	margin-top: 5px;
}

.key-top-inner article .logo div:nth-child(1) img { width: 82px; }
.key-top-inner article .logo div:nth-child(2) img { width: 494px; }

.key-top-inner dl {
	background: url(../img/key_Illust.png) no-repeat right bottom;
	margin: 24px auto 0;
	min-height: 158px;
	text-align: left;
	width: 512px;
}

.key-top-inner dt {
	align-items: center;
	background-color: #f5b6bd;
	border-radius: 100vw;
	color: #fff;
	display: flex;
	font-size: 1.8rem;
	font-weight: bold;
	justify-content: center;
	letter-spacing: 2px;
	max-width: 295px;
	padding: 4px 0;
	position: relative;
}

.key-top-inner dt::after {
	background: url(../img/key_arrow.png) no-repeat;
	bottom: 3px;
	content: '';
	display: block;
	height: 18px;
	position: absolute;
	right: -12px;
	width: 18px;
}

.key-top-inner dd {
	margin-top: 20px;
	max-width: 295px;
	text-align: center;
}

.key-top-inner dd ul {
	align-items: center;
	display: flex;
	justify-content: space-between;
	margin: auto;
	max-width: 268px;
}

.key-top-inner dd li img {
	height: 40px;
	width: auto;
}

/* slider */
.popular-slider {
	padding-top: 60px;
	text-align: center;
}

.popular-slider > h2 {
	display: inline-block;
	font-size: 3.2rem;
	font-weight: bold;
	letter-spacing: 1px;
	position: relative;
}

.popular-slider > h2::before {
	background: url(../img/icon_popular.png) no-repeat;
	content: '';
	display: block;
	height: 41px;
	left: -71px;
	position: absolute;
	top: calc(50% - 20px);
	width: 41px;
}

.popular-slider .swiper-container {
	margin-top: 40px;
	overflow: inherit;
}

.popular-slider .post-item > div { width: 444px; }
.popular-slider .post-item > div img { max-height: 297px; }
.popular-slider .post-item > .no-image { min-height: 305px; }
.popular-slider .post-item > section { width: 450px; }

.popular-slider .swiper-pagination {
	bottom: 0;
	display: flex;
	justify-content: center;
	margin-top: 26px;
	position: relative;
}

.popular-slider .swiper-pagination-bullet {
	background-color: #ccc;
	opacity: 1;
}

.popular-slider .swiper-container-horizontal > .swiper-pagination-bullets .swiper-pagination-bullet { margin: 0 0 0 15px; }
.popular-slider .swiper-container-horizontal > .swiper-pagination-bullets .swiper-pagination-bullet:first-child { margin: 0; }

.popular-slider .swiper-pagination-bullet:first-child { margin-left: 0; }

.popular-slider .swiper-pagination-bullet-active { background-color: #eb6d7b; }

.popular-slider .swiper-button-prev,
.popular-slider .swiper-button-next {
	align-items: center;
	background-color: #eb6d7b;
	background-image: none;
	border-radius: 100vw;
	display: flex;
	height: 48px;
	justify-content: center;
	margin-top: 0;
	top: calc(50% - 48px);
	width: 48px;
}

.popular-slider .swiper-button-prev { left: -24px; }
.popular-slider .swiper-button-next { right: -24px; }

.popular-slider .swiper-button-prev::before,
.popular-slider .swiper-button-next::before {
	border-bottom: 3px solid #fff;
	border-right: 3px solid #fff;
	content: '';
	display: inline-block;
	height: 10px;
	width: 10px;
}

.popular-slider .swiper-button-prev::before {
	margin-left: 4px;
	transform: rotate(135deg);
}

.popular-slider .swiper-button-next::before {
	margin-right: 4px;
	transform: rotate(315deg);
}

/* --------------------------------------------------------------------------------------
   ios用のリンク対策
--------------------------------------------------------------------------------------- */

@media (min-width: 1024px) {


}

/* --------------------------------------------------------------------------------------
   スマホ
--------------------------------------------------------------------------------------- */

@media (max-width: 1024px) {

	.content { padding-top: 14.667vw; }

	.key-top  {
		background:
			url(../img/key_top_sp.png) no-repeat center 52vw / 85.867vw auto,
			#fff7f4 url(../img/key_cloud_sp.png) no-repeat center top / 100% auto;
	}

	.key-top > .box { min-height: 131.333vw; }

	.key-top .key-top-inner {
		bottom: auto;
		padding: 7.333vw 5.333vw 0;
		position: relative;
		right: auto;
	}

	.key-top .key-top-inner article h2 {
		background: url(../img/key_Illust.png) no-repeat 51.733vw top / 27.333vw auto;
		display: block;
		font-size: 4.267vw;
		margin-bottom: 4.533vw;
		min-height: 23.2vw;
		padding-left: 10.667vw;
		padding-top: 4vw;
		position: relative;
		text-align: left;
	}

	.key-top .key-top-inner article h2::before,
	.key-top .key-top-inner article h2::after {
		background: url(../img/key_deco_sp.png) no-repeat;
		bottom: 0;
		height: 16.667vw;
		position: absolute;
		width: 6.8vw;
	}

	.key-top .key-top-inner article h2::before { left: 0; }
	.key-top .key-top-inner article h2::after {
		right: 0;
		transform: scale(1, -1);
	}

	.key-top-inner article .logo div:nth-child(1) {
		margin-right: 2.667vw;
		margin-top: .667vw;
	}

	.key-top-inner article .logo div:nth-child(1) img { width: 12.4vw; }
	.key-top-inner article .logo div:nth-child(2) img { width: 74.4vw; }

	.key-top-inner dl {
		background: none;
		left: 10.667vw;
		margin-top: 0;
		position: absolute;
		top: 104.033vw;
		width: 78.667vw;
	}

	.key-top-inner dt {
		font-size: 4.267vw;
		max-width: inherit;
		padding: 1.067vw 0;
	}

	.key-top-inner dt::after { display: none; }

	.key-top-inner dd {
		margin-top: 3.333vw;
		max-width: inherit;
	}

	.key-top-inner dd ul {
		justify-content: center;
		max-width: inherit;
	}

	.key-top-inner dd li { margin-left: 2vw; }
	.key-top-inner dd li:first-child { margin-left: 0; }

	.key-top-inner dd li img { height: 9.6vw; }

	.popular-slider { padding-top: 10.667vw; }

	.popular-slider > h2 { font-size: 5.333vw; }

	.popular-slider > h2::before {
		background-size: cover;
		height: 6.667vw;
		left: -12vw;
		top: calc(50% - 3.333vw);
		width: 6.667vw;
	}

	.popular-slider .swiper-button-prev,
	.popular-slider .swiper-button-next {
		height: 11.333vw;
		width: 11.333vw;
	}

	.popular-slider .swiper-container {
		margin-top: 7.467vw;
		width: 74.667vw;
	}

	.popular-slider .post-item > div {
		min-height: 39.6vw;
		width: 100%;
	}

	.popular-slider .post-item > div img { max-height: inherit; }

	.popular-slider .post-item > .no-image { min-height: 44.2vw; }

	.popular-slider .post-item > section { margin-top: 5.067vw; }

	.popular-slider .post-item > section p {
		display: block;
		line-height: 1.5;
	}

	.popular-slider .swiper-pagination { margin-top: 7.333vw; }

	.popular-slider .swiper-pagination-bullet {
		height: 2.533vw;
		width: 2.533vw;
	}

	.popular-slider .swiper-container-horizontal > .swiper-pagination-bullets .swiper-pagination-bullet { margin-left: 4.533vw; }

}