@charset "utf-8";
body,div,dl,dt,dd,ul,ol,li,p,h1,h2,h3,h4,h5,h6,th,td,pre,code,blockquote,form,fieldset,legend,input,textarea,figcaption,figure{margin:0;padding:0}table{border-collapse:collapse;border-spacing:0}fieldset,img{border:0}address,caption,cite,code,dfn,em,th,var{font-style:normal;font-weight:normal}li{list-style:none}caption,th{text-align:left}h1,h2,h3,h4,h5,h6{font-size:100%;font-weight:normal}q:before,q:after{content:''}abbr,acronym{border:0;font-variant:normal}sup{vertical-align:text-top}sub{vertical-align:text-bottom}input,textarea,select{font-family:inherit;font-size:inherit;font-weight:inherit}input,textarea,select{*font-size:100%}legend{color:#FFF}hr{display:none}img{vertical-align:bottom;width: 100%}select,input,button,textarea{font-size:99%}table{font-size:inherit;font:100%;border-collapse:collapse;border-spacing:0}pre,code,kbd,samp,tt{font-family:monospace;*font-size:108%;line-height:100%}.hd{display:block;width:0;height:0;overflow:hidden}.cf:before,.cf:after{content:"";display:table}.cf:after{clear:both}.cf{*zoom:1}article,aside,details,figcaption,figure,footer,header,hgroup,hr,menu,nav,section,main{display:block}*{margin:0;padding:0;box-sizing:border-box;max-height:999999px;outline:none;}*:focus{outline: none;}button{background-color:transparent;border:none;cursor:pointer;outline:none;padding:0;}
/*-----------------------------------------------
 * Bace
 * common
 * Modal
 * Header
 * Parts
-------------------------------------------------*/
/*-----------------------------------------------
 * Bace
-------------------------------------------------*/
:root{
	/* color */
	--color-yellow: #b69848;
	--color-red: #C40002;
	--color-gray: #444444;

	/* font */
	--font-en: "Fraunces", serif;

	/* sp-size */
	--sp-size-2: min(0.2667vw, 2px);
	--sp-size-4: min(0.5334vw, 4px);
	--sp-size-8: min(1.0667vw, 8px);
	--sp-size-10: min(1.3334vw, 10px);
	--sp-size-12: min(1.6vw, 12px);
	--sp-size-16: min(2.1334vw, 16px);
	--sp-size-20: min(2.6667vw, 20px);
	--sp-size-24: min(3.2vw, 24px);
	--sp-size-26: min(3.4667vw, 26px);
	--sp-size-28: min(3.7334vw, 28px);
	--sp-size-30: min(4vw, 30px);
	--sp-size-32: min(4.2667vw, 32px);
	--sp-size-36: min(4.8vw, 36px);
	--sp-size-40: min(5.3334vw, 40px);
	--sp-size-48: min(6.4vw, 48px);
	--sp-size-56: min(7.4667vw, 56px);
	--sp-size-64: min(8.5334vw, 64px);
	--sp-size-72: min(9.6vw, 72px);
	--sp-size-80: min(10.6667vw, 80px);
	--sp-size-96: min(12.8vw, 96px);
	--sp-size-192: min(25.6vw, 192px);

		/* vw min 計算 => min(calc(数値 / var(--vw-min) * 100vw), 数値); */
		--vw-min: 1290;
	}
	
	@media screen and (max-width:767px) {
		:root {
			/* vw min 計算 => min(calc(数値 / var(--vw-min) * 100vw), 数値); */
			--vw-min: 750;
		}
	}
html{overflow-y: scroll;}
body{
	-webkit-text-size-adjust: 100%;
	background-color: #000;
	color: #fff;
	font-family: "Noto Serif JP", serif;
	font-weight: 400;
	font-style: normal;
	font-size: 16px;
	letter-spacing: 0.07em;
	line-height: 1;
	word-wrap: break-word;
}
.pc{ display: block; }
.sp{ display: none; }
a{ color: #222; text-decoration: none; }
a:hover{ text-decoration: none; }
.ah { transition: opacity .3s ease; }
.ah:hover { opacity: .7; }
::selection{
	background: #6ccfee;
	color: #fff;
}
::-moz-selection{
	background: #6ccfee;
	color:#fff;
}
@media screen and (max-width:767px){ 
	html{ 
		font-size: 62.5%;
	}
	body{
		font-size: 10px; 
		font-size: 1rem;
		min-width: 320px;
	}
	.sp{ display: block; }
	.pc{ display: none; }
	.ah:hover { opacity: 1; }
}

/*---------------------------------
* common
----------------------------------*/
#fullWrap{
	background-color: #000;
}
/* sub BG */
.sub_bg{
	z-index: 0;
	opacity: 0;
	filter: blur(10px);
	transition: all .6s ease;
}
.-loaded .sub_bg{
	opacity: 1;
	filter: blur(0);
}

/* page loading */
.-fade{
	opacity: 0;
	transform: translateY(calc(20 / var(--vw-min) * 100vw));
	transition: all .6s ease;
}
.-fade.is-ani{
    opacity: 1;
    transform: translateY(0);
}

/* X */
.officialX_link{
	position: absolute;
	right: min(calc(30 / var(--vw-min) * 100vw),30px);
	top: min(calc(70 / var(--vw-min) * 100vw),70px);
	z-index: 1;
}
@media screen and (max-width:768px) {
	.officialX_link.sp{
		position: relative;
		right:unset;
		top: unset;
		z-index: 1;
		display: flex;
        justify-content: center;
		margin-bottom: calc(60 / var(--vw-min) * 100vw);
	}
}
.officialX_link a{
	display: flex;
	width:min(calc(180 / var(--vw-min) * 100vw),180px);
    justify-content: space-between;
}
.officialX_link-text{
	display: inline-block;
	position: relative;
	color: #FFF;
	font-size: min(calc(24 / var(--vw-min) * 100vw),24px);
	line-height: 1.3;
	transition: all .4s ease;
	letter-spacing: normal;
	font-family: var(--font-en);
}
.officialX_link-text::after{
	display: block;
	content: "";
	position: absolute;
	bottom: 0;
	width: 100%;
	height: 1px;
	background-color: #FFF;
}
/*arrow*/
.officialX_link-arrow{
    position: relative;
    width: min(calc(28 / var(--vw-min) * 100vw),28px);
}
.officialX_link-arrow::before{
    content: "";
    position: absolute;
    margin: auto;
    top: 0;
    bottom: 0;
    left: 0;
    width: 100%;
    height: 1px;
    background-color:#FFF;
}
.officialX_link-arrow::after{
    content: "";
    position: absolute;
    margin: auto;
    top: 0;
    bottom: 0;
    right: 0;
    width: 5px;
    height: 5px;
    border-radius: 50%;
    background-color:#FFF;
    transition: all .4s ease;
}
@media screen and (max-width:768px) {
    .officialX_link-arrow::after{
        width: calc(5 / var(--vw-min) * 100vw);
        height: calc(5 / var(--vw-min) * 100vw);
    }
}
/*hover*/
.officialX_link:hover .officialX_link-text{
    transform: translateX(5px);
}
.officialX_link:hover .officialX_link-arrow::after{
    right: 100%;
}
@media screen and (max-width:768px) {
	.officialX_link:hover .officialX_link-text{
		transform: translateX(calc(5 / var(--vw-min) * 100vw));
	}
}

/*-----------------------------------------------
 * Modal
-------------------------------------------------*/
/**
 * modalBox
 * 基盤のモーダル
 */
.modalBox{
	-webkit-overflow-scrolling: touch;
	background:#000 url(../img/common/modal_bg.jpg) no-repeat center bottom /cover;
	display: none;
	width: 100%;
	height: 100%;
	overflow: auto;
	position: fixed;
	top: 0;
	left: 0;
	z-index: 9999;
}
@media screen and (max-width:767px){
	.modalBox{
		background:#000 url(../img/common/modal_bg_sp.jpg) no-repeat center bottom /cover;
	}
}
.oneModal{
	display: none;
	width: 100%;
	height: 100%;
	position: relative;
	z-index: 1;
}

/* oneModalIn */
.oneModalIn{
	display: flex;
	justify-content: center;
	align-items: center;
	height: auto;
	width: 100%;
	min-width: 100%;
	min-height: 100%;
	margin: 0 auto;
	position: relative;
}
.oneModalIn__cont{
	padding: 50px 0;
}
@media screen and (max-width:767px){
	.oneModalIn{
		min-width: 100%;
	}
	.oneModalIn__cont{
		width: 100%;
		padding: 100px 0;
	}
}

/**
 * closeBtn
 */
.closeBtn{
	width: min(calc(80 / var(--vw-min) * 100vw),80px);
	height: min(calc(30 / var(--vw-min) * 100vw),30px);
	position: absolute;
	top:min(calc(30 / var(--vw-min) * 100vw),30px);
	right: min(calc(30 / var(--vw-min) * 100vw),30px);
	z-index: 2;
	transition: all .4s ease;
}
@media screen and (max-width:767px){
	.closeBtn{
		width: calc(100 / var(--vw-min) * 100vw);
		height: calc(50 / var(--vw-min) * 100vw);
	}
}
.closeBtn a{
	display: block;
	width: 100%;
	height: 100%;
	position: relative;
}

.closeBtn a::before, .closeBtn a::after {
	content: "";
	position: absolute;
	top: 0;
	right: 0;
	left: 0;
	bottom: 0;
	margin: auto;
	width: 100%;
	height: 1px;
	background-color: #FFF;
	transition: all .4s ease;
}

.closeBtn a::before {
	transform: rotate(15deg);
}
.closeBtn a::after {
	transform: rotate(-15deg);
}
/*hover*/
.closeBtn:hover a::before {
	transform: rotate(10deg);
}
.closeBtn:hover a::after {
	transform: rotate(-10deg);
}

/**
 * iframe
 */
/* common */
.commonIframe{
	width: 100%;
	height: 100%;
	display: block;
}

/* youtube */
.youtubeIframeWrap {
	width: 70%;
	max-width: 159.993vh;
	position: relative;
}
@media screen and (max-width:767px){
	.youtubeIframeWrap {
		width: 100%;
		max-width: 100%;
	}
}
.youtubeIframeWrap:before{
	content: "";
	display: block;
	padding-top: 56.25%;
	z-index: 0;
}
.youtubeIframe{
	position: absolute;
	top: 0;
	left: 0;
	z-index: 1;
}

/*-----------------------------------------------
 * Header
-------------------------------------------------*/
.header {
	width: 100%;
	height: 100%;
	position: absolute;
    z-index: 800;
    z-index: 1001;
	pointer-events: none;
}

@media screen and (max-width:767px){
	.header {
		width: 100%;
		z-index: 910;
		position: fixed;
	}
}
/* headerWrap */
.headerWrap {
	width: 100%;
	position: absolute;
    top: 94vw;
	top: 0;
    right: 0;
    bottom: 0;
    left: 0;
}

.sub-fullWrapIn .headerWrap {
	top: 0;
}

@media screen and (max-width:767px){
	.headerWrap {
		top: 0;
	}
}

.headerWrap-sticky {
	position: sticky;
	top: 0;
}

/* inner */
/*
@media screen and (max-width:767px){*/
	.headerWrap-sticky {
		top: calc(50 / var(--vw-min)* 100vw)
	}
	
	.header__inner {
		-webkit-overflow-scrolling: touch;
		width: 50%;
		height: 100%;
		overflow: auto;
		position: fixed;
		top: 0;
		right: -50%;
		padding: calc(80 / var(--vw-min) * 100vw) 0;
		pointer-events: none;
		z-index: 1;
		transition: all .5s ease-in-out;
	}

	.header.is-active .header__inner {
		right: 0;
		pointer-events: auto;
	}

	.header__inner:before {
		content: "";
		background: rgba(0,0,0,.8);
		position: fixed;
		width: 50%;
		height: 100%;
		top: 0;
		right: -50%;
		z-index: 0;
		backdrop-filter: blur(8px);
		-webkit-backdrop-filter: blur(8px);
		transition: all .5s ease-in-out;
	}
	@media screen and (min-width: 769px) {
		.header__inner {
			width: 40%;
		}
		.header__inner:before {
			width: 40%;
		}
	}

	.header.is-active .header__inner::before {
		right: 0;
	}
/*}*/

/**
 * headerNav
 */

 .headerNav {
	height: min(calc(90 /var(--vw-min) * 100vw), 90px);
	display: flex;
    align-items: center;
    justify-content: center;
	background-color: rgba(0,0,0,.8);
	pointer-events: auto;
 }
/*
 @media screen and (max-width:767px){*/
	.headerNav {
		height: auto;
		display: block;
		position: relative;
		z-index: 1;
		background-color:transparent;
	 }
 /*}*/

 .headerNavLists {
	font-family: var(--font-en);
	display: flex;
	align-items: flex-end;
 }
/*
 @media screen and (max-width:767px){*/
	.headerNavLists {
		padding: calc(80 / var(--vw-min) * 100vw) calc(50 / var(--vw-min) * 100vw) 0 0; 
	 }
	/*}*/

 .headerNavLists__item {
	padding: 0 min(calc(12 / var(--vw-min) * 100vw), 12px);
 }

 .headerNavLists-logo {
	padding: 0 min(calc(28 / var(--vw-min) * 100vw), 28px);
 }

 .headerNavLists__item:nth-child(2) {
	padding: 0;
 }

 .headerNav-Link {
	height: min(calc(25 / var(--vw-min) * 100vw), 25px);
	color: #fff;
	overflow: hidden;
	position: relative;
	display: inline-block;
}

.headerNav-Link::before,
.headerNav-Link::after {
 content: '';
  position: absolute;
  width: 100%;
  left: 0;
}

.headerNav-Link::before {
	background-color: var(--color-red);
	height: 2px;
	bottom: 0;
	transform-origin: 100% 50%;
	transform: scaleX(0);
	transition: transform .3s cubic-bezier(0.76, 0, 0.24, 1);
  }
  
  .headerNav-Link::after {
	content: attr(data-replace);
	height: 100%;			
	top: 0;
	transform-origin: 100% 50%;
	transform: translate3d(200%, 0, 0);
	transition: transform .3s cubic-bezier(0.76, 0, 0.24, 1);
	color: var(--color-red)
  }
  
  .headerNav-Link:hover::before,
  .headerNavLists__item.is-active .headerNav-Link::before {
	transform-origin: 0% 50%;
	transform: scaleX(1);
  }

  .headerNav-Link:hover::after,
  .headerNavLists__item.is-active .headerNav-Link::after {
	transform: translate3d(0, 0, 0);
  }
  
  .headerNav-Link .navList__linkTxt {
	font-family: var(--font-en);
	display: inline-block;
	transition: transform .3s cubic-bezier(0.76, 0, 0.24, 1);
  }
  
  .headerNav-Link:hover .navList__linkTxt,
  .headerNavLists__item.is-active .headerNav-Link .navList__linkTxt {
	transform: translate3d(-200%, 0, 0);
  }

.headerNav-img {
	width: min(calc(150 / var(--vw-min) * 100vw), 150px);
	pointer-events: auto;
}

.headerNav-img img {
	pointer-events: none;
}

/*
@media screen and (max-width:767px){*/
	.headerNavLists {
		flex-direction: column;
		align-items: flex-end;
	}

	.headerNavLists__item {
		font-size: calc(38 / var(--vw-min) * 100vw);
		padding: 0;
		margin: calc(30 / var(--vw-min) * 100vw) 0;
	 }

	 .headerNavLists__item:last-child {
		margin-bottom: 0;
	 }

	 .headerNav-Link {
		height: calc(40 / var(--vw-min) * 100vw);
		color: #fff;
	}
/*}*/

/**
 * navBtn
 */
/*@media screen and (max-width:767px){*/
	.header__navBtnWrap {
		background-color: #000;
		width: calc(70 / var(--vw-min) * 100vw);
		height: calc(70 / var(--vw-min) * 100vw);
		position: absolute;
		top: 0;
		right: calc(50 / var(--vw-min) * 100vw);
		z-index: 1001;
		border: calc(2 / var(--vw-min) * 100vw) solid #fff;
		transform: rotate(45deg);
		transition: all .3s ease;
	}


	.header__navBtnWrap.js-menu.is-active {
		background-color: #fff;
	}

	.header__navBtn {
		display: flex;
		align-items: center;
		justify-content: center;
		width: 100%;
		height: 100%;
		position: relative;
		transform: rotate(-45deg);
		pointer-events: auto;
	}

	.header__navBtn__lineWrap {
		width: calc(32 / var(--vw-min) * 100vw);
		height: calc(13 / var(--vw-min) * 100vw);
		position: relative;
	}

	.header__navBtn--line {
		background-color: #fff;
		display: block;
		width: 100%;
		height: calc(2 / var(--vw-min) * 100vw);
		margin: auto;
		position: absolute;
		transition: all .3s ease;
	}
	@media screen and (min-width: 769px) {
		.header__navBtnWrap {
			width: 55px;
			height:  55px;
			border: 1px solid #fff;
		}
		.header__navBtn__lineWrap {
			width: 18px;
			height:6px;
		}
		.header__navBtn--line {
			height: 1px;
		}
		.headerNavLists__item {
			margin: 20px 0 0;
		}
	}

	.header__navBtn.js-menu.is-active .header__navBtn--line {
		background-color: var(--color-red);
	}

	.header__navBtn--line:nth-child(1) {
		top: 0;
	}

	.header__navBtn--line:nth-child(2) {
		bottom: 0;
	}

	.js-menu.is-active .header__navBtn--line:nth-child(1) {
		transform: rotate(25deg);
		top: 0;
		bottom: 0;
	}

	.js-menu.is-active .header__navBtn--line:nth-child(2) {
		transform: rotate(-25deg);
		top: 0;
		bottom: 0;
	}
/*}*/



/*-----------------------------------------------
 * footer
-------------------------------------------------*/

/*-----------------------------------------------
 * Parts
-------------------------------------------------*/

/**
 * shareLists
 */
.shareLists {
	display: flex;
	align-items: center;
}

/* item */
.shareLists__item {
	width: 60px;
	height: 60px;
}

/* link */
.shareLists__link {
	display: flex;
	align-items: center;
	justify-content: center;
	width: 100%;
	height: 100%;
	position: relative;
	text-decoration: none;
}
.shareLists__link:before {
	content: "";
	background-color: #fff;
	display: block;
	-webkit-mask-repeat: no-repeat;
	mask-repeat: no-repeat;
	-webkit-mask-position: center;
	mask-position: center;
	-webkit-mask-size: 100%;
	mask-size: 100%;
	transition: background-color .4s ease;
}
.shareLists__link:hover:before {
	background-color: #ff0000;
}

/* 各SNSパーツ */
.shareLists__item.is-twitter .shareLists__link:before {
	width: 26px;
	height: 26px;
	-webkit-mask-image: url(../img/common/icon_tw.svg);
	mask-image: url(../img/common/icon_tw.svg);
	background-color: #fff;
}
.shareLists__item.is-facebook .shareLists__link:before {
	width: 26px;
	height: 26px;
	-webkit-mask-image: url(../img/common/icon_fb.svg);
	mask-image: url(../img/common/icon_fb.svg);
	background-color: #fff;
}
.shareLists__item.is-line .shareLists__link:before {
	width: 26px;
	height: 26px;
	-webkit-mask-image: url(../img/common/icon_line.svg);
	mask-image: url(../img/common/icon_line.svg);
	background-color: #fff;
}

.shareLists__item:first-child {
	font-family: var(--font-en);
	font-size: min(calc(16 / var(--vw-min) * 100vw), 16px);
	height: 13px;
}

@media screen and (max-width:768px) {
	.shareLists__item:first-child {
		font-size: calc(23 / var(--vw-min)* 100vw);
		height: calc(20 / var(--vw-min) * 100vw);
		width: calc(80 / var(--vw-min) * 100vw);
	}
}

/*-----------------------
* around Wrap
-------------------------*/
.content__aroundWrap {
    width: 100%;
    position: relative;
}

.content__aroundWrap-itemsWrap {
    position: absolute;
    top: 0;
    right: 0;
    bottom: 0;
    left: 0;
    width: 100%;
    height: 100%;
	z-index: 900;
    pointer-events: none;
}

.content__aroundWrap-items {
    position: sticky;
    top: 0;
    width: 100%;
    height: min(100vh, 100%);
    z-index: 501;
    pointer-events: none;
    background-image: url(../img/common/deco/around/around-t-left.png), url(../img/common/deco/around/around-t-right.png), url(../img/common/deco/around/around-b-left.png), url(../img/common/deco/around/around-b-right.png), url(../img/common/deco/around/aroundLine-top.png), url(../img/common/deco/around/aroundLine-right.png), url(../img/common/deco/around/aroundLine-bottom.png), url(../img/common/deco/around/aroundLine-left.png);
    background-repeat: no-repeat, no-repeat, no-repeat, no-repeat, repeat-x, repeat-y, repeat-x, repeat-y;
    background-position: top left, top right, bottom left, bottom right, top, right, bottom, left;
    background-size: 80px, 80px, 80px, 80px, 50px 25px, 25px 50px, 50px 25px, 25px 50px;
    margin-top: -7px;
}

.kv__aroundWrap-items {
    position: sticky;
    top: 0;
    width: 100%;
    height: min(100vh, 100%);
    z-index: 501;
    pointer-events: none;
    background-image: url(../img/common/deco/around/around-t-left.png), url(../img/common/deco/around/around-t-right.png), url(../img/common/deco/around/around-b-left.png), url(../img/common/deco/around/around-b-right.png), url(../img/common/deco/around/aroundLine-top.png), url(../img/common/deco/around/aroundLine-right.png), url(../img/common/deco/around/aroundLine-bottom.png), url(../img/common/deco/around/aroundLine-left.png);
    background-repeat: no-repeat, no-repeat, no-repeat, no-repeat, repeat-x, repeat-y, repeat-x, repeat-y;
    background-position: top left, top right, bottom left, bottom right, top, right, bottom, left;
    background-size: 80px, 80px, 80px, 80px, 50px 25px, 25px 50px, 50px 25px, 25px 50px;
}

/*--------------------------------- 
* アニメーション
-----------------------------------*/

.content-titleWrap.js-scrani .content-title {
    opacity: 0;
    transform: translateX(-40px);
    transition: opacity .3s ease, transform .8s ease;
}

.content-titleWrap.js-scrani.is-ani .content-title {
    opacity: 1;
    transform: translateX(0);
}

.special.subpage .content-title.js-scrani.is-ani {
	transition-delay: 0.5s;
}

.content-titleWrap.js-scrani .content-title-navIn {
    opacity: 0;
    transform: translateX(40px);
    transition: opacity .3s ease, transform .8s ease;
}

.content-titleWrap.js-scrani.is-ani .content-title-navIn {
    opacity: 1;
    transform: translateX(0);
    transition-delay: 0.5s;
	display: flex;
    flex-direction: column;
	padding-bottom: 5vw;
}

.contentWrap-box.js-scrani {
    opacity: 0;
    transform: translateY(40px);
    transition: opacity .6s ease, transform .8s ease;
}

.contentWrap-box.js-scrani.is-ani {
    opacity: 1;
    transform: translateY(0);
    transition-delay: 0.5s;
}

.contentWrap-box-fade.js-scrani {
    opacity: 0;
    filter: blur(8px);
    transition: .4s ease-in, filter .8s cubic-bezier(.59, .25, .45, .96);
}

.contentWrap-box-fade.js-scrani.is-ani {
    opacity: 1;
    filter: blur(0);
    transition-delay: .6s;
}

.subfullWrap-logo img {
	width: 100%;
}

.kv__logo {
	opacity: 0;
	transform: scale(0.8);
	filter: blur(6px);
	transition: opacity 1s ease, transform 1s ease-out, filter 1s ease;
}

body.-loaded .kv__logo {
	opacity: 1;
	transform: scale(1);
	filter: blur(0);
}

.kv__mainTextInWrap {
	opacity: 0;
	filter: blur(10%);
	transition: opacity 2s ease, filter 1s ease;
}

body.-loaded .kv__mainTextInWrap {
	opacity: 1;
	filter: blur(0);
	transition-delay: 1.5s;
}

/*breadcrumbs*/
.breadcrumbs{
	display: flex;
    flex-direction: row;
    align-items: center;
	justify-content: flex-end;
	margin: auto 0 0;
}
.breadcrumbs li a,
.breadcrumbs li span{
	font-size: min(calc(12 / 1200 * 100vw), 12px);
	color: #FFF;
	opacity: 0.6;
	line-height: 1;
	transition: opacity .3s ease;

}
.breadcrumbs li a:hover,
.breadcrumbs li .is-current{
	opacity: 1;	
}
.breadcrumbs li{
	position: relative;
	padding: 0 min(calc(20 / 1200 * 100vw), 20px) 0 min(calc(13 /1200 * 100vw), 13px);
	line-height: 1;	
}
.breadcrumbs li:first-child{
	padding-left: 0;
}
.breadcrumbs li:last-child{
	padding-right: 0;
}
.breadcrumbs li:not(:last-child):before{
	position: absolute;
	content: ">";
	top: 0;
	bottom: 0;
	right: 0;
	margin: auto;
	display: flex;
	height: 100%;
    align-items: flex-end;
	line-height: 1;
	color: #8E8E8E;
	font-size: min(calc(12 /1200 * 100vw), 12px);
	height: 100%;
}
@media screen and (max-width:768px) {
	.content-titleWrap{
		overflow: hidden;
		padding-bottom: 5vw;
		width: 100%;
		position: relative;
		min-height: calc(190 / var(--vw-min)* 100vw);
	}
	.breadcrumbs{
		margin-top: calc(23 / var(--vw-min) * 100vw);
		position: absolute;
		bottom:0;
		right: calc(45 / var(--vw-min)* 100vw);
	}
	.subpage .breadcrumbs{
		bottom: unset;
		top: 0;
	}
	.breadcrumbs li a,
	.breadcrumbs li span{
		font-size: min(calc(19 / var(--vw-min) * 100vw), 19px);
	}

	.breadcrumbs li{
		position: relative;
		padding: 0 min(calc(20 / var(--vw-min) * 100vw), 20px) 0 min(calc(13 / var(--vw-min) * 100vw), 13px);
		line-height: 1;	
	}
	.breadcrumbs li:last-child{
		padding: 0 0 0 min(calc(13 / var(--vw-min) * 100vw), 13px);
	}
	.news.article .breadcrumbs li:last-child{
		overflow: hidden;
		text-overflow: ellipsis;
		white-space: nowrap;
		max-width: 33%;
	}
	.subpage .breadcrumbs li{
		margin-bottom: 2vw;
	}
	.breadcrumbs li:not(:last-child):before{
		top: 0;
		font-size: min(calc(19 / var(--vw-min) * 100vw), 19px);
	}

}


/*head_logo*/
.head_logo{
	position: fixed;
	display: flex;
	width: 100%;
	height: 80px;
    align-items: center;
    justify-content: center;
}




/*---------------------------------
* footerArea
----------------------------------*/
.footerArea{
    display: flex;
    flex-direction: column;
    align-items: center;
    min-height: calc(600 / var(--vw-min)* 100vw);
    padding-top: calc(207 / var(--vw-min)* 100vw);
    padding-bottom:calc(50 / var(--vw-min)* 100vw);
    background: url(../img/common/ft_bg_top.jpg) no-repeat center center / cover;
}
/*sub footerArea bg*/
.sub .footerArea{
    background: url(../img/common/ft_bg_sub.jpg) no-repeat center center / cover;
}
@media screen and (max-width:768px) {
	.sub .footerArea{
		background: url(../img/common/ft_bg_sub_sp.jpg) no-repeat center center / cover;
	}
}
.ft_logo{
    background: url(../img/common/logo/logo_w.png) no-repeat center center / contain;
    width: min(calc(700 / var(--vw-min)* 100vw),700px);
    height: min(calc(183 / var(--vw-min)* 100vw),183px);
    margin: 0 auto min(calc(20 / var(--vw-min)* 100vw),20px);
	transition: all .4s ease;
}
.ft_logo a{
	display: block;
	height: 100%;
}
.ft_logo:hover{
	transform: scale(.98);  
}

.ft_copy{
    color: #FFF;
    font-size: min(calc(12 / var(--vw-min)* 100vw),12px);
    margin-bottom:min(calc(70 / var(--vw-min)* 100vw),70px);
}
.bnrList{
    width: 100%;
    max-width: 1290px;
    padding:0 min(calc(60 / var(--vw-min)* 100vw),60px);
    margin: 0 auto;
    display: flex;
    justify-content: center;
    flex-wrap: wrap;
}
.bnrList__item{
    width: min(calc(220 / var(--vw-min) * 100vw), 220px);
	overflow: hidden;
	border: 1px solid var(--color-red);
	background-color: var(--color-red);
	margin-right:min(calc(10 / var(--vw-min) * 100vw), 10px);
}
@media screen and (min-width: 769px) {
	.bnrList__item:last-child,
	.bnrList__item:nth-child(5n){
		margin-right:0;
	}
	.bnrList__item:nth-child(n+6){
		margin-top:min(calc(10 / var(--vw-min) * 100vw), 10px);
	}
}


.bnrList__item img{
    width: 100%;
    height: auto;
	transition: all .4s ease;
}
.bnrList__item:hover img{
	transform: scale(1.06);
	opacity: 0.8;
}
.bnrList__item a{
    width: 100%;
    display: block;
}
@media screen and (max-width:768px) {
	.bnrList{
		padding:0 calc(30 / var(--vw-min)* 100vw);
		justify-content: center;
		flex-wrap: wrap;
	}
	.bnrList__item{
		width: calc((100% - calc(20 / var(--vw-min)* 100vw)) / 3);
		margin-right:calc(10 / var(--vw-min)* 100vw);
	}
	.bnrList__item:nth-child(3n),
	.bnrList__item:last-child{
		margin-right: 0;
	}
	.bnrList__item:nth-child(n+4){
		margin-top:min(calc(10 / var(--vw-min) * 100vw), 10px);
	}}

/*---------------
SUB COMMON
----------------*/
.sub_bg{
	width: 100%;
	height: 100%;
	background: url(../img/common/sub_bg.jpg) no-repeat center top;
	background-size: 100% auto;
	position: absolute;
	top: 0;
	right: 0;
	z-index: 0;
}
@media screen and (max-width:768px) {
	.sub_bg{
		background: url(../img/common/sub_bg_sp.jpg) no-repeat center top;
		background-size: 100% auto;
	}
}
.hd_logo{
    background: url(../img/common/logo/logo_w.png) no-repeat center center / contain;
    width: min(calc(466 / var(--vw-min)* 100vw),466px);
    height: min(calc(121 / var(--vw-min)* 100vw),121px);
	margin: 0 auto;
    position: relative;
	transition: all .4s ease;
}
.hd_logo a{
	display: block;
	height: 100%;
}
.hd_logo:hover{
	transform: scale(.98);  
}
/*ttl*/
.pageTtlWrap{
    display: flex;
    align-items: flex-start;
    height: calc(145 / var(--vw-min) * 100vw);
    max-height: 145px;
	margin-bottom: calc(90 / var(--vw-min) * 100vw);
}

@media screen and (max-width:768px) {
    .pageTtlWrap{
        display: flex;
        align-items: flex-start;
        height: calc(145 / var(--vw-min) * 100vw);
        max-height: 145px;
		margin-bottom: calc(40 / var(--vw-min) * 100vw);
    }

}
/* sub pageTtlWrap */
.sub .pageTtlWrap{
	opacity: 0;
	transform:translateY(40px);
	transition: all .6s ease;
	transition-delay: 1s;
}
.sub.-loaded .pageTtlWrap{
	opacity: 1;
	transform: translateY(0);
}

.pageTtl-text{
    color: var(--color-red);
    font-size: 145px;
    font-family: var(--font-en);
    line-height: 0.7em;
    margin-right: min(calc(30 / var(--vw-min) * 100vw),30px);
}
@media screen and (max-width:768px) {
    .pageTtl-text{
        font-size: calc(145 / var(--vw-min) * 100vw);
        margin-right: min(calc(30 / var(--vw-min) * 100vw),30px);
    }
}

/*backLink*/
.backLink{
    display: flex;
    width: 64px;
    justify-content: space-between;
}
.backLink-text{
    color: var(--color-red);
    font-family: var(--font-en);
    font-size: 24px;
    writing-mode: vertical-rl;
    transition: all .4s ease;
}
@media screen and (max-width:768px) {
	.backLink-text{
		font-size: calc(24 / var(--vw-min) * 100vw);
	}
}


/*sub */
.sub .pageTtlWrap .backLink{
	position: absolute;
	left: -64px;
}
.sub .pageTtlWrap{
	padding-left: 40px;
}
@media screen and (max-width:768px) {
	.sub .pageTtlWrap .backLink{
		position: relative;
		left:unset;
		width: calc(70 / var(--vw-min) * 100vw);
		order: 1;
	}
	.sub .pageTtlWrap{
		padding-left: unset;
	}
}



/*page > backLink-text*/
.backLink.-page .backLink-text{
    writing-mode: unset;
}

/*newsList > backLinkWrap*/
.backLinkWrap.-newsList{
	display: flex;
	width: 100%;
	justify-content: center;
}
.backLinkWrap.-newsList .backLink.-page{
    width: 120px;
	margin-right: 150px;
    writing-mode: unset;
}
@media screen and (max-width:768px) {
	.backLinkWrap.-newsList .backLink.-page{
		width: calc(130 / var(--vw-min) * 100vw);
        margin-right: calc(200 / var(--vw-min) * 100vw);
	}
}
/*newsDetail > backLinkWrap*/
.backLinkWrap.-newsDetail{
	display: flex;
	justify-content: flex-end;
}
.backLinkWrap.-newsDetail .backLink.-page{
    width: 120px;
	margin-right: 0;
}
@media screen and (max-width:768px) {
	.backLinkWrap.-newsDetail{
		justify-content: center;
	}
	.backLinkWrap.-newsDetail .backLink.-page{
		width: calc(130 / var(--vw-min) * 100vw);
        margin-right: calc(200 / var(--vw-min) * 100vw);
	}
}
/*arrow*/
.backLink-arrow{
    position: relative;
    width: min(calc(30 / var(--vw-min) * 100vw),30px);
}
.backLink-arrow::before{
    content: "";
    position: absolute;
    margin: auto;
    top: 0;
    bottom: 0;
    left: 0;
    width: 100%;
    height: 1px;
    background-color: var(--color-red);
}
.backLink-arrow::after{
    content: "";
    position: absolute;
    margin: auto;
    top: 0;
    bottom: 0;
    left: 0;
    width: 5px;
    height: 5px;
    border-radius: 50%;
    background-color: var(--color-red);
    transition: all .4s ease;
}
@media screen and (max-width:768px) {
    .backLink-arrow::after{
        width: calc(5 / var(--vw-min) * 100vw);
        height: calc(5 / var(--vw-min) * 100vw);
    }
}
/*hover*/
.backLink:hover .backLink-text{
    transform: translateX(-10px);
}
.backLink:hover .backLink-arrow::after{
    left: 100%;
}
@media screen and (max-width:768px) {
	.backLink:hover .backLink-text{
		transform: translateX(calc(-10 / var(--vw-min) * 100vw));
	}
}

/**/
.mainArea{
	position: relative;
	padding-bottom: min(calc(60 / var(--vw-min) * 100vw),60px);
	padding-top: min(calc(60 / var(--vw-min) * 100vw),60px);
	z-index: 1;
}
.sub_deco{
	width: 100%;
	height: calc(100% - min(calc(60 / var(--vw-min) * 100vw),60px));
	position: absolute;
	top: 0;
	right: 0;
	z-index: 0;
}
.sub_deco::after{
    content: "";
    display: block;
    background-color: var(--color-red);
    height: 100%;
    width: 1px;
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    margin: auto;
}   
.sub_deco::before{
    content: "";
    position: absolute;
    margin: auto;
    bottom: 0;
    left: 0;
    right: 0;
    width: 5px;
    height: 5px;
    border-radius: 50%;
    background-color: var(--color-red);
    transition: all .4s ease;
}
@media screen and (max-width:768px) {
    .sub_deco::before{
        width: calc(5 / var(--vw-min) * 100vw);
        height: calc(5 / var(--vw-min) * 100vw);
    }
}