@charset "UTF-8";
/*----------------------------------------

	+ header
		- legacy
	+ content
		+ bgwrap
			+ bgmovie
				- mv
			- mvtitle
			- bgcover
			- openyt
			- mvlist1
			- mvlist2
		- concept
		- slider
	+ aside_wrapper
		+ aside
			- bnr01
			- bnr02
			- bnr03
		- copy
	+ footer
		- pagetop
		- sns

-----------------------------------------*/

/*----------------------------------------
	legacy
-----------------------------------------*/
#legacy {
	padding: 23px 50px 22px;
	background-color: #3d434a;
}

#legacy p {
	text-align: center;
	line-height: 2;
}

/*----------------------------------------
	header
-----------------------------------------*/
header {
	z-index: 10;
	position: absolute;
	height: 1px;
	width: 100%;
	transition: all 0.3s;
}

header h1 {
	width: 73px;
	margin: 22px auto 0;
	transition: all 0.3s;
}

@media screen and (min-width: 768px) and (max-width: 1100px) {
	header h1 {
		width: calc(73px * 0.7);
	}
}

@media screen and (max-width: 767px) {
	header h1 {
		width: calc(73px * 0.35);
		margin-top: 11px;
	}
}

/*----------------------------------------
	content
-----------------------------------------*/
#content {
	overflow: hidden;
	position: relative;
	margin: 0 auto;
	padding-bottom: 100px;
}

@media screen and (max-width: 768px) {
	#content {
		padding-bottom: 40px;
	}
}

/*----------------------------------------
	bgwrap
-----------------------------------------*/
#bgwrap {
	position: relative;
	overflow: hidden;
	min-width: 100%;
	min-height: 100%;
}

#bgmovie {
	position: relative;
	height: 56.25vw;
	width: 100vw;
	background-color: #000;
}

#bgmovie.bg1 {
	background: #000 url(../img/mv_p01.jpg) no-repeat left top;
	background-size: cover;
}

#bgmovie.bg2 {
	background: #000 url(../img/mv_p02.jpg) no-repeat left top;
	background-size: cover;
}

#bgmovie.bg3 {
	background: #000 url(../img/mv_p03.jpg) no-repeat left top;
	background-size: cover;
}

#bgmovie.bg4 {
	background: #000 url(../img/mv_p04.jpg) no-repeat left top;
	background-size: cover;
}

#mv {
	width: 100%;
	height: 100%;
	opacity: 0;
}

#bgcover {
	display: flex;
	justify-content: center;
	align-items: flex-end;
	position: absolute;
	top: 0;
	left: 0;
	height: 56.25vw;
	width: 100vw;
}

#bgcover a {
	display: none;
	height: 50px;
	width: 50px;
	margin-bottom: 20%;
	transition: all 0.3s;
}

#bgcover a img {
	height: auto;
	width: 100%;
}

@media screen and (max-width: 768px) {
	#bgcover a {
		display: none;
		height: 39px;
		width: 39px;
		margin-bottom: 14.6%;
	}
}

@media screen and (max-width: 375px) {
	#bgcover a {
		margin-bottom: 14.5%;
	}
}

@media screen and (max-width: 374px) {
	#bgcover a {
		height: 25px;
		width: 25px;
		margin-bottom: 14%;
	}
}

/*----------------------------------------
	mvtitle
-----------------------------------------*/
#mvtitle {
	position: absolute;
	bottom: 40.2%;
	left: 68px;
	width: 261px;
	transition: all 0.3s;
}

#mvtitle img {
	height: auto;
	width: 100%;
	transition: all 0.3s;
}

@media screen and (min-width: 768px) and (max-width: 1100px) {
	#mvtitle {
		bottom: 32%;
		left: calc(50px*0.7);
		width: calc(287px*0.7);
	}
}

@media screen and (max-width: 767px) {
	#mvtitle {
		bottom: 61%;
		left: calc(50px*0.5);
		width: calc(287px*0.5);
	}
}

@media screen and (max-width: 425px) {
	#mvtitle {
		bottom: 66.5%;
		left: calc(49.8px*0.24);
		width: calc(287px*0.3);
	}
}

/*----------------------------------------
	mvlist1
-----------------------------------------*/

