@charset "utf-8";

@media screen and (max-width: 768px){
	.section {
		position: relative;
		color: var(--vezel-c-text);
		font-size: calc(32 / 750 * 100vw);
		font-feature-settings: 'palt' 1;
	}
	.section img {
		display: block;
		width: 100%;
	}
	.section sup {
		vertical-align: top;
		font-size: 75%;
	}
	.section h3 {
		text-align: center;
		letter-spacing: .03em;
		font-family: var(--font-bold);
		font-size: calc(46 / 750 * 100vw);
	}
	.section h3 span {
		display: inline-block;
		min-width: calc(480 / 750 * 100vw);
		padding-bottom: calc(24 / 750 * 100vw);
		border-bottom: 2px solid;
	}

	.section .box_flex {
		display: flex;
		flex-wrap: wrap;
		justify-content: center;
		align-items: center;
	}

	.block_inner {
		margin: 0;
	}

	.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: calc(22 / 750 * 100vw);
		height: calc(22 / 750 * 100vw);
		margin-left: calc(10 / 750 * 100vw);
		background: url(../img/link_arrow_blue.svg) 50% 50% / contain no-repeat;
		vertical-align: top;
	}


/* ----------------------------------------
	section_kv
---------------------------------------- */

	#kv_sound,
	#kv_restart {
		position: absolute;
		bottom: 20px;
		z-index: 1;
		width: 36px;
		height: 36px;
		border-radius: 50%;
		background-color: rgba(0,0,0,.2) !important;
	}
	#kv_sound {
		right: 10px;
		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: 56px;
		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: 8px;
		width: 2px;
		height: 18px;
		background: #fff;
	}
	#kv_restart::after {
		right: 8px;
		border: solid transparent;
		border-width: 9px 16px;
		border-right-color: #fff;
	}


/* ----------------------------------------
	enquete
---------------------------------------- */

	#contents_area .enquete {
		width: 85%;
		margin: 20px auto 50px;
	}
	#contents_area .enquete a {
		display: block;
		background: url(../common/img/parts_ico_btn_detail_arrow_w.png) right 10px center / 20px no-repeat #0064a1;
		padding: 10px 40px 10px 10px;
		border-radius: 7px;
		text-decoration: none;
		color: #fff;
		font-size: 14px;
		line-height: 1.5;
	}
	#contents_area .enquete a small {
		display: inline-block;
		font-size: 10px;
	}


/* ----------------------------------------
	section_movie
---------------------------------------- */

	#section_movie {
		margin: calc(60 / 750 * 100vw) auto;
		text-align: center;
	}

	#section_movie p {
		font-size: calc(34 / 750 * 100vw);
		line-height: calc(46 / 34);
	}
	#section_movie h3 {
		margin-top: 50px;
		font-size: calc(44 / 750 * 100vw);
		line-height: calc(56 / 44);
	}

	#section_movie .movie_area {
		width: calc(720 / 750 * 100vw);
		margin: calc(25 / 750 * 100vw) auto 0;
	}

	#section_movie .modal_mov_open a::after {
		background-image: url(../img/icon_play.svg);
		background-size: calc(60 / 750 * 100vw);
	}


/* ----------------------------------------
	section_special
---------------------------------------- */

	.section_special {
		margin-top: calc(30 / 750 * 100vw);
		color: #fff;
	}
	.section_special h3 img {
		width: auto;
		height: calc(145 / 750 * 100vw);
	}
	.section_special h3+p {
		margin-top: calc(30 / 750 * 100vw);
		text-align: center;
		letter-spacing: .1em;
		font-size: calc(34 / 750 * 100vw);
		line-height: calc(60 / 39);
	}

	.section_special .block_inner {
		margin: 0 calc(15 / 750 * 100vw);
		background: #000;
	}

	.section_special .header {
		flex-direction: column;
		align-items: center;
		padding: calc(90 / 750 * 100vw) 0;
	}

	.section_special .link::after {
		width: calc(27 / 750 * 100vw);
		height: calc(27 / 750 * 100vw);
		margin-left: calc(15 / 750 * 100vw);
		background-image: url(../img/link_arrow_wht.svg);
	}

	#section_recommend li {
		width: 50%;
	}
	#section_recommend li>a {
		display: block;
		position: relative;
	}
	#section_recommend .link {
		position: absolute;
		left: 0;
		right: 0;
		bottom: 0;
		height: calc(75 / 750 * 100vw);
		background: rgba(0,0,0,.65);
	}
	#section_recommend .link img {
		width: auto;
		height: calc(39 / 750 * 100vw);
	}

	#section_customize a {
		display: block;
		color: inherit;
	}

	#section_customize .link {
		position: relative;
	}
	#section_customize .link::after {
		position: absolute;
		left: 100%;
		bottom: calc(12 / 750 * 100vw);
		margin-left: calc(6 / 750 * 100vw);
	}


