/****************************************/
/********** ArtLab-Tokyo [CSS] **********/
/****************************************/


@media (min-width: 48em) {
	body {
		margin-top: 100px;
	}
}

@media (min-width: 48em) {
	nav {
		transition: all 0.3s ease;
		background-color: transparent;
	}

	nav.nav-initial,
	nav.nav-onmouse {
		background-color: #ffffff;
	}
}

/*========= Loading ===============*/

.loading-bg {
	position: fixed;
	z-index: 10000;
	top: 0;
	left: 0;
	width: 100%;
	height: 100vh;
}

.bg-black {
	color: #ffffff;
	background-color: rgb(0, 0, 0, 0.85);
}

.bg-white {
	color: #000000;
	background-color: #ffffff;
}

.loading-animation-text {
	position: absolute;
	top: 50%;
	left: 50%;
	width: 9em;
	transform: translate(-50%, -50%);
	font-size: 2.25rem;
}

@media (min-width: 48em) {
	.loading-animation-text {
		width: 9em;
		font-size: 6rem;
	}
}

.loading-animation-text p {
	display: none;
	overflow: hidden;
	margin: 0.5em 0;
	white-space: nowrap;
	border-right: 2px solid #aaaaaa;
	font-size: 2.25rem;
	line-height: 1.5;
}

@media (min-width: 48em) {
	.loading-animation-text p {
		font-size: 6rem;
	}
}

.loading-animation-text .loading-p1 {
	-webkit-animation: typewriter 1s steps(15) 1s 1 normal both,blinkTextCursor 500ms steps(15) 6 normal forwards;
	animation: typewriter 1s steps(15) 1s 1 normal both,blinkTextCursor 500ms steps(15) 6 normal forwards;
}

.loading-animation-text .loading-p2 {
	-webkit-animation: typewriter 1s steps(15) 0s 1 normal both,blinkTextCursor 500ms steps(15) 4 normal forwards;
	animation: typewriter 1s steps(15) 0s 1 normal both,blinkTextCursor 500ms steps(15) 4 normal forwards;
}

.loading-animation-text .loading-p3 {
	-webkit-animation: typewriter 1s steps(15) 0s 1 normal both,blinkTextCursor 500ms steps(15) infinite normal;
	animation: typewriter 1s steps(15) 0s 1 normal both,blinkTextCursor 500ms steps(15) infinite normal;
}

@-webkit-keyframes typewriter {
	from {
		width: 0;
	}

	to {
		width: 9em;
	}
}

@keyframes typewriter {
	from {
		width: 0;
	}

	to {
		width: 9em;
	}
}

@-webkit-keyframes blinkTextCursor {
	from {
		border-right-color: #aaaaaa;
	}

	to {
		border-right-color: transparent;
	}
}

@keyframes blinkTextCursor {
	from {
		border-right-color: #aaaaaa;
	}

	to {
		border-right-color: transparent;
	}
}

/****************************** Content Slider ******************************/

@media (min-width: 48em) {
	#content_slider {
		display: flex;
	}
}

.side-content {
	width: 100%;
	padding-right: 15px;
	padding-left: 15px;
}

@media (min-width: 48em) {
	.side-content {
		position: relative;
		flex-shrink: 0;
		order: -1;
		width: 0;
		padding: 0;

		-webkit-box-ordinal-group: 0;
		-ms-flex-negative: 0;
		-ms-flex-order: -1;
	}
}

.side-content .vertical-logo {
	position: absolute;
	z-index: 9999;
	top: 20px;
	left: 50px;
	display: none!important;
}

.side-content .vertical-logo .wrapper {
	width: 130px;
}

.side-content h1 {
	margin: 0;
	padding-top: 2rem;
	letter-spacing: 0.8em;
	font-size: 1.0rem;
	line-height: 2;
}

