@charset "utf-8";
@import url(https://fonts.googleapis.com/earlyaccess/notosansjapanese.css);

/* CSS Document */

* {

	margin: 0;
	padding: 0;
	/*line-height: 0;*/
}
#scroll_area{
    line-height: 0;
}


/* --------------------------------
	html
-------------------------------- */
html {

	font-size: calc(100vw / 1366);
	background: black;
}

@media screen and (min-width: 1366px) {

	html {

		font-size: 1px;
	}
}

@media screen and (max-width: 767px) {

	html {

		font-size: calc(100vw / 750);
	}
}

@media screen and (max-height: 720px) and (orientation: landscape) {

	html {

		font-size: calc(100vw / 1366 * 0.75);
	}
}

/* --------------------------------
	override
-------------------------------- */
body {

	margin-top: 0 !important;
	min-width: initial;
}

#scroll_area #scroll_wrap #header {

	position: static;
	left: initial;
	top: initial;
	min-width: initial;
}

/* --------------------------------
	common
-------------------------------- */
.section {

	width: 100%;
	position: relative;
	overflow: hidden;
}

.spacer {

	width: 100%;
}

.sp {

	display: none;
}

.slide_in {

	animation-name: common_slide_in_anim;
	animation-duration: 1600ms;
	animation-fill-mode: both;
	animation-timing-function: cubic-bezier(0.190, 1.000, 0.220, 1.000); /* easeOutExpo */
}

@keyframes common_zoom_in_anim {

	  0% { opacity: 0.00; transform: scale(0.95); }
	100% { opacity: 1.00; transform: scale(1.00); }
}

@keyframes common_zoom_out_anim {

	  0% { opacity: 1.00; transform: scale(1.00); }
	100% { opacity: 0.00; transform: scale(0.95); }
}

@keyframes common_slide_in_anim {

	  0% { opacity: 0.00; transform: translateY(40rem); }
	100% { opacity: 1.00; transform: translateY(0); }
}

@keyframes common_slide_out_anim {

	  0% { opacity: 1.00; transform: translateY(0); }
	100% { opacity: 0.00; transform: translateY(40rem); }
}

@keyframes common_fade_in_anim {

	  0% { opacity: 0.00; }
	100% { opacity: 1.00; }
}

@keyframes common_fade_out_anim {

	  0% { opacity: 1.00; }
	100% { opacity: 0.00; }
}

/* --------------------------------
	modal_wrapper
-------------------------------- */
.modal_wrapper {

	position: fixed;
	left: 0;
    top: 0;
	width: 100vw;
	height: 100vh;
	opacity: 0.00;
	display: none;
}

.modal_wrapper .modal_overlay {

	position: absolute;
	left: 0;
	top: 0;
	width: 100%;
	height: 100%;
	background-color: rgba(0, 0, 0, 0.80);
}

.modal_wrapper .modal_container.show {

	animation-name: common_zoom_in_anim;
	animation-duration: 800ms;
	animation-fill-mode: both;
	animation-timing-function: cubic-bezier(0.190, 1.000, 0.220, 1.000); /* easeOutExpo */
}

.modal_wrapper .modal_container.hide {

	animation-name: common_zoom_out_anim;
	animation-duration: 800ms;
	animation-fill-mode: both;
	animation-timing-function: cubic-bezier(0.190, 1.000, 0.220, 1.000); /* easeOutExpo */
}

.modal_wrapper .modal_container .close_btn {

	position: absolute;
	right: 0;
	top: -64rem;
	width: 64rem;
	height: 64rem;
	background-image: url("../assets/images/ic_close.png");
	background-size: 100%;
	background-repeat: no-repeat;
	cursor: pointer;
}

.modal_wrapper .modal_container .close_btn:hover
.modal_wrapper .modal_container .close_btn:active {

	opacity: 0.80;
}

#video_container {

	position: absolute;
	top: 0;
	right: 0;
	bottom: 0;
	left: 0;
	margin: auto;
	width: 80vw;
	height: calc(80vw * 9 / 16);
	opacity: 0.00;
}

#catalog_menu_container {

	position: absolute;
	top: 0;
	right: 0;
	bottom: 0;
	left: 0;
	margin: auto;
	display: flex;
	justify-content: space-between;
	align-items: center;
	width: 914rem;
	height: 180rem;
	padding: 50rem;
	background-color: #1a1a1a;
	opacity: 0.00;
}

#catalog_menu_container .bottom_btn {

	position: relative;
	width: 432rem;
	height: 180rem;
	background-size: 100%;
	background-repeat: no-repeat;
}

#catalog_menu_container .bottom_btn .thumb {

	position: absolute;
	display: inline-block;
	left: 0;
	top: 0;
	width: 127rem;
	height: auto;
	background-size: 100%;
	border: 1rem solid #cccccc;
	box-sizing: border-box;
	background-repeat: no-repeat;
}

#catalog_menu_container .bottom_btn .label {

	position: absolute;
	left: 144rem;
	top: 0;
	width: 160rem;
	height: auto;
	background-size: 100%;
	background-repeat: no-repeat;
}

#catalog_menu_container .bottom_btn .btn {

	position: absolute;
	right: 0;
	bottom: 0;
	width: 285rem;
	height: 60rem;
	background-color: #49a4aa;
	transition: background-color 600ms cubic-bezier(0.215, 0.610, 0.355, 1.000); /* easeOutCubic */
}

#catalog_menu_container .bottom_btn .btn:hover,
#catalog_menu_container .bottom_btn .btn:active {

	transition: background-color 200ms cubic-bezier(0.215, 0.610, 0.355, 1.000); /* easeOutCubic */
	background-color: #6db6bb;
}