#mvlist1 {
	display: flex;
	justify-content: center;
	align-items: flex-end;
	position: absolute;
	top: 39px;
	right: 210px;
	height: 30px;
	margin-top: 0;
	transition: all 0.3s;
}

#mvlist1 li+li {
	margin-left: 40px;
	transition: all 0.3s;
}

#mvlist1 li:nth-of-type(3) a>img {
	padding: 1px 0 0;
}

#mvlist1 li a {
	display: block;
	position: relative;
	height: 30px;
}

#mvlist1 li a>img {
	display: block;
	height: auto;
	width: 100%;
	transition: all 0.3s;
}

#mvlist1 li a:hover>img {
	opacity: 0.6;
}

#mvlist1 li a::before {
	content: "";
	display: block;
	position: absolute;
	top: -10px;
	left: 50%;
	width: 0;
	height: 4px;
	background: #c1b69f;
	background: var(--brown02-color);
	transform: translateX(-50%);
	transition: .5s all;
}

#mvlist1 li a:hover::before {
	width: 100%;
}

#mvlist1 li a.active::before {
	width: 100%;
}

@media screen and (min-width: 1101px) and (max-width: 1499px) {
	#mvlist1 {
		right: 7vw;
	}

	#mvlist1 li+li {
		margin-left: 2vw;
	}
}

@media screen and (min-width: 831px) and (max-width: 1100px) {
	#mvlist1 {
		right: 70px;
		margin-top: -3px;
		transform: scale(0.8);
		-ms-transform-origin: top right;
		transform-origin: top right;
	}

	#mvlist1 li+li {
		margin-left: 2vw;
	}
}

@media screen and (min-width: 769px) and (max-width: 830px) {
	#mvlist1 {
		right: 70px;
		margin-top: -3px;
		transform: scale(0.7);
		-ms-transform-origin: top right;
		transform-origin: top right;
	}

	#mvlist1 li+li {
		margin-left: 2vw;
	}
}

@media screen and (max-width: 768px) {
	#mvlist1 {
		display: none;
	}
}

/*----------------------------------------
	mvlist2
-----------------------------------------*/

#mvlist2 {
	display: flex;
	justify-content: center;
	align-items: stretch;
	flex-wrap: wrap;
}

#mvlist2 li {
	flex-basis: 25%;
}

#mvlist2 li a {
	display: block;
	position: relative;
	background-color: #000;
	background-color: var(--black01-color);
}

#mvlist2 li a>img {
	display: block;
	height: auto;
	width: 100%;
	opacity: 0.6;
}

#mvlist2 li a span {
	display: block;
	position: absolute;
	top: 0;
	left: 50%;
	height: inherit;
	width: 24%;
	margin-left: -12%;
	background: none;
}

#mvlist2 li a span img {
	position: absolute;
	top: 0;
	opacity: 1;
	transition: all 0.4s;
	-webkit-backface-visibility: hidden;
}

#mvlist2 li a span img+img {
	opacity: 0;
	transition: all 0.4s;
}

#mvlist2 li a:hover span img {
	opacity: 0;
}

#mvlist2 li a:hover span img+img {
	opacity: 1;
}

#mvlist2 li a.active span img {
	opacity: 0;
}

#mvlist2 li a.active span img+img {
	opacity: 1;
}

@media screen and (max-width: 767px) {
	#mvlist2 li {
		flex-basis: 50%;
	}
}

/*----------------------------------------
	openyt
-----------------------------------------*/

#openyt {
	z-index: 1000;
	position: absolute;
	top: 0;
	right: 0;
	transition: all 0.3s;
}

#openyt a {
	display: flex;
	align-items: center;
	width: 60px;
	height: 211px;
	border-left: 1px solid #c1b69f;
	border-left: 1px solid var(--brown02-color);
	background: url(../img/open_yt01.png) no-repeat center top 32px;
	background-size: 33px 23px;
	color: #c1b69f;
	color: var(--brown02-color);
	transition: all 0.3s;
}

#openyt a:link,
#openyt a:active,
#openyt a:hover,
#openyt a:visited {
	color: #c1b69f;
	color: var(--brown02-color);
	text-decoration: none;
}

#openyt a:hover {
	opacity: 0.5;
}

#openyt.nontransparent a:hover {
	opacity: 1;
}

