@charset "utf-8";

/* 共通項目 */
* {
	box-sizing: border-box;
}

html {
	/* font-size: 62.5%; */
	overflow-y: scroll;
}

@import url(http://fonts.googleapis.com/earlyaccess/notosansjp.css);

body {
	display: none;
	background: #fff;
	/* font-family: "Arial", 'Noto Sans JP', sans-serif; */
	/*font-family: "ヒラギノ角ゴ Pro W3","Hiragino Kaku Gothic Pro",sans-serif;*/
	/* font-size: 1.6rem; */
	/* font-size: 16px; */
	line-height: 1.85;
	letter-spacing: 1px;
	color: #090909;
	-webkit-font-smoothing: antialiased;
	-moz-osx-font-smoothing: grayscale;
	-webkit-text-size-adjust: 100%;
	word-wrap: break-word;
}

@media screen and (max-width: 640px) {
	body {
		/*font-size: clamp(1.5rem, 2vw + 1rem, 2.25rem);*/
	}
}

.mincho {
	font-family: "ヒラギノ明朝 ProN W3", "Hiragino Mincho ProN", serif;
}

.gothic {
	font-family: "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", sans-serif;
}

.pc {
	display: block;
}

.sp {
	display: none;
}

.pcBr {
	display: inline;
}

.spBr {
	display: none;
}

@media screen and (max-width: 640px) {
	.pc {
		display: none;
	}

	.sp {
		display: block;
	}

	.pcBr {
		display: none;
	}

	.spBr {
		display: inline;
	}
}

a {
	text-decoration: none;
	color: #090909;
}

a:hover {
	text-decoration: underline;
}

p {
	line-height: 1.7;
}

ul {
	list-style: none;
}

/* Base design */
.container {
	margin: 0 auto;
	position: relative;
	width: 100%;
}

@media screen and (max-width: 640px) {
	.container {
		margin: 0 auto;
		width: 100%;
	}
}

main {
	margin: 0 auto;
	min-width: 1200px;
}

@media screen and (max-width: 640px) {
	main {
		margin: 0 auto;
		width: 100%;
		min-width: initial;
	}
}

.title_1 {
	font-size: 36px;
	font-size: 36px;
	font-weight: normal;
}

@media screen and (max-width: 640px) {
	.title_1 {
		margin-top: 20px;
		font-size: 2.4rem;
		font-size: 24px;
		font-weight: bold;
	}
}


/* wrapper */
.wrapper1 {
	padding-top: 90px;
	min-width: 1200px;
}

@media screen and (max-width: 640px) {
	.wrapper1 {
		padding-top: 60px;
		min-width: initial;
	}
}

.wrapper2 {
	margin: 0 auto 100px auto;
	width: 1200px;
}

@media screen and (max-width: 640px) {
	.wrapper2 {
		margin: 0 auto 50px auto;
		width: 90%;
	}
}

.wrapper3 {
	margin: 40px auto 100px auto;
	width: 1200px;
}

@media screen and (max-width: 640px) {
	.wrapper3 {
		width: 90%;
		margin: 30px auto 50px auto;
	}
}

.wrapper4 {
	min-width: 1200px;
}

@media screen and (max-width: 640px) {
	.wrapper4 {
		width: 90%;
		margin: 0 auto;
		min-width: auto;
	}
}

.wrapper5 {
	margin: 98px auto 0;
	min-width: 1200px;
	text-align: center;
}

@media screen and (max-width: 640px) {
	.wrapper5 {
		margin: 0 auto;
		min-width: initial;
		text-align: center;
	}
}

.wrapper6 {
	margin: 100px auto;
	width: 1200px;
	text-align: center;
}

@media screen and (max-width: 640px) {
	.wrapper6 {
		margin: 50px auto;
		width: 90%;
	}
}

.wrapper7 {
	height: 70vh;
	width: 100%;
	object-fit: cover;
	object-position: top;
}

@media screen and (max-width: 640px) {
	.wrapper7 {
		height: 155vw;
		width: 100%;
		object-fit: cover;
		object-position: 53% center;
	}
}

.wrapper8 {
	margin: 0 auto;
	width: 1200px;
}

@media screen and (max-width: 640px) {
	.wrapper8 {
		width: 100%;
		margin: 0 auto;
	}
}

.wrapper9 {
	height: 70vh;
	width: 100%;
	object-fit: cover;
	object-position: center;
}

@media screen and (max-width: 640px) {
	.wrapper9 {
		height: 87vw;
		width: 100%;
		object-fit: contain;
	}
}

.wrapper10 {
	margin: 0 auto;
	width: 1200px;
	padding-top: 95px;
}

.wrapper11 {
	width: 100%;
	background-color: #f8f8f8;
}

.wrapper12 {
	width: 100%;
}

.wrapper13,
.wrapper14 {
	margin: 100px auto 0 auto;
	width: 1200px;
}

@media screen and (max-width: 640px) {
	.wrapper13 {
		width: 100%;
		margin: 100px auto 0 auto;
	}

	.wrapper14 {
		width: 90%;
		margin: 0 auto;
	}
}

.wrapper15 {
	height: 40vh;
	width: 100%;
	object-fit: cover;
	object-position: top;
}

@media screen and (max-width: 640px) {
	.wrapper15 {
		height: 71vw;
		width: 100%;
		object-fit: cover;
		object-position: center 50px;
	}
}

.wrapper16 {
	margin: 0 auto;
	width: 1200px;
}

@media screen and (max-width: 640px) {
	.wrapper16 {
		width: 100%;
		margin: 50px 0 0 0;
	}
}

.wrapper17 {
	margin: 100px auto 0 auto;
	width: 1200px;
}

@media screen and (max-width: 640px) {
	.wrapper17 {
		width: 90%;
		margin: 50px auto 0 auto;
	}
}

.wrapper18 {
	margin: 100px auto 0 auto;
	width: 1200px;
}

@media screen and (max-width: 640px) {
	.wrapper18 {
		margin: 50px auto 0 auto;
		width: 100%;
	}
}

.wrapper19 {
	margin: 100px auto 0 auto;
	width: 100%;
}

@media screen and (max-width: 640px) {
	.wrapper19 {
		margin: 50px auto 0 auto;
	}
}

.wrapper20 {
	margin: 0 auto;
	width: 1200px;
}

@media screen and (max-width: 640px) {
	.wrapper20 {
		width: 90%;
		margin: 0 auto;
	}
}

.wrapper21 {
	margin: 0 auto;
	width: 1200px;
}

@media screen and (max-width: 640px) {
	.wrapper21 {
		margin: 0 auto;
		width: 100%;
	}
}

.wrapper22 {
	margin: 100px auto 0 auto;
	width: 1200px;
	text-align: center;
	position: relative;
}

@media screen and (max-width: 640px) {
	.wrapper22 {
		margin: 50px auto 0 auto;
		width: 100%;
	}
}

.wrapper23 {
	min-width: 1200px;
}

@media screen and (max-width: 640px) {
	.wrapper23 {
		width: 100%;
		margin: 0 auto;
		min-width: auto;
	}
}

.wrapper24 {
	margin: 0 auto;
	width: 1200px;
	text-align: center;
	position: relative;
}

@media screen and (max-width: 640px) {
	.wrapper24 {
		margin: 50px auto 0 auto;
		width: 100%;
	}
}

.wrapper25 {
	width: 100%;
	background-color: #faf8f5;
	padding: 20px 0 1px 0;
}

@media screen and (max-width: 640px) {
	.wrapper25 {
		width: 100%;
		background-color: #faf8f5;
		padding: 20px 0 1px 0;
	}
}

.wrapper26 {
	margin: 98px auto 0;
	min-width: 1200px;
	text-align: center;
	position: relative;
}

@media screen and (max-width: 640px) {
	.wrapper26 {
		margin-top: 75px;
		min-width: initial;
	}
}

.wrapper27 {
	margin: 0 auto 50px auto;
	width: 1200px;
}

@media screen and (max-width: 640px) {
	.wrapper27 {
		margin: 0 auto;
		width: 90%;
	}
}

.wrapper28 {
	margin: 50px auto 0 auto;
	width: 1200px;
	text-align: center;
	position: relative;
}

@media screen and (max-width: 640px) {
	.wrapper28 {
		margin: 50px auto 0 auto;
		width: 90%;
	}
}







/* header */
#header {
	margin: 0;
	padding: 20px 0 0 0;
	position: fixed;
	min-width: 1200px;
	width: 100%;
	z-index: 999;
	background-color: #fff;
	border-bottom: 1px solid #dadada;
}

@media screen and (max-width: 640px) {
	#header {
		margin: 0;
		padding: 0;
		height: 64px;
		min-width: initial;
		display: flex;
		align-items: center;
	}
}

.header_area {
	/*position: relative;*/
	margin: 0 auto;
	width: 100%;
	min-width: 1200px;
}

@media screen and (max-width: 640px) {
	.header_area {
		position: relative;
		margin: 0 5%;
		width: 90%;
	}
}

.header_area_sub {
	width: 1200px;
	margin: 0 auto;
	position: relative;
	/*border: 1px solid #ff0000;*/
}

@media screen and (max-width: 640px) {
	.header_area_sub {
		width: 100%;
	}
}

#header.UpMove {
	position: fixed;
	width: 100%;
	animation: UpAnime 0.5s forwards;
}

@keyframes UpAnime {
	from {
		opacity: 1;
		transform: translateY(0);
	}

	to {
		opacity: 0;
		transform: translateY(-100px);
	}
}

#header.DownMove {
	position: fixed;
	width: 100%;
	animation: DownAnime 0.5s forwards;
}

@keyframes DownAnime {
	from {
		opacity: 0;
		transform: translateY(-100px);
	}

	to {
		opacity: 1;
		transform: translateY(0);
	}
}

.global-nav {
	margin: 0 auto;
	position: relative;
	z-index: 1;
}

.global-nav .nav-list {
	display: flex;
	justify-content: center;
	list-style: none;
	/*margin: 0 52px 0 0;*/
	margin: 0;
	padding: 0 52px 0 0;
}

.global-nav .nav-list .nav-item {
	/*flex: 1;*/
	/*width: 100%;*/
	/*height: 70px;*/
	padding: 0 1.4em 1.4em 1.4em;
}

.global-nav .nav-list .nav-item a {
	/*border-right: 1px solid #ccc;*/
	color: #090909;
	display: block;
	padding: 0.6em 0.4em;
	text-align: center;
	text-decoration: none;
	transition: 0.5s;
}

.global-nav .nav-list .nav-item a:hover {
	color: #aaaaaa;
}


/* spボタン */
.global-nav-icon {
	display: none;
}

@media screen and (max-width: 640px) {
	.global-nav-header {}

	.global-nav .nav-list {
		background: rgba(255, 255, 255, 0.9);
		display: none;
		left: 50%;
		padding: 10px 10px 10px 10px;
		position: absolute;
		transform: translate(-50%, 0%);
		width: 100%;
	}

	.global-nav .nav-list .nav-item:first-child {
		padding: 0.6em 1.4em 0 1.4em;
	}

	.global-nav .nav-list .nav-item {
		padding: 0 1.4em;
	}

	.global-nav .nav-list .nav-item a {
		border-bottom: 1px solid #090909;
		color: #090909;
		padding: 1rem 1rem;
		text-align: left;
	}

	.global-nav-icon {
		cursor: pointer;
		display: inline-block;
		position: absolute;
		left: 0;
		top: -20px;
		z-index: 2;
		width: 50px;
		height: 50px;
	}

	/*ボタン内側*/
	.global-nav-icon span {
		display: inline-block;
		transition: all 0.5s;
		/*アニメーションの設定*/
		position: absolute;
		left: 10px;
		height: 2px;
		border-radius: 2px;
		background: #090909;
		width: 45%;
	}

	.global-nav-icon span:nth-of-type(1) {
		top: 10px;
	}

	.global-nav-icon span:nth-of-type(2) {
		top: 18px;
	}

	.global-nav-icon span:nth-of-type(3) {
		top: 26px;
	}

	/*activeクラスが付与されると線が回転して×に*/
	.global-nav-icon.active span:nth-of-type(1) {
		top: 10px;
		left: 10px;
		transform: translateY(8px) rotate(-45deg);
		width: 40%;
	}

	.global-nav-icon.active span:nth-of-type(2) {
		opacity: 0;
		/*真ん中の線は透過*/
	}

	.global-nav-icon.active span:nth-of-type(3) {
		top: 26px;
		left: 10px;
		transform: translateY(-8px) rotate(45deg);
		width: 40%;
	}
}

/* サブナビ */
@media screen and (min-width: 641px) {
	.nav-list {
		position: relative;
	}

	.nav-item_sub {
		background: #fff;
		left: 0;
		/*margin: 0 calc(50% - 50vw);*/
		opacity: 0;
		position: absolute;
		top: 70px;
		transition: all 0.5s ease;
		/*visibility: hidden;*/
		display: none;
		width: 100%;
		box-shadow: 0 2px 10px #dadada;
	}

	.nav-item_sub .nav-inner {
		display: flex;
		justify-content: center;
		margin: 0 auto;
		width: 1200px;
	}

	.nav-item_sub .nav-inner ul {
		margin: 20px 20px 20px;
	}

	.global-nav .nav-list .nav-item_sub a {
		text-align: left;
	}

	.nav-item:hover .nav-item_sub {
		opacity: 1;
		/*visibility: visible;*/
		display: block;
		animation: appear 0.5s ease;
	}

	@keyframes appear {
		0% {
			opacity: 0;
		}

		100% {
			opacity: 1;
		}
	}
}

@media screen and (max-width: 640px) {
	.nav-item_sub {
		display: none;
	}

	.global-nav {
		height: 100%;
		left: 0;
		position: fixed;
		top: 64px;
		width: 100%;
		z-index: 1;
	}

	.nav-list {
		height: 100%;
		overflow: auto;
		-webkit-overflow-scrolling: touch;
	}
}

/* ヘッダー */
.logo_orientstar {
	position: absolute;
	z-index: 10;
}

.logo_orientstar img {
	position: absolute;
	top: 4px;
	left: 5px;
	height: 40px;
}

.logo_cart {
	/*position: absolute;*/
	font-size: 1.6rem;
	font-size: 16px;
	font-weight: normal;
}

.logo_cart img {
	position: absolute;
	top: 3px;
	right: 0;
	z-index: 10;
	width: 40px;
	float: right;
}

.logo_cart p {
	position: absolute;
	top: 14px;
	right: 48px;
	z-index: 10;
	width: 170px;
}

@media screen and (max-width: 640px) {
	.logo_orientstar img {
		position: absolute;
		top: -20px;
		left: 32vw;
		width: 110px;
	}

	.logo_cart img {
		position: absolute;
		top: -20px;
		left: 80vw;
		/* width: 50px; */
		z-index: 10;
	}

	.logo_cart p {
		display: none;
	}
}

.menu_ds-f {
	display: flex;
	flex-wrap: wrap;
	justify-content: center;
}

.menu_ds-f p {
	text-align: center;
}

.menu_sub_1 {
	width: 176px;
}

.menu_sub_2 {
	width: 330px;
	height: 150px;
	object-fit: cover;
}

.menu_sub_3 {
	width: 106px;
	height: 100px;
	margin: 0 20px;
	object-fit: cover;
	object-position: 93% 50%;
}

.menu_sub_4 {
	text-align: center !important;
	border: 1px solid #d9d9d9;
}

.menu_sub_4 img {
	width: 320px;
	margin-bottom: 5px;
}

.menu_sub_5 {
	text-align: center !important;
	border: 1px solid #d9d9d9;
}

.menu_sub_5 img {
	width: 100%;
}

.menu_sub_6 {}

.menu_sub_6 img {
	width: 25100%x;
	height: 150px;
	object-fit: cover;
}

@media screen and (max-width: 640px) {
	.menu_ds-f {
		display: block;
	}

	.menu_ds-f p {
		text-align: left;
		margin-left: 2rem;
	}

	.menu_sub_1 {
		display: none;
	}

	.menu_sub_2 {
		display: none;
	}

	.menu_sub_3 {
		display: none;
	}

	.menu_sub_4 {
		font-size: 1.2rem;
		font-size: 12px;
		border: none;
	}

	.menu_sub_4 img {
		width: 80%;
	}

	.menu_sub_5 {
		font-size: 1.2rem;
		font-size: 12px;
		border: none;
	}
}



/* パンくず */
.breadcrumb {
	margin: 0;
	padding: 0;
	list-style: none;
	font-size: 1.4rem;
	font-size: 14px;
}

.breadcrumb li {
	display: inline;
	/*横に並ぶように*/
	list-style: none;
	font-weight: normal;
	/*太字*/
}

.breadcrumb li:after {
	/* >を表示*/
	content: '>';
	padding: 0 0.2em;
}

.breadcrumb li:last-child:after {
	content: '';
}

.breadcrumb li a {
	text-decoration: none;
}

.breadcrumb li a:hover {
	text-decoration: underline;
}



/* フッター */
#footer {
	/*margin: 100px 0 0 0;
	padding: 50px 0 0 0;*/
	padding: 150px 0 0 0;
	position: relative;
	background-color: #f8f8f8;
	min-width: 1200px;
	width: 100%;
}

@media screen and (max-width: 640px) {
	#footer {
		/*margin: 50px 0 0 0;
		padding: 50px 0 0 0;*/
		padding: 100px 0 0 0;
		position: relative;
		background-color: #f8f8f8;
		min-width: initial;
	}
}

.footer_area {
	margin: 0 auto;
	width: 1200px;
}

@media screen and (max-width: 640px) {
	.footer_area {
		margin: 0 5%;
		width: 90%;
	}
}

.footer_notes {
	padding-left: 1em !important;
	text-indent: -1em !important;
	margin-top: 20px;
	font-size: 1.2rem;
	font-size: 12px;
}

@media screen and (max-width: 640px) {
	.footer_notes {
		margin-top: 10px;
	}
}

.logo_sns {
	width: 3%;
}

@media screen and (max-width: 640px) {
	.logo_sns {
		width: 12%;
	}
}

.logo_sns img {
	width: 100%;
}

a .logo_sns_facebook:hover {
	fill: #3b5998;
}

a .logo_sns_instagram:hover {
	fill: #d83776;
}

a .logo_sns_youtube:hover {
	fill: #ff0000;
}

.ac_footer {
	float: left;
	width: 16.5%;
	/*border: 1px solid #090909;*/
}