#catalog_menu_container .bottom_btn .btn::after {

	content: "";
	position: absolute;
	right: 0;
	top: 0;
	width: 60rem;
	height: 60rem;
	background-image: url("../assets/images/ic_pdf.png");
	background-size: 100%;
}

#catalog_menu_container .bottom_btn .btn p {

	position: absolute;
	left: 24rem;
	top: 52%;
	font-family: 'Noto Sans Japanese', "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", "メイリオ", Meiryo, Osaka, "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
	font-size: 20rem;
	font-weight: bold;
	color: white;
	transform: translateY(-50%);
}

/* --------------------------------
	scroll_area
-------------------------------- */
#scroll_area {

	position: fixed;
	left: 0;
	top: 0;
	width: 100%;
	height: 100vh;
	overflow: hidden;
}

#scroll_wrap {

	position: absolute;
	width: 100%;
	background-color: black;
}

/* --------------------------------
	top_area : main
-------------------------------- */
#main_image_container {

	position: relative;
	width: 100vw;
	height: calc(100vw * 1696 / 2968);
	max-height: calc(100vh - 66px);
}

#main_canvas {

	width: 100%;
	height: 100%;
	object-fit: contain;
}

#loading_logo {

	position: absolute;
	left: 50%;
	top: 50%;
	width: 240rem;
	height: 60rem;
	transform: translate(-50%, -50%);
	opacity: 0.00;
}

#loading_logo.flash {

	/* animation */
	animation: flash_anim 2000ms linear infinite;
}

@keyframes flash_anim {

	  0% { opacity: 0.00; }
	 50% { opacity: 1.00; }
	100% { opacity: 0.00; }
}

#main_title_container {

	position: absolute;
	left: 50%;
	top: calc(80rem + 66px);
	width: 800rem;
	height: auto;
	transform: translateX(-50%);
}

#main_title_01 {

	width: 100%;
	opacity: 0.00;
}

#main_title_02 {

	display: block;
	width: 55%;
	opacity: 0.00;
	margin: 0 auto;
}

#main_title_tkg_series {

	display: block;
	width: 40%;
	margin: 24rem auto 0 auto;
	opacity: 0.00;
}

#main_title_01.slide_in,
#main_title_02.slide_in,
#main_title_tkg_series.slide_in {

	animation-name: common_slide_in_anim;
	animation-duration: 3200ms;
	animation-fill-mode: both;
	animation-timing-function: cubic-bezier(0.190, 1.000, 0.220, 1.000); /* easeOutExpo */
}

#main_title_01.slide_in { animation-delay: 2400ms; }
#main_title_02.slide_in { animation-delay: 2600ms; }
#main_title_tkg_series.slide_in { animation-delay: 3000ms; }

#main_title_01.fade_out,
#main_title_02.fade_out,
#main_title_tkg_series.fade_out {

	animation-name: common_fade_out_anim;
	animation-duration: 1600ms;
	animation-fill-mode: both;
	animation-timing-function: cubic-bezier(0.230, 1.000, 0.320, 1.000); /* easeOutQuint */
}

#main_title_01.fade_in,
#main_title_02.fade_in,
#main_title_tkg_series.fade_in {

	animation-name: common_fade_in_anim;
	animation-duration: 1600ms;
	animation-delay: 1600ms;
	animation-fill-mode: both;
	animation-timing-function: cubic-bezier(0.445, 0.050, 0.550, 0.950); /* easeInOutSine */
}

#top_telescopic_label_container {

	position: absolute;
	left: 50%;
	top: min(calc(100vw * 1696 / 2968 + 66px - 40rem), calc(100vh - 66px));
	width: 920rem;
	height: 80rem;
	transform: translateX(-50%);
}

#top_telescopic_label {

	width: 100%;
	height: auto;
	opacity: 0.00;
}

#top_telescopic_label.slide_in {

	animation-name: common_slide_in_anim;
	animation-duration: 3200ms;
	animation-delay: 3200ms;
	animation-fill-mode: both;
	animation-timing-function: cubic-bezier(0.190, 1.000, 0.220, 1.000); /* easeOutExpo */
}

#top_anchor_link_container {

	display: flex;
	flex-wrap: wrap;
	width: 740rem;
	justify-content: space-between;
	margin: 40rem auto 0 auto;
	opacity: 0.00;
}

#top_anchor_link_container .anchor_link {

	width: auto;
	height: 60rem;
	cursor: pointer;
	transition: opacity 600ms cubic-bezier(0.215, 0.610, 0.355, 1.000); /* easeOutCubic */
}

#top_anchor_link_container .anchor_link:hover,
#top_anchor_link_container .anchor_link:active {

	transition: opacity 200ms cubic-bezier(0.215, 0.610, 0.355, 1.000); /* easeOutCubic */
	opacity: 0.80;
}

#top_btn_Container {

	display: flex;
	flex-wrap: wrap;
	width: 898rem;
	justify-content: space-between;
	margin: 60rem auto 0 auto;
}

#top_btn_Container .btn {

	position: relative;
	width: 441rem;
	height: 141rem;
	border: 1rem solid #c0c0c0;
	box-sizing: border-box;
	overflow: hidden;
	opacity: 0.00;
	cursor: pointer;
}

#top_btn_Container .btn .image {

	position: relative;
	width: 100%;
	height: 100%;
	object-fit: cover;
}

#top_btn_Container .btn .label {

	position: absolute;
	left: 28rem;
	top: 32rem;
	line-height: 1.00;
	font-family: 'Noto Sans Japanese', "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", "メイリオ", Meiryo, Osaka, "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
	font-size: 24rem;
	font-weight: bold;
	color: white;
	user-select: none;
}