#openyt a span {
	display: block;
	position: absolute;
	top: 67px;
	left: 38px;
	height: 1em;
	width: 10em;
	line-height: 1;
	letter-spacing: 0.6px;
	transform: rotate(90deg) scale(1.1);
	transform-origin: top left;
}

/* IE11 のみ適用される */
_:-ms-lang(x)::-ms-backdrop, #openyt a span.hack{
	margin-top: -4px;
}

@media screen and (max-width: 1100px) {
	#openyt {
		transform: scale(0.85);
		transform-origin: top right;
	}
}

@media screen and (max-width: 767px) {
	#openyt {
		top: calc(100vw*0.48);
		transform: scale(1);
	}

	#openyt a {
		height: 25px;
		width: 113px;
		border-left: none;
		background-position: center right 9px;
		background-size: 16px 11px;
	}

	#openyt a span {
		top: auto;
		top: initial;
		left: auto;
		left: initial;
		letter-spacing: 0.5px;
		transform: rotate(0deg) scale(1);
	}
}

@media screen and (min-width: 426px) and (max-width: 767px) {
	#openyt {
		top: calc(100vw*0.467);
		transform: scale(1.3);
	}
}

/*----------------------------------------
	mutebtn
-----------------------------------------*/

#mutebtn {
	z-index: 1001;
	position: absolute;
	top: 241px;
	right: 13px;
	height: 33px;
	width: 33px;
	outline: none;
	cursor: pointer;
	transition: all 0.3s;
}

#mutebtn:hover {
	opacity: 0.5;
}

@media screen and (max-width: 1100px) {
	#mutebtn {
		top: calc(241px*0.85);
		right: calc(13px*0.85);
	}
}

@media screen and (max-width: 767px) {
	#mutebtn {
		top: 10px;
		right: 10px;
	}
}

@media screen and (max-width: 425px) {
	#mutebtn {
		top: 7px;
		right: 7px;
		height: 25px;
		width: 25px;
	}
}

/*----------------------------------------
	concept
-----------------------------------------*/
#concept {
	background: url(../img/concept_bg01.jpg) no-repeat center center;
	background-size: cover;
}

#concept div {
	max-width: 1200px;
	width: 100%;
	min-height: 750px;
	margin: 0 auto;
	padding: 191px 0 210px;
	box-sizing: border-box;
	text-align: center;
	transition: all 0.6s;
}

#concept div h1 {
	margin-bottom: 16px;
	padding: 0 0 176px 20px;
	background: url(../img/concept_t01.png) no-repeat left calc(50% - 10px) bottom 5px;
	background-size: 510px 154px;
	letter-spacing: 0.06em;
}

#concept div p {
	padding-left: 1px;
	line-height: 2;
}

@media screen and (max-width: 767px) {
	#concept {
		background: #fff url(../img/concept_bg01.jpg) no-repeat center bottom;
		background-size: 100%;
	}

	#concept div {
		min-height: auto;
		min-height: initial;
		height: auto;
		width: 85%;
		padding: 46px 0 50px;
	}

	#concept div h1 {
		margin-bottom: 8px;
		padding: 0 0 91px;
		background: url(../img/concept_t01.png) no-repeat left 50% bottom 4px;
		background-size: 255px 78px;
		letter-spacing: normal;
	}

	#concept div p {
		padding-left: 0;
		line-height: 1.5;
	}

	#concept div p br {
		display: none;
	}
}

/*----------------------------------------
	slider
-----------------------------------------*/
#slider {
	overflow-x: hidden;
}

.container {
	position: relative;
	margin-left: auto;
	margin-right: auto;
	max-width: 1200px;
	width: 80%;
}

.swiper-container {
	z-index: 1;
	overflow: visible;
	width: 100%;
	height: 100%;
}

.swiper-pagination {
	position: static;
	margin-top: 30px;
}

.swiper-pagination-bullet {
	width: 21px;
	height: 21px;
	background: #ede9e2;
	background: var(--brown01-color);
	margin-left: 9px;
	opacity: 1;
	outline: none;
}

.swiper-pagination-bullet:first-child {
	margin-left: 0;
}

.swiper-pagination-bullet-active {
	background: #6e2855;
	background: var(--purple01-color);
}

@media screen and (max-width: 767px) {
	.swiper-pagination {
		position: static;
		margin-top: 20px;
	}

	.swiper-pagination-bullet {
		width: 15px;
		height: 15px;
		margin-left: 10px;
	}
}