@media (min-width: 48em) {
	.side-content h1 {
		position: absolute;
		top: 25%;
		right: 50%;
		transform: translateX(50%);
		letter-spacing: 0.6em;
		-webkit-writing-mode: vertical-rl;
		-ms-writing-mode: tb-rl;
		writing-mode: vertical-rl;
		font-size: 1.125rem;

		-webkit-transform: translateX(50%);
	}
}

/*- スライドサイズ指定 -*/
.swiper-container {
	width: 100%;
	height: 80vw;
}

@media (min-width: 48em) {
	.swiper-container {
		height: 44.7vw;
	}
}

@media (min-width: 1366px) {
	.swiper-container {
		height: 611px;
	}
}

.swiper-slide {
	position: relative;
	overflow: hidden;
}

.swiper-slide .container {
	position: absolute;
	top: 0;
	right: 0;
	bottom: 0;
	left: 0;
}

.swiper-slide-img {
	height: 100%;
	background-repeat: no-repeat;
	background-position: center;
	background-size: cover;
}

/*- スライド画像指定(モバイル用) -*/
.slide_img-01 {
	background-image: url(../img/slide_img-004.jpg);
}

.slide_img-02 {
	background-image: url(../img/slide_img-005.jpg);
}

.slide_img-03 {
	background-image: url(../img/slide_img-006.jpg);
}

.slide_img-04 {
	background-image: url(../img/slide_img-010.jpg);
}

.slide_img-05 {
	background-image: url(../img/slide_img-011.jpg);
}

.slide_img-06 {
	background-image: url(../img/slide_img-012.jpg);
}

/*- スライド画像指定(PC用) -*/
@media (min-width: 48em) {
	.slide_img-01 {
		background-image: url(../img/slide_img-001.jpg);
	}

	.slide_img-02 {
		background-image: url(../img/slide_img-002.jpg);
	}

	.slide_img-03 {
		background-image: url(../img/slide_img-003.jpg);
	}

	.slide_img-04 {
		background-image: url(../img/slide_img-004.jpg);
	}

	.slide_img-05 {
		background-image: url(../img/slide_img-005.jpg);
	}

	.slide_img-06 {
		background-image: url(../img/slide_img-006.jpg);
	}
}

/*- スライド画像内テキストのスタイル -*/
.swiper-slide-text {
	position: absolute;
	top: 45%;
	left: 45%;
	width: 80%;
	transform: translate(-50%, -50%);

	-webkit-transform: translate(-50%, -50%);
}

@media (min-width: 48em) {
	.swiper-slide-text {
		top: 35%;
		left: 55%;
		width: 95%;
		margin-top: 60px;
		transform: none;
		/*- navの透過部分の高さをプラスして表示位置調整 -*/

		-webkit-transform: none;
	}
}

.swiper-slide-text h2 {
	letter-spacing: 0.1em;
	color: #333333;
	text-shadow: 3px 3px 3px #ffffff, -3px -3px 3px #ffffff,
	-3px 3px 3px #ffffff,  3px -3px 3px #ffffff,
	3px 0 3px #ffffff, -3px -0 3px #ffffff,
	0 3px 3px #ffffff,  0 -3px 3px #ffffff;
	font-size: 20px;
	font-weight: bold;
}

@media (min-width: 48em) {
	.swiper-slide-text h2 {
		margin-bottom: 6px;
		color: #333333;
		text-shadow: 3px 3px 3px #ffffff, -3px -3px 3px #ffffff,
		-3px 3px 3px #ffffff,  3px -3px 3px #ffffff,
		3px 0 3px #ffffff, -3px -0 3px #ffffff,
		0 3px 3px #ffffff,  0 -3px 3px #ffffff;
		font-size: 60px;
		font-weight: bold;
		line-height: 4rem;
	}
}

.swiper-slide-text p {
	margin-top: 1.5rem;
	letter-spacing: 0.1em;
	color: #696969;
	text-shadow: 3px 3px 3px #ffffff, -3px -3px 3px #ffffff,
	-3px 3px 3px #ffffff,  3px -3px 3px #ffffff,
	3px 0 3px #ffffff, -3px -0 3px #ffffff,
	0 3px 3px #ffffff,  0 -3px 3px #ffffff;
	font-size: 1.0rem;
	line-height: 2rem;
}