#top_btn_Container .btn .icon {

	position: absolute;
	right: 0;
	top: 0;
	width: 100rem;
	height: 100rem;
}
	
#top_btn_Container .btn .logo {

	position: absolute;
	left: 20rem;
	bottom: 20rem;
	width: 260rem;
	height: 50rem;
}

#top_btn_Container a,
#top_btn_Container a:hover,
#top_btn_Container a:active,
#top_btn_Container a:visited {

	color: inherit;
}

#top_btn_Container .btn::after {

	content: "";
	position: absolute;
	left: 0;
	top: 0;
	width: 100%;
	height: 100%;
	background-color: rgba(255, 255, 255, 0.10);
	transition: opacity 600ms cubic-bezier(0.215, 0.610, 0.355, 1.000); /* easeOutCubic */
	opacity: 0.00;
}

#top_btn_Container .btn:hover::after,
#top_btn_Container .btn:active::after {

	transition: opacity 200ms cubic-bezier(0.215, 0.610, 0.355, 1.000); /* easeOutCubic */
	opacity: 1.00;
}

.top_stripe_label {

	display: block;
	width: 640rem;
	height: auto;
	margin: 120rem auto 0 auto;
	object-fit: cover;
	opacity: 0.00;
}

.top_stripe_label.sp {

	display: none !important;
}

#top_arrow_down {

	display: block;
	width: 64rem;
	height: auto;
	margin: -16rem auto 0 auto;
	object-fit: cover;
	cursor: pointer;
	transition: bottom 600ms cubic-bezier(0.215, 0.610, 0.355, 1.000); /* easeOutCubic */
	opacity: 0.00;
}

#top_arrow_down.slide_in {

	animation-delay: 200ms;
}

#top_botton_spacer {

	height: 200rem;
}

/* --------------------------------
	- strengths
-------------------------------- */
.strengths {
	
	height: 100vh;
}

.strengths_video {

	position: absolute;
	left: 0;
	top: 0;
	width: 100%;
	height: 100%;
	object-fit: cover;
}

.strengths_video_overlay {

	position: absolute;
	left: 0;
	top: 0;
	width: 100%;
	height: 100%;
	background: linear-gradient(90deg, black 0%, rgba(0, 0, 0, 0.00) 10%, rgba(0, 0, 0, 0.00) 90%, black 100%);
}

.strengths_text_area {

	position: absolute;
	top: 0;
	left: 0;
	width: 50%;
	height: 100%;
}

.strengths_text_area.right {

	left: auto;
	right: 0;
}

.strengths_text_container {

	position: absolute;
	top: 20%;
	left: 50%;
	text-align: center;
	/*transform: translate(-50%, -50%);*/
	transform: translateX(-50%)
}

.strengths_text_title {

	width: 400rem;
	margin-bottom: 32rem;
	opacity: 0.00;
}

.strengths_text_sub_title_box {

	position: relative;
	height: 80rem;
	color: white;
	margin-top: 32rem;
	/*margin-bottom: 32rem;*/
	opacity: 0.00;
}

.strengths_text_sub_title {

	position: absolute;
	left: 50%;
	top: 50%;
	font-family: 'Noto Sans Japanese', "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", "メイリオ", Meiryo, Osaka, "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
	font-size: 30rem;
	font-weight: bold;
	letter-spacing: 2.00rem;
	line-height: 1.30;
	color: white;
	padding: 0 48rem;
	transform: translate(-50%, -50%);
	white-space: nowrap;
}

.strengths_text_sub_title::before {

	content: "";
	position: absolute;
	left: 0;
	top: 50%;
	width: 12rem;
	height: 80rem;
	background-image: url("../assets/images/brackets_L.svg");
	background-repeat: no-repeat;
	transform: translateY(-50%);
}

.strengths_text_sub_title::after {

	content: "";
	position: absolute;
	right: 0;
	top: 50%;
	width: 12rem;
	height: 80rem;
	background-image: url("../assets/images/brackets_R.svg");
	background-repeat: no-repeat;
	transform: translateY(-50%);
}

.strengths_text_content_box {

	width: 400rem;
	padding: 32rem;
	background: linear-gradient(rgba(0, 0, 0, 0.00), 33%, rgba(21, 41, 54, 0.50));
	opacity: 0.00;
}

#strengths_04 .strengths_text_content_box {

	width: 424rem;
}

.strengths_text_content {

	text-align: left;
	font-family: 'Noto Sans Japanese', "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", "メイリオ", Meiryo, Osaka, "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
	font-size: 22rem;
	line-height: 1.60;
	color: white;
}

.strengths_text_content .sub {

	font-size: 14rem;
}

.strengths_text_content .annotation {

	font-size: 14rem;
	line-height: 1.60;
}

.strengths_text_area.show .strengths_text_title,
.strengths_text_area.show .strengths_text_sub_title_box,
.strengths_text_area.show .strengths_text_content_box {

	animation-name: common_slide_in_anim;
	animation-duration: 3200ms;
	animation-fill-mode: both;
	animation-timing-function: cubic-bezier(0.190, 1.000, 0.220, 1.000); /* easeOutExpo */
}

.strengths_text_area.show .strengths_text_title { animation-delay: 0ms; }
.strengths_text_area.show .strengths_text_sub_title_box { animation-delay: 200ms; }
.strengths_text_area.show .strengths_text_content_box { animation-delay: 400ms; }

.strengths_arrow_down {

	position: absolute;
	left: 50%;
	bottom: 40rem;
	width: 64rem;
	height: auto;
	object-fit: cover;
	transform: translateX(-50%);
	opacity: 0.00;
	cursor: pointer;
	transition: bottom 600ms cubic-bezier(0.215, 0.610, 0.355, 1.000); /* easeOutCubic */
}