/*----------------------------------------
	aside_wrapper
-----------------------------------------*/
@media screen and (max-width: 768px) {
	#aside_wrapper {
		position: relative;
	}
}

/*----------------------------------------
	aside
-----------------------------------------*/
aside {
	position: relative;
	top: 0;
	left: 0;
	max-width: 1200px;
	min-width: 320px;
	width: 100%;
	margin: 51px auto 0;
	padding-top: 30px;
	transition: all .3s ease-in-out;
	overflow: hidden;
}

/* オフィシャルリンク バナー ロゴ周り */
aside::before {
	content: "";
	position: absolute;
	top: 0;
	left: calc(50% - 1px);
	width: 1px;
	height: 120px;
	background: #ede9e2;
	background: var(--brown01-color);
	transition: all .3s ease-in-out;
	z-index: 10;
}

aside h1 {
	position: absolute;
	top: 141px;
	left: 373px;
	z-index: 1;
	-moz-user-select: none;
	-webkit-user-select: none;
	-ms-user-select: none;
	user-select: none;
	transition: all .3s ease-in-out;
}

aside h1 img {
	-webkit-user-drag: none;
	-khtml-user-drag: none;
}

/* オフィシャルリンク バナー */
aside ul li:nth-child(1) {
	margin-top: 173px;
	transition: all .3s ease-in-out;
}

aside ul li:nth-child(2) {
	margin-top: 80px;
	transition: all .3s ease-in-out;
}

aside ul li:nth-child(3) {
	margin-top: 79px;
	transition: all .3s ease-in-out;
}

aside ul li div {
	width: 100%;
	height: calc(1200px*0.392);
}

aside ul li div a {
	height: inherit;
	-moz-user-select: none;
	-webkit-user-select: none;
	-ms-user-select: none;
	user-select: none;
}

aside ul li div a:hover {
	text-decoration: none;
}

/* オフィシャルリンク バナー テキストボックス */
aside ul li div a p {
	position: relative;
	width: 500px;
	height: 200px;
	background: #6e2855;
	background: var(--purple01-color);
	transition: all .3s ease-in-out;
}

aside ul li div a:hover p {
	background: #ede9e2;
	background: var(--brown01-color);
}

/* ＞ */
aside ul li div a p::before {
	content: "";
	position: absolute;
	right: 37px;
	bottom: -11px;
	width: 82px;
	height: 82px;
	border-top: 1px solid #a79d89;
	border-top: 1px solid var(--brown03-color);
	transform: rotate(45deg);
}

aside ul li div a p::after {
	content: "";
	position: absolute;
	right: 20px;
	bottom: 30px;
	width: 460px;
	height: 1px;
	background: #a79d89;
	background: var(--brown03-color);
}

aside ul li div a p span {
	display: block;
	font-feature-settings : 'palt';
}

aside ul li div a p span span {
	text-align: center;
	transition: all .3s ease-in-out;
}

aside ul li div a p span span:first-child::before {
	content: "";
	position: absolute;
	top: 0;
	left: calc(50% - 7px);
	width: 14px;
	height: 14px;
	background: #a79d89;
	background: var(--brown03-color);
}

aside ul li div a:hover p span span:nth-child(2) {
	color: #202020;
	color: var(--black02-color);
}

/* オフィシャルリンク バナー 個別設定 */
aside ul li#bnr01 {
	position: relative;
}

aside ul li#bnr01::before {
	content: "";
	position: absolute;
	top: -173px;
	left: 178px;
	width: 661px;
	height: 710px;
	background: url(../img/bnr_map01.png) no-repeat left top;
	pointer-events: none;
	transition: all .3s ease-in-out;
	z-index: 2;
}

aside ul li#bnr01 div::before {
	bottom: 67px;
}

aside ul li#bnr01 div::after {
	top: 173px;
}

aside ul li#bnr01 div a {
	display: flex;
	justify-content: flex-end;
	align-items: center;
	position: relative;
	background: url(../img/bnr_bg01.jpg) no-repeat center top;
	background-size: contain;
}

aside ul li#bnr01 div a p {
	position: relative;
	margin-top: -31px;
	z-index: 3;
}

aside ul li#bnr01 div a p > span {
	padding-top: 25px;
}

aside ul li#bnr01 div a p > span span:first-child {
	width: 77px;
	margin: 0 auto;
	padding-left: 3px;
}

