@charset "utf-8";

:root {
	--vezel-c-text: #000;
	--vezel-c-link: #91c0ff;
}

@media print, screen and (min-width : 769px){
	.section {
		position: relative;
		color: var(--vezel-c-text);
		font-feature-settings: 'palt' 1;
	}
	.section:first-child {
		margin-top: 0;
	}
	.section img {
		display: block;
		width: 100%;
	}
	.section sup {
		vertical-align: top;
		font-size: 75%;
	}
	.section h3 {
		text-align: center;
		letter-spacing: .1em;
		font-family: var(--font-bold);
		font-size: 36px;
	}
	.section h3 span {
		display: inline-block;
		min-width: 380px;
		padding-bottom: 18px;
		border-bottom: 4px solid;
	}

	.block_inner {
		width: 1008px;
		margin: auto;
	}

	.section .movie {
		position: relative;
		z-index: 1;
		padding-top: 56.25%;
	}
	.section .movie iframe {
		position: absolute;
		left: 0;
		top: 0;
		width: 100%;
		height: 100%;
	}

	.section .link {
		font: inherit;
	}
	.section .link::after {
		content: '';
		display: inline-block;
		width: 22px;
		height: 22px;
		margin-left: 10px;
		background: url(../img/link_arrow_blue.svg) 50% 50% / contain no-repeat;
		vertical-align: top;
	}


/* ----------------------------------------
	section_kv
---------------------------------------- */

	#kv_sound,
	#kv_restart {
		position: absolute;
		bottom: 80px;
		z-index: 1;
		width: 42px;
		height: 42px;
		border-radius: 50%;
		cursor: pointer;
		background-color: rgba(0,0,0,.2) !important;
	}
	#kv_sound {
		right: 40px;
		background: url(../img/ico_audio_on.png) 50% 50% / contain no-repeat;
	}

	#kv_sound.on {
		background-image:url(../img/ico_audio_off.png);
	}

	#kv_restart {
		right: 102px;
		border: 1px solid #fff;
	}
	#kv_restart::before,
	#kv_restart::after {
		content: '';
		position: absolute;
		top: 50%;
		z-index: 1;
		transform: translateY(-50%);
	}
	#kv_restart::before {
		left: 10px;
		width: 2px;
		height: 20px;
		background: #fff;
	}
	#kv_restart::after {
		right: 10px;
		border: solid transparent;
		border-width: 10px 18px;
		border-right-color: #fff;
	}


/* ----------------------------------------
	enquete
---------------------------------------- */

	#contents_area .enquete {
		width: 980px;
		margin: 115px auto;
		text-align: center;
	}
	#contents_area .enquete a {
		display: inline-block;
		background: url(../common/img/parts_ico_btn_detail_arrow_w.png) right 20px center / 20px no-repeat #0064a1;
		padding: 14px 50px 14px 20px;
		border-radius: 7px;
		text-align: left;
		text-decoration: none;
		color: #fff;
		font-size: 16px;
		line-height: 1.75;
	}
	#contents_area .enquete a small {
		display: inline-block;
		font-size: 11px;
	}


/* ----------------------------------------
	section_movie
---------------------------------------- */

	#section_movie {
		margin: 90px auto;
		text-align: center;
	}

	#section_movie p {
		font-size: 26px;
		line-height: calc(36 / 26);
	}
	#section_movie h3 {
		margin-top: 50px;
		font-size: 32px;
		line-height: 1;
	}

	#section_movie .movie_area {
		width: 720px;
		margin: 50px auto 0;
	}

	#section_movie .modal_mov_open a::after {
		background-image: url(../img/icon_play.svg);
	}