.strengths_arrow_down:hover,
.strengths_arrow_down:active {

	transition: bottom 200ms cubic-bezier(0.215, 0.610, 0.355, 1.000); /* easeOutCubic */
	bottom: 32rem;
}

.strengths_arrow_down.slide_in {

	animation-name: strengths_arrow_slide_in_anim;
	animation-duration: 1600ms;
	animation-delay: 800ms;
	animation-fill-mode: both;
	animation-timing-function: cubic-bezier(0.190, 1.000, 0.220, 1.000); /* easeOutExpo */
}

@keyframes strengths_arrow_slide_in_anim {

	0% { opacity: 0.00; transform: translate(-50%, -40rem); }
  100% { opacity: 1.00; transform: translate(-50%, 0); }
}

/* --------------------------------
	- toughteles
-------------------------------- */
#toughteles {

	width: 100vw;
	height: 100vh;
}

#toughteles_layer_container {

	position: absolute;
	left: 50%;
	top: 50%;
	width: 683rem;
	height: 900rem;
	transform: translate(-50%, -50%);
}

#toughteles_layer_01 {

	position: absolute;
	left: 0;
	top: 0;
	width: 100%;
	height: 100%;
	object-fit: contain;
}

#toughteles_layer_02 {

	position: absolute;
	left: 0;
	top: 0;
	width: 100%;
	height: 100%;
	object-fit: contain;
}

#toughteles_scroll_guide {

	position: absolute;
	left: 50%;
	bottom: 40rem;
	width: 64rem;
	transform: translateX(-50%);
	opacity: 0.00;
}

#toughteles_scroll_guide.show {

	animation-name: toughteles_scroll_guide_show_anim;
	animation-duration: 3200ms;
	animation-fill-mode: both;
	animation-timing-function: cubic-bezier(0.190, 1.000, 0.220, 1.000); /* easeOutExpo */
}

#toughteles_scroll_guide.hide {

	animation-name: toughteles_scroll_guide_hide_anim;
	animation-duration: 1600ms;
	animation-fill-mode: both;
	animation-timing-function: cubic-bezier(0.190, 1.000, 0.220, 1.000); /* easeOutExpo */
}

@keyframes toughteles_scroll_guide_show_anim {

	  0% { opacity: 0.00; transform: translate(-50%, -40rem); }
	100% { opacity: 1.00; transform: translate(-50%,   0rem); }
}

@keyframes toughteles_scroll_guide_hide_anim {

	0% { opacity: 1.00; transform: translate(-50%,   0rem); }
  100% { opacity: 0.00; transform: translate(-50%,  40rem); }
}

#toughteles_scroll_guide .scroll_guide_arrow {

	width: 64rem;
	height: auto;
	margin-bottom: -16rem;

	animation-name: guide_arrow_anim;
	animation-duration: 2000ms;
	animation-fill-mode: both;
	animation-iteration-count: infinite;
	animation-timing-function: cubic-bezier(0.645, 0.045, 0.355, 1.000); /* easeInOutCubic */
}

#toughteles_scroll_guide .scroll_guide_arrow:last-child {

	margin-bottom: 0;
}

#toughteles_scroll_guide #scroll_guide_arrow_01 { animation-delay:   0ms; }
#toughteles_scroll_guide #scroll_guide_arrow_02 { animation-delay: 250ms; }
#toughteles_scroll_guide #scroll_guide_arrow_03 { animation-delay: 500ms; }

@keyframes guide_arrow_anim {

	  0% { opacity: 0.00; }
	 50% { opacity: 1.00; }
	100% { opacity: 0.00; }
}

#toughteles_label_container {

	position: absolute;
	left: 50%;
	top: 75%;
	width: 640rem;
	transform: translate(-50%, -50%);
}

.toughteles_stripe_label {

	width: 100%;
	opacity: 0.00;
}

.toughteles_stripe_label.sp {

	display: none !important;
}

#toughteles_text {

	margin: 0 auto;
	text-align: center;
	opacity: 0.00;
}

#toughteles_text.slide_in {

	animation-delay: 200ms;
}

#toughteles_text p {

	text-align: left;
	line-height: 1.60;
	color: white;
	font-family: 'Noto Sans Japanese', "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", "メイリオ", Meiryo, Osaka, "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
	font-size: 22rem;
	margin-top: 32rem;
	display: inline-block;
}

/* --------------------------------
	- bottom
-------------------------------- */
#bottom {

	height: calc(100vw * 2094 / 1366 + 480rem);
	background-position: center 160rem;
	background-image: url("../assets/images/bottom_base.jpg");
	background-size: 100% auto;
	background-repeat: no-repeat;
	display: flex;
	flex-direction: column;
}

#bottom_spacer_top {

	width: 100%;
	height: 160rem;
}

/* --------------------------------
	- bottom : bottom_detail
-------------------------------- */
#bottom_detail_container {

	position: relative;
	width: 100vw;
	height: 100vh;
	opacity: 0.00;
}

#bottom_detail {

	position: absolute;
	left: 50%;
	top: 50%;
	width: 1060rem;
	height: 650rem;
	transform: translate(-50%, -50%);
	background-color: #1a1a1a;
}

#bottom_detail #spec_canvas {

	position: absolute;
	left: 0;
	top: 0;
	width: 100%;
	height: 100%;
	object-fit: contain;
}

#bottom_detail .spec_box {

	position: absolute;
	left: 0;
	top: 0;
	width: 100%;
	height: 100%;
}