aside ul li#bnr01 div a p > span span:nth-child(2) {
	position: relative;
	margin-top: 68px;
	letter-spacing: 0.7px;
}

aside ul li#bnr02 div a {
	display: flex;
	justify-content: flex-start;
	align-items: center;
	background: url(../img/bnr_bg02.jpg) no-repeat center top;
	background-size: contain;
}

aside ul li#bnr02 div a p {
	margin-bottom: -30px;
	z-index: 3;
}

aside ul li#bnr02 div a p > span {
	padding-top: 25px;
}

aside ul li#bnr02 div a p > span span:first-child {
	width: 290px;
	margin: 0 auto;
}

aside ul li#bnr02 div a p > span span:nth-child(2) {
	position: relative;
	margin-top: 68px;
}

aside ul li#bnr03 div a {
	display: flex;
	justify-content: flex-end;
	align-items: center;
	background: url(../img/bnr_bg03.jpg) no-repeat center top;
	background-size: contain;
}

aside ul li#bnr03 div a p {
	margin-top: -31px;
	z-index: 3;
}

aside ul li#bnr03 div a p > span {
	padding-top: 25px;
}

aside ul li#bnr03 div a p > span span:first-child {
	width: 188px;
	margin: 0 auto;
}

aside ul li#bnr03 div a p > span span:nth-child(2) {
	position: relative;
	margin-top: 68px;
}

aside ul li#bnr03 div a p>span span:nth-child(2)::before {
	left: calc(50% - 17px);
}

@media screen and (max-width: 1200px) {
	aside h1 {
		right: 50%;
		left: auto;
	}

	/* オフィシャルリンク バナー ロゴ周り */
	aside ul li:nth-child(n+2) {
		margin-top: 80px;
	}

	aside ul li div {
		width: 100%;
		height: calc(100vw*0.392);
	}

	aside ul li div a:hover p {
		background: #6e2855;
		background: var(--purple01-color);
	}
	aside ul li div a:hover p span span:nth-child(2) {
		color: #fff;
		color: var(--white01-color);
	}
}

@media screen and (max-width: 1000px) {
	/* オフィシャルリンク バナー 日本地図 */
	aside ul li#bnr01::before {
		left: calc(50% - 210px);
		width: calc(661px * 0.7);
		height: calc(710px * 0.7);
		background-size: contain;
	}

	aside ul li:nth-child(n+2) {
		margin-top: 40px;
	}

	aside ul li div a p {
		transform: scale(0.65);
		transform-origin: right center;
	}

	aside ul li#bnr02 div a p {
		transform-origin: left center;
	}
}

@media screen and (max-width: 768px) {
	aside {
		margin-top: 7px;
		padding: 30px 0 123px;
		overflow: visible;
	}
}

@media screen and (max-width: 767px) {
	aside::before {
		top: 14px;
		height: 60px;
	}

	aside h1 {
		top: 80px;
		left: calc(50% - 113px);
	}

	aside h1 img {
		width: calc(226px/2);
		height: auto;
	}

	/* オフィシャルリンク バナー */
	aside ul li:nth-child(1) {
		margin-top: 83px;
	}

	aside ul li:nth-child(2) {
		margin-top: 102px;
	}

	aside ul li:nth-child(3) {
		margin-top: 102px;
	}

	aside ul li div a {
		align-items: flex-end;
	}

	aside ul li#bnr03 div a p>span span:nth-child(2)::before {
		left: calc(50% - 9px);
	}
}