@media (min-width: 48em) {
	.swiper-slide-text p {
		margin-top: 2rem;
		letter-spacing: 0.1em;
		color: #696969;
		text-shadow: 3px 3px 3px #ffffff, -3px -3px 3px #ffffff,
		-3px 3px 3px #ffffff,  3px -3px 3px #ffffff,
		3px 0 3px #ffffff, -3px -0 3px #ffffff,
		0 3px 3px #ffffff,  0 -3px 3px #ffffff;
		font-size: 1.0rem;
		font-weight: bold;
		line-height: 2rem;
	}
}

/*- ナビゲーションのスタイル -*/
.swiper-button-prev {
	left: 3%;
}

.swiper-button-next {
	right: 3%;
}

.swiper-button-prev,
.swiper-button-next {
	top: calc(50% + 30px);
	/*- navの透過部分の高さの半分をプラスして表示位置調整 -*/
}

@media (min-width: 48em) {
	.swiper-container.swiper-infinite .swiper-wrapper {
		transition-timing-function: linear !important;

		-webkit-transition-timing-function: linear !important;
	}
}

/****************************** Content Slider End ******************************/
.badge-primary {
	color: #ffffff;
	background-color: #00a1e9;
}

/*- カードイメージのラウンド化(class="rounded-circle")スタイル -*/
.card-body {
	flex: 1 1 auto;
	padding: 0.7rem;

	-ms-flex: 1 1 auto;
}

.card-img-wrapper {
	position: relative;
	overflow: hidden;
}

.card-img-wrapper img {
	display: block;
	max-width: 100%;
	margin: auto;
}

.round-card .card {
	border: 0;
	border-radius: 0;
}

.round-card .card .card-img-wrapper {
	width: 50%;
	margin: auto;
	margin-top: -15%;
	border: 3px solid #ffffff;
}

/*- カードの背景はみ出し -*/
.round-card .stick_out {
	margin-top: -5rem;
	/*- 上部はみ出し量 -*/
	margin-bottom: calc(5rem + 25%);
}

@media screen and (min-width: 48em) {
	.round-card .stick_out {
		margin-bottom: 3rem;
	}
}

/*- カードの重ねと背景はみ出し -*/
.stack-card .image-card {
	margin-top: -10rem;
	/*- 上部はみ出し量 -*/
	margin-bottom: 0;
	/*- SP表示時のカード間隔詰め -*/
}

@media screen and (min-width: 48em) {
	.stack-card .image-card {
		margin-top: -5rem;
		/*- 上部はみ出し量 -*/
		margin-right: -3rem;
		/*- 右部はみ出し量 -*/
		margin-bottom: 3rem;
	}

	.stack-card .text-card {
		margin-top: -2rem;
		/*- 上部はみ出し量 -*/
		margin-bottom: 3rem;
	}
}

.stack-card .text-card .card-body {
	padding: 3rem;
}

.stack-card .image-card,
.stack-card .image-card .card-img,
.stack-card .text-card {
	border: 0;
	border-radius: 0;
}

/****************************** Message Board ******************************/

#message-board .background-link {
	height: 50vh;
	background-repeat: no-repeat;
	background-position: center;
	background-size: cover;
}

@media (min-width: 48em) {
	#message-board .background-link {
		height: 500px;
	}
}

#message-board .wrapper {
	position: relative;
}

#message-board .information-label {
	position: absolute;
	z-index: 1;
	top: 0;
	left: 0;
	width: 150px;
	height: 110px;
}

@media (min-width: 48em) {
	#message-board .information-label {
		left: 150px;
	}
}

#message-board .information-label::before {
	position: absolute;
	z-index: -1;
	top: 25px;
	left: 80px;
	width: 70px;
	height: 70px;
	content: '';
	transform: rotate(45deg);

	-webkit-transform: rotate(45deg);
}