#bottom_detail .spec_box.show_prev { 

	animation-name: spec_box_show_prev;
	animation-duration: 800ms;
	animation-delay: 200ms;
	animation-fill-mode: both;
	animation-timing-function: cubic-bezier(0.190, 1.000, 0.220, 1.000); /* easeOutExpo */
}

#bottom_detail .spec_box.hide_prev { 

	animation-name: spec_box_hide_prev;
	animation-duration: 600ms;
	animation-fill-mode: both;
	animation-timing-function: cubic-bezier(0.190, 1.000, 0.220, 1.000); /* easeOutExpo */
	pointer-events: none;
}

#bottom_detail .spec_box.show_next { 

	animation-name: spec_box_show_next;
	animation-duration: 800ms;
	animation-delay: 200ms;
	animation-fill-mode: both;
	animation-timing-function: cubic-bezier(0.190, 1.000, 0.220, 1.000); /* easeOutExpo */
}

#bottom_detail .spec_box.hide_next { 

	animation-name: spec_box_hide_next;
	animation-duration: 600ms;
	animation-fill-mode: both;
	animation-timing-function: cubic-bezier(0.190, 1.000, 0.220, 1.000); /* easeOutExpo */
	pointer-events: none;
}

@keyframes spec_box_show_prev {

	  0% { opacity: 0.00; transform: translateY(20rem); }
	100% { opacity: 1.00; transform: translateY(0); }
}

@keyframes spec_box_hide_prev {

	  0% { opacity: 1.00; transform: translateY(0); }
	100% { opacity: 0.00; transform: translateY(-20rem); }
}

@keyframes spec_box_show_next {

	  0% { opacity: 0.00; transform: translateY(-20rem); }
	100% { opacity: 1.00; transform: translateY(0); }
}

@keyframes spec_box_hide_next {

	  0% { opacity: 1.00; transform: translateY(0); }
	100% { opacity: 0.00; transform: translateY(20rem); }
}

#bottom_detail .spec_text {

	position: absolute;
	left: 610rem;
	top: 75rem;
	width: 400rem;
	height: 500rem;
}

#bottom_detail .spec_name_label {

	position: absolute;
	left: 74rem;
	bottom: 42rem;
	width: auto;
	height: 80rem;
}

#bottom_detail .spec_new_mark {

	position: absolute;
	left: 80rem;
	bottom: 122rem;
	width: auto;
	height: 30rem;
}

#bottom_detail .product_info_btn,
#bottom_detail .spec_catalog_btn {

	position: absolute;
	left: 640rem;
	top: 512rem;
	width: 256rem;
	height: 40rem;
	background-color: #49a4aa;
	transition: background-color 600ms cubic-bezier(0.215, 0.610, 0.355, 1.000); /* easeOutCubic */
}

#bottom_detail .spec_catalog_btn {

	left: 640rem;
	top: 560rem;
}

#bottom_detail .product_info_btn:hover,
#bottom_detail .product_info_btn:active,
#bottom_detail .spec_catalog_btn:hover,
#bottom_detail .spec_catalog_btn:active {

	transition: background-color 200ms cubic-bezier(0.215, 0.610, 0.355, 1.000); /* easeOutCubic */
	background-color: #6db6bb;
}

#bottom_detail .spec_catalog_btn .btn::after,
#bottom_detail .product_info_btn .btn::after {

	content: "";
	position: absolute;
	right: 0;
	top: 0;
	width: 40rem;
	height: 40rem;
	background-image: url("../assets/images/ic_arrow.png");
	background-size: 100%;
}

#bottom_detail .spec_catalog_btn .btn::after {

	background-image: url("../assets/images/ic_pdf.png");
}

#bottom_detail .product_info_btn .btn p,
#bottom_detail .spec_catalog_btn .btn p {

	position: absolute;
	left: 24rem;
	top: 50%;
	font-family: 'Noto Sans Japanese', "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", "メイリオ", Meiryo, Osaka, "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
	font-size: 16rem;
	font-weight: bold;
	color: white;
	transform: translateY(-50%);
}

#bottom_detail #spec_navi_line {

	position: absolute;
	left: 22rem;
	top: 0;
	width: 1px;
	height: 100%;
	background-color: #7c7f81;
}

#bottom_detail .spec_navi_item {

	position: absolute;
	height: 24rem;
	cursor: pointer;
}

#bottom_detail .spec_navi_item.focus {

	pointer-events: none;
}

#bottom_detail .spec_navi_item::before {

	content: "";
	position: absolute;
	left: 0;
	top: 0;
	width: 5px;
	height: 24rem;
	background-color: #cccccc;
}

#bottom_detail .spec_navi_item.focus::before {

	background-color: #459ea3;
}

#bottom_detail #spec_navi_item_01 { left: 20rem; top: 255rem; }
#bottom_detail #spec_navi_item_02 { left: 20rem; top: 284rem; }
#bottom_detail #spec_navi_item_03 { left: 20rem; top: 313rem; }
#bottom_detail #spec_navi_item_04 { left: 20rem; top: 342rem; }
#bottom_detail #spec_navi_item_05 { left: 20rem; top: 371rem; }

#bottom_detail .spec_navi_item .label_normal {

	position: absolute;
	left: 0;
	top: 0;
	width: auto;
	height: 100%;
	opacity: 0.80;
	transition: opacity 600ms cubic-bezier(0.215, 0.610, 0.355, 1.000); /* easeOutCubic */
}

#bottom_detail .spec_navi_item:hover .label_normal {

	opacity: 1.00;
	transition: opacity 200ms cubic-bezier(0.215, 0.610, 0.355, 1.000); /* easeOutCubic */
}

#bottom_detail .spec_navi_item.focus .label_normal {

	opacity: 0.00;
}