@media screen and (max-width: 660px) {
	aside ul li div a p {
		width: 250px;
		height: 100px;
		transform: scale(1)
	}

	aside ul li div a p::before {
		right: 19px;
		bottom: -5px;
		width: 41px;
		height: 41px;
	}

	aside ul li div a p::after {
		right: 10px;
		bottom: 15px;
		width: 230px;
	}

	aside ul li div a p span span:first-child::before {
		left: calc(50% - (7px/2));
		width: 7px;
		height: 7px;
	}

	aside ul li div a p span span:nth-child(2)::before {
		left: calc(50% - 7px);
		width: 15px;
		height: 3px;
	}

	aside ul li#bnr01 div a p {
		margin: 0 0 -170px;
	}

	aside ul li#bnr01 div a p > span {
		padding-top: 12px;
	}

	aside ul li#bnr01 div a p > span span:first-child {
		width: calc(77px/2);
		height: auto;
		padding-left: 0;
		line-height: 1;
	}

	aside ul li#bnr01 div a p>span span:nth-child(2) {
		margin-top: 34px;
		letter-spacing: 0.2px;
	}

	aside ul li#bnr02 div a p {
		margin-bottom: -170px;
	}

	aside ul li#bnr02 div a p > span {
		padding-top: 12px;
	}

	aside ul li#bnr02 div a p>span span:first-child {
		width: 145px;
		height: auto;
		line-height: 1;
	}

	aside ul li#bnr02 div a p>span span:nth-child(2) {
		margin-top: 34px;
		letter-spacing: 0.2px;
	}

	aside ul li#bnr03 div a p {
		margin: 0 0 -170px;
	}

	aside ul li#bnr03 div a p > span {
		padding-top: 12px;
	}

	aside ul li#bnr03 div a p>span span:first-child {
		width: 94px;
		height: auto;
		line-height: 1;
	}

	aside ul li#bnr03 div a p>span span:nth-child(2) {
		margin-top: 34px;
		letter-spacing: 0.2px;
	}
}

@media screen and (max-width: 426px) {
	aside ul li#bnr01::before {
		top: -125px;
		right: -15px;
		left: auto;
		width: calc(661px * 0.4);
		height: calc(710px * 0.4);
		background-size: contain;
	}
}

@media screen and (max-width: 374px) {
	aside ul li#bnr01 div a p {
		margin-bottom: -160px;
	}

	aside ul li#bnr02 div a p {
		margin-bottom: -160px;
	}

	aside ul li#bnr03 div a p {
		margin-bottom: -160px;
	}
}

/*----------------------------------------
	copy
-----------------------------------------*/
#copy {
	display: block;
	position: absolute;
	bottom: 160px;
	left: -101px;
	transform: rotate(90deg);
	-moz-user-select: none;
	-webkit-user-select: none;
	-ms-user-select: none;
	user-select: none;
}

@media screen and (max-width: 768px) {
	#copy {
		bottom: 80px;
		left: -50px;
	}

	#copy span {
		display: block;
	}
}

@media screen and (max-width: 426px) {
	#copy {
		bottom: 68px;
		left: -48px;
	}
}

@media screen and (max-width: 320px) {
	#copy {
		bottom: 65px;
	}
}

/*----------------------------------------
	archive_bnr
-----------------------------------------*/
#archive_bnr {
	max-width: 1200px;
	min-width: 320px;
	width: 100%;
	margin: 100px auto 0;
}

#archive_bnr > li:nth-child(n+2) {
	margin-top: 10px;
}

#archive_bnr > li > a {
	display: block;
	transition: all .3s ease-in-out;
}

#archive_bnr > li > a:hover {
	opacity: 0.5;
}

@media screen and (max-width: 1200px) {
	#archive_bnr > li > a:hover {
		opacity: 1;
	}
}

@media screen and (max-width: 768px) {
	#archive_bnr {
		margin-top: 0;
	}

	#archive_bnr > li:nth-child(n+2) {
		margin-top: 5px;
	}
}

/*----------------------------------------
	footer
-----------------------------------------*/
footer {
	overflow: hidden;
	position: relative;
	width: 100%;
	padding: 40px 0 54px;
	background-color: #3d434a;
	background: var(--gray05-color);
}

footer::before {
	content: '';
	display: block;
	height: 120px;
	width: 1px;
	margin-left: 50%;
	background-color: #6f757c;
}

footer p#pagetop {
	position: absolute;
	right: 0;
	bottom: 0;
	height: 201px;
	width: 36px;
	padding-right: 25px;
	border-left: 1px solid #cad0d7;
	border-left: 1px solid var(--gray04-color);
	transition: all 0.3s;
	cursor: pointer;
}

footer p#pagetop:hover {
	opacity: 0.5;
}

footer p#pagetop.nontransparent:hover {
	opacity: 1;
}

footer p#pagetop::before {
	content: '';
	display: block;
	position: absolute;
	top: 0;
	left: 0;
	height: 1px;
	width: 27px;
	border-left: 1px solid #cad0d7;
	border-left: 1px solid var(--gray04-color);
	background-color: #fff;
	background: var(--white01-color);
	transform: rotate(45deg);
	transform-origin: left top;
}