.ac_footer-label {
	font-weight: bold;
}

.ac_footer-content {
	font-size: 1.4rem;
	font-size: 14px;
	padding: 0 0 8px 0;
}

.ac_footer-content p {}

@media screen and (max-width: 640px) {
	.ac_footer {
		width: 100%;
		margin: 0 auto;
	}

	.ac_footer>li {
		padding-bottom: 6px;
		list-style: none;
	}

	.ac_footer-label {
		cursor: pointer;
		position: relative;
		padding: 0.4em;
		border-bottom: 1px solid #d9d9d9;
	}

	.ac_footer-content {
		display: none;
	}

	.ac_footer-content p {
		padding: 8px 0 8px 20px;
		border-bottom: 1px solid #d9d9d9;
	}

	.ac_footer-content_block {
		padding: 0.4em;
		border-bottom: 1px solid #d9d9d9;
	}

	.icon-wrap {
		position: absolute;
		right: 5px;
		top: 50%;
		transform: translatey(-50%);
		width: 30px;
		height: 30px;
		background: #d3d3d3;
	}

	.icon {
		position: relative;
		display: inline-block;
		width: 100%;
		height: 100%;
	}

	.icon:before,
	.icon:after {
		position: absolute;
		content: "";
		display: block;
		transition: all 0.5s;
		background: #fff;
		left: 50%;
		top: 50%;
		width: 50%;
		height: 2px;
		transform: translate(-50%, -50%);
	}

	.icon:before {
		transform: translate(-50%, -50%) rotate(90deg);
	}

	/*＋、－切り替え*/
	.icon.open:before {
		transform: translate(-50%, -50%) rotate(0deg);
	}
}


.l-footer-bottom-wrap {
	background-color: #212121;
}

.l-footer-bottom {
	width: 1120px;
	margin: 0px auto;
	padding: 10px 0px;
}

.l-footer-bottom-navi {
	padding: 12px 0 5px 0;
	text-align: center;
}

.l-copyright {
	font-size: 1.2rem;
	font-size: 12px;
	line-height: 28px;
	color: #aeaeae;
	text-align: center;
}

@media screen and (max-width:640px) {
	.l-footer-bottom-wrap {
		background-color: #212121;
	}

	.l-footer-bottom {
		width: 100%;
		margin: 0px auto;
		padding: 17px 0 28px 0;
		text-align: center;
	}

	.l-footer-bottom-navi {
		float: none;
		padding-bottom: 28px;
	}

	.l-footer-bottom-navi img {
		width: 20%;
	}

	.l-footer-bottom-navi li {
		font-size: 2.2rem;
		font-size: 22px;
		line-height: 28px;
		color: #aeaeae;
		float: none;
		display: inline-block;
	}

	.l-footer-bottom-navi li a {
		color: #aeaeae;
	}

	.l-copyright {
		font-size: 1.1rem;
		font-size: 11px;
		line-height: 0;
		color: #aeaeae;
		float: none;
	}
}









/* Page Top */
#page-top a {
	display: flex;
	justify-content: center;
	align-items: center;
	background: #aaa;
	border-radius: 5px;
	width: 60px;
	height: 60px;
	color: #fff;
	text-align: center;
	text-transform: uppercase;
	text-decoration: none;
	font-size: 1rem;
	font-size: 10px;
	transition: all 0.5s;
}

/*@media screen and (max-width: 640px) {
	#page-top a{
		font-size:1rem;
        font-size:10px;
	}
}*/
#page-top a:hover {
	background: #2b2b2b;
}

/*リンクを右下に固定*/
#page-top {
	position: fixed;
	right: 10px;
	bottom: 40px;
	z-index: 2;
	/*はじめは非表示*/
	opacity: 0;
	transform: translateY(100px);
}

#page-top.UpMove {
	animation: page-top_UpAnime 0.5s forwards;
}

@keyframes page-top_UpAnime {
	from {
		opacity: 0;
		transform: translateY(100px);
	}

	to {
		opacity: 1;
		transform: translateY(0);
	}
}

#page-top.DownMove {
	animation: page-top_DownAnime 0.5s forwards;
}

@keyframes page-top_DownAnime {
	from {
		opacity: 1;
		transform: translateY(0);
	}

	to {
		opacity: 1;
		transform: translateY(100px);
	}
}




/* TOP */
.top_m-collection_1 {
	position: absolute;
	top: 150px;
	left: 130px;
	z-index: 10;
	line-height: 3em;
}

@media screen and (max-width: 640px) {
	.top_m-collection_1 {
		width: 10em;
		position: absolute;
		top: calc(50% + 145px);
		left: calc(1% - 75px);
		z-index: 10;
		text-align: left;
		line-height: 2em;
	}
}

.top_m-collection_3 {
	height: 339px;
	overflow: hidden;
	min-width: 1200px;
	background-color: #002c55;
}

@media screen and (max-width: 640px) {
	.top_m-collection_3 {
		height: 70vw;
		min-width: initial;
	}
}

.top_m-collection_4 {
	text-align: center;
	margin-top: 100px;
	min-width: 1200px;
	font-weight: normal;
}

@media screen and (max-width: 640px) {
	.top_m-collection_4 {
		min-width: initial;
		margin-top: 50px;
		font-size: 2.2rem;
		font-size: 22px;
	}
}

.top_m-collection_5 {
	text-align: center;
	margin-top: 50px;
}

@media screen and (max-width: 640px) {
	.top_m-collection_5 {
		margin: 20px 0 0 0;
	}
}

.top_m-collection_6 {
	position: absolute;
	top: 110px;
	left: 200px;
	z-index: 10;
	width: 12%;
}

@media screen and (max-width: 640px) {
	.top_m-collection_6 {
		position: absolute;
		top: calc(50% + 15px);
		left: calc(50% + 30px);
		z-index: 10;
		width: 45%;
	}
}

.top_m-collection_7 {
	border: 2px solid #fff;
	padding: 10px 40px;
	font-weight: bold;
}

@media screen and (max-width: 640px) {
	.top_m-collection_7 {
		border: 2px solid #fff;
		padding: 10px 20px;
		font-weight: bold;
	}
}

.top_m-collection_8 {
	position: absolute;
	top: 110px;
	left: 230px;
	z-index: 10;
	width: 10%;
}

@media screen and (max-width: 640px) {
	.top_m-collection_8 {
		position: absolute;
		top: calc(50% + 10px);
		left: calc(50% + 60px);
		z-index: 10;
		width: 42%;
	}
}

.top_m-collection_9 {
	width: 1200px;
	margin: 0 auto;
	position: relative;
}

@media screen and (max-width: 640px) {
	.top_m-collection_9 {
		width: 50%;
		text-align: center;
		position: relative;
	}
}

.top_m-collection_10 {
	object-fit: none;
	height: 339px;
	width: 100%;
}

.top_m-collection_11 {
	height: 239px;
	overflow: hidden;
	min-width: 1200px;
	background-color: #002c55;
}

@media screen and (max-width: 640px) {
	.top_m-collection_11 {
		height: 70vw;
		min-width: initial;
	}
}

.top_m-collection_14 {
	object-fit: cover;
	height: 239px;
	width: 100%;
}

@media screen and (max-width: 640px) {
	.top_m-collection_14 {
		object-fit: cover;
		object-position: center -20px;
		height: 339px;
		width: 100%;
	}
}

.top_m-collection_15 {
	position: absolute;
	top: 100px;
	left: 130px;
	z-index: 10;
	line-height: 3em;
}

.top_m-collection_16 {
	position: absolute;
	top: 30px;
	left: 200px;
	z-index: 10;
	width: 12%;
}

@media screen and (max-width: 640px) {
	.top_m-collection_16 {
		position: absolute;
		top: calc(50% + 15px);
		left: calc(50% + 30px);
		z-index: 10;
		width: 45%;
	}
}

.top_m-collection_17 {
	position: absolute;
	top: 70px;
	left: 130px;
	z-index: 10;
	line-height: 3em;
}

@media screen and (max-width: 640px) {
	.top_m-collection_17 {
		width: 10em;
		position: absolute;
		top: calc(50% + 145px);
		left: calc(1% - 75px);
		z-index: 10;
		text-align: left;
		line-height: 2em;
	}
}

.top_m-collection_18 {
	margin-top: 30px;
	height: 310px;
	overflow: hidden;
	min-width: 1200px;
}

@media screen and (max-width: 640px) {
	.top_m-collection_18 {
		min-width: initial;
		height: 450px;
		overflow: hidden;
	}
}

@media screen and (max-width: 640px) {
	.top_m-collection_19 {
		width: 100%;
		object-fit: cover;
		object-position: center;
	}
}

.top_m-collection_20 {
	position: absolute;
	top: 30px;
	left: 230px;
	z-index: 10;
	width: 10%;
}

@media screen and (max-width: 640px) {
	.top_m-collection_20 {
		position: absolute;
		top: calc(50% + 10px);
		left: calc(50% + 60px);
		z-index: 10;
		width: 42%;
	}
}



.top_fade-in-background {
	background-color: #ddd;
	position: relative;
	width: 100%;
	min-width: auto;
	height: 250px;
}

@media screen and (max-width: 640px) {
	.top_fade-in-background {
		background-color: #ddd;
		position: relative;
		width: 100%;
		min-width: auto;
		height: 56vw;
	}
}

@keyframes fadeIn {
	from {
		opacity: 0;
	}

	to {
		opacity: 1;
	}
}

.top_m-collection_21 {
	width: 100%;
	padding: 30px 0;
	text-align: center;
}

@media screen and (max-width: 640px) {
	.top_m-collection_21 {
		width: 100%;
		padding: 5vw 0;
	}
}

.top_m-collection_22 {
	width: 1200px;
	margin: 10px auto;
	text-align: center;
	/*border: 1px solid #FF0000;*/
}

.top_m-collection_22 .img_01 {
	width: 50%;
}

@media screen and (max-width: 640px) {
	.top_m-collection_22 {
		width: 100%;
		margin-top: 10px;
		text-align: center;
	}

	.top_m-collection_22 .img_01 {
		width: 95%;
	}
}


.top_m-collection_23 {
	width: 90%;
	margin: 20px auto 0 auto;
	font-size: 22px;
	font-weight: normal;
}

@media screen and (max-width: 640px) {
	.top_m-collection_23 {
		width: 90%;
		margin: 10px auto 0 auto;
		font-size: 1.2em;
		font-weight: normal;
	}
}

.top_m-collection_24 {
	background-color: #fff;
	width: 20%;
	margin: 30px auto 0 auto;
	font-size: 16px;
	font-weight: normal;
	padding: 10px 20px;
}

@media screen and (max-width: 640px) {
	.top_m-collection_24 {
		background-color: #fff;
		width: 50%;
		margin: 1em auto 0 auto;
		font-size: 1em;
		padding: 0.5em;
	}
}



.top_basic_1 {
	width: 100%;
	background-color: #faf8f5;
	padding: 150px 0 1px 0;
}

@media screen and (max-width: 640px) {
	.top_basic_1 {
		background-color: #faf8f5;
		padding: 100px 5px 20px 5px;
	}
}

.top_basic_2 {
	position: absolute;
	top: 75px;
	left: 50px;
	z-index: 10;
	line-height: 3em;
}

@media screen and (max-width: 640px) {
	.top_basic_2 {
		position: absolute;
		top: 80px;
		left: 5px;
		z-index: 10;
		text-align: center;
		line-height: 2em;
	}
}

.top_basic_3 {
	width: 25%;
	padding: 0 10px;
	overflow: hidden;
}

.top_basic_3 img {
	width: 100%;
	object-fit: cover !important;
}

@media screen and (max-width: 640px) {
	.top_basic_3 {
		width: 50%;
		overflow: hidden;
		margin-bottom: 20px;
	}
}

.top_other_1 {
	margin-top: 100px;
}

@media screen and (max-width: 640px) {
	.top_other_1 {
		margin-top: 50px;
	}
}

.top_other_2 {
	height: 300px;
	width: 100%;
	display: block;
	text-align: center;
}

@media screen and (max-width: 640px) {
	.top_other_2 {
		height: 200px;
		width: 100%;
		display: block;
		text-align: center;
	}
}

.top_other_3 {
	text-align: center;
	margin-top: 70px;
}

@media screen and (max-width: 640px) {
	.top_other_3 {
		text-align: center;
		margin-top: 30px;
	}
}

.top_other_4 {
	width: 30%;
	margin: 10px auto;
}

@media screen and (max-width: 640px) {
	.top_other_4 {
		width: 90%;
		margin: 10px auto;
	}
}

.top_other_5 {
	margin-top: 20px;
}

@media screen and (max-width: 640px) {
	.top_other_5 {
		margin-top: 10px;
	}
}

.top_other_6 {
	position: absolute;
	top: 100px;
	width: 100%;
	z-index: 10;
}

@media screen and (max-width: 640px) {
	.top_other_6 {
		position: absolute;
		top: 35px;
		width: 100%;
		z-index: 10;
	}
}

.top_other_6 p {
	font-size: 1.6rem;
	color: #fff;
	font-size: 16px;
	color: #fff;
}

@media screen and (max-width: 640px) {
	.top_other_6 p {
		font-size: 1.2rem;
		font-size: 12px;
	}
}

.top_other_7 {
	border: 2px solid #fff;
	padding: 10px 40px;
}

.top_other_8 {
	width: 100%;
	margin-top: 100px;
	background-color: #fff;
}

@media screen and (max-width: 640px) {
	.top_other_8 {
		margin-top: 0;
		background-color: #fff;
	}
}

.top_other_9 {
	text-align: center;
	padding: 100px 0 50px 0;
	font-weight: normal;
	font-size: 1.6rem;
	text-align: center;
	padding: 100px 0 50px 0;
	font-weight: normal;
	font-size: 16px;
}

@media screen and (max-width: 640px) {
	.top_other_9 {
		text-align: center;
		padding: 70px 0 0 0;
	}
}

.top_other_10 {
	display: flex;
	width: 100%;
	padding-bottom: 100px;
}

@media screen and (max-width: 640px) {
	.top_other_10 {
		display: block;
		width: 100%;
		padding-bottom: 70px;
	}
}

.top_other_10_2 {
	display: flex;
	width: 100%;
	padding-bottom: 50px;
}

@media screen and (max-width: 640px) {
	.top_other_10_2 {
		display: block;
		width: 100%;
		padding-bottom: 50px;
	}
}

@media screen and (max-width: 640px) {
	.top_other_11 {
		margin-top: 30px;
	}
}

.top_other_12 {
	width: 100%;
	margin-top: 0px;
	padding-bottom: 50px;
}

@media screen and (max-width: 640px) {
	.top_other_12 {
		margin-top: 0;
		padding-bottom: 0;
	}
}

.top_other_13 {
	/*width: 100%;*/
	width: 1200px;
	margin: 0 auto;
}

@media screen and (max-width: 640px) {
	.top_other_13 {
		width: 90%;
		margin-left: 5%;
	}
}

.top_other_14 {
	padding: 20px 100px 0 100px;
}

@media screen and (max-width: 640px) {
	.top_other_14 {
		padding: 20px;
		margin: 0 0 50px 0;
		background-color: #fff;
	}
}

@media screen and (max-width: 640px) {
	.top_other_15 {
		margin-top: 20px;
	}
}

.top_other_16 {
	margin-top: 50px;
}

@media screen and (max-width: 640px) {
	.top_other_16 {
		margin-top: 20px
	}
}

.top_other_17 {
	width: 50%;
}

@media screen and (max-width: 640px) {
	.top_other_17 {
		width: 100%;
	}
}

.top_other_19 {
	margin: 0 0 100px 0;
}

@media screen and (max-width: 640px) {
	.top_other_19 {
		margin: 20px 0 80px 0;
	}
}

.top_other_20 {
	/*margin-top: 50px;*/
	padding: 40px 0 0 0;
	height: 339px;
	background-color: rgba(0, 44, 85, 1);
	color: #fff;
}

@media screen and (max-width: 640px) {
	.top_other_20 {
		padding: 50px 0;
		height: 520px;
		background-color: rgba(0, 44, 85, 1);
		color: #fff;
	}
}

.top_other_21 {
	/*background-image: url(../images_2023/top_m-collection_bg.jpg);
    background-position: center top 60%;
    background-size: cover;*/
	text-align: center;
	/* opacity: 0.8; */
	height: 1080px;
	padding-top: 100px;
	font-size: 1.8rem;
	font-size: 18px;
}

@media screen and (max-width: 640px) {
	.top_other_21 {
		/*background-image: url(../images_2023/top_m-collection_bg.jpg);
		background-position: center top 50%;
		background-size: cover;*/
		text-align: center;
		opacity: 0.8;
		height: 1250px;
		padding-top: 100px;
		font-size: 1.6rem;
		font-size: 16px;
	}
}

.top_other_22 {
	margin-top: 100px;
}

.top_other_23 {
	padding: 50px 100px;
}

@media screen and (max-width: 640px) {
	.top_other_23 {
		padding: 50px 0 0 0;
	}
}

.top_other_24 {
	width: 200px;
	float: left;
	margin-right: 20px;
}

@media screen and (max-width: 640px) {
	.top_other_24 {
		width: 100%;
		float: none;
		margin-right: 0;
	}
}

.top_other_25 {
	padding-top: 40px;
}

@media screen and (max-width: 640px) {
	.top_other_25 {
		padding-top: 10px;
	}
}

.top_other_26 {
	margin-top: 30px;
}

@media screen and (max-width: 640px) {
	.top_other_26 {
		margin-top: 10px;
	}
}



.contents_btn {
	margin: 0 auto;
	display: inline-block;
	width: 250px;
	text-align: center;
	text-decoration: none;
	line-height: 60px;
	outline: none;
	color: #000;
	background-color: #fff;
	position: relative;
	border: 1px solid #000;
	transition: color 0.5s ease;
}

.contents_btn:hover {
	color: #fff;
}

.contents_btn:hover::before {
	transform: scaleY(1);
}

.contents_btn::before {
	position: absolute;
	top: 0;
	left: 0;
	content: "";
	display: block;
	width: 100%;
	height: 100%;
	background: #000;
	transform: scaleX(0);
	transition: all 0.5s ease;
	transition-property: transform;
}

.contents_text {
	position: relative;
}

.pick-up_background {
	background-color: #ddd;
	position: relative;
	width: 100%;
	min-width: auto;
	height: 250px;
}