#message-board .information {
	position: relative;
	width: 100%;
	padding-right: 15px;
	padding-left: 15px;
}

@media (min-width: 48em) {
	#message-board .information {
		position: absolute;
		z-index: 1;
		top: 120px;
		left: 150px;
		width: 600px;
		padding: 0;
	}
}

#message-board .information-label h2 {
	margin: 0;
	margin-top: 30px;
	text-align: center;
	font-size: 1.15rem;
	line-height: 30px;
}

#message-board .information-label p {
	margin: 0;
	margin-top: 0rem;
	text-align: center;
	font-size: 0.85rem;
}

#message-board .information-category {
	margin: 2rem 0 0;
	color: #b7985b;
}

@media (min-width: 48em) {
	#message-board .information-category {
		margin: 1.5rem 0 0;
	}
}

#message-board .information-title {
	margin: 1.75rem 0 0;
	color: #333333;
}

#message-board .information-text {
	margin: 1.75rem 0 0;
	color: #333333;
	line-height: 30px;
}

#message-board .information-data {
	display: block;
	margin: 1.5rem 0 0;
	color: #333333;
	font-size: 0.875rem;
}

#message-board .information-link {
	position: relative;
	display: block;
	margin: 1.5rem 0 0;
	text-align: center;
	color: #b7985b;
}

@media (any-hover: hover) {
	#message-board .information-link:hover {
		text-decoration: underline;
	}
}

#message-board .information-link::before,
#message-board .information-link::after {
	position: absolute;
	top: calc(50% - 2px);
	width: 100px;
	height: 3px;
	content: '';
	border-top: solid 1px #b7985b;
	border-bottom: solid 1px #b7985b;
}

#message-board .information-link::before {
	left: 0;
}

#message-board .information-link::after {
	right: 0;
}

/*- board-1 -*/
#message-board.board-1 .background-link {
	background-image: url(../img/../img/showroom_0001.jpg);
}

@media (min-width: 48em) {
	#message-board.board-1 .background-link {
		background-image: linear-gradient(90deg, rgba(255, 255, 255, 0.85) 800px, transparent 500px), url(../img/showroom_001.jpg);
	}
}

#message-board.board-1 .information-label {
	background-color: #0068b7;
}

#message-board.board-1 .information-label h2 {
	color: #ffffff;
	background-color: #0068b7;
}

#message-board.board-1 .information-label p {
	color: #ffffff;
}

/*- board-2 -*/
#message-board.board-2 .background-link {
	background-image: url(../img/slide_img-07.jpg);
}

@media (min-width: 48em) {
	#message-board.board-2 .background-link {
		background-image: linear-gradient(90deg, rgba(255, 255, 255, 0.75) 500px, transparent 500px), url(../img/slide_img-07.jpg);
	}
}

#message-board.board-2 .information-label {
	background-color: #cccccc;
}

#message-board.board-2 .information-label h2 {
	color: #333333;
	background-color: #cccccc;
}

#message-board.board-2 .information-label p {
	color: #333333;
}

/*	background: linear-gradient(90deg, rgba(255, 255, 255, 0.95) 10%, rgba(255, 255, 255, 0.8) 20%, rgba(255, 255, 255, 0.6) 40%, transparent 40%), url(../img/slide_img-04.jpg);*/

/****************************** Message Board End ******************************/


/****************************** Card ******************************/

#card01 .card {
	margin-top: 0;
}

@media (min-width: 48em) {
	#card01 .card {
		margin-top: 20px;
	}
}

#card01 .card .information-label {
	position: absolute;
	z-index: 1;
	top: -60px;
	left: 50%;
	width: 180px;
	height: 120px;
	transform: translateX(-50%);

	-webkit-transform: translateX(-50%);
}

@media (min-width: 48em) {
	#card01 .card .information-label {
		top: -20px;
	}
}

#card01 .card .information-label::before {
	position: absolute;
	z-index: -1;
	top: 25px;
	left: 55px;
	width: 70px;
	height: 70px;
	content: '';
	transform: rotate(45deg);
	border: 1px solid #b7985b;

	-webkit-transform: rotate(45deg);
}