/* ----------------------------------------
	section_special
---------------------------------------- */

	.section_special {
		margin-top: 45px;
		color: #fff;
	}
	.section_special h3 img {
		width: auto;
	}
	.section_special h3+p {
		margin-top: 15px;
		text-align: center;
		letter-spacing: .1em;
		font-size: 24px;
	}

	.section_special .block_inner {
		background: #000;
	}

	.section_special .header {
		flex-direction: column;
		justify-content: center;
		align-items: center;
		height: 152px;
	}

	.section_special .link::after {
		width: 20px;
		height: 20px;
		background-image: url(../img/link_arrow_wht.svg);
	}

	#section_recommend li {
		width: 252px;
	}
	#section_recommend li>a {
		display: block;
		position: relative;
	}
	#section_recommend .link {
		position: absolute;
		left: 0;
		right: 0;
		bottom: 0;
		height: 45px;
		background: rgba(0,0,0,.65);
	}
	#section_recommend .link img {
		width: auto;
		height: 27.5px;
	}

	#section_customize a {
		display: block;
		color: inherit;
	}


/* ----------------------------------------
	bnr_cp_blackemblem
---------------------------------------- */

	#bnr_cp_blackemblem {
		max-width: 1008px;
		margin: 45px auto 0;
	}


/* ----------------------------------------
	section_note
---------------------------------------- */

	#section_note {
		margin-top: 45px;
		font-family: var(--font-light);
		font-size: 12px;
	}


/* ----------------------------------------
	section_items
---------------------------------------- */

	#section_items {
		margin-top: 45px;
		padding: 60px 0 110px;
		background: #f0f0f0;
	}
	#section_items h3 {
		color: #707070;
	}

	#section_items .item_list {
		flex-wrap: wrap;
		justify-content: space-between;
		align-items: flex-end;
		margin: 70px auto -50px;
		font-family: var(--font-bold);
	}
	#section_items .item_list li {
		width: 480px;
		margin-bottom: 50px;
	}
	#section_items .item_list li>a {
		display: block;
		overflow: hidden;
	}
	#section_items .item_list li img {
		transition: .3s transform;
	}
	#section_items .item_list li:hover img {
		transform: scale(1.05);
	}
	#section_items .item_list a>div {
		justify-content: space-between;
		align-items: center;
		position: relative;
		box-sizing: border-box;
		min-height: 48px;
		padding: 10px 15px;
		background: #353535;
	}
	#section_items .item_list h4 {
		padding: 1px 10px;
		border-left: 6px solid;
		text-align: left;
		letter-spacing: .1em;
		color: #fff;
		font-size: 21px;
		line-height: calc(24 / 21);
	}

	#section_items .item_list .link {
		letter-spacing: .03em;
		color: var(--vezel-c-link);
		font-size: 18px;
		line-height: calc(22 / 18);
	}

	#section_items .item_a-collect a {
		position: relative;
	}
	#section_items .item_a-collect a::before {
		content: '';
		position: absolute;
		left: 0;
		right: 0;
		top: 0;
		bottom: 0;
		border: 5px solid #353535;
		z-index: 1;
	}
	#section_items .item_a-collect a>div {
		justify-content: center;
		padding: 0;
	}
	#section_items .item_a-collect h4 {
		border: 0;
		font-family: var(--font-bold);
		font-size: 33px;
		line-height: 1;
		font-family: "メイリオ", Meiryo, "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", Osaka, "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
	}


/* ----------------------------------------
	cta, footer
---------------------------------------- */

	.cta .box div {
		display: flex;
		justify-content: center;
		align-items: center;
		width: 80%;
		padding: 12px 22px;
		border: 2px solid var(--vezel-c-link);
		border-bottom-width: 0;
		background: #fff;
	}


/* ----------------------------------------
	movie_modal
---------------------------------------- */

	#movie_modal {
		position: fixed;
		text-align: center;
		white-space: nowrap;
	}
	#movie_modal::after,
	#movie_modal_inner {
		display: inline-block;
		vertical-align: middle;
	}
	#movie_modal::after {
		content: '';
		width: 0;
		height: 100%;
	}
	#movie_modal_inner {
		position: relative;
		width: 90%;
		max-width: 800px;
	}
	#movie_modal_data {
		position: relative;
		padding-top: 56.25%;
	}
	#movie_modal_data iframe {
		position: absolute;
		left: 0;
		top: 0;
		width: 100%;
		height: 100%;
	}
}