#bottom_detail .spec_navi_item .label_focus {

	position: absolute;
	left: 0;
	top: 0;
	width: auto;
	height: 100%;
	opacity: 0.00;
	transition: opacity 600ms cubic-bezier(0.215, 0.610, 0.355, 1.000); /* easeOutCubic */
}

#bottom_detail .spec_navi_item.focus .label_focus {

	transition: opacity 200ms cubic-bezier(0.215, 0.610, 0.355, 1.000); /* easeOutCubic */
	opacity: 1.00;
}

#bottom_detail #spec_navi_arrow_up {

	position: absolute;
	left: 60rem;
	top: 222rem;
	width: 24rem;
	height: 16rem;
	cursor: pointer;
	transition: opacity 600ms cubic-bezier(0.215, 0.610, 0.355, 1.000); /* easeOutCubic */
}

#bottom_detail #spec_navi_arrow_up:hover {

	transition: opacity 200ms cubic-bezier(0.215, 0.610, 0.355, 1.000); /* easeOutCubic */
	opacity: 0.80;
}

#bottom_detail #spec_navi_arrow_down {

	position: absolute;
	left: 60rem;
	bottom: 222rem;
	width: 24rem;
	height: 16rem;
	cursor: pointer;
	transition: opacity 600ms cubic-bezier(0.215, 0.610, 0.355, 1.000); /* easeOutCubic */
}

#bottom_detail #spec_navi_arrow_down:hover {

	transition: opacity 200ms cubic-bezier(0.215, 0.610, 0.355, 1.000); /* easeOutCubic */
	opacity: 0.80;
}

#bottom_detail #spec_arrow_left,
#bottom_detail #spec_arrow_right {

	display: none !important;
}

#bottom_detail #spec_navi_arrow_up.disable,
#bottom_detail #spec_navi_arrow_down.disable,
#bottom_detail #spec_arrow_left.disable,
#bottom_detail #spec_arrow_right.disable {

	opacity: 0.20;
	pointer-events: none;
}

#bottom_info_container {

	margin-top: auto;

	width: 100vw;
}

#bottom_info_label_container {

	width: 640rem;
	margin: 0 auto;
}

.bottom_info_stripe_label {

	width: 100%;
	opacity: 0.00;
}

.bottom_info_stripe_label.sp {

	display: none !important;
}

#bottom_info_text {

	margin: 0 auto;
	text-align: center;
	opacity: 0.00;
}

#bottom_info_text.slide_in {

	animation-delay: 200ms;
}

#bottom_info_text p {

	text-align: left;
	line-height: 1.60;
	color: white;
	font-family: 'Noto Sans Japanese', "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", "メイリオ", Meiryo, Osaka, "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
	font-size: 22rem;
	margin-top: 16rem;
	display: inline-block;
}

#bottom_btn_container {

	display: flex;
	flex-wrap: wrap;
	width: 914rem;
	justify-content: space-between;
	margin: 80rem auto 0 auto;
}

#bottom_btn_container .bottom_btn {

	width: 432rem;
	height: 180rem;
	background-size: 100%;
	background-repeat: no-repeat;
	opacity: 0.00;
}

#bottom_btn_container .bottom_btn .thumb {

	position: absolute;
	left: 0;
	top: 0;
	width: 127rem;
	height: auto;
	background-size: 100%;
	border: 1rem solid #cccccc;
	box-sizing: border-box;
	background-repeat: no-repeat;
}

#bottom_btn_container .bottom_btn .label {

	position: absolute;
	left: 144rem;
	top: 0;
	width: 160rem;
	height: auto;
	background-size: 100%;
	background-repeat: no-repeat;
}

#bottom_btn_container .bottom_btn .btn {

	position: absolute;
	right: 0;
	bottom: 0;
	width: 285rem;
	height: 60rem;
	background-color: #49a4aa;
	transition: background-color 600ms cubic-bezier(0.215, 0.610, 0.355, 1.000); /* easeOutCubic */
}

#bottom_btn_container .bottom_btn .btn:hover,
#bottom_btn_container .bottom_btn .btn:active {

	transition: background-color 200ms cubic-bezier(0.215, 0.610, 0.355, 1.000); /* easeOutCubic */
	background-color: #6db6bb;
}

#bottom_btn_container .bottom_btn .btn::after {

	content: "";
	position: absolute;
	right: 0;
	top: 0;
	width: 60rem;
	height: 60rem;
	background-image: url("../assets/images/ic_pdf.png");
	background-size: 100%;
}

#bottom_btn_container .bottom_btn .btn p {

	position: absolute;
	left: 24rem;
	top: 52%;
	font-family: 'Noto Sans Japanese', "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", "メイリオ", Meiryo, Osaka, "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
	font-size: 20rem;
	font-weight: bold;
	color: white;
	transform: translateY(-50%);
}

#goto_top_btn {

	margin: 80rem auto;
	width: 200rem;
	height: 60rem;
	cursor: pointer;
	opacity: 0.00;
}

#goto_top_btn .btn {

	width: 100%;
	height: 100%;
	transition: opacity 600ms cubic-bezier(0.215, 0.610, 0.355, 1.000); /* easeOutCubic */
}

#goto_top_btn:hover .btn,
#goto_top_btn:active .btn {

	transition: opacity 200ms cubic-bezier(0.215, 0.610, 0.355, 1.000); /* easeOutCubic */
	opacity: 0.80;
}

#bottom_spacer_bottom {

	width: 100%;
	height: 0rem;
}

#bottom #footer {

	min-width: initial;
}

#bottom #footer #FixMenu,
#bottom #footer #scorollvisible,
#bottom #footer .footerInner,
#bottom #footer #footerSNS,
#bottom #footer #footerGlobal {

	display: none !important;
}