#card01 .card .information-label h2 {
	margin: 0;
	margin-top: 45px;
	text-align: center;
	font-size: 1.25rem;
	line-height: 30px;
}

#card01 .card .information-label p {
	margin: 0;
	margin-top: 0.25rem;
	text-align: center;
}

#card01 .card.board-1 .information-label {
	background-color: #333333;
}

#card01 .card.board-1 .information-label h2 {
	color: #ffffff;
	background-color: #333333;
}

#card01 .card.board-1 .information-label p {
	color: #ffffff;
}

#card01 .card.board-2 .information-label {
	background-color: #cccccc;
}

#card01 .card.board-2 .information-label h2 {
	color: #333333;
	background-color: #cccccc;
}

#card01 .card.board-2 .information-label p {
	color: #333333;
}

#card01 .card .card-body .underline {
	width: 50px;
	height: 1px;
	margin: 1rem auto;
	border-radius: 5;
	background-color: #b7985b;
}

/*- Card hoverエフェクト用ラッパー -*/
.card-img-wrapper {
	position: relative;
	overflow: hidden;
}

.card-img-wrapper img {
	display: block;
	margin: auto;
}

/*- Card hover ズームエフェクト -*/
@media (any-hover: hover) {
	.card a.scale-up:hover img {
		transform: scale(1.03) !important;

		-webkit-transform: scale(1.03);
	}
}

/****************************** Card End ******************************/
hr {
	width: 18%;
	height: 2px;
	margin-bottom: 3rem;
	text-align: left;
	border: none;
	background-color: #0068b7;
}

/****************************** Panel ******************************/

#panel .background-image {
	display: flex;
	align-items: center;
	justify-content: center;
	height: 50vh;
	background-repeat: no-repeat;
	background-position: center;
	background-size: cover;

	-webkit-box-align: center;
	-webkit-box-pack: center;
	-ms-flex-align: center;
	-ms-flex-pack: center;
}

@media (min-width: 48em) {
	#panel .background-image {
		height: 350px;
	}
}

#panel .background-image.left {
	background-image: url(../img/slide_img-08.jpg);
}

#panel .background-image.right {
	background-color: #ffffff;
}

#panel .image-wrapper {
	width: 80px;
}

@media (min-width: 48em) {
	#panel .image-wrapper {
		width: 160px;
	}
}

#panel .image-wrapper img {
	width: 100%;
	max-width: initial;
}

#panel .item-wrapper {
	width: 460px;
}

#panel .item-wrapper .logo {
	width: 80px;
	margin: auto;
	margin-bottom: 2rem;
}

#panel .item-wrapper h4 {
	margin: 0;
	margin-bottom: 2rem;
	color: #333333;
	font-size: 1.125rem;
	line-height: 1.5;
}

@media (min-width: 48em) {
	#panel .item-wrapper h4 {
		line-height: 1.75;
	}
}

#panel .item-wrapper .btn-navy {
	width: 150px;
	color: #b4f0dc;
	border-color: #b4f0dc;
	background-color: #002850;
}

@media (any-hover: hover) {
	#panel .item-wrapper .btn-navy:hover {
		color: #002850;
		border-color: #b4f0dc;
		background-color: #b4f0dc;
	}
}

.typing {
	overflow: hidden;
	width: 30ch;
	-webkit-animation: typing 2s steps(16), blink 5.9s step-end infinite alternate;
	animation: typing 2s steps(16), blink 5.9s step-end infinite alternate;
	white-space: nowrap;
	border-right: 3px solid;
	font-size: 6em;
}

@-webkit-keyframes typing {
	from {
		width: 0;
	}
}

@keyframes typing {
	from {
		width: 0;
	}
}

@-webkit-keyframes blink {
	50% {
		border-color: transparent;
	}
}

@keyframes blink {
	50% {
		border-color: transparent;
	}
}