footer p#pagetop span {
	display: block;
	position: absolute;
	top: 40px;
	left: 26px;
	height: 1em;
	width: 8em;
	color: #cad0d7;
	color: var(--gray04-color);
	line-height: 1;
	letter-spacing: 0.7px;
	transform: rotate(90deg);
	transform-origin: top left;
}

footer div {
	max-width: 738px;
	width: 100%;
	margin: 0 auto;
	padding-top: 36px;
}

footer div p:nth-of-type(1) a {
	display: flex;
	justify-content: center;
	text-decoration: none;
	transition: all 0.3s;
}

footer div p:nth-of-type(1) a::before {
	content: '';
	display: inline-block;
	height: 25px;
	width: 25px;
	margin-right: 10px;
	background: url(../img/f_arrow01.png) no-repeat center center;
	background-size: 25px 25px;
}

footer div p:nth-of-type(1) a:hover {
	opacity: 0.5;
}

footer div p:nth-of-type(1) a span {
	display: inline-block;
	line-height: 1.1;
	letter-spacing: 2.7px;
	font-feature-settings: 'palt';
}

footer div ul {
	margin-top: 80px;
	padding: 6px;
	background-color: #fff;
	background-color: var(--white01-color);
}

footer div ul li {
	float: left;
}

footer div ul li+li {
	margin-left: 6px;
}

footer div ul li a {
	display: flex;
	justify-content: flex-start;
	align-items: center;
	height: 128px;
	width: 238px;
	background-color: #3d434a;
	background-color: var(--gray05-color);
}

footer div ul li span {
	display: block;
}

footer div ul li:nth-of-type(1) span:first-child {
	height: 23px;
	width: 23px;
	margin: 0 20px 0 28px;
}

footer div ul li:nth-of-type(2) span:first-child {
	height: 23px;
	width: 33px;
	margin: 0 20px 0 28px;
}

footer div ul li:nth-of-type(3) span:first-child {
	height: 24px;
	width: 24px;
	margin: 0 20px 0 28px;
}

footer div p:nth-of-type(2) {
	margin-top: 97px;
	text-align: center;
	color: #fff;
	color: var(--white01-color);
}

footer div p:nth-of-type(1) a {
	display: flex;
	justify-content: center;
	text-decoration: none;
	transition: all 0.3s;
}

footer div p.font22_16.nontransparent a:hover {
	opacity: 1;
}

footer #sns.nontransparent a:hover {
	background-color: #3d434a;
	background-color: var(--gray05-color);
}

footer #sns.nontransparent a:hover {
	opacity: 1;
}

@media screen and (max-width: 767px) {
	footer {
		width: 100%;
		padding: 10px 0 47px;
		background-color: #3d434a;
		background-color: var(--gray05-color);
	}

	footer::before {
		display: none;
	}

	footer p#pagetop {
		padding-right: 0;
	}

	footer div {
		padding-top: 41px;
	}

	footer div p:nth-of-type(1) a::before {
		height: 15px;
		width: 15px;
		margin-bottom: -2px;
		margin-right: 6px;
		background-size: 100% 100%;
	}

	footer div p:nth-of-type(1) a span {
		letter-spacing: 1.9px;
	}

	footer div ul {
		display: flex;
		justify-content: center;
		align-items: center;
		margin-top: 99px;
		padding: 0;
		background-color: #3d434a;
		background-color: var(--gray05-color);
	}

	footer div ul li+li {
		margin-left: 0;
	}

	footer div ul li:nth-of-type(2) {
		margin: 0 30px 0 31px;
	}

	footer div ul li a {
		display: block;
		height: auto;
		width: auto;
		background-color: none;
	}

	footer div ul li a span {
		display: block;
	}

	footer div ul li a span+span {
		display: none;
	}

	footer div ul li:nth-of-type(1) a span:first-child {
		height: 23px;
		width: 23px;
		margin: 0;
	}

	footer div ul li:nth-of-type(2) a span:first-child {
		height: 23px;
		width: 33px;
		margin: 0;
	}

	footer div ul li:nth-of-type(3) a span:first-child {
		height: 24px;
		width: 24px;
		margin: 0;
	}

	footer div p:nth-of-type(2) {
		margin-top: 46px;
	}
}