/* ----------------------------------------
	bnr_cp_blackemblem
---------------------------------------- */

	#bnr_cp_blackemblem {
		width: calc(720 / 750 * 100vw);
		margin: calc(30 / 750 * 100vw) auto 0;
	}


/* ----------------------------------------
	section_note
---------------------------------------- */

	#section_note {
		margin: calc(25 / 750 * 100vw) calc(15 / 750 * 100vw) calc(-5 / 750 * 100vw);
		font-family: var(--font-light);
		font-size: calc(24 / 750 * 100vw);
		line-height: calc(34 / 24);
	}


/* ----------------------------------------
	section_items
---------------------------------------- */

	#section_items {
		background: #f0f0f0;
		margin-top: calc(30 / 750 * 100vw);
		padding: calc(45 / 750 * 100vw) 0 calc(60 / 750 * 100vw);
	}
	#section_items h3 {
		color: #707070;
	}

	#section_items .item_list {
		justify-content: space-between;
		align-items: stretch;
		margin: calc(40 / 750 * 100vw) auto calc(-30 / 750 * 100vw);
		font-family: var(--font-bold);
	}
	#section_items .item_list li {
		width: calc(368 / 750 * 100vw);
		margin-bottom: calc(30 / 750 * 100vw);
	}
	#section_items .item_list li>a {
		display: block;
	}
	#section_items .item_list a>div {
		position: relative;
		box-sizing: border-box;
		padding: calc(9 / 750 * 100vw) calc(14 / 750 * 100vw);
		background: #353535;
	}
	#section_items .item_list h4 {
		box-sizing: border-box;
		width: 100%;
		min-height: calc(30 / 750 * 100vw);
		padding: calc(2 / 750 * 100vw) calc(6 / 750 * 100vw);
		border-left: calc(6 / 750 * 100vw) solid;
		text-align: left;
		letter-spacing: .1em;
		color: #fff; 
		font-size: calc(22 / 750 * 100vw);
		line-height: calc(25 / 22);
	}

	#section_items .item_list .link {
		margin: calc(8 / 750 * 100vw) 0 0 auto;
		letter-spacing: .03em;
		color: var(--vezel-c-link);
		font-size: calc(19 / 750 * 100vw);
		line-height: calc(22 / 19);
	}

	#section_items .item_lines2 a {
		position: relative;
		height: 100%;
	}
	#section_items .item_lines2 img {
		width: auto;
		height: calc(183 / 750 * 100vw);
		margin: auto;
	}
	#section_items .item_lines2 a>div {
		position: absolute;
		bottom: 0;
	}

	#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: calc(5 / 750 * 100vw) solid #353535;
		z-index: 1;
	}
	#section_items .item_a-collect a>div {
		align-items: center;
		height: calc(78 / 750 * 100vw);
	}
	#section_items .item_a-collect h4 {
		border: 0;
		text-align: center;
		font-family: var(--font-bold);
		font-size: calc(27 / 750 * 100vw);
		line-height: 1;
		font-family: "メイリオ", Meiryo, "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", Osaka, "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
	}


/* ----------------------------------------
	cta, footer
---------------------------------------- */

	.cta .box div {
		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%;
	}
}