@media screen and (max-width: 640px) {
	.pick-up_background {
		background-color: #ddd;
		position: relative;
		width: 100%;
		height: auto;
		padding-bottom: 15vw;
	}
}

.pick-up_01 {
	width: 1080px;
	margin: 0 auto;
}

@media screen and (max-width: 640px) {
	.pick-up_01 {
		width: 90%;
		margin: 0 auto;
	}
}

.pick-up_02 {
	width: 200px;
	margin-top: 35px;
	float: left;
}

@media screen and (max-width: 640px) {
	.pick-up_02 {
		width: 53%;
		margin-top: 35px;
		float: left;
	}
}

.pick-up_03 {
	float: left;
	width: 700px;
	padding: 30px 0;
	text-align: center;
}

@media screen and (max-width: 640px) {
	.pick-up_03 {
		float: none;
		width: 100%;
		padding: 30px 0 0 0;
		text-align: center;
	}
}

.pick-up_04 {
	width: 100%;
	margin: 10px auto;
}

@media screen and (max-width: 640px) {}

.pick-up_05 {
	background-color: #fff;
	width: 300px;
	margin: 0 auto;
	font-size: 16px;
	font-weight: normal;
	padding: 10px 20px;
}

@media screen and (max-width: 640px) {
	.pick-up_05 {
		background-color: #fff;
		width: 90%;
		margin: 0 auto;
		font-size: 16px;
		font-weight: normal;
		padding: 10px 20px;
	}
}

.pick-up_06 {
	width: 180px;
	margin-top: 27px;
	float: left;
}

@media screen and (max-width: 640px) {
	.pick-up_06 {
		width: 47%;
		margin-top: 27px;
		float: left;
	}
}

@media screen and (max-width: 640px) {
	.pick-up_07 {
		margin-top: 10vw;
		background-color: #fff;
	}
}

.pick-up_btn {
	font-size: 16px;
	font-weight: normal;
	padding: 10px 20px;
	display: inline-block;
	width: 300px;
	text-align: center;
	text-decoration: none;
	line-height: 60px;
	outline: none;
	color: #3e3e3e;
	background-color: #fff;
	position: relative;
	border: 1px solid #3e3e3e;
	transition: color 0.5s ease;
}

.pick-up_btn:hover {
	color: #fff;
	text-decoration: none;
}

.pick-up_btn:hover::before {
	transform: scaleY(1);
}

.pick-up_btn::before {
	position: absolute;
	top: 0;
	left: 0;
	content: "";
	display: block;
	width: 100%;
	height: 100%;
	background: #3e3e3e;
	transform: scaleX(0);
	transition: all 0.5s ease;
	transition-property: transform;
}

.pick-up_text {
	position: relative;
}











/* category */
.category_01 {
	background-color: #f8f8f8;
}

@media screen and (max-width: 640px) {
	.category_01 {
		padding-top: 50px;
	}
}

.category_02 {
	text-align: center;
	padding-top: 50px;
}

@media screen and (max-width: 640px) {
	.category_02 {}
}

.category_03 img {
	float: left;
	width: 50%;
}

@media screen and (max-width: 640px) {
	.category_03 img {
		float: none;
		width: 100%;
	}
}

.category_03_2 img {
	float: right;
	width: 50%;
}

@media screen and (max-width: 640px) {
	.category_03_2 img {
		float: none;
		width: 100%;
	}
}

.category_04 {
	padding-top: 0px;
}

@media screen and (max-width: 640px) {
	.category_04 {
		padding-top: 50px;
	}
}

.category_05 {
	text-align: center;
	font-size: 36px;
	font-size: 36px;
	font-weight: normal;
	line-height: 4.8rem;
	padding-top: 50px;
	background-color: #fff;
}

@media screen and (max-width: 640px) {
	.category_05 {
		font-size: 2.4rem;
		font-size: 24px;
		padding-top: 50px;
	}
}

.category_06 {}

@media screen and (max-width: 640px) {
	.category_06 {}
}

.category_07 {}

@media screen and (max-width: 640px) {
	.category_07 {}
}

.category_08 {}

@media screen and (max-width: 640px) {
	.category_08 {}
}

.category_09 {}

@media screen and (max-width: 640px) {
	.category_09 {}
}

.category_10 {}

@media screen and (max-width: 640px) {
	.category_10 {}
}





.underline {
	border-bottom: 1px solid;
	border-color: #002c55;
	/*width: 5em;*/
	padding-bottom: 3px;
}

.slider_sp_1 {
	margin-top: 50px;
}

@media screen and (max-width: 640px) {
	.slider_sp_1 {
		margin-top: 30px;
	}
}

.slider_sp_2 {
	margin-top: 50px;
}

@media screen and (max-width: 640px) {
	.slider_sp_2 {
		margin-top: 20px;
	}
}



/* Collection */
.collection_1 {
	margin: 0 auto 100px auto;
	width: 1200px;
	background-image: url(../images_2023/top_m-collection_m45_b.svg);
	background-position: center top;
	background-color: rgba(255, 255, 255, 0.95);
	background-blend-mode: lighten;
}

@media screen and (max-width: 640px) {
	.collection_1 {
		margin: 0 auto 100px auto;
		width: 90%;
	}
}

.collection_2 {
	text-align: center;
	min-width: 1200px;
	font-size: 2.4rem;
	font-size: 24px;
}

@media screen and (max-width: 640px) {
	.collection_2 {
		text-align: center;
		min-width: 100%;
	}
}