@media screen and (max-width: 767px) and (orientation: portrait) {

	.br_pc {

		display: none !important;
	}


	.modal_wrapper .modal_container .close_btn {

		top: -96rem;
		width: 96rem;
		height: 96rem;
	}

	/* --------------------------------
		video_container
	-------------------------------- */
	#video_container {

		width: 100vw;
		height: calc(100vw * 9 / 16);
	}

	/* --------------------------------
		catalog_menu_container
	-------------------------------- */
	#catalog_menu_container {

		display: block;
		flex-wrap: nowrap;
		width: 670rem;
		height: 712rem;
		justify-content: normal;
		margin: auto;
		background-color: transparent;
		padding: 0;
	}

	#catalog_menu_container .bottom_btn {
	
		width: 100%;
		height: 316rem;
	}
	
	#catalog_menu_container .bottom_btn:first-child {

		margin-bottom: 80rem;
	}

	#catalog_menu_container .bottom_btn .thumb {
	
		width: auto;
		height: 316rem;
	}
	
	#catalog_menu_container .bottom_btn .label {
	
		left: 256rem;
		width: 320rem;
	}
	
	#catalog_menu_container .bottom_btn .btn {
	
		width: 408rem;
		height: 80rem;
	}
	
	#catalog_menu_container .bottom_btn .btn::after {
	
		width: 80rem;
		height: 80rem;
	}
	
	#catalog_menu_container .bottom_btn .btn p {
	
		left: 32rem;
		font-size: 28rem;
	}

	/* --------------------------------
		top_area : main
	-------------------------------- */
	#main_image_container {

		width: 100vw;
		height: calc(100vw * 4 / 3);
	}

	#loading_logo {

		width: 360rem;
		height: 90rem;
	}

	#main_title_container {

		position: absolute;
		left: 50%;
		top: calc(128rem + 50px);
		width: 720rem;
		height: auto;
		transform: translateX(-50%);
	}
	
	#main_title_02 {
	
		margin-top: 16rem;
	}
	
	#main_title_tkg_series {
	
		margin-top: 128rem;
	}

	#top_telescopic_label_container {

		position: absolute;
		left: 50%;
		top: calc(100vw * 4 / 3 + 50px - 32rem);
		width: 680rem;
		height: auto;
		transform: translateX(-50%);
	}

	#top_btn_Container {

		display: block;
		flex-wrap: nowrap;
		width: 672rem;
		justify-content: normal;
		margin-top: 80rem;
	}
	
	#top_btn_Container .btn {
	
		width: 672rem;
		height: 162rem;
	}
	
	#top_btn_Container .btn:first-child {

		margin-bottom: 16rem;
	}
	
	#top_btn_Container .btn .label {

		left: 30rem;
		top: 36rem;
		font-size: 36rem;
	}
	
	#top_btn_Container .btn .icon {

		width: 80rem;
		height: 80rem;
	}
	
	#top_btn_Container .btn .logo {

		position: absolute;
		left: 24rem;
		bottom: 24rem;
		width: 260rem;
		height: 50rem;
	}

	#top_anchor_link_container {

		display: block;
		flex-wrap: nowrap;
		width: 100%;
		justify-content: normal;
		margin: 80rem auto 0 auto;
	}
	
	#top_anchor_link_container .anchor_link {
	
		width: 100%;
		height: 100rem;
		cursor: pointer;
		object-fit: contain;
		margin-top: 64rem;
	}

	#top_anchor_link_container .anchor_link:first-child {

		margin-top: 0;
	}

	.top_stripe_label {

		width: 672rem;
		margin: 160rem auto 0 auto;
	}

	.top_stripe_label.pc {

		display: none !important;
	}

	.top_stripe_label.sp {

		display: block !important;
	}

	#top_arrow_down {

		width: 76rem;
		margin: -4rem auto 0 auto;
	}

	#top_botton_spacer {

		height: 160rem;
	}

	/* --------------------------------
		- strengths
	-------------------------------- */
	.strengths_video {

		top: auto;
		bottom: 0;
		width: 100%;
		height: auto;
	}

	.strengths_video_overlay {

		top: auto;
		bottom: 0;
		height: calc(100vw * 1350 / 960);
		background: linear-gradient(black 20%, rgba(0, 0, 0, 0.00) 30%);
	}

	.strengths_text_area {

		width: 100%;
	}

	.strengths_text_container {

		top: 10%;
	}

	.strengths_text_title {

		width: 446rem;
	}

	.strengths_text_sub_title_box {

		height: 100rem;
	}
	
	.strengths_text_sub_title {
	
		font-size: 36rem;
		line-height: 1.44;
	}
	
	.strengths_text_sub_title::before {
	
		width: calc(100rem * 24 / 156);
		height: 100rem;
	}
	
	.strengths_text_sub_title::after {
	
		width: calc(100rem * 24 / 156);
		height: 100rem;
	}

	.strengths_text_content_box {

		width: 558rem;
	}

	#strengths_04 .strengths_text_content_box {

		width: 558rem;
	}

	.strengths_text_content {

		font-size: 28rem;
		line-height: 1.72;
	}

	.strengths_text_content .sub {

		font-size: 18rem;
	}
	
	.strengths_text_content .annotation {
	
		font-size: 18rem;
		line-height: 1.60;
	}

	.strengths_arrow_down {

		bottom: 160rem;
	}
	
	.strengths_arrow_down:hover,
	.strengths_arrow_down:active  {
	
		bottom: 152rem;
	}

	/* --------------------------------
		- toughteles
	-------------------------------- */
	#toughteles_layer_container {

		top: calc(50% - 80rem);
		width: calc(1366rem * 0.60);
		height: calc(1800rem * 0.60);
	}

	#toughteles_label_container {

		top: auto;
		bottom: 160rem;
		width: 672rem;
		transform: translateX(-50%);
	}

	.toughteles_stripe_label.pc {

		display: none !important;
	}

	.toughteles_stripe_label.sp {

		display: block !important;
	}

	#toughteles_text p {

		line-height: 1.70;
		font-size: 32rem;
		margin-top: 20rem;
	}

	#toughteles_scroll_guide {

		bottom: 160rem;
	}

	/* --------------------------------
		- bottom
	-------------------------------- */
	#bottom {

		display: block;
		height: auto;
		background-image: none;
	}

	#bottom_spacer_top {

		height: 240rem;
	}

	#bottom_detail {

		top: calc(50% - 40rem);
		width: calc(100vw - 80rem);
		height: calc(100vh - 200rem);
	}

	#bottom_detail #spec_canvas {

		object-fit: cover;
	}
	
	@keyframes spec_box_show_prev {
	
		  0% { opacity: 0.00; transform: translateX(20rem); }
		100% { opacity: 1.00; transform: translateX(0); }
	}
	
	@keyframes spec_box_hide_prev {
	
		  0% { opacity: 1.00; transform: translateX(0); }
		100% { opacity: 0.00; transform: translateX(-20rem); }
	}
	
	@keyframes spec_box_show_next {
	
		  0% { opacity: 0.00; transform: translateX(-20rem); }
		100% { opacity: 1.00; transform: translateX(0); }
	}
	
	@keyframes spec_box_hide_next {
	
		  0% { opacity: 1.00; transform: translateX(0); }
		100% { opacity: 0.00; transform: translateX(20rem); }
	}

	#bottom_detail .spec_text {

		left: calc((100% - 640rem) / 2);
		top: 0;
		width: 640rem;
		height: auto;
		display: block !important;
	}

	#bottom_detail .spec_name_label {

		bottom: 136rem;
		height: 64rem;
		left: 50%;
		transform: translateX(-50%);
	}

	#bottom_detail .spec_new_mark {

		left: 176rem;
		bottom: 200rem;
	}

	#bottom_detail .product_info_btn,
	#bottom_detail .spec_catalog_btn {
	
		left: 32rem;
		top: 512rem;
		width: 288rem;
		height: 80rem;
		top: auto;
		bottom: 32rem;
	}
	
	#bottom_detail .spec_catalog_btn {
	
		left: auto;
		right: 40rem;
	}
	
	#bottom_detail .spec_catalog_btn .btn::after,
	#bottom_detail .product_info_btn .btn::after {
	
		width: 80rem;
		height: 80rem;
	}
	
	#bottom_detail .product_info_btn .btn p,
	#bottom_detail .spec_catalog_btn .btn p {
	
		left: 24rem;
		width: 192rem;
		font-size: 24rem;
		line-height: 1.20;
	}

	#bottom_detail #spec_navi_line,
	#bottom_detail #spec_navi_item_01,
	#bottom_detail #spec_navi_item_02,
	#bottom_detail #spec_navi_item_03,
	#bottom_detail #spec_navi_item_04,
	#bottom_detail #spec_navi_item_05,
	#bottom_detail #spec_navi_arrow_up,
	#bottom_detail #spec_navi_arrow_down {

		display: none !important;
	}

	#bottom_detail #spec_arrow_left {

		display: block !important;
		position: absolute;
		left: -40rem;
		top: 50%;
		width: 96rem;
		height: 144rem;
		transform: translateY(-50%);
	}

	#bottom_detail #spec_arrow_right {

		display: block !important;
		position: absolute;
		right: -40rem;
		top: 50%;
		width: 96rem;
		height: 144rem;
		transform: translateY(-50%);
	}

	#bottom_info_container {

		background-image: url("../assets/images/bottom_base.jpg");
		background-size: 100% auto;
		background-repeat: no-repeat;
	}

	#bottom_info_label_container {

		width: 672rem;
	}
	
	#bottom_spacer_middle {

		height: calc(100vw * 3712 / 2732);
	}

	.bottom_info_stripe_label.pc {

		display: none !important;
	}
	
	.bottom_info_stripe_label.sp {
	
		display: block !important;
	}

	#bottom_info_text p {

		line-height: 1.70;
		font-size: 32rem;
		margin-top: 20rem;
	}

	#bottom_btn_container {

		display: block;
		flex-wrap: nowrap;
		width: 670rem;
		justify-content: normal;
		margin: 80rem auto 0 auto;
	}
	
	#bottom_btn_container .bottom_btn {
	
		width: 100%;
		height: 316rem;
	}
	
	#bottom_btn_container .bottom_btn:last-child {

		margin-top: 80rem;
	}

	#bottom_btn_container .bottom_btn .thumb {
	
		width: auto;
		height: 316rem;
	}
	
	#bottom_btn_container .bottom_btn .label {
	
		left: 256rem;
		width: 320rem;
	}
	
	#bottom_btn_container .bottom_btn .btn {
	
		width: 408rem;
		height: 80rem;
	}
	
	#bottom_btn_container .bottom_btn .btn::after {
	
		width: 80rem;
		height: 80rem;
	}
	
	#bottom_btn_container .bottom_btn .btn p {
	
		left: 32rem;
		font-size: 28rem;
	}

	#goto_top_btn {

		margin: 160rem auto 0 auto;
		width: calc(400rem * 100 / 120);
		height: 100rem;
	}

	#bottom_spacer_bottom {

		height: 80rem;
	}
}

@media screen and (min-aspect-ratio: 16 / 10) {

	#video_container {

		width: calc(75vh * 16 / 9);
		height: 75vh;
	}
}