.collection_3 {
	margin: 0 auto;
	padding: 150px 0 80px 0;
	width: 1200px;
	background-image: url(https://www.orient-watch.jp/orientstar/m45/f7_mechanical-moon-phase/images/concept_img_01.png);
	background-repeat: no-repeat;
	background-position: right 30px top 100px;
	background-size: 150px auto;
}

@media screen and (max-width: 640px) {
	.collection_3 {
		margin: 0 auto;
		padding: 100px 5% 50px 5%;
		width: 100%;
		background-image: url(https://www.orient-watch.jp/orientstar/m45/f7_mechanical-moon-phase/images/concept_img_01.png);
		background-repeat: no-repeat;
		background-position: right top 50px;
		background-size: 150px auto;
	}

}

.collection_4 {
	position: relative;
	width: 100%;
	height: 70vh;
	border: 0px solid #ff0000;
	font-size: 1.4rem;
	font-size: 14px;
	background: transparent;
	position: relative;
	width: 100%;
	height: 70vh;
	border: 0px solid #ff0000;
	font-size: 14px;
	background: transparent;
	color: #fff;
}

@media screen and (max-width: 640px) {
	.collection_4 {
		position: relative;
		width: 100%;
		height: 71vw;
		border: 0px solid #ff0000;
		font-size: 1.4rem;
		font-size: 14px;
		background: transparent;
		color: #fff;
	}
}

.collection_5 {
	width: 200px;
	text-align: center;
	position: absolute;
	bottom: 0;
	left: 50%;
	margin-left: -100px;
}

@media screen and (max-width: 640px) {
	.collection_5 {
		width: 200px;
		text-align: center;
		position: absolute;
		bottom: 0;
		left: 50%;
		margin-left: -100px;
	}
}

.collection_6 {
	width: 18px;
	vertical-align: -4px;
}

.collection_7 {
	position: absolute;
	bottom: 0;
	right: 0;
}

@media screen and (max-width: 640px) {
	.collection_7 {
		position: absolute;
		bottom: -5vw;
		right: 0;
		z-index: 1;
	}
}

.collection_8 {
	width: 1000px;
	margin-top: 100px;
}

@media screen and (max-width: 640px) {
	.collection_8 {
		width: 90%;
		margin-top: 50px;
	}
}

.collection_9 {
	float: left;
	width: 45%;
	margin-right: 50px;
}

@media screen and (max-width: 640px) {
	.collection_9 {
		float: none;
		width: 90%;
		margin: 0 5%;
	}
}

.collection_10 {
	float: right;
	width: 45%;
	margin: -100px 0 0 50px;
}

@media screen and (max-width: 640px) {
	.collection_10 {
		float: none;
		width: 90%;
		margin: 0 5%;
	}
}

.collection_11 {
	padding: 130px 50px 0 0;
}

@media screen and (max-width: 640px) {
	.collection_11 {
		padding: 0 5% 50px 5%;
	}
}

.collection_12 {
	margin-top: -100px;
}

@media screen and (max-width: 640px) {
	.collection_12 {
		margin-top: 0;
	}
}

.collection_13 {
	padding: 130px 0 0 100px;
}

@media screen and (max-width: 640px) {
	.collection_13 {
		padding: 0 5%;
	}
}

.collection_14 {
	position: absolute;
	top: 0;
	left: 0;
}

@media screen and (max-width: 640px) {
	.collection_14 {
		width: 100%;
	}
}

.collection_15 {
	position: relative;
	width: 1200px;
	height: 800px;
	margin: 100px auto 0 auto;
}

@media screen and (max-width: 640px) {
	.collection_15 {
		position: relative;
		width: 100%;
		height: 290vw;
		margin-top: 50px;
	}
}

.collection_16 {
	width: 320px;
	position: absolute;
	top: 15px;
	left: 0;
	text-align: left;
}

@media screen and (max-width: 640px) {
	.collection_16 {
		width: 61%;
		position: absolute;
		top: -13vw;
		left: 5%;
		text-align: left;
	}
}

.collection_17 {
	width: 320px;
	position: absolute;
	top: 470px;
	left: 0;
	text-align: left;
}

@media screen and (max-width: 640px) {
	.collection_17 {
		width: 60%;
		position: absolute;
		top: 60vw;
		left: 5%;
		text-align: left;
	}
}

.collection_18 {
	width: 320px;
	position: absolute;
	top: 320px;
	right: 0;
	text-align: left;
}

@media screen and (max-width: 640px) {
	.collection_18 {
		width: 50%;
		position: absolute;
		top: 148vw;
		right: 5%;
		text-align: left;
	}
}

.collection_19 {
	width: 450px;
}

@media screen and (max-width: 640px) {
	.collection_19 {
		width: 90%;
		margin-left: 5%;
	}
}

.collection_20 {
	width: 450px;
	margin-left: 50px;
}

@media screen and (max-width: 640px) {
	.collection_20 {
		width: 90%;
		margin-left: 5%;
		margin-top: 50px
	}
}

.collection_21 {
	margin-top: 100px;
}

@media screen and (max-width: 640px) {
	.collection_21 {
		margin-top: 50px;
	}
}

.collection_22 {
	height: 70vh;
	width: 100%;
	object-fit: cover;
	object-position: center 40%;
}

@media screen and (max-width: 640px) {
	.collection_22 {
		height: 155vw;
		width: 100%;
		object-fit: cover;
		object-position: center 50px;
	}
}

.collection_23 {
	float: left;
	width: 45%;
	margin-right: 50px;
}

@media screen and (max-width: 640px) {
	.collection_23 {
		float: none;
		width: 100%;
		margin: 0;
	}
}

.collection_24 {
	float: right;
	width: 45%;
	margin: 0 0 0 50px;
}

@media screen and (max-width: 640px) {
	.collection_24 {
		float: none;
		width: 100%;
		margin: 50px 0 0 0;
	}
}

.collection_25 {
	padding: 120px 0 0 0;
}

@media screen and (max-width: 640px) {
	.collection_25 {
		padding: 10px 0 0 0;
	}
}

.collection_26 {
	width: 100%;
	background-color: #000;
	margin-top: 100px;
	padding-top: 100px;
}

@media screen and (max-width: 640px) {
	.collection_26 {
		width: 100%;
		background-color: #000;
		margin-top: 50px;
		padding-top: 50px;
	}
}

.collection_27 {
	position: relative;
	height: 600px;
	width: 1200px;
	margin: 0 auto;
}

@media screen and (max-width: 640px) {
	.collection_27 {
		position: relative;
		height: 180vw;
		width: 100%;
		margin: 0 auto;
	}
}

.collection_28 {
	width: 330px;
	position: absolute;
	top: 230px;
	left: 0;
	text-align: left;
}

@media screen and (max-width: 640px) {
	.collection_28 {
		width: 46%;
		position: absolute;
		top: 20vw;
		left: 5%;
		text-align: left;
	}
}

.collection_29 {
	width: 380px;
	position: absolute;
	top: 410px;
	left: 100px;
	text-align: left;
}

@media screen and (max-width: 640px) {
	.collection_29 {
		width: 60%;
		position: absolute;
		top: 64vw;
		left: 5%;
		text-align: left;
	}
}

.collection_30 {
	width: 260px;
	position: absolute;
	top: 210px;
	right: 0;
	text-align: left;
}

@media screen and (max-width: 640px) {
	.collection_30 {
		width: 45%;
		position: absolute;
		top: 107vw;
		right: 5%;
		text-align: left;
	}
}

.collection_31 {
	margin-left: 350px;
}

@media screen and (max-width: 640px) {
	.collection_31 {
		margin: 0 5%;
	}
}

.collection_32 {
	float: left;
	width: 50%;
	margin: 0 20px 100px 0;
}

@media screen and (max-width: 640px) {
	.collection_32 {
		float: none;
		width: 100%;
		margin: 20px 0 0 0;
	}
}

.collection_33 {
	padding-top: 90px;
}

@media screen and (max-width: 640px) {
	.collection_33 {
		padding: 0 0 50px 0;
	}
}

.collection_34 {
	float: left;
	width: 45%;
	margin-right: 50px;
}

@media screen and (max-width: 640px) {
	.collection_34 {
		float: none;
		width: 100%;
		margin: 50px 0 0 0;
	}
}

.collection_35 {
	width: 1200px;
	margin: 100px auto 0 auto;
}

@media screen and (max-width: 640px) {
	.collection_35 {
		margin-top: 50px;
		width: 100%;
	}
}

.collection_36 {
	width: 50%;
	background-color: #abbcd4;
	padding-bottom: 30px;
}

.collection_36 p {
	margin-top: 30px;
}

.collection_36 h3 {
	margin-top: 10px;
}

.collection_36 img {
	margin-top: 30px;
}

@media screen and (max-width: 640px) {
	.collection_36 {
		width: 100%;
		background-color: #abbcd4;
	}

	.collection_36 p {
		margin-top: 0;
		padding-top: 30px;
	}

	.collection_36 h3 {
		margin-top: 10px;
	}

	.collection_36 img {
		margin: 30px 5% 0 5%;
		width: 90%;
	}
}

.collection_37 {
	width: 50%;
	background-color: #d9d9d9;
	padding-bottom: 30px;
}

.collection_37 p {
	margin-top: 30px;
}

.collection_37 h3 {
	margin-top: 10px;
}

.collection_37 img {
	margin-top: 30px;
}

@media screen and (max-width: 640px) {
	.collection_37 {
		width: 100%;
		background-color: #d9d9d9;
		padding-bottom: 0;
	}

	.collection_37 p {
		margin-top: 0;
		padding-top: 30px;
	}

	.collection_37 h3 {
		margin-top: 10px;
	}

	.collection_37 img {
		margin: 30px 5% 0 5%;
		width: 90%;
		padding-bottom: 50px;
	}
}

.collection_38 {
	background-color: #d9d9d9;
}

.collection_39 {
	background-color: #d9d9d9;
}

.collection_40 {
	width: 560px;
	height: 315px;
}

@media screen and (max-width: 640px) {
	.collection_40 {
		width: 100%;
	}
}

.collection_41 {
	width: auto;
}

@media screen and (max-width: 640px) {
	.collection_41 {
		width: 100%;
	}
}

.collection_42 {
	margin: 0 auto;
	padding: 150px 0 80px 0;
	width: 1200px;
}

@media screen and (max-width: 640px) {
	.collection_42 {
		padding: 40px 0 0 0;
		width: 100%;
	}
}

.collection_42_2 {
	margin: 0 auto;
	padding: 120px 0 80px 0;
	width: 1200px;
}

@media screen and (max-width: 640px) {
	.collection_42_2 {
		padding: 40px 0 0 0;
		width: 90%;
	}
}

.collection_43 {
	position: relative;
	width: 100%;
	/*height: 77vh;*/
	border: 0px solid #ff0000;
	font-size: 1.4rem;
	font-size: 14px;
	position: relative;
	width: 100%;
	/*height: 77vh;*/
	border: 0px solid #ff0000;
	font-size: 14px;
	color: #fff;
}

@media screen and (max-width: 640px) {
	.collection_43 {
		height: auto;
		font-size: 1.4rem;
		font-size: 14px;
		height: auto;
		font-size: 14px;
		color: #fff;
	}
}

.collection_44 {
	width: 200px;
	text-align: center;
	position: absolute;
	bottom: 150px;
	left: 50%;
	margin-left: -100px;
}

@media screen and (max-width: 640px) {
	.collection_44 {
		position: absolute;
		bottom: 50px;
		left: 50%;
		margin-left: -100px;
	}
}

.collection_45 {
	width: 100%;
	height: 600px;
	object-fit: cover;
	object-position: center;
}

@media screen and (max-width: 640px) {
	.collection_45 {
		width: 100%;
		height: 130vw;
		object-fit: cover;
		object-position: 50% -30vw;
	}
}

.collection_46 {
	float: left;
	margin-right: 50px;
}

.collection_47 {
	float: right;
	margin-left: 50px;
}

@media screen and (max-width: 640px) {

	.collection_46,
	.collection_47 {
		float: none;
		margin: 50px 0 0 0;
		width: 100%
	}
}

.collection_48 {
	padding-top: 200px;
}

.collection_50 {
	padding-top: 150px;
}

@media screen and (max-width: 640px) {

	.collection_48,
	.collection_50 {
		padding-top: 0;
	}
}

.collection_49 {
	padding-top: 200px;
	padding-left: 300px;
}

@media screen and (max-width: 640px) {
	.collection_49 {
		padding-top: 10px;
		padding-left: 0;
	}
}

.collection_51 {
	padding-top: 130px;
	padding-left: 180px;
}

@media screen and (max-width: 640px) {
	.collection_51 {
		padding-top: 0;
		padding-left: 0;
	}
}

.collection_52 {
	width: 30%;
	margin-right: 5%;
}

.collection_53 {
	width: 30%;
}

@media screen and (max-width: 640px) {

	.collection_52,
	.collection_53 {
		width: 100%;
		margin: 10px 0;
	}
}

.collection_54 {
	width: 100%;
	margin-top: 20px;
}

@media screen and (max-width: 640px) {
	.collection_54 {
		margin: 20px 0 0 0;
	}
}

.collection_55 {
	float: right;
	width: 220px;
	margin: -50px 100px 0 50px;
}

@media screen and (max-width: 640px) {
	.collection_55 {
		float: none;
		width: 100%;
		margin: 0;
	}
}

.collection_56 {
	margin-left: 100px;
	padding-top: 70px;
}

@media screen and (max-width: 640px) {
	.collection_56 {
		margin-left: 100px;
		padding-top: 50px;
	}
}

.collection_57 {
	float: left;
	width: 40%;
	margin: 0 50px;
}

@media screen and (max-width: 640px) {
	.collection_57 {
		float: none;
		width: 100%;
		margin: 0;
	}
}

.collection_58 {
	padding: 100px 50px 0 0;
}

@media screen and (max-width: 640px) {
	.collection_58 {
		padding: 0;
	}
}

.collection_59 {
	float: right;
	width: 40%;
	margin: -100px 0 0 50px;
}

@media screen and (max-width: 640px) {
	.collection_59 {
		float: none;
		width: 100%;
		margin: 0;
	}
}

.collection_60 {
	padding: 180px 0 0 150px;
}

@media screen and (max-width: 640px) {
	.collection_60 {
		padding: 0;
	}
}

.collection_61 {
	margin-left: 100px;
}

@media screen and (max-width: 640px) {
	.collection_61 {
		margin-left: 0;
	}
}

.collection_62 {
	margin-top: 100px;
	width: 90%
}

@media screen and (max-width: 640px) {
	.collection_62 {
		margin: 50px 5% 0 5%;
		width: 90%;
	}
}

.collection_63 {
	position: relative;
	width: 100%;
	height: 730px;
	margin-top: 10px;
	border: 0px solid #ff0000;
}

@media screen and (max-width: 640px) {
	.collection_63 {
		position: relative;
		width: 100%;
		height: 245vw;
		margin-top: 10px;
	}
}

.collection_64 {
	width: 250px;
	position: absolute;
	top: 380px;
	left: 80px;
	text-align: left;
}

@media screen and (max-width: 640px) {
	.collection_64 {
		width: 250px;
		position: absolute;
		top: 63vw;
		left: 5%;
		text-align: left;
	}
}

.collection_65 {
	width: 250px;
	position: absolute;
	top: 420px;
	right: 50px;
	text-align: left;
}

@media screen and (max-width: 640px) {
	.collection_65 {
		width: 250px;
		position: absolute;
		top: 170vw;
		right: 5%;
		text-align: left;
	}
}

.collection_66 {
	margin: 50px 0 0 100px;
}

@media screen and (max-width: 640px) {
	.collection_66 {
		margin: 50px 5% 0 5%;
		width: 90%;
	}
}

.collection_67 {
	margin: 100px 0 0 0;
}

.collection_68 {
	margin: 50px 0 0 0;
}

@media screen and (max-width: 640px) {

	.collection_67,
	.collection_68 {
		margin: 50px 5% 0 5%;
		width: 90%;
	}
}

.collection_69 {
	width: 1190px;
	margin: 0 0 10px 0;
}

@media screen and (max-width: 640px) {
	.collection_69 {
		width: 100%;
		margin: 0 0 10px 0;
	}
}

.collection_70 {
	width: 45%;
}

.collection_71 {
	width: 45%;
	margin-left: 10%;
}

@media screen and (max-width: 640px) {
	.collection_70 {
		width: 100%;
	}

	.collection_71 {
		width: 100%;
		margin: 30px 0 0 0;
	}
}

.collection_72 {
	width: 850px;
}

@media screen and (max-width: 640px) {
	.collection_72 {
		width: 100%;
	}
}

.collection_73 {
	width: 850px;
	height: 478px;
}

@media screen and (max-width: 640px) {
	.collection_73 {
		width: 100%;
	}
}

.collection_74 {
	position: relative;
	width: 1200px;
	height: 738px;
	margin-top: 20px;
}

@media screen and (max-width: 640px) {
	.collection_74 {
		position: relative;
		width: 100%;
		height: 270vw;
		margin-top: 20px;
	}
}

.collection_75 {
	width: 320px;
	position: absolute;
	top: 480px;
	left: 0;
	text-align: left;
}

@media screen and (max-width: 640px) {
	.collection_75 {
		width: 43%;
		position: absolute;
		top: 153vw;
		left: 57%;
		text-align: left;
	}
}

.collection_76 {
	width: 300px;
	position: absolute;
	top: 160px;
	right: 0;
	text-align: left;
}

@media screen and (max-width: 640px) {
	.collection_76 {
		width: 55%;
		position: absolute;
		top: 64vw;
		left: 3%;
		text-align: left;
	}
}

.collection_77 {
	width: 45%;
}

.collection_78 {
	width: 45%;
	margin-left: 10%;
}

@media screen and (max-width: 640px) {
	.collection_77 {
		width: 100%;
	}

	.collection_78 {
		width: 100%;
		margin: 50px 0 0 0;
	}
}

.collection_79 {
	padding: 80px 0 0 150px;
}

@media screen and (max-width: 640px) {
	.collection_79 {
		padding: 0;
	}
}

.collection_80 {
	width: 100%;
	height: 500px;
	overflow: hidden;
	background: url("/ja/orientstar/collection/contemporary/lp/m34_avant-garde_f8_skeleton/images/concept_img_01.jpg") no-repeat top center;
	background-size: 3000px;
}

@media screen and (max-width: 640px) {
	.collection_80 {
		width: 100%;
		height: 127vw;
		background: url("/ja/orientstar/collection/contemporary/lp/m34_avant-garde_f8_skeleton/images/concept_img_01.jpg") no-repeat top center;
		background-size: 3000px;
		background-position: -1030px 0;
		overflow: hidden;
	}
}

.collection_81 {
	width: 1000px;
	height: 100%;
	margin: 0 auto;
	position: relative;
}

@media screen and (max-width: 640px) {
	.collection_81 {
		width: 100%;
		height: 100%;
		margin: 0 auto;
		position: relative;
	}
}

.collection_82 {
	position: absolute;
	top: 200px;
	right: 0;
	width: 520px;
	color: #fff;
}

@media screen and (max-width: 640px) {
	.collection_82 {
		position: static;
		text-align: center;
		width: 90%;
		margin: 20px 5%;
		top: 200px;
		right: 0;
	}
}

.collection_83 {
	position: absolute;
	top: 100px;
	right: 0;
	color: #fff;
}

@media screen and (max-width: 640px) {
	.collection_83 {
		position: static;
		text-align: center;
		margin-top: 60px;
	}
}

.collection_84 {
	width: 50%;
	background-color: #000;
	padding: 50px 0 20px 0;
}

@media screen and (max-width: 640px) {
	.collection_84 {
		width: 100%;
	}
}

.collection_85 {
	width: 70%;
	margin: 30px 15%;
}

@media screen and (max-width: 640px) {
	.collection_85 {
		width: 90%;
		margin: 30px 5%;
	}
}

.collection_86 {
	width: 50%;
	background-color: #fff;
	padding: 50px 0 20px 0;
}

@media screen and (max-width: 640px) {
	.collection_86 {
		width: 100%;
	}
}

.collection_87 {
	position: relative;
	width: 1200px;
	height: 900px;
	margin: auto;
	overflow: hidden;
	background-color: #000;
}

@media screen and (max-width: 640px) {
	.collection_87 {
		position: relative;
		width: 100%;
		height: 900px;
		margin: auto;
		overflow: hidden;
		background-color: #000;
	}
}

.collection_88 {
	position: absolute;
	top: 0;
	left: -75%;
	width: 250%;
}

@media screen and (max-width: 640px) {
	.collection_88 {
		position: absolute;
		top: 0;
		left: -250%;
		width: 600%;
	}
}

.collection_89 {
	position: absolute;
	top: 650px;
	padding: 0 100px;
	left: 0px;
}

@media screen and (max-width: 640px) {
	.collection_89 {
		position: absolute;
		top: 500px;
		padding: 0 5%;
		left: 0px;
	}
}

.collection_90 {
	padding: 30px 0 0 0;
	width: 50%;
	background-color: #d9d9d9;
	text-align: center;
}

@media screen and (max-width: 640px) {
	.collection_90 {
		padding: 30px 0 10px 0;
		width: 100%;
		background-color: #d9d9d9;
	}
}

.collection_91 {
	margin: 30px;
}

@media screen and (max-width: 640px) {
	.collection_91 {
		margin: 20px 5%;
	}
}

.collection_92 {
	width: 50%;
	text-align: center;
	float: left;
}

.collection_93 {
	padding: 50px 0;
	text-align: center;
}

@media screen and (max-width: 640px) {
	.collection_93 {
		padding: 20px 5%;
	}
}

.collection_94 {
	background-color: #606d82;
	margin-top: 50px
}

.collection_95 {
	position: relative;
	height: 720px;
	width: 1000px;
	margin: 0 auto;
}

@media screen and (max-width: 640px) {
	.collection_95 {
		position: relative;
		height: 315vw;
		width: 100%;
		margin: 0 auto;
	}
}

.collection_96 {
	position: absolute;
	top: 100px;
	left: 100px;
}

@media screen and (max-width: 640px) {
	.collection_96 {
		position: static;
		margin: 50px 5%;
		width: 90%;
	}
}

.collection_97 {
	position: absolute;
	top: 100px;
	right: 100px;
	text-align: center;
}

@media screen and (max-width: 640px) {
	.collection_97 {
		position: static;
		top: 100px;
		right: 100px;
		text-align: center;
	}
}

.collection_98 {
	width: 1200px;
	height: 442px;
	position: relative;
}

@media screen and (max-width: 640px) {
	.collection_98 {
		width: 100%;
		height: auto;
	}
}

.collection_99 {
	position: absolute;
	top: 150px;
	left: 600px;
}

@media screen and (max-width: 640px) {
	.collection_99 {
		position: static;
	}
}

.collection_100 {
	position: absolute;
	top: 170px;
	left: 600px;
}

@media screen and (max-width: 640px) {
	.collection_100 {
		position: static;
	}
}

.collection_101 {
	position: absolute;
	top: 190px;
	left: 600px;
}

@media screen and (max-width: 640px) {
	.collection_101 {
		position: static;
	}
}

.collection_102 {
	position: relative;
	width: 1200px;
	height: 700px;
	margin: auto;
	overflow: hidden;
}

@media screen and (max-width: 640px) {
	.collection_102 {
		position: relative;
		width: 100%;
		height: 140vw;
		margin: auto;
		overflow: hidden;
	}
}

.collection_103 {
	position: absolute;
	top: -150px;
	left: -75%;
	width: 250%;
}

@media screen and (max-width: 640px) {
	.collection_103 {
		position: absolute;
		top: -40vw;
		left: -240%;
		width: 600%;
	}
}

.collection_104 {
	width: 330px;
	position: absolute;
	top: 20px;
	left: 90px;
	text-align: left;
}

@media screen and (max-width: 640px) {
	.collection_104 {
		width: 220px;
		position: absolute;
		top: 0;
		left: 60px;
		text-align: left;
	}
}

.collection_105 {
	width: 270px;
	position: absolute;
	top: 510px;
	left: 130px;
	text-align: left;
}

@media screen and (max-width: 640px) {
	.collection_105 {
		width: 210px;
		position: absolute;
		top: 90vw;
		left: 33px;
		text-align: left;
	}
}

.collection_106 {
	width: 350px;
	position: absolute;
	top: 20px;
	right: 30px;
	text-align: left;
}

@media screen and (max-width: 640px) {
	.collection_106 {
		width: 250px;
		position: absolute;
		top: 127vw;
		left: 130px;
		text-align: left;
	}
}

.collection_107 {
	width: 260px;
	position: absolute;
	top: 510px;
	right: 90px;
	text-align: left;
}

@media screen and (max-width: 640px) {
	.collection_107 {
		width: 210px;
		position: absolute;
		top: 208vw;
		right: 10px;
		text-align: left;
	}
}

.collection_108 {
	position: absolute;
	top: 500px;
	color: #fff;
	left: 340px;
}

@media screen and (max-width: 640px) {
	.collection_108 {
		position: absolute;
		top: 80vw;
		color: #fff;
		left: 5%;
		width: 90%;
	}
}

.collection_109 {
	float: left;
	width: 320px;
	margin: 0px 20px 0 130px;
}

@media screen and (max-width: 640px) {
	.collection_109 {
		float: none;
		width: 100%;
		margin: 0;
	}
}

.collection_110 {
	width: 1200px;
	margin: 30px auto;
}

@media screen and (max-width: 640px) {
	.collection_110 {
		width: 90%;
		margin: 0 auto;
		padding: 100px 0 30px 0;
	}
}

.collection_111 {
	text-align: center;
	margin-top: 100px;
	min-width: 1200px;
}

@media screen and (max-width: 640px) {
	.collection_111 {
		min-width: static;
		margin-top: 70px;
	}
}

.collection_112 {
	text-align: center;
}

@media screen and (max-width: 640px) {
	.collection_112 {
		text-align: left;
	}
}

.collection_113 {
	text-align: center;
}

@media screen and (max-width: 640px) {
	.collection_113 {
		text-align: left;
		width: 90%;
		margin: 0 5%;
	}
}

.collection_114 {
	width: 330px;
	position: absolute;
	top: 60px;
	right: 320px;
	text-align: left;
}

@media screen and (max-width: 640px) {
	.collection_114 {
		width: 50%;
		position: absolute;
		top: 6vw;
		left: 37vw;
		text-align: left;
	}
}

.collection_115 {
	width: 500px;
	position: absolute;
	top: 380px;
	right: 80px;
	text-align: left;
}

@media screen and (max-width: 640px) {
	.collection_115 {
		width: 46%;
		position: absolute;
		top: 37vw;
		right: 3%;
		text-align: left;
	}
}

.collection_116 {
	position: relative;
	width: 100%;
	height: 650px;
	margin-top: 10px;
	border: 0px solid #ff0000;
}

@media screen and (max-width: 640px) {
	.collection_116 {
		position: relative;
		width: 100%;
		height: 215vw;
		margin-top: 10px;
	}
}

.collection_117 {
	width: 200px;
	position: absolute;
	top: 100px;
	right: 0px;
}

@media screen and (max-width: 640px) {
	.collection_117 {
		width: 200px;
		position: absolute;
		top: 150vw;
		right: 0px;
	}
}

.collection_118 {
	width: 400px;
	position: absolute;
	top: 220px;
	right: 160px;
	text-align: left;
}

@media screen and (max-width: 640px) {
	.collection_118 {
		width: 41%;
		position: absolute;
		top: 150vw;
		left: 3%;
		text-align: left;
	}
}

.collection_119 {
	width: 450px;
}

@media screen and (max-width: 640px) {
	.collection_119 {
		width: 90%;
		margin-left: 5%;
	}
}

.collection_120 {
	width: 450px;
	margin-left: 50px;
}

@media screen and (max-width: 640px) {
	.collection_120 {
		width: 90%;
		margin-left: 5%;
		margin-top: 10px
	}
}

.collection_121 {
	margin-top: 30px;
}

@media screen and (max-width: 640px) {
	.collection_121 {
		margin: 10px 5%;
		width: 90%;
	}
}

.collection_122 {
	margin-top: 0;
}

@media screen and (max-width: 640px) {
	.collection_122 {
		margin-top: 80px;
	}
}

.collection_123 {
	margin: 0 auto 100px auto;
	width: 1200px;
	background-image: url(../images_2023/top_m-collection_m34_b.svg);
	background-position: center top;
	background-color: rgba(255, 255, 255, 0.95);
	background-blend-mode: lighten;
}

@media screen and (max-width: 640px) {
	.collection_123 {
		margin: 0 auto 100px auto;
		width: 90%;
	}
}

.collection_124 {
	margin: 0 auto 100px auto;
	width: 1200px;
	background-image: url(../images_2023/top_m-collection_m42_b.svg);
	background-position: center top;
	background-color: rgba(255, 255, 255, 0.95);
	background-blend-mode: lighten;
}

@media screen and (max-width: 640px) {
	.collection_124 {
		margin: 0 auto 100px auto;
		width: 90%;
	}
}

.collection_125 {
	width: 20%;
	float: left;
}

@media screen and (max-width: 640px) {
	.collection_125 {
		width: 50%;
		float: left;
	}
}

.collection_126 {
	margin-top: -50px;
	color: #fff;
}

@media screen and (max-width: 640px) {
	.collection_126 {
		margin-top: -90vw;
		margin-left: 250px;
	}
}

.collection_127 {
	position: relative;
	width: 100%;
	height: 580px;
	margin-top: 10px;
	border: 0px solid #ff0000;
}

@media screen and (max-width: 640px) {
	.collection_127 {
		position: relative;
		width: 100%;
		height: 245vw;
		margin-top: 10px;
	}
}

.collection_128 {
	width: 50%;
}

@media screen and (max-width: 640px) {
	.collection_128 {
		width: 45%;
	}
}

.collection_129 {
	text-align: left;
	width: 70%;
	margin: 0 auto;
}

@media screen and (max-width: 640px) {
	.collection_129 {
		width: 90%;
		margin: 50px 5% 0 5%;
	}
}

.collection_130 {
	position: relative;
	width: 100%;
	height: 700px;
}

@media screen and (max-width: 640px) {
	.collection_130 {
		height: auto;
	}
}

.collection_131 {
	position: absolute;
	top: 0;
	left: 0;
}

@media screen and (max-width: 640px) {
	.collection_131 {
		position: static;
	}
}

.collection_132 {
	position: absolute;
	top: 0;
	right: 0;
}

@media screen and (max-width: 640px) {
	.collection_132 {
		position: static;
	}
}

.collection_133 {
	position: absolute;
	top: 326px;
	left: 0;
}

@media screen and (max-width: 640px) {
	.collection_133 {
		position: static;
	}
}

.collection_134 {
	position: absolute;
	top: 326px;
	right: 0;
}

@media screen and (max-width: 640px) {
	.collection_134 {
		position: static;
	}
}

.collection_135 {
	position: relative;
	margin: 100px auto;
	width: 1200px;
	height: 335px;
	text-align: center;
}

@media screen and (max-width: 640px) {
	.collection_135 {
		margin: 80px auto 20px auto;
		width: 100%;
		height: 147vw;
	}
}

.collection_136 {
	position: absolute;
	top: 60px;
	left: 50px;
	width: 45%;
}

@media screen and (max-width: 640px) {
	.collection_136 {
		position: absolute;
		top: 30px;
		left: 5%;
		width: 90%;
	}
}

.collection_137 {
	color: #fff;
	text-align: center;
	font-weight: normal;
	font-size: 1.6em;
}

@media screen and (max-width: 640px) {}

.collection_138 {
	width: 50%;
}

@media screen and (max-width: 640px) {
	.collection_138 {
		width: 100%;
	}
}

.collection_139 {
	width: 100%;
	height: 70vh;
	position: relative;
}

@media screen and (max-width: 640px) {
	.collection_139 {
		height: 155vw !important;
		position: relative;
	}
}

.collection_140 {
	position: absolute;
	top: 0;
	left: 0;
}

@media screen and (max-width: 640px) {}

.collection_141 {
	width: 30% !important;
	height: auto !important;
	position: absolute;
	top: 45%;
	left: 2%;
}

@media screen and (max-width: 640px) {
	.collection_141 {
		width: 50% !important;
		height: auto !important;
		position: absolute;
		top: 17%;
		left: 25%;
	}
}

.collection_142 {
	height: 70vh;
	width: 100%;
	object-fit: cover;
	object-position: center 40%;
}

@media screen and (max-width: 640px) {
	.collection_142 {
		height: 100%;
		width: 100%;
		object-fit: cover;
		object-position: center 50px;
	}
}

.collection_143 {}

@media screen and (max-width: 640px) {}

.collection_144 {
	width: 30% !important;
	height: auto !important;
	position: absolute;
	top: 22%;
	right: 10%;
}

@media screen and (max-width: 640px) {
	.collection_144 {
		width: 90% !important;
		height: auto !important;
		position: absolute;
		top: 12%;
		left: 5%;
	}
}

.collection_145 {
	width: 100%;
	height: 70vh;
	position: relative;
}

@media screen and (max-width: 640px) {
	.collection_145 {
		height: 155vw !important;
		position: relative;
	}
}

.collection_146 {
	width: 12% !important;
	height: auto !important;
	padding: 0.5%;
	position: absolute;
	top: 62%;
	right: 18%;
	color: #fff;
	border: 1px solid #fff;
}

.collection_145:hover .collection_146 {
	background-color: #fff;
	color: #000;
	transition: 0.5s ease-in-out;
	/*移り変わる速さを変更したい場合はこの数値を変更*/
}

@media screen and (max-width: 640px) {
	.collection_146 {
		width: 50% !important;
		padding: 2%;
		position: absolute;
		top: 87%;
		left: 25%;
		color: #fff;
		border: 1px solid #fff;
	}
}

.collection_147 {
	margin: 0 auto;
	width: 1200px;
	position: relative;
	height: 490px;
}

@media screen and (max-width: 640px) {
	.collection_147 {
		width: 100%;
		height: auto;
	}
}

.collection_148 {
	position: absolute;
	top: 0;
	right: 0;
	z-index: -1;
}

@media screen and (max-width: 640px) {
	.collection_148 {
		position: static;
		width: 100%;
	}
}

.collection_149 {
	position: absolute;
	top: 100px;
	left: 0;
	font-weight: normal;
	width: 50%;
}

@media screen and (max-width: 640px) {
	.collection_149 {
		position: static;
		width: 90%;
		margin: 10% 5% 5% 5%;
		font-size: 2.2rem;
		position: static;
		width: 90%;
		margin: 10% 5% 5% 5%;
		font-size: 22px;
	}
}

.collection_150 {
	position: absolute;
	top: 180px;
	left: 0;
	font-weight: normal;
	width: 45%;
}

@media screen and (max-width: 640px) {
	.collection_150 {
		position: static;
		width: 90%;
		margin: 0 5%;
		font-size: 1.8rem;
		position: static;
		width: 90%;
		margin: 0 5%;
		font-size: 18px;
	}
}

.collection_151 {
	position: absolute;
	bottom: 50px;
	left: 0;
	width: 45%;
	font-size: 1.2rem;
	position: absolute;
	bottom: 50px;
	left: 0;
	width: 45%;
	font-size: 12px;
}

@media screen and (max-width: 640px) {
	.collection_151 {
		position: static;
		width: 90%;
		margin: 2% 5%;
	}
}

.collection_152 {
	position: relative;
	margin: 150px auto 0 auto;
	width: 1200px;
	height: 1010px;
	text-align: center;
}

@media screen and (max-width: 640px) {
	.collection_152 {
		margin: 80px auto 0 auto;
		width: 100%;
		height: auto;
	}
}

.collection_153 {
	position: absolute;
	top: 130px;
	left: 50px;
	font-weight: normal;
	width: 45%;
	text-align: left;
	color: #fff;
	z-index: 1;
}

@media screen and (max-width: 640px) {
	.collection_153 {
		position: static;
		margin: 0 5%;
		width: 90%;
		color: #000;
		padding-top: 3%;
	}
}

.collection_154 {
	margin: 150px 50px 0 50px;
}

@media screen and (max-width: 640px) {
	.collection_154 {
		margin: 30px 5%;
	}
}

.collection_155 {
	margin: 200px 50px 0 50px;
}

@media screen and (max-width: 640px) {
	.collection_155 {
		margin: 30px 5%;
	}
}

.collection_156 {
	width: 50%;
	background-color: #f7f7f7;
}

.collection_156:nth-child(1) {
	order: 1;
}

.collection_156:nth-child(2) {
	order: 2;
}

.collection_156:nth-child(3) {
	order: 3;
}

.collection_156:nth-child(4) {
	order: 3;
}

@media screen and (max-width: 640px) {
	.collection_156 {
		width: 100%;
	}

	.collection_156:nth-child(1) {
		order: 1;
	}

	.collection_156:nth-child(2) {
		order: 2;
	}

	.collection_156:nth-child(3) {
		order: 3;
	}

	.collection_156:nth-child(4) {
		order: 4;
	}
}

.collection_157 {
	position: relative;
	margin: 0 auto;
	width: 1200px;
	height: 1010px;
	text-align: center;
}

@media screen and (max-width: 640px) {
	.collection_157 {
		margin: 80px auto 0 auto;
		width: 100%;
		height: auto;
	}
}

.collection_158 {
	position: relative;
	width: 100%;
	height: 75vh;
	border: 0px solid #ff0000;
	font-size: 1.4rem;
	font-size: 14px;
	background-color: #000;
	position: relative;
	width: 100%;
	height: 75vh;
	border: 0px solid #ff0000;
	font-size: 14px;
	background-color: #000;
	color: #fff;
}

@media screen and (max-width: 640px) {
	.collection_158 {
		position: relative;
		width: 100%;
		height: 155vw !important;
		color: #fff;
	}
}

.collection_159 {
	height: 75vh;
	width: 100%;
	object-fit: cover;
	object-position: center;
}

@media screen and (max-width: 640px) {
	.collection_159 {
		height: 100%;
		width: 100%;
		object-fit: cover;
		object-position: center;
	}
}

.collection_160 {
	margin: 0 auto;
	width: 1200px;
	position: relative;
	height: 771px;
}

@media screen and (max-width: 640px) {
	.collection_160 {
		width: 100%;
		height: 215vw;
	}
}

.collection_161 {
	position: absolute;
	top: 80px;
	left: 50px;
}

@media screen and (max-width: 640px) {
	.collection_161 {
		width: 60%;
		position: absolute;
		top: 4%;
		left: 25%;
	}
}

.collection_162 {
	width: 90%;
	z-index: -1;
}

@media screen and (max-width: 640px) {}

.collection_163 {
	position: absolute;
	top: 150px;
	left: 50px;
	font-weight: normal;
	width: 50%;
	color: #fff;
}

@media screen and (max-width: 640px) {
	.collection_163 {
		position: absolute;
		top: 120vw;
		left: 5%;
		width: 90%;
		color: #000;
		font-size: 2.2rem;
		font-size: 22px;
	}
}

.collection_164 {
	position: absolute;
	top: 300px;
	left: 50px;
	font-weight: normal;
	width: 45%;
	color: #fff;
}

@media screen and (max-width: 640px) {
	.collection_164 {
		position: absolute;
		top: 160vw;
		left: 5%;
		width: 90%;
		color: #000;
		font-size: 1.8rem;
		font-size: 18px;
	}
}

.collection_165 {
	width: 100%;
	position: absolute;
	top: 0;
	right: 0;
	z-index: -1;
}

.collection_166 {
	margin: 0 auto;
	width: 1200px;
	position: relative;
	height: 688px;
}

@media screen and (max-width: 640px) {
	.collection_166 {
		margin: 0 auto;
		width: 100%;
		height: auto;
	}
}

.collection_167 {
	width: 100%;
	position: absolute;
	top: 0;
	left: 0;
}

@media screen and (max-width: 640px) {
	.collection_167 {
		position: static;
	}
}

.collection_168 {
	position: absolute;
	bottom: 50px;
	right: 0;
	width: 30%;
}

@media screen and (max-width: 640px) {
	.collection_168 {
		position: static;
		width: 90%;
		margin: 0 5%;
	}
}

.collection_169 {
	position: relative;
	width: 100%;
	height: 1650px;
}

@media screen and (max-width: 640px) {
	.collection_169 {
		height: auto;
	}
}

.collection_170 {
	width: 25%;
	float: right;
	margin: 0 0 0 20px;
}

@media screen and (max-width: 640px) {}

.collection_171 {
	position: absolute;
	top: 652px;
	left: 0;
}

@media screen and (max-width: 640px) {
	.collection_171 {
		position: static;
	}
}

.collection_172 {
	position: absolute;
	top: 652px;
	right: 0;
}

@media screen and (max-width: 640px) {
	.collection_172 {
		position: static;
	}
}

.collection_173 {
	position: relative;
	margin: 0 auto;
	width: 1200px;
	height: 1010px;
	text-align: center;
}

@media screen and (max-width: 640px) {
	.collection_173 {
		margin: 0 auto;
		width: 100%;
		height: auto;
	}
}

.collection_174 {
	position: absolute;
	top: 30px;
	right: 0px;
	font-weight: normal;
	width: 45%;
}

@media screen and (max-width: 640px) {
	.collection_174 {
		position: absolute;
		top: 8%;
		right: 5%;
		font-weight: normal;
		width: 90%;
	}
}

.collection_175 {
	width: 80% !important;
	position: absolute;
	top: 40px;
	left: 0;
}

@media screen and (max-width: 640px) {}

.collection_176 {
	position: absolute;
	bottom: 45px;
	left: 60px;
	color: #fff;
	font-weight: bold;
}

@media screen and (max-width: 640px) {
	.collection_176 {
		position: absolute;
		top: 5%;
		left: 28%;
	}
}

.collection_177 {
	width: 70% !important;
}

@media screen and (max-width: 640px) {
	.collection_177 {
		position: absolute !important;
		bottom: 10% !important;
		left: 0 !important;
		width: 90% !important;
		height: 10% !important;
	}

	.collection_177 a {
		font-size: 0.8rem !important;
		font-size: 8px !important;
	}
}

.collection_178 {
	width: 60%;
	margin: 100px auto 150px auto;
}

@media screen and (max-width: 640px) {
	.collection_178 {
		width: 100%;
		margin: 100px 0;
	}
}

.collection_179 {
	width: 100%;
	position: absolute;
	top: -30px;
	left: 0;
}

@media screen and (max-width: 640px) {}

.collection_180 {
	position: absolute;
	bottom: 80px;
	left: 70px;
	color: #575757;
}

@media screen and (max-width: 640px) {
	.collection_180 {
		position: absolute;
		bottom: 30%;
		left: 23%;
	}
}

.collection_181 {
	position: absolute;
	bottom: 50px;
	left: 70px;
}

@media screen and (max-width: 640px) {
	.collection_181 {
		position: absolute;
		bottom: 20%;
		left: 23%;
	}
}

.collection_182 {}

@media screen and (max-width: 640px) {
	.collection_182 {
		color: #000 !important;
		font-size: 1rem !important;
		line-height: 2.6em !important;
		color: #000 !important;
		font-size: 10px !important;
		line-height: 2.6em !important;
	}
}

.collection_183 {
	width: 73.3%;
	margin: 0 auto;
}

@media screen and (max-width: 640px) {
	.collection_183 {
		width: 100%;
	}
}

.collection_184 {
	height: 70vh;
	width: 100%;
	object-fit: cover;
	object-position: center 40%;
}

@media screen and (max-width: 640px) {
	.collection_184 {
		height: 100%;
		width: 100%;
		object-fit: cover;
		object-position: center 10px;
	}
}

.collection_185 {}

@media screen and (max-width: 640px) {}

.collection_186 {}

@media screen and (max-width: 640px) {}

.collection_187 {}

@media screen and (max-width: 640px) {}

.collection_188 {}

@media screen and (max-width: 640px) {}

.collection_189 {}

@media screen and (max-width: 640px) {}

.collection_190 {}

@media screen and (max-width: 640px) {}










.contents_1 {
	width: 50%;
	padding: 0 10px;
	overflow: hidden;
}

.contents_1 img {
	width: 100%;
	margin-bottom: 20px;
}

@media screen and (max-width: 640px) {
	.contents_1 {
		width: 100%;
	}
}



















.spec_1 {
	width: 65%
}

@media screen and (max-width: 640px) {
	.spec_1 {
		width: 100%
	}
}

.spec_2 {
	width: 50%;
	text-align: center;
	position: relative;
}

@media screen and (max-width: 640px) {
	.spec_2 {
		width: 100%;
		text-align: center;
		position: relative;
		margin-bottom: 50px;
	}
}

.spec_3 {
	position: absolute;
	bottom: 0;
	left: 80px;
}

@media screen and (max-width: 640px) {
	.spec_3 {
		position: absolute;
		bottm: 0;
		left: 0;
	}
}

.spec_4 {
	float: left;
	width: 20%;
	margin: 3px;
	border: 1px solid #dedede;
}

@media screen and (max-width: 640px) {
	.spec_4 {
		float: left;
		width: 23%;
		margin: 3px;
	}
}

.spec_5 {
	width: 50%
}

@media screen and (max-width: 640px) {
	.spec_5 {
		width: 100%
	}
}

.spec_6 {
	text-align: center;
	vertical-align: middle;
	width: 30%;
	padding: 3px;
	background-color: #f0f0f0;
	border-bottom: 3px solid #ffffff;
	font-weight: normal
}

@media screen and (max-width: 640px) {
	.spec_6 {
		width: 35%;
	}
}

.spec_7 {
	width: 70%;
	padding: 3px 3px 3px 30px;
}

@media screen and (max-width: 640px) {
	.spec_7 {
		width: 65%;
		padding: 3px 3px 3px 15px;
	}
}

.spec_8 {
	margin-top: 30px;
	text-align: center;
	float: right;
	width: 25%;
	height: 50px;
	background-color: #fff;
	border: 1px solid #c0c0c0;
	font-size: 1.8rem;
	font-size: 18px;
	line-height: 2em;
}

@media screen and (max-width: 640px) {
	.spec_8 {
		width: 50%;
	}
}

.spec_8 a {
	width: 100%;
	height: 100%;
	padding: 5px;
	display: block;
	color: #c0c0c0;
	transition: 0.5s;
}

.spec_8 a:hover {
	background-color: #c0c0c0;
	color: #fff;
}

.spec_9 {
	position: absolute;
	top: 80px;
	left: 0;
	width: 15%;
}

@media screen and (max-width: 640px) {
	.spec_9 {
		position: absolute;
		top: 18vw;
		left: -2vw;
		width: 17%;
	}
}

.spec_10 {
	width: 270px;
	height: 20px;
	margin: 4px 0 0 70px;
}

@media screen and (max-width: 640px) {
	.spec_10 {
		width: 100%;
		height: 20px;
		margin: 4px auto;
	}
}

.spec_11 {
	width: 90px;
	height: 20px;
	margin: 4px 0 0 155px;
}

@media screen and (max-width: 640px) {
	.spec_11 {
		width: 40%;
		height: 20px;
		margin: 4px auto;
	}
}

.spec_12 {
	position: absolute;
	top: 70px;
	left: 30%;
	color: #ff0000;
}

@media screen and (max-width: 640px) {
	.spec_12 {
		position: absolute;
		top: 66px;
		left: 50%;
		width: 70%;
		margin-left: -35%;
	}
}




.spec_10_2 {
	display: block;
	width: 270px;
	height: 20px;
	margin: 4px auto 0 auto;
}

.spec_10_2 img {
	display: block;
	margin: 0 auto;
}

.spec_11_2 {
	width: 90px;
	height: 20px;
	margin: 4px 0 0 100px;
	display: block;
}

.spec_11_2 img {
	display: block;
	margin: 0 auto;
}

.spec_12_2 {
	position: absolute;
	top: 70px;
	left: 43%;
	color: #ff0000;
}

@media screen and (max-width: 640px) {
	.spec_10_2 {
		width: 100%;
		margin: 2px auto 0 auto;
	}

	.spec_11_2 {
		width: 70px;
		margin: 4px auto 0 auto;
	}

	.spec_12_2 {
		position: absolute;
		top: 65px;
		left: 40%;
		font-size: 0.95em;
	}
}

.spec_13 {
	float: left;
	width: 70%;
	font-size: 1.2rem;
	font-size: 12px;
	line-height: 1.2em;
	text-align: left;
	margin-top: 30px;
}

@media screen and (max-width: 640px) {
	.spec_13 {
		width: 100%;
		font-size: 1.4rem;
		font-size: 14px;
		line-height: 1.4em;
	}
}

.spec_1 img,
.spec_2 img,
.spec_3 img,
.spec_4 img,
.spec_5 img,
.spec_6 img,
.spec_7 img,
.spec_8 img,
.spec_9 img,
.spec_10 img,
.spec_11 img,
.spec_12 img,
.spec_13 img {
	display: block;
}

.spec_14 {}

@media screen and (max-width: 640px) {}

.spec_15 {}

@media screen and (max-width: 640px) {}

.spec_16 {}

@media screen and (max-width: 640px) {}

.spec_17 {}

@media screen and (max-width: 640px) {}

.spec_18 {}

@media screen and (max-width: 640px) {}

.spec_19 {}

@media screen and (max-width: 640px) {}

.spec_20 {}

@media screen and (max-width: 640px) {}







/* 360° */
.inner {
	width: 700px;
	height: 700px;
	margin: 0 auto;
}

.image-wrap {
	width: 700px;
	margin: 0 auto;
}

.cloudimage-360-view-360-icon {
	display: block !important;
}

@media screen and (max-width: 640px) {
	.inner {
		width: 100%;
		height: auto;
		margin: 0 auto;
	}

	.image-wrap {
		width: 100%;
		margin: 0 auto;
	}
}


/* Brand Story */
.brand-story_1,
.brand-story_6,
.brand-story_9 {
	margin: 0 auto 100px auto;
	width: 1200px;
}

.brand-story_2 {
	margin: 0 auto 100px auto;
	width: 1200px;
	background-color: #e5e5e7;
}

.brand-story_3 {
	float: left;
	margin: -30px 40px 0 0;
}

.brand-story_4 {
	margin: 0 auto 100px auto;
	width: 1200px;
	background: url(../brand-story/images/concept_img_02.jpg);
	padding: 100px 150px;
	text-align: center;
}

.brand-story_5 {
	margin-top: 100px;
}

.brand-story_7 {
	margin-top: 50px;
}

.brand-story_8 {
	text-align: center;
	margin-top: 100px;
	min-width: 1200px;
}

.brand-story_10 {
	margin: 100px auto;
	width: 1200px;
	text-align: center;
}

.brand-story_11 {
	text-align: center;
	margin-top: 30px;
	min-width: 1200px;
}

@media screen and (max-width: 640px) {
	.brand-story_11 {
		min-width: initial;
		margin-top: 0;
		/*padding-bottom: 30px;*/
		font-size: 1.6rem;
		font-size: 16px;
	}
}

@media screen and (max-width: 640px) {
	.brand-story_1 {
		margin: -20px auto 30px auto;
		width: 90%;
	}

	.brand-story_2 {
		margin: 0 auto 100px auto;
		width: 90%;
		background-color: #e5e5e7;
	}

	.brand-story_3 {
		float: none;
		width: 100%;
	}

	.brand-story_4 {
		margin: 50px auto;
		width: 90%;
		padding: 50px 30px;
		text-align: left;
	}

	.brand-story_5 {
		margin-top: 20px;
	}

	.brand-story_6 {
		margin: 0 auto 30px auto;
		width: 90%;
	}

	.brand-story_7 {
		margin-top: 20px;
	}

	.brand-story_8 {
		text-align: center;
		margin-top: 50px;
		min-width: initial;
	}

	.brand-story_9 {
		margin: 15px auto 30px auto;
		width: 90%;
	}

	.brand-story_10 {
		margin: 100px auto;
		width: 90%;
		text-align: center;
	}

	.brand-story_10 img {
		width: 100%;
	}
}





























/*==================================================
スライダー
===================================*/
.slider1 {
	/*スライダーの幅と高さを調整*/
	width: 100%;
	height: 500px;
	margin: 0 auto;
	/*border: 1px solid #ff0000;*/
	overflow: hidden;
}

.slider1_1 {
	/*スライダーの幅と高さを調整*/
	width: 20%;
	height: 500px;
	margin: 0 auto;
	/*border: 1px solid #ff0000;*/
	overflow: hidden;
}

.slider1_2 {
	/*スライダーの幅と高さを調整*/
	width: 47%;
	height: 500px;
	margin: 0 auto;
	/*border: 1px solid #ff0000;*/
	overflow: hidden;
}

.slider1_3 {
	/*スライダーの幅と高さを調整*/
	width: 73.3%;
	height: 500px;
	margin: 0 auto;
	/*border: 1px solid #ff0000;*/
	overflow: hidden;
}

@media screen and (max-width: 640px) {
	.slider1 {
		width: 100%;
		height: 150vw;
		margin: 0 auto;
	}

	.slider1_1 {
		width: 66%;
		height: 150vw;
		margin: 0 auto;
	}

	.slider1_2 {
		width: 100%;
		height: 150vw;
		margin: 0 auto;
	}

	.slider1_3 {
		width: 100%;
		height: 150vw;
		margin: 0 auto;
	}
}

.swiper-slide {
	/*スライド要素の幅と高さを調整*/
	width: 100%;
	height: 100%;
}

.slider1 .swiper-button-prev,
.slider1_1 .swiper-button-prev,
.slider1_2 .swiper-button-prev,
.slider1_3 .swiper-button-prev {
	left: -40px;
	color: #cfcfcf;
}

.slider1 .swiper-button-next,
.slider1_1 .swiper-button-next,
.slider1_2 .swiper-button-next,
.slider1_3 .swiper-button-next {
	right: -40px;
	color: #cfcfcf;
}

.slider1 .swiper-pagination,
.slider1_1 .swiper-pagination,
.slider1_2 .swiper-pagination,
.slider1_3 .swiper-pagination {
	bottom: 0 !important;
}

.slider1 .swiper-pagination-bullet,
.slider1_1 .swiper-pagination-bullet,
.slider1_2 .swiper-pagination-bullet,
.slider1_3 .swiper-pagination-bullet {
	background-color: #333333;
}

.slider2 {
	width: 100%;
	height: 400px;
	margin: 0 auto 100px auto;
	/* border: 1px solid #ff0000; */
	overflow: hidden;
}

@media screen and (max-width: 640px) {
	.slider2 {
		height: 150vw;
		margin: 0 auto;
	}
}

.slider2 .swiper-button-prev {
	left: -40px;
	color: #cfcfcf;
}

.slider2 .swiper-button-next {
	right: -40px;
	color: #cfcfcf;
}

.slider2 .swiper-pagination {
	bottom: -20px !important;
}

@media screen and (max-width: 640px) {
	.slider2 .swiper-pagination {
		bottom: 15px !important;
	}
}

.slider2 .swiper-pagination-bullet {
	background-color: #333333;
}

.swiper {
	width: 100%;
	height: 100%;
}

.swiper-slide {
	text-align: center;
	font-size: 1.8rem;
	font-size: 18px;
	background: transparent;
	display: flex;
	justify-content: center;
	align-items: center;
}

.swiper-slide img {
	display: block;
	width: 100%;
	height: 100%;
	object-fit: cover;
}

@media screen and (max-width: 640px) {
	.swiper-slide img {
		display: block;
		width: 100%;
		height: 100%;
		object-fit: cover;
		object-position: center 8vw;
	}
}

.swiper-slide a {
	margin: 0;
}

.slider3 .swiper-pagination {
	bottom: 15px !important;
}

.slider3 .swiper-pagination-bullet {
	background-color: #333333;
}







/*==================================================
背景色が伸びて出現
===================================*/
.bgextend {
	animation-name: bgextendAnimeBase;
	animation-duration: 1s;
	animation-fill-mode: forwards;
	position: relative;
	overflow: hidden;
	/*　はみ出た色要素を隠す　*/
	opacity: 0;
}

@keyframes bgextendAnimeBase {
	from {
		opacity: 0;
	}

	to {
		opacity: 1;
	}
}

/*中の要素*/
.bgappear {
	animation-name: bgextendAnimeSecond;
	animation-duration: 1s;
	animation-delay: 0.5s;
	animation-fill-mode: forwards;
	opacity: 0;
}

@keyframes bgextendAnimeSecond {
	0% {
		opacity: 0;
	}

	100% {
		opacity: 1;
	}
}

/*左から右*/
.bgLRextend_n::before {
	animation-name: bgLRextendAnime;
	animation-duration: 1s;
	animation-fill-mode: forwards;
	content: "";
	position: absolute;
	width: 100%;
	height: 100%;
	background-color: #002c55;
	/*伸びる背景色の設定*/
}

.bgLRextend_w::before {
	animation-name: bgLRextendAnime;
	animation-duration: 1s;
	animation-fill-mode: forwards;
	content: "";
	position: absolute;
	width: 100%;
	height: 100%;
	background-color: #fff;
	/*伸びる背景色の設定*/
}

@keyframes bgLRextendAnime {
	0% {
		transform-origin: left;
		transform: scaleX(0);
	}

	50% {
		transform-origin: left;
		transform: scaleX(1);
	}

	50.001% {
		transform-origin: right;
	}

	100% {
		transform-origin: right;
		transform: scaleX(0);
	}
}

/*右から左*/
.bgRLextend_n::before {
	animation-name: bgRLextendAnime;
	animation-duration: 1s;
	animation-fill-mode: forwards;
	content: "";
	position: absolute;
	width: 100%;
	height: 100%;
	background-color: #002c55;
	/*伸びる背景色の設定*/
}

.bgRLextend_w::before {
	animation-name: bgRLextendAnime;
	animation-duration: 1s;
	animation-fill-mode: forwards;
	content: "";
	position: absolute;
	width: 100%;
	height: 100%;
	background-color: #fff;
	/*伸びる背景色の設定*/
}

@keyframes bgRLextendAnime {
	0% {
		transform-origin: right;
		transform: scaleX(0);
	}

	50% {
		transform-origin: right;
		transform: scaleX(1);
	}

	50.001% {
		transform-origin: left;
	}

	100% {
		transform-origin: left;
		transform: scaleX(0);
	}
}


/* スクロールをしたら出現する要素にはじめに透過0を指定　*/
.bgappearTrigger,
.bgRLextendTrigger_n,
.bgRLextendTrigger_w,
.bgLRextendTrigger_n,
.bgLRextendTrigger_w {
	opacity: 0;
}




/*==================================================
スタート時は要素自体を透過0にするためのopacity:0;を指定する
===================================*/

.flex {
	display: flex;
	flex-wrap: wrap;
	justify-content: center;
}

.flex2 {
	display: flex;
	flex-wrap: wrap;
}

.flex3 {
	display: flex;
}

.flex4 {
	display: flex;
	flex-wrap: wrap;
	justify-content: space-between;
}

@media screen and (max-width: 640px) {
	.flex {
		display: flex;
	}

	.flex3 {
		display: block;
	}

	.flex4 {
		display: block;
	}
}

.box1 {
	/*width: 300px;*/
	height: 500px;
	margin: auto;
	/*border: 3px solid #f8f8f8;*/
	box-sizing: border-box;
	list-style: none;
	text-align: center;
}

.box2 {
	/*width: 180px;*/
	height: 340px;
	margin: auto;
	/*background-color: #fff;*/
	box-sizing: border-box;
	list-style: none;
	text-align: center;
}

.box3 {
	width: 290px !important;
	height: 660px;
	margin: 20px 50px;
	/* border: 3px solid #f8f8f8; */
	box-sizing: border-box;
	list-style: none;
	text-align: center;
}

.box1 img {
	width: 100% !important;
	margin: -100px auto 0 auto;
}

.box2 img {
	width: 100% !important;
	margin: -50px auto 0 auto;
}

.box3 img {
	width: 100% !important;
	margin: 0 auto;
}

.balloonoya {
	position: relative;
}

.balloonoya:hover .balloon1,
.balloonoya:hover .balloon2,
.balloonoya:hover .balloon3 {
	display: inline;
	animation: appear 0.5s ease;
}

@media screen and (max-width: 640px) {

	.box1,
	.box2 {
		width: 100%;
		height: 100%;
		margin: auto;
		border-bottom: 1px solid #aaaaaa;
		box-sizing: border-box;
		list-style: none;
		text-align: center;
	}

	.box3 {
		width: 45% !important;
		height: 135vw;
		margin: 10vw auto 0 auto;
		border-bottom: 1px solid #aaaaaa;
		box-sizing: border-box;
		list-style: none;
		text-align: center;
	}

	.box1 img {
		height: auto;
		width: 90%;
		margin: -100px auto 0 auto;
	}

	.box2 img {
		height: auto;
		width: 90%;
		margin: -100px auto 0 auto;
	}

	.box3 img {
		height: auto;
		width: 90%;
		margin: 0 auto;
	}

	.balloonoya:hover .balloon1,
	.balloonoya:hover .balloon2,
	.balloonoya:hover .balloon3 {}
}

@keyframes appear {
	0% {
		opacity: 0;
	}

	100% {
		opacity: 1;
	}
}

.balloon1 {
	position: absolute;
	display: none;
	width: 90%;
	/* border: 1px solid #dadada; */
	bottom: 50px;
	left: 5%;
	background-color: #fff;
	border: 1px solid #c0c0c0;
}

.balloon2 {
	position: absolute;
	display: none;
	width: 90%;
	/* border: 1px solid #dadada; */
	bottom: 0;
	left: 5%;
	background-color: #fff;
	border: 1px solid #c0c0c0;
}

.balloon3 {
	position: absolute;
	display: none;
	width: 90%;
	/* border: 1px solid #dadada; */
	bottom: 0;
	left: 5%;
	background-color: #fff;
	border: 1px solid #c0c0c0;
}

.balloon1 a,
.balloon2 a,
.balloon3 a {
	width: 100%;
	height: 100%;
	padding: 5px;
	display: block;
	font-size: 1.4rem;
	font-size: 14px;
	color: #9d9d9d;
}

.balloon1 a:hover,
.balloon2 a:hover,
.balloon3 a:hover {
	background-color: #c0c0c0;
	color: #fff;
	transition: 0.5s ease-in-out;
	/*移り変わる速さを変更したい場合はこの数値を変更*/
}

@media screen and (max-width: 640px) {

	.balloon1,
	.balloon2 {
		display: block;
		position: absolute;
		bottom: 20vw;
		left: 0;
		width: 90%;
		height: 50px;
		border: 1px solid #c0c0c0;
		margin: 0 0 0 6%;
	}

	.balloon3 {
		display: block;
		position: absolute;
		bottom: 5vw;
		left: 0;
		width: 90%;
		height: 50px;
		border: 1px solid #c0c0c0;
		margin: 0 0 0 6%;
	}

	.balloon1 a,
	.balloon2 a,
	.balloon3 a {
		width: 100%;
		height: 50px;
		display: block;
		background-color: #c0c0c0;
		color: #fff;
		font-size: 1.8rem;
		font-size: 18px;
		line-height: 2em;
	}

	.balloon1 a:hover,
	.balloon2 a:hover,
	.balloon3 a:hover {
		background-color: #c0c0c0;
		color: #fff;
	}
}

.box4 {
	width: 250px;
	height: 400px;
	margin: auto;
	/*border: 3px solid #f8f8f8;*/
	box-sizing: border-box;
	list-style: none;
	text-align: center;
}

.box4 img {
	width: 80% !important;
	margin: 0 auto;
	position: absolute;
	bottom: 40px;
	left: 0;
}

.box5 {
	width: 250px;
	height: 450px;
	margin: auto;
	/*border: 3px solid #f8f8f8;*/
	box-sizing: border-box;
	list-style: none;
	text-align: center;
}

.box5 img {
	width: 100% !important;
	margin: 0 auto;
	position: absolute;
	bottom: 40px;
	left: 0;
}

@media screen and (max-width: 640px) {
	.box4 {
		width: 50%;
		height: 80vw;
		margin: 5vw auto;
	}

	.box4 img {
		width: 80% !important;
		margin: 0 auto;
		position: absolute;
		bottom: 15vw;
		left: 10%;
	}

	.box5 {
		width: 50%;
		height: 90vw;
		margin: 5vw auto;
	}

	.box5 img {
		width: 90% !important;
		margin: 0 auto;
		position: absolute;
		bottom: 15vw;
		left: 5%;
	}
}

.balloonoya:hover .balloon4,
.balloonoya:hover .balloon5 {
	animation: appear 0s;
}

.balloon4 a:hover,
.balloon5 a:hover {
	background-color: #c0c0c0;
	color: #fff;
	transition: 0.5s ease-in-out;
	/*移り変わる速さを変更したい場合はこの数値を変更*/
}

.balloon4,
.balloon5 {
	display: block !important;
	position: absolute;
	width: 90%;
	/* border: 1px solid #dadada; */
	bottom: 0px;
	left: 5%;
	background: transparent;
	border: 1px solid #c0c0c0;
}

.balloon4 a,
.balloon5 a {
	width: 100%;
	height: 100%;
	padding: 5px;
	display: block;
	font-size: 1.4rem;
	font-size: 14px;
	color: #9d9d9d;
}

@media screen and (max-width: 640px) {
	.balloon4 {
		display: block;
		position: absolute;
		bottom: 0;
		left: 0;
		width: 80% !important;
		height: 50px;
		border: 1px solid #c0c0c0;
		margin: 0 0 0 10%;
	}

	.balloon5 {
		display: block;
		position: absolute;
		bottom: 0;
		left: 0;
		width: 90% !important;
		height: 50px;
		border: 1px solid #c0c0c0;
		margin: 0 0 0 5%;
	}

	.balloon4 a {
		width: 100%;
		height: 50px;
		display: block;
		color: #fff;
		font-size: 1.2rem !important;
		font-size: 12px !important;
		line-height: 1.8em;
	}

	.balloon4 a:hover {
		background-color: #c0c0c0;
		color: #fff;
	}

	.balloon5 a {
		width: 100%;
		height: 50px;
		display: block;
		line-height: 2em;
		color: #9d9d9d !important;
		font-size: 1.6rem !important;
		font-size: 16px !important;
	}

	.balloon5 a:hover {
		background-color: #c0c0c0;
	}
}



/*==================================================
動かしたい動き（ふわっ）
===================================*/

.fadeUp {
	animation-name: fadeUpAnime;
	animation-duration: 1s;
	animation-fill-mode: forwards;
	opacity: 0;
}

@keyframes fadeUpAnime {
	from {
		opacity: 0;
		transform: translateY(20px);
	}

	to {
		opacity: 1;
		transform: translateY(0);
	}
}


/* その場で */
.fadeIn {
	animation-name: fadeInAnime;
	animation-duration: 1s;
	animation-fill-mode: forwards;
	opacity: 0;
}

@keyframes fadeInAnime {
	from {
		opacity: 0;
	}

	to {
		opacity: 1;
	}
}



/*========= 流れるテキスト ===============*/

/*全共通*/

.slide-in {
	overflow: hidden;
	display: inline-block;
}

.slide-in_inner {
	display: inline-block;

}

/*左右のアニメーション*/
.leftAnime {
	opacity: 0;
	/*事前に透過0にして消しておく*/
}

.slideAnimeLeftRight {
	animation-name: slideTextX100;
	animation-duration: 1.5s;
	animation-fill-mode: forwards;
	opacity: 0;
}

@keyframes slideTextX100 {
	from {
		transform: translateX(-100%);
		/*要素を左の枠外に移動*/
		opacity: 0;
	}

	to {
		transform: translateX(0);
		/*要素を元の位置に移動*/
		opacity: 1;
	}
}

.slideAnimeRightLeft {
	animation-name: slideTextX-100;
	animation-duration: 1.5s;
	animation-fill-mode: forwards;
	opacity: 0;
}


@keyframes slideTextX-100 {
	from {
		transform: translateX(100%);
		/*要素を右の枠外に移動*/
		opacity: 0;
	}

	to {
		transform: translateX(0);
		/*要素を元の位置に移動*/
		opacity: 1;
	}
}



/*　画像の透過+グラデーション＋テキスト出現　*/

.opacityText {
	/*テキストの基点となる位置を定義*/
	position: relative;
}


.opacityText span.cap1 {
	opacity: 0;
	transition: 0.5s ease-in-out;
	/*移り変わる速さを変更したい場合はこの数値を変更*/
	position: absolute;
	z-index: 3;
	/*テキストを前面に出す*/
	top: 50%;
	left: 50%;
	transform: translate(-50%, -50%);
	color: #fff;
	/*テキストの色を変えたい場合はここを修正*/
	line-height: 1.5;
	/*行の高さを1.5にする*/
}

.opacityText span.cap2 {
	opacity: 0;
	transition: 0.5s ease-in-out;
	position: absolute;
	z-index: 3;
	top: 42%;
	left: 50%;
	transform: translate(-50%, -50%);
	color: #fff;
	line-height: 1.5;
	width: 65%;
	text-align: center;
}

.opacityText span.cap3 {
	opacity: 0;
	transition: 0.5s ease-in-out;
	/*移り変わる速さを変更したい場合はこの数値を変更*/
	position: absolute;
	z-index: 3;
	/*テキストを前面に出す*/
	top: 70%;
	left: 50%;
	transform: translate(-50%, -50%);
	color: #fff;
	/*テキストの色を変えたい場合はここを修正*/
	line-height: 1.5;
	/*行の高さを1.5にする*/
}

.opacityText span.cap4 {
	opacity: 0;
	transition: 0.5s ease-in-out;
	/*移り変わる速さを変更したい場合はこの数値を変更*/
	position: absolute;
	z-index: 3;
	/*テキストを前面に出す*/
	top: 50%;
	left: 50%;
	transform: translate(-50%, -50%);
	color: #fff;
	/*テキストの色を変えたい場合はここを修正*/
	line-height: 1.5;
	/*行の高さを1.5にする*/
}

.opacityText span.cap5 {
	opacity: 0;
	transition: 0.5s ease-in-out;
	/*移り変わる速さを変更したい場合はこの数値を変更*/
	position: absolute;
	z-index: 3;
	/*テキストを前面に出す*/
	top: 50%;
	left: 50%;
	transform: translate(-50%, -50%);
	color: #fff;
	/*テキストの色を変えたい場合はここを修正*/
	line-height: 1.5;
	/*行の高さを1.5にする*/
}

.opacityText span.cap6 {
	opacity: 0;
	transition: 0.5s ease-in-out;
	/*移り変わる速さを変更したい場合はこの数値を変更*/
	position: absolute;
	z-index: 3;
	/*テキストを前面に出す*/
	top: 40%;
	left: 50%;
	transform: translate(-50%, -50%);
	color: #fff;
	/*テキストの色を変えたい場合はここを修正*/
	line-height: 1.5;
	/*行の高さを1.5にする*/
}

@media screen and (max-width: 640px) {
	.opacityText span.cap1 {
		opacity: 0;
		transition: 0.5s ease-in-out;
		/*移り変わる速さを変更したい場合はこの数値を変更*/
		position: absolute;
		z-index: 3;
		/*テキストを前面に出す*/
		top: calc(50%);
		left: calc(50%);
		transform: translate(-50%, -50%);
		color: #fff;
		/*テキストの色を変えたい場合はここを修正*/
		line-height: 1.5;
		/*行の高さを1.5にする*/
	}

	.opacityText span.cap2 {
		opacity: 0;
		transition: 0.5s ease-in-out;
		/*移り変わる速さを変更したい場合はこの数値を変更*/
		position: absolute;
		z-index: 3;
		/*テキストを前面に出す*/
		top: 95px;
		left: calc(50%);
		transform: translate(-50%, -50%);
		color: #fff;
		/*テキストの色を変えたい場合はここを修正*/
		line-height: 1.5;
		/*行の高さを1.5にする*/
	}

	.opacityText span.cap3 {
		opacity: 0;
		transition: 0.5s ease-in-out;
		/*移り変わる速さを変更したい場合はこの数値を変更*/
		position: absolute;
		z-index: 3;
		/*テキストを前面に出す*/
		top: calc(50% + 50px);
		left: calc(50% - 5px);
		transform: translate(-50%, -50%);
		color: #fff;
		/*テキストの色を変えたい場合はここを修正*/
		line-height: 1.5;
		/*行の高さを1.5にする*/
	}

	.opacityText span.cap4 {
		opacity: 0;
		transition: 0.5s ease-in-out;
		/*移り変わる速さを変更したい場合はこの数値を変更*/
		position: absolute;
		z-index: 3;
		/*テキストを前面に出す*/
		top: 180px;
		left: calc(50%);
		transform: translate(-50%, -50%);
		color: #fff;
		/*テキストの色を変えたい場合はここを修正*/
		line-height: 1.5;
		/*行の高さを1.5にする*/
	}

	.opacityText span.cap4 {
		opacity: 0;
		transition: 0.5s ease-in-out;
		/*移り変わる速さを変更したい場合はこの数値を変更*/
		position: absolute;
		z-index: 3;
		/*テキストを前面に出す*/
		top: 0;
		left: calc(50%);
		transform: translate(-50%, -50%);
		color: #fff;
		/*テキストの色を変えたい場合はここを修正*/
		line-height: 1.5;
		/*行の高さを1.5にする*/
	}
}

.opacityText:hover span.cap1,
.opacityText:hover span.cap2,
.opacityText:hover span.cap3,
.opacityText:hover span.cap4,
.opacityText:hover span.cap5,
.opacityText:hover span.cap6 {
	/*hoverした時の変化*/
	opacity: 1;
}

.zoomIn img.zoomIn_img {
	transform: scale(1);
	transition: 1.5s ease-in-out;
	/*移り変わる速さを変更したい場合はこの数値を変更*/
}

.zoomIn a:hover img.zoomIn_img {
	/*hoverした時の変化*/
	transform: scale(1.05);
	/*拡大の値を変更したい場合はこの数値を変更*/
	filter: blur(2px);
	/*ぼかし具合を変更したい場合はこの数値を変更*/
}



/*== 線から塗に変化（左から右） */
.btn04 {
	/*線の基点とするためrelativeを指定*/
	position: relative;
	/*ボタンの形状*/
	display: inline-block;

	border-top: 1px solid #dadada;
	border-bottom: 1px solid #dadada;
	text-decoration: none;
	outline: none;
	/*はみ出す背景色を隠す*/
	overflow: hidden;
}

/*hoverした際のボタンの形状*/
.btn04:hover {
	border-color: transparent;
	/*色の変化を遅らせる*/
	transition-delay: 0.5s;
}

/*線の設定*/
.btn04 div {
	display: block;
	z-index: 2;
}

/*線の設定*/
.borderleft div::before,
.borderleft div::after {
	content: '';
	/*絶対配置で線の位置を決める*/
	position: absolute;
	width: 0;
	height: 1px;
	/*線の形状*/
	background: #333;
	/*アニメーションの設定*/
	transition: all 0.5s;
}

/*左上線*/
.borderleft div::before {
	left: 0;
	top: 0;
}

/*左下線*/
.borderleft div::after {
	left: 0;
	bottom: 0;
}

/*hoverをすると線が伸びる*/
.borderleft:hover div::before,
.borderleft:hover div::after {
	width: 100%;
}

/*背景の設定*/
.borderleft::before {
	content: '';
	/*絶対配置で線の位置を決める*/
	position: absolute;
	left: 0;
	bottom: 0;
	z-index: -1;
	/*背景の形状*/
	height: 100%;
	width: 0;
	/*background:#f8f8f8;*/
	/*アニメーションの設定*/
	transition: all 0.5s;
}

/*hoverをすると背景が伸びる*/
.borderleft:hover::before {
	width: 100%;
	/*0.4秒遅れてアニメーション*/
	transition-delay: 0.5s;
}


/*========= スクロールで線表示 ===============*/
.horizon1_active {
	border-bottom: solid 1px #002c55;
	animation: border_anim 1s linear forwards;
}

.horizon2_active {
	border-bottom: solid 1px #d5d5d5;
	animation: border_anim 1s linear forwards;
}

@keyframes border_anim {
	0% {
		width: 0%;
	}

	100% {
		width: 100%;
	}
}




/* ボタン共通設定 */
.btn05 {
	/*線の基点とするためrelativeを指定*/
	position: relative;
	/*ボタンの形状*/
	display: inline-block;
	padding: 10px 30px;
	color: #333;
	border: 1px solid #ccc;
	text-decoration: none;
	outline: none;
	/*はみ出す背景色を隠す*/
	overflow: hidden;
}

/*hoverした際のボタンの形状*/
.btn05:hover {
	color: #ccc;
	border-color: transparent;
	/*色の変化を遅らせる*/
	transition-delay: .6s;
}

/*線の設定*/
.btn05 span {
	display: block;
	z-index: 2;
}

/*== 線から塗に変化（左から右） */

/*線の設定*/
.borderleft05 span::before,
.borderleft05 span::after {
	content: '';
	/*絶対配置で線の位置を決める*/
	position: absolute;
	width: 0;
	height: 1px;
	/*線の形状*/
	background: #333;
	/*アニメーションの設定*/
	transition: all .3s;
}

/*左上線*/
.borderleft05 span::before {
	left: 0;
	top: 0;
}

/*左下線*/
.borderleft05 span::after {
	left: 0;
	bottom: 0;
}

/*hoverをすると線が伸びる*/
.borderleft05:hover span::before,
.borderleft05:hover span::after {
	width: 100%;
}

/*背景の設定*/
.borderleft05::before {
	content: '';
	/*絶対配置で線の位置を決める*/
	position: absolute;
	left: 0;
	bottom: 0;
	z-index: -1;
	/*背景の形状*/
	height: 100%;
	width: 0;
	background: #333;
	/*アニメーションの設定*/
	transition: all .3s;
}

/*hoverをすると背景が伸びる*/
.borderleft05:hover::before {
	width: 100%;
	/*0.4秒遅れてアニメーション*/
	transition-delay: .4s;
}




/* ボタン共通設定 */
.btn03 {
	/*影の基点とするためrelativeを指定*/
	position: relative;
	/*ボタンの形状*/
	text-decoration: none;
	display: inline-block;
	text-align: center;
	background: transparent;
	/*border-radius: 25px;
	border: solid 1px #333;*/
	outline: none;
	/*アニメーションの指定*/
	transition: all 0.2s ease;
}

/*hoverをした後のボタンの形状*/
.btn03:hover {
	border-color: transparent;
}

/*ボタンの中のテキスト*/
.btn03 span {
	position: relative;
	z-index: 2;
	/*z-indexの数値をあげて文字を背景よりも手前に表示*/
	/*テキストの形状*/
	display: block;
	padding: 10px 30px;
	background: #fff;
	/*border-radius: 25px;*/
	color: #333;
	/*アニメーションの指定*/
	transition: all 0.3s ease;
}

/*== 下に押し込まれる（立体が平面に） */

/*影の設定*/
.pushdown:before {
	content: "";
	/*絶対配置で影の位置を決める*/
	position: absolute;
	z-index: -1;
	top: 4px;
	left: 0;
	/*影の形状*/
	width: 100%;
	height: 100%;
	/*border-radius: 25px;*/
	background-color: #333;
}

/*hoverの際にY軸に4pxずらす*/
.pushdown:hover span {
	background-color: #333;
	color: #fff;
	transform: translateY(4px);
}






/*横アコーディオン*/
ul.menu-list {
	display: flex;
}

ul.menu-list li {
	width: calc(100% / 3);
	height: 600px;
	padding: 0;
	overflow: hidden;
	transition: 2s;
}

/* メニューが開いた時の幅 */
ul.menu-list li.open {
	width: 2000px;
}

@media screen and (max-width:600px) {
	ul.menu-list {
		display: block;
	}

	ul.menu-list li {
		width: 100%;
		height: 50vw;
		margin: 0 auto;
	}

	ul.menu-list li+li {
		margin: -1px auto 0;
	}

	ul.menu-list li.open {
		width: 100%;
		height: 80vw;
	}
}

/*categoryのアコーディオン*/
.cat_accordion_container {
	width: 50%;
}

@media screen and (max-width: 640px) {
	.cat_accordion_container {
		width: 100%;
	}
}

.cat_accordion_title {
	width: 100%;
	height: 326px;
	display: block;
	background: transparent;
	position: relative;
	z-index: +1;
	cursor: pointer;
	transition-duration: 0.2s;
}

@media screen and (max-width: 640px) {
	.cat_accordion_title {
		margin-top: -48.5vw;
		height: 48.5vw;
	}
}

.cat_accordion_title:hover {
	opacity: 0.8;
}

.cat_accordion_icon_wrap {
	display: flex;
	justify-content: center;
	align-items: center;
	position: absolute;
	bottom: 5%;
	right: 5%;
	width: 40px;
	height: 40px;
	margin-top: -20px;
	box-sizing: border-box;
	-webkit-transform: rotate(45deg);
	transform: rotate(45deg);
	transform-origin: center center;
	transition-duration: 0.2s;
}

.cat_accordion_icon {
	background-color: #a3a3a3;
	border-radius: 20px;
	display: block;
	width: 40px;
	height: 40px;
	-webkit-transform: rotate(45deg);
	transform: rotate(45deg);
	transform-origin: center center;
	transition-duration: 0.2s;
	position: relative;
}

.cat_accordion_title.open .cat_accordion_icon_wrap {
	-webkit-transform: rotate(0deg);
	transform: rotate(0deg);
}

.cat_accordion_icon:before,
.cat_accordion_icon:after {
	display: flex;
	content: '';
	background-color: #fff;
	width: 30px;
	height: 8px;
	position: absolute;
	top: 15px;
	left: 5px;
	-webkit-transform: rotate(0deg);
	transform: rotate(0deg);
	transform-origin: center center;
}

.cat_accordion_icon:before {
	width: 8px;
	height: 30px;
	top: 5px;
	left: 15px;
}

.cat_accordion_title.open .cat_accordion_icon_wrap .cat_accordion_icon:before {
	content: none;
}

.cat_accordion_title.open .cat_accordion_icon_wrap .cat_accordion_icon:after {
	-webkit-transform: rotate(-45deg);
	transform: rotate(-45deg);
}

.cat_accordion_inner {
	display: none;
	padding: 10px;
	background-color: #fff;
	opacity: 0.8;
}

.ac_inner_wraper {
	/*height: 100px;*/
}

p.txt_a_ac {
	margin: 0;
}




/* 星空の背景のスタイル */
.stars {
	position: relative;
	width: 100%;
	/* 星空の横幅 */
	height: 100%;
	/* 星空の縦幅 */
	/*background-image: linear-gradient(0deg, #00dedc, #115d89, #080f1c);*/
	/* 星空の背景色 */
	overflow: hidden;
	/* 星が枠外にはみ出すのを防ぐ */
}

/* 星のスタイル */
.star {
	position: absolute;
	display: block;
	background-color: #fff;
	/* 星の色 */
	border-radius: 50%;
	box-shadow: 0 0 4px 2px rgba(#fff, 0.2);
	/* 星の影 */
	opacity: 0;
	animation: twinkle 5s infinite;
}

/* 星がキラキラ光るアニメーション */
@keyframes twinkle {
	0% {
		opacity: 0;
	}

	50% {
		transform: scale(1.1);
		opacity: 1;
	}

	100% {
		opacity: 0;
		transform: scale(1);
	}
}



/* テキスト影 */
.text-shadow1 {
	text-shadow: 1px 1px 2px #000;
}

/* 画像影 */
.pict-shadow1 {
	filter: drop-shadow(1px 1px 2px #000);
}




/* 画像のモーダル */
.hide-area {
	display: none;
}

/*全て共通：モーダルのボタンの色を変更したい場合*/
.modaal-close:after,
.modaal-close:before {
	background: #ccc;
}

.modaal-close:focus:after,
.modaal-close:focus:before,
.modaal-close:hover:after,
.modaal-close:hover:before {
	background: #666;
}

/*確認を促すモーダル：タイトルの色を変更したい場合*/
#modaal-title {
	font-size: 1.2rem;
	font-size: 12px;
	text-align: center;
	margin: 0 0 20px 0;
}

/*動画表示のモーダル：余白を変更したい場合*/
.modaal-video .modaal-inner-wrapper {
	padding: 0;
}

.modaal-wrapper {
	overflow-y: scroll;
}



/* 線 */
.hr1 {
	border-width: 1px 0 0 0;
	border-style: solid;
	border-color: #002855;
}

.hr2 {
	width: 550px;
	margin: 0 auto;
	border-width: 3px 0 0 0;
	border-style: solid;
	border-color: #002855;
}

.hr3 {
	width: 350px;
	margin: 0 auto;
	border-width: 3px 0 0 0;
	border-style: solid;
	border-color: #002855;
}

@media screen and (max-width:600px) {

	.hr2,
	.hr3 {
		width: 100%;
		margin: 0 auto;
		border-width: 3px 0 0 0;
		border-style: solid;
		border-color: #002855;
	}
}





/****/
.etc_01_pc {
	height: 70vh;
	width: 100%;
	object-fit: cover;
	object-position: center top;
}

.etc_01_sp {
	height: 155vw;
	width: 100%;
	object-fit: cover;
	object-position: center 50px;
}

.etc_bg_duration_01 {
	animation: slide 3s ease-in-out infinite alternate;
	background-image: linear-gradient(0.25turn, transparent 30%, #d1ecfd 50%, transparent 70%);
	bottom: 0;
	left: -50%;
	opacity: .5;
	position: fixed;
	right: -50%;
	top: 0;
	z-index: -1;
}

.etc_bg_duration_02 {
	animation: slide 3s ease-in-out infinite alternate;
	background-image: linear-gradient(0.25turn, transparent 30%, #d8d9ef 50%, transparent 70%);
	bottom: 0;
	left: -50%;
	opacity: .5;
	position: fixed;
	right: -50%;
	top: 0;
	z-index: -1;
}

.etc_bg_duration2 {
	animation-direction: alternate-reverse;
	animation-duration: 4s;
}

.etc_bg_duration3 {
	animation-duration: 5s;
}

@keyframes slide {
	0% {
		transform: translateX(-40%);
	}

	100% {
		transform: translateX(40%);
	}
}

.etc_02 {
	width: 20px;
	border-top: 1px solid #3e3e3e;
	margin: 10px auto 50px auto;
}

.etc_03 {
	font-size: 1.6rem;
	font-size: 16px;
	line-height: 2.6em;
}

.etc_04 {
	font-size: 1.6rem;
	font-size: 16px;
	line-height: 2.6em;
	margin-top: 30px;
}

.etc_05 {
	margin-top: 75px;
	padding-top: 100px;
	background-color: #fff;
}

@media screen and (max-width:600px) {
	.etc_05 {
		margin-top: 50px;
		padding-top: 50px;
		background-color: #fff;
	}
}

.etc_06 {
	width: 20px;
	border-top: 1px solid #3e3e3e;
	margin: 3px auto 50px auto;
}

.etc_07 {}

@media screen and (max-width:600px) {}

.etc_08 {}

@media screen and (max-width:600px) {}

.etc_09 {}

@media screen and (max-width:600px) {}

.etc_10 {}

@media screen and (max-width:600px) {}





/* gressive */
.gressive_01 {
	height: 700px;
	width: 100%;
	object-fit: contain;
	object-position: top;
}

@media screen and (max-width:600px) {
	.gressive_01 {
		height: 110vw;
		width: 100%;
		object-fit: contain;
		object-position: bottom;
	}
}

.gressive_02 {
	padding-bottom: 100px;
	background: #FFF;
	background: -webkit-linear-gradient(to right, #FFF, #efefef);
	background: linear-gradient(to right, #FFF, #efefef);
	color: #444;
}

.gressive_03 {
	width: 750px;
	margin: 0 auto;
	padding: 100px 0 50px 0;
}

.gressive_03_01 {
	font-size: 2.6rem;
	font-size: 26px;
}

.gressive_03_02 {
	font-size: 3.4rem;
	font-size: 34px;
	font-weight: bold;
	line-height: 1em;
}

@media screen and (max-width:600px) {
	.gressive_03 {
		width: 95%;
		margin: 0 auto;
		padding: 50px 0;
	}

	.gressive_03_01 {
		font-size: 1.6rem;
		font-size: 16px;
		line-height: 1.8em;
		display: block;
	}

	.gressive_03_02 {
		margin-top: -30px;
		font-size: 2rem;
		font-size: 20px;
		font-weight: bold;
		line-height: 1.8em;
		display: block;
	}
}

.gressive_04 {
	width: 960px;
	margin: 0 auto;
	line-height: 0;
}

@media screen and (max-width:600px) {
	.gressive_04 {
		width: 95%;
		margin: 0 auto;
		line-height: 0;
	}

	.gressive_04 img {
		width: 100%;
	}
}

.gressive_05 {
	padding-bottom: 100px;
	background: #444;
	background: -webkit-linear-gradient(to right, #444, #161616);
	background: linear-gradient(to right, #444, #161616);
	color: #FFF;
}

.gressive_06 {
	padding-bottom: 100px;
	background: #030f27;
	background: -webkit-linear-gradient(to right, #030f27, #164768);
	background: linear-gradient(to right, #030f27, #164768);
	color: #FFF;
}

.gressive_07 {
	padding-bottom: 100px;
	background: #444;
	background: -webkit-linear-gradient(to right, #444, #161616);
	background: linear-gradient(to right, #444, #161616);
	color: #FFF;
}

.gressive_08 {
	width: 750px;
	margin: 0 auto;
	padding: 50px 0 0 0;
}

@media screen and (max-width:600px) {
	.gressive_08 {
		width: 95%;
		margin: 0 auto;
		padding: 50px 0 0 0;
	}
}

.gressive_09 {
	padding-bottom: 100px;
	background: #FFF;
	background: -webkit-linear-gradient(to right, #FFF, #efefef);
	background: linear-gradient(to right, #FFF, #efefef);
	color: #444;
}

.gressive_10 {
	width: 960px;
	margin: 30px auto 0 auto;
	line-height: 0;
}

@media screen and (max-width:600px) {
	.gressive_10 {
		width: 95%;
		margin: 30px auto 0 auto;
		line-height: 0;
	}

	.gressive_10 img {
		width: 100%;
	}
}

.gressive_11 {
	width: 750px;
	margin: 0 auto;
	padding: 20px 0 0 0;
}

@media screen and (max-width:600px) {
	.gressive_11 {
		width: 95%;
		margin: 0 auto;
		padding: 20px 0 0 0;
	}
}

.gressive_12 {
	display: block;
	text-align: center;
	font-size: 112%;
	color: #333 !important;
	background: linear-gradient(#FFF, #d0c9b7);
	padding: 28px 20px;
	margin-top: 20px;
}

.gressive_12:hover {
	text-decoration: none;
	opacity: 0.7;
}

.gressive_13 {
	width: 960px;
	margin: 60px auto 0 auto;
	line-height: 0;
}

@media screen and (max-width:600px) {
	.gressive_13 {
		width: 95%;
		margin: 60px auto 0 auto;
		line-height: 0;
	}

	.gressive_13 img {
		width: 100%;
	}
}

.gressive_14 {
	padding-bottom: 100px;
	background: #444;
	background: -webkit-linear-gradient(to left, #000863, #06001c);
	background: linear-gradient(to left, #000863, #06001c);
	color: #FFF;
}

.gressive_15 {
	padding-top: 140px;
	padding-bottom: 100px;
	background: #444;
	background: -webkit-linear-gradient(to left, #0a0f15, #585e78);
	background: linear-gradient(to left, #0a0f15, #585e78);
	color: #FFF;
}

.gressive_16 {
	width: 1000px;
	margin: 0 auto;
	padding: 100px 0 50px 0;
	font-size: 2.6rem;
	font-size: 26px;
	line-height: 1.8em;
}

.gressive_16_01 {
	font-size: 2.6rem;
	font-size: 26px;
}

.gressive_16_02 {
	font-size: 3.4rem;
	font-size: 34px;
	font-weight: bold;
}

@media screen and (max-width:600px) {
	.gressive_16 {
		width: 95%;
		margin: 0 auto;
		padding: 50px 0;
	}

	.gressive_16_01 {
		font-size: 1.6rem;
		font-size: 16px;
		line-height: 1.8em;
		display: block;
	}

	.gressive_16_02 {
		margin-top: -30px;
		font-size: 2rem;
		font-size: 20px;
		font-weight: bold;
		line-height: 1.8em;
		display: block;
	}
}

.gressive_17 {
	width: 960px;
	margin: 50px auto 100px auto;
	line-height: 1.4em;
}

@media screen and (max-width:600px) {
	.gressive_17 {
		width: 95%;
		margin: 0 auto;
		line-height: 1.6em;
	}

	.gressive_17 img {
		width: 100%;
	}
}

.gressive_18 {}

@media screen and (max-width:600px) {}

.gressive_19 {}

@media screen and (max-width:600px) {}

.gressive_20 {}

@media screen and (max-width:600px) {}





/* hodinkee */
.hodinkee_01 {
	font-family: "ヒラギノ明朝 ProN W3", "Hiragino Mincho ProN", serif;
	background-color: #222222;
	color: #fff;
}

.hodinkee_02 {
	width: 100%;
	margin: 0 auto;
}

@media screen and (max-width:600px) {
	.hodinkee_02 {
		width: 95%;
		margin: 0 auto;
		padding-top: 10vw;
	}
}

.hodinkee_03 {
	width: 1000px;
	padding-top: 50px;
	margin: 0 auto 10px auto;
	line-height: 1.35em;
	font-size: 39px;
	text-align: center;
}

@media screen and (max-width:600px) {
	.hodinkee_03 {
		width: 95%;
		padding-top: 20px;
		margin: 0 auto 10px auto;
		line-height: 1.35em;
		font-size: 6vw;
		text-align: center;
	}
}

.hodinkee_04 {
	width: 850px;
	margin: 0 auto 50px auto;
	font-size: 22px;
	line-height: 1.2em;
	text-align: center;
}

@media screen and (max-width:600px) {
	.hodinkee_04 {
		width: 95%;
		margin: 0 auto 30px auto;
		font-size: 4vw;
		line-height: 1.4em;
		text-align: center;
	}
}

.hodinkee_05 {
	width: 1200px;
	margin: 0 auto;
	padding: 20px 0 22px 0;
	font-size: 11px;
	line-height: 1.8em;
	text-align: left;
	border-top: 1px solid #999999;
	border-bottom: 1px solid #999999;
}

@media screen and (max-width:600px) {
	.hodinkee_05 {
		width: 95%;
		margin: 0 auto;
		padding: 20px 0 22px 0;
		font-size: 11px;
		line-height: 1.8em;
		text-align: left;
		border-top: 1px solid #999999;
		border-bottom: 1px solid #999999;
	}
}

.hodinkee_06 {
	float: left;
	margin: 1px 10px 0 0;
}

.hodinkee_07 {
	width: 680px;
	margin: 30px auto 0 auto;
}

.hodinkee_07_2 {
	width: 680px;
	margin: 0 auto;
}

@media screen and (max-width:600px) {
	.hodinkee_07 {
		width: 95% !important;
		margin: 30px auto 0 auto;
	}

	.hodinkee_07_2 {
		width: 100%;
		margin: 0 auto;
	}
}

.hodinkee_08 {
	margin: 30px 0;
	line-height: 1.7em;
	font-size: 17px;
	margin-bottom: 10px;
}

.hodinkee_08::first-letter {
	font-size: 52px;
	font-family: "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", sans-serif;
	float: left;
	padding-right: 5px;
	margin-top: 10px;
}

@media screen and (max-width:600px) {
	.hodinkee_08 {
		margin: 30px 0;
		line-height: 1.7em;
		font-size: 4vw;
		margin-bottom: 10px;
	}

	.hodinkee_08::first-letter {
		font-size: 48px;
		font-family: "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", sans-serif;
		float: left;
		padding-right: 5px;
		margin-top: 10px;
	}
}

.hodinkee_09 {
	margin: 30px 0;
	line-height: 1.7em;
	font-size: 17px;
}

@media screen and (max-width:600px) {
	.hodinkee_09 {
		margin: 30px 0;
		line-height: 1.7em;
		font-size: 4vw;
	}
}

.hodinkee_10 {
	width: 850px;
	margin: 30px auto 0 auto;
}

.hodinkee_10_2 {
	width: 850px;
	margin: 0 auto;
}

@media screen and (max-width:600px) {
	.hodinkee_10 {
		width: 100% !important;
		margin: 30px auto 0 auto;
	}

	.hodinkee_10_2 {
		width: 95%;
		margin: 0 auto;
	}
}

.hodinkee_11 {
	width: 680px;
	margin: 0 auto;
	padding-top: 20px;
}

@media screen and (max-width:600px) {
	.hodinkee_11 {
		width: 90%;
		margin: 0 auto;
		padding-top: 20px;
	}
}

.hodinkee_12 {
	background-color: #999999;
	height: 1px;
	width: 80px;
	margin-left: 0;
	border: none;
}

@media screen and (max-width:600px) {}

.hodinkee_13 {
	line-height: 1.2em;
	margin-top: 40px;
	margin-bottom: 35px;
	font-size: 28px;
}

@media screen and (max-width:600px) {
	.hodinkee_13 {
		line-height: 1.35em;
		margin-top: 40px;
		margin-bottom: 35px;
		font-size: 6vw;
	}
}

.hodinkee_14 {
	margin: 30px 0 0 0;
	padding-bottom: 30px;
	line-height: 1.7em;
	font-size: 17px;
}

@media screen and (max-width:600px) {
	.hodinkee_14 {
		margin: 30px 0 0 0;
		padding-bottom: 30px;
		line-height: 1.7em;
		font-size: 4vw;
	}
}

.hodinkee_15 {
	color: rgb(204, 204, 204);
}

.hodinkee_15 a {
	color: rgb(204, 204, 204);
	text-decoration: underline;
}

@media screen and (max-width:600px) {
	.hodinkee_15 {
		font-size: 4vw;
	}
}

.hodinkee_16 {
	width: 1200px;
	margin: 0 auto;
}

.hodinkee_16_2 {
	width: 1200px;
	margin: 0 auto 40px auto;
}

@media screen and (max-width:600px) {
	.hodinkee_16 {
		width: 100% !important;
	}

	.hodinkee_16_2 {
		width: 95%;
		margin: 0 auto 30px auto;
	}
}

.hodinkee_17 {
	margin: 0 auto;
	text-align: center;
}

.hodinkee_17 a {
	margin: 20px 0 10px 0;
	display: inline-block;
	text-decoration: none;
	border-radius: 25px;
	font-weight: bold;
	font-size: 18px;
	color: white;
	background-color: #222222;
	border: 2px solid white;
	transition: all .5s;
	text-align: center;
	padding: 10px 22px;
}

.hodinkee_17 a:hover {
	color: #222222;
	background-color: #ffffff;
	border: 2px solid white;
	transition: all .5s;
	text-align: center;
	padding: 10px 22px;
}

@media screen and (max-width:600px) {
	.hodinkee_17 {
		width: 95%;
		margin: 0 auto;
	}

	.hodinkee_17 a {
		font-size: 4vw;
	}
}

.hodinkee_18 {
	width: 415px;
	float: left;
}

@media screen and (max-width:600px) {
	.hodinkee_18 {
		width: 100%;
		float: none;
	}
}

.hodinkee_19 {
	width: 415px;
	float: right;
}

@media screen and (max-width:600px) {
	.hodinkee_19 {
		width: 100%;
		float: none;
	}
}

.hodinkee_20 {
	width: 680px;
	margin: 0 auto 60px auto;
	padding-top: 20px;
}

@media screen and (max-width:600px) {
	.hodinkee_20 {
		width: 95%;
		margin: 0 auto 60px auto;
		padding-top: 20px;
	}
}

.hodinkee_21 {
	width: 32%;
	float: left;
	margin-right: 2%;
}

@media screen and (max-width:600px) {
	.hodinkee_21 {
		width: 48%;
		float: left;
		margin-right: 2%;
	}
}

.hodinkee_22 {
	width: 32%;
	float: left;
}

@media screen and (max-width:600px) {
	.hodinkee_22 {
		width: 48%;
		float: left;
	}
}

.hodinkee_23 {
	text-align: left;
	line-height: 1.7em;
	font-size: 14px;
	margin: 0;
}

@media screen and (max-width:600px) {
	.hodinkee_23 {
		text-align: left;
		line-height: 1.7em;
		font-size: 4vw;
		margin: 0;
	}
}

.hodinkee_24 {
	text-align: left;
	line-height: 1.6em;
	font-size: 12px;
	margin: 5px 0 0;
}

@media screen and (max-width:600px) {}

.hodinkee_25 {
	width: 1200px;
	margin: 30px auto 0 auto;
	text-align: right;
	margin-top: 30px;
	padding-bottom: 10px;
}

@media screen and (max-width:600px) {
	.hodinkee_25 {
		width: 95%;
		margin: 30px auto 0 auto;
		text-align: right;
		margin-top: 30px;
		padding-bottom: 10px;
	}
}

.hodinkee_26 {
	font-size: 12px;
	text-align: center;
}

@media screen and (max-width:600px) {
	.hodinkee_26 {
		font-size: 3vw;
		text-align: center;
	}
}

.hodinkee_27 {}

@media screen and (max-width:600px) {}

.hodinkee_28 {}

@media screen and (max-width:600px) {}

.hodinkee_29 {}

@media screen and (max-width:600px) {}

.hodinkee_30 {}

@media screen and (max-width:600px) {}



/* colorbox */
a.modal_gallery {
	cursor: -moz-zoom-in;
	cursor: -webkit-zoom-in;
	cursor: zoom-in;
}

/* swiper */
.swiper-button-prev,
.swiper-button-next {
	color: #b8b8b8;
}

.swiper-button-prev,
.swiper-button-next {
	position: static;
	margin-top: initial;
}

.swiper-pagination-bullet-active {
	background: #b8b8b8;
}

.sample-slider {
	margin: 0 auto;
}

.swiper-slide {
	width: 850px;
}

.swiper-slide img {
	width: 100%;
}

.slide-pagination-wrapper {
	display: flex;
	justify-content: right;
}

.swiper-pagination {
	position: static;
}

.swiper-horizontal>.swiper-pagination-bullets,
.swiper-pagination-bullets.swiper-pagination-horizontal,
.swiper-pagination-custom,
.swiper-pagination-fraction {
	width: auto;
}

/*.swiper-pagination-bullets {
    display: flex;
    align-items: center;
}*/
/* 幅・高さを指定 */
.swiper-button-prev,
.swiper-button-next {
	height: 60px;
	width: 45px;
}

/* 矢印を消す、画像に変更 */
.swiper-button-prev:after,
.swiper-button-next:after {
	content: "";
	background-color: #222222;
	background-repeat: no-repeat;
	background-size: contain;
	height: 35px;
	width: 35px;
	margin: auto;
}

/* 前に戻る画像パス */
.swiper-button-prev:after {
	background-image: url(../images_2023/hodinkee_arrow_prev.png);
}

/* 次に進む画像パス */
.swiper-button-next:after {
	background-image: url(../images_2023/hodinkee_arrow_next.png);
}

.swiper-button-prev:hover,
.swiper-button-next:hover {
	opacity: 0.7;
}

/* 解説（caption）のスタイル */
.caption {
	position: absolute;
	/* 絶対配置で配置 */
	bottom: -55px;
	/* 画像の下からの位置に配置 */
	left: 0;
	width: 100%;
	border-bottom: 1px solid #999999;
	color: rgb(204, 204, 204);
	padding: 10px 0 10px 10px;
	text-align: left;
}

@media screen and (max-width:600px) {
	.caption {
		font-size: 4vw;
		line-height: 1.2em;
	}
}
.articles-padding {
  padding-top: 98px;
  padding-bottom: 80px;
}
@media screen and (max-width: 1024px) {
  .articles-padding {
    padding-top: 75px;
	padding-bottom: 40px;
  } 
}