@charset "UTF-8";
/* CSS Document */
@font-face { font-family: 'dinpro-bold'; src: url('fonts/dinpro-bold.woff') format('woff'); font-weight: normal; font-style: normal; font-display: block; }
.ff-dinpro-bold { font-family: 'dinpro-bold'; }
	/*
font-family: YakuHanJP_Noto, "Noto Sans JP", sans-serif;
font-family: YakuHanMP_Noto, "Noto Serif JP", serif;
	*/
/*************************************************************************************************************************
* reset
*************************************************************************************************************************/
html{ height: 100%; overflow-y: scroll; font-size: 62.5%;}
body{ height: 100%; margin: 0; padding: 0; text-align: justify; text-justify: inter-ideograph; -webkit-text-size-adjust: 100%; -webkit-font-smoothing: antialiased; -moz-osx-font-smoothing: grayscale; }
img{ width: 100%; max-width: 100%; height: auto; border: 0; vertical-align: bottom;}
svg{ vertical-align: bottom;}
form{ margin: 0; padding: 0;}
p{ margin: 0; padding: 0;}
a, a:hover{ text-decoration: none; outline: none;}
h1, h2, h3, h4, h5, h6{ margin: 0; padding: 0; font-size: 0; line-height: 0;}
ul, dl, dt, dd{ margin: 0; padding: 0;}
li, ol{ margin: 0; padding: 0; list-style: none;}
table{ border: 0; border-collapse: collapse; border-spacing: 0;}
caption, th{ text-align: left;}
figure { margin: 0; padding: 0; }
header, nav, main, article, aside, section, footer{ display: block;}
*{ box-sizing: border-box;}

/**********************************************************
*　追加ベース
**********************************************************/
body.is-fixed {
	/*position: fixed;*/
}
button{ background-color: transparent; border: none; cursor: pointer; outline: none; padding: 0; appearance: none; font-family: YakuHanJP_Noto, "Noto Sans JP", sans-serif; }

.l-wrapper { margin-left: auto; margin-right: auto; }

@media screen and (max-width: 680px) {
	.l-wrapper { width: calc(100% - 40px); }
}
@media screen and (min-width: 681px) {
	.l-wrapper { min-width: 1100px; max-width: 1100px; }
}
@media screen and (min-width: 1401px) {
	/*.l-wrapper { width: 950px; }*/
}

.sp-only { display: none !important; }
.sp-only-2 { display: none !important; }
.pc-only { display: block !important; }
.pc-only-2 { display: inline-block !important; }
@media screen and (max-width: 680px) {
	.sp-only { display: block !important; }
	.sp-only-2 { display: inline-block !important; }
	.pc-only { display: none !important; }
	.pc-only-2 { display: none !important; }
}


body{ height: 100%; font-family: YakuHanJP_Noto, "Noto Sans JP", sans-serif; font-weight: 500; color: #000; -webkit-font-feature-settings: 'palt' 1; font-feature-settings: 'palt' 1; }
@media print, screen and (min-width:681px) {
	body{ min-width: 1056px; }
}

/*	iOS Sarafi Hack	*/
_::-webkit-full-page-media,
_:future,
:root .something {  }






/*************************************************************************************************************************
* Objective Fit Image
*************************************************************************************************************************/
.ofi-cover { width: 100%; height: 100%; object-fit: cover; font-family: 'object-fit: cover'; }
.ofi-contain { width: 100%; height: 100%; object-fit: contain; font-family: 'object-fit: contain'; }

/*
.wrapper-outer { position: relative; overflow: hidden; background: #ebf0fa; }
@media print, screen and (min-width:681px) {
	.wrapper-outer:before,
	.wrapper-outer:after { position: absolute; left: 0; display: block; width: 100%; background: #fff; content: ""; z-index: 0; }
	.wrapper-outer:before { top: 0; height: 275px; }
}
@media print, screen and (min-width:1401px) {
	.wrapper-outer:before { height: 285px; }
}
*/
.caption { font: 500 12px/16px 'YakuHanJP_Noto', 'Noto Sans JP', sans-serif; margin-top: 10px; }


.btn { display: flex; align-items: center; }
.btn--center { justify-content: center; }

.btn--white { border-color: #fff; }
.btn--detail { display: flex; justify-content: center; align-items: center; width: 280px; height: 54px; background-color: #fff; border-radius: 28px; border-color: #004fa2; margin-left: auto; margin-right: auto; font-size: 1.6rem; font-weight: 700; letter-spacing: 0.2em; color: #000; transition: all 400ms ease; }
.btn--detail:after { width: 9px; height: 14px; background: url("../img/ico_arrow.png") no-repeat 50% 50%/100% auto; transform: rotate(-90deg); margin-left: 80px; content: ""; }
.btn--detail:hover { background-color: #004fa2; color: #fff; }
.btn--detail:hover:after { background-image: url("../img/ico_arrow_white.png"); }



.main-ttl { font-size: 3.4rem; line-height: 1.35; }
.cont-txt  { font-size: 1.5rem; line-height: 2.14; }
.ttl--blue { background: #004fa2; border-radius: 5px; padding: 5px 15px 7px; font-size: 1.5rem; font-weight: 500; line-height: 1.74; color: #fff; }

@media print, screen and (min-width:681px) {
	.upper-ttl { font-size: 1.5rem; }
	.main-ttl { font-size: 4.5rem; line-height: 1.35; }
	.cont-txt  { font-size: 1.6rem; line-height: 2.2; }
	.ttl--blue { foant-size: 1.6rem; line-height: 1.74; }
}
.ktkn { font-size: inherit; letter-spacing: -0.05em; }

/*	Common Things	*/

body:before { position: fixed; top: 0; bottom: 0; left: 0; display: block; width: calc(100% - 20px); height: 100vh; border-style: solid; border-color: #a91b49; border-width: 10px 10px 0 10px; content: ""; z-index: 500; pointer-events: none; }

_::-webkit-full-page-media,
_:future,
:root body:before { transform: translate3d(0, 0, 0); }

body:after { position: fixed; bottom: 0; left: 0; display: block; width: 100%; height: 10px; background: #a91b49; content: ""; z-index: 500; pointer-events: none; }

@media print, screen and (min-width:681px) {
	body:before { width: calc(100% - 60px); border-width: 30px 30px 0 30px; }
	body:after { height: 30px; }
}




/*	Header	*/
.header { position: relative; display: flex; align-items: center; height: 47px; background: #a91b49; padding-left: 10px; padding-right: 10px; z-index: 1000; }
.header__logo img { width: 185px; }
@media print, screen and (max-width:680px) {
	
}
@media print, screen and (min-width:681px) {
	.header { min-width: 1300px; height: 75px; }
}
@media print, screen and (min-width:1201px) {
	
	
}


/*	First View	*/
.fv { position: relative; width: calc(100% - 20px); height: calc(100% - 47px); background: #fff; margin-left: auto; margin-right: auto; z-index: 100; }
.fv__inner { position: relative; height: 100%; overflow: hidden; }
.fv__base { position: absolute; bottom: 0; left: 14px; display: block; width: calc(100% - 44px); height: calc(100% - 40px); background: url("../img/bg_fv_sp.jpg") no-repeat 90% 10%/cover; z-index: 0; }

.fv__obj { position: absolute; z-index: 100; transition: 0.4s; }


.fv__subttl { top: 12px; right: 12px; width: calc(100% - 46px); z-index: 200; }
.fv__ttl { bottom: 30px; left: -10px; width: calc(100% - 8px); z-index: 200; }


/*
.fv__obj--antique,
.fv__obj--castle,
.fv__obj--clothe,
.fv__obj--haniwa,
.fv__obj--katana,
.fv__obj--paper,
.fv__obj--ship,
.fv__obj--stick { display: none; }

}
*/





.fv__obj--antique { top: 75%; left: 48%; width: 34px; }
.fv__obj--castle { top: 39%; left: 61%; width: 51px; }
.fv__obj--clothe { top: 49%; left: 73%; width: 79px; }
.fv__obj--haniwa { top: 53%; left: 50%; width: 29px; }
.fv__obj--katana { top: 39%; left: 45%; width: 13px; }
.fv__obj--paper { top: 79%; right: -24px; width: 50px }
.fv__obj--ship { top: 66%; left: 62%; width: 59px; }
.fv__obj--stick { top: 72%; right: 36px; width: 33px; }
.fv__obj--girl { position: absolute; bottom: 90px; right: 45%; width: calc(100% - 23px); z-index: 190; } /* left: 50%; transform: translateX(-95%);  */
.fv__obj--splash { position: absolute; top: 0; right: 0; width: calc(100% - 60px); z-index: 10; }

@media print, screen and (min-width:461px) {
	.fv__obj--antique { top: 101vw; left: 53vw; }
	.fv__obj--castle { top: 52vw; left: 62vw; }
	.fv__obj--clothe { top: 67vw; left: 70vw; }
	.fv__obj--haniwa { top: 71vw; left: 55vw; }
	.fv__obj--katana { top: 54vw; left: 49vw; }
	.fv__obj--paper { top: 105vw; }
	.fv__obj--ship { top: 87vw; left: 64vw; }
	.fv__obj--stick { top: 96vw; }
}

@media print, screen and (max-width:680px) {
	.fv__obj--girl { max-width: 400px; }
	.fv__obj--splash { max-width: 334px; }
}
@media print, screen and (min-width:681px) {
	.fv { min-width: 1300px; width: auto; height: calc(100% - 75px); padding-left: 30px; padding-right: 30px; }
	/*.fv__inner { width: calc(100% - 60px); margin-left: auto; margin-right: auto; }*/
	.fv__base { left: 40px; width: calc(100% - 114px); height: calc(100% - 78px); background: url("../img/bg_fv_pc.jpg") no-repeat 60% 10%/cover; z-index: 10; }

	.fv__subttl { top: 30px; right: 30px; max-width: 536px; }
	.fv__ttl { bottom: 134px; left: -20px; max-width: 771px; }
	
	.fv__obj--antique { top: 88%; right: 34%; left: auto; width: 77px; }
	.fv__obj--castle { top: 27%; right: 24%; left: auto; width: 117px; }
	.fv__obj--clothe { top: 45%; right: 12%; left: auto; width: 182px; }
	.fv__obj--haniwa { top: 48%; right: 33%; left: auto; width: 66px; }
	.fv__obj--katana { top: 34%; right: 39%; left: auto; width: 30px; }
	.fv__obj--paper { top: 90%; right: 8%; width: 114px }
	.fv__obj--ship { top: 70%; right: 20%; left: auto; width: 136px; }
	.fv__obj--stick { top: 79%; right: 16%; width: 76px; }
	.fv__obj--girl { top: 20px; bottom: auto; right: 45%; min-width: 719px; width: calc(100% - 521px); max-width: 920px; z-index: 190; } /* left: 50%; transform: translateX(-95%);  */
	.fv__obj--splash { top: 0; right: 0; min-width: 623px; width: calc(100% - 60px); max-width: 334px; z-index: 0; }
	
	
	
}

@media print, screen and (min-width:1700px) {
	.fv__subttl { max-width: 636px; }
	.fv__ttl { max-width: 870px; }
	.fv__base { background-position: 60% 100%; }
	.fv__obj--antique { top: 46vw; left: 56vw; }
	.fv__obj--castle { top: 13vw; left: 63vw; }
	.fv__obj--clothe { top: 22vw; left: 70vw; }
	.fv__obj--haniwa { top: 25vw; left: 59vw; }
	.fv__obj--katana { top: 15vw; left: 55vw; }
	.fv__obj--paper { top: 46vw; left: 83vw; right: auto; }
	.fv__obj--ship { top: 38vw; left: 65vw; }
	.fv__obj--stick { top: 43vw; right: 16vw; }
	.fv__obj--girl { right: 50%; margin-right: -4%; }
}

@media all and (device-width: 768px) and (device-height: 1024px) and (orientation:portrait) {
	.fv__obj--girl { top: auto; bottom: 0; min-width: 1000px; }
}





/*	Different World	*/
/*
.dif-wrap { position: relative; background: rgb(91,62,16); background: radial-gradient(circle, rgba(91,62,16,1) 0%, rgba(187,150,70,1) 95%); height: 100vh; overflow: hidden; }
*/
.dif-wrap .deco { position: relative; width: calc(100% + 24px); height: 140px; margin-top: -98px; margin-left: -12px; margin-right: -12px; overflow: hidden; }
.dif-wrap .deco:before,
.dif-wrap .deco:after { position: absolute; display: block; width: 900px; height: 100px; content: ""; }
.dif-wrap .deco:before { top: calc(100% - 280px); left: 50%; transform: rotate(-30deg) translateX(-50%); height: 200px; background: #1f2c5c; z-index: 10; }
.dif-wrap .deco:after { top: calc(100% + 23px); left: 50%; transform: rotate(5deg) translateX(-50%); background: #a91b49; z-index: 50; }

/*
.dif-wrap .deco { position: absolute; display: block; width: 900px; height: 100px; content: ""; }
.dif-wrap .deco--navy { top: calc(100% - 280px); left: 50%; transform: rotate(-30deg) translateX(-50%); height: 200px; background: #1f2c5c; z-index: 10; }
.dif-wrap .deco--wine { top: calc(100% + 23px); left: 50%; transform: rotate(5deg) translateX(-50%); background: #a91b49; z-index: 50; }
*/

/*
.dif-wrap { position: fixed; top: 0; left: 0; width: 100%; height: 100%; background: rgb(91,62,16); background: radial-gradient(circle, rgba(91,62,16,1) 0%, rgba(187,150,70,1) 95%); overflow: hidden; z-index: 0; }
*/



/*
.dif-wrap:before { position: absolute; top: 50%; left: 50%; display: block; width: 150%; height: 110%; background: url("../img/bg_dif_sp.png") no-repeat center/cover; content: ""; z-index: 0; animation: spin 15s infinite linear; opacity: 0.7; mix-blend-mode: lighten; } /*animation: spin 15s infinite ease-in-out;*/
/*.dif-inner { position: relative; width: 100%; height: 100%; padding-top: 50px; padding-left: 20px; padding-right: 20px; overflow: scroll; scrollbar-width: none; }
*/
.dif-inner { position: relative; width: 100%; padding-top: 50px; padding-left: 20px; padding-right: 20px; }


/*	TEMP
.dif-wrap.is-fixed { position: fixed; top: 0; left: 0; width: 100%; height: 100% !important; z-index: 400; }
.dif-wrap.is-fixed .dif-inner { overflow: scroll;  border: 2px solid #FF0; }
*/
.dif-int { padding-bottom: 50px; }
.dif-int__ttl { margin-bottom: 20px; text-align: center; }
.dif-int__ttl img { width: 260px; }

.dif-int__txt { font: 500 1.4rem YakuHanMP_Noto, "Noto Serif JP", serif; line-height: 2.785; text-align: center; color: #fff; text-shadow: 0px 0px 10px rgba(0, 0, 0, 0.8); }


.dif-yt { padding: 30px 30px 100px 30px; }
.dif-yt__ttl { margin-bottom: 16px; text-align: center; color: #fff; }
.dif-yt__ttl__en,
.dif-yt__ttl__jp { display: block; }
.dif-yt__ttl__en { margin-bottom: 5px; font: 900 1.2rem 'Lato', sans-serif; line-height: 1; letter-spacing: 0.3em; text-indent: 0.3em; }
.dif-yt__ttl__jp { font-size: 1.8rem; font-weight: 700; line-height: 1; letter-spacing: 0.1em; text-indent: 0.1em; }
.dif-yt__video { min-height: 192px; }
.dif-yt__video iframe { border: none; aspect-ratio: 16 / 9; width: 100%; height: auto; box-shadow: 0px 0px 30px 3px rgba(0, 0, 0, 0.3); }




.dif-wld__img { position: relative; }

.dif-wld__img__caption { position: absolute; z-index: 10; }
.dif-wld__img__caption--txt { z-index: 15; }
.dif-wld__img__caption--shadow { mix-blend-mode: multiply; opacity: 0.75; }
.dif-wld__cont { position: relative; }
.dif-wld__cont__label { position: relative; display: inline-block; background: #000; padding: 5px 10px 8px 24px; font-size: 1.5rem; font-weight: 400; line-height: 1; letter-spacing: 0.1em; color: #fff; }
.dif-wld__cont__label:before { position: absolute; left: 10px; top: 50%; transform: translateY(-50%); display: block; width: 0; height: 0; border-style: solid; border-width: 5px 0 5px 8px; border-color: transparent transparent transparent #a91b48; margin-right: 5px; content: ""; }
.dif-wld__cont__txt { font-size: 1.4rem; line-height: 1.7142; color: #fff; text-align: justify; }

.dif-wld:nth-of-type(even) .dif-wld__img { text-align: right; }



.dif-other { position: relative; background: #000; padding: 5px; font-weight: 400; color: #fff; z-index: 100; }
.dif-other__inner { border: 1px solid #808080; padding-bottom: 16px; }
.dif-other__ttl { border-bottom: 1px solid #808080; margin-bottom: 16px; padding-top: 10px; padding-bottom: 10px; font-size: 1.4rem; font-weight: 400; line-height: 1; letter-spacing: 0.2em; text-indent: 0.2em; text-align: center; }
.dif-other__list { display: flex; flex-wrap: wrap; padding-left: 15px; }
.dif-other__list__item { position: relative; margin-bottom: 14px; padding-left: 12px; font-size: 1.3rem; line-height: 1; letter-spacing: 0.1em; }
.dif-other__list__item:before { position: absolute; left: 0; top: 50%; transform: translateY(-50%); width: 0; height: 0; border-style: solid; border-width: 4px 0 4px 6px; border-color: transparent transparent transparent #a91b48; content: ""; }
.dif-other__list__item:not(:last-of-type) { margin-right: 20px; }
.dif-other__cap{ padding-right: 20px; font-size: 1.2rem; text-align: right;}

@media print, screen and (max-width:374px) {
	.dif-other__list__item { font-size: 1.2rem; }
}
@media print, screen and (max-width:680px) {
	.dif-wld { padding-top: 20px; padding-bottom: 20px; }
	.dif-wld:nth-of-type(odd) .dif-wld__cont__label { left: -12px; }
	.dif-wld:nth-of-type(even) .dif-wld__cont__label { right: -12px; }
	.dif-wld__img { margin-left: -12px; margin-right: -12px; }
	.dif-wld__img__ph { width: calc(100% - 65px); }
	.dif-wld__cont { margin-top: -10px; padding-top: 39px; }
	.dif-wld__cont__label { position: absolute; top: 0; }
	.dif-wld:nth-of-type(even).dif-wld--4 .dif-wld__cont__label { left: -12px; right: auto; }
	.dif-other__list__item:nth-of-type(7),
	.dif-other__list__item:last-of-type { margin-right: 0; }
	.dif-other__cap{ padding-left: 15px; text-align: left;}
	
.dif-wld--1 .dif-wld__img__caption { right: -5px; bottom: -30px; }
.dif-wld--1 .dif-wld__img__caption img { width: 48vw; }
.dif-wld--2 .dif-wld__cont { margin-top: -30px; }
.dif-wld--2 .dif-wld__img__caption { top: -10px; left: -5px; }
.dif-wld--2 .dif-wld__img__caption img { width: 36vw; }
.dif-wld--3 .dif-wld__img__caption { right: -2px; bottom: -27px; }
.dif-wld--3 .dif-wld__img__caption img { width: 33vw; }
.dif-wld--4 .dif-wld__cont { margin-top: -50px; }
.dif-wld:nth-of-type(even).dif-wld--4 .dif-wld__img__ph { width: calc(100 - 50px); }
.dif-wld--4 .dif-wld__img__caption { top: -20px; left: 0; }
.dif-wld--4 .dif-wld__img__caption img { width: 45vw; }
.dif-wld--5 .dif-wld__cont { margin-top: 28px; }
.dif-wld:nth-of-type(odd).dif-wld--5 .dif-wld__img { text-align: right; }
.dif-wld--5 .dif-wld__img__caption { bottom: -35px; left: -5px; }
.dif-wld--5 .dif-wld__img__caption img { width: 46vw; }
.dif-wld--6 { padding-top: 46px; }
.dif-wld:nth-of-type(even).dif-wld--6 .dif-wld__img { text-align: left; }
.dif-wld--6 .dif-wld__img__caption { top: -55px; right: -2px; }
.dif-wld--6 .dif-wld__img__caption img { width: 61vw; }
	
}


@media print, screen and (min-width:681px) {
	
	.dif-wrap { min-width: 1300px; overflow: hidden; }
	.dif-wrap:before { width: 120%; height: 150%; background-image: url("../img/bg_dif_pc.png"); opacity: 0.5; }
	.dif-inner { min-width: 1300px; margin-left: auto; margin-right: auto; padding-top: 100px; padding-left: 30px; padding-right: 30px; }
	.dif-int { padding-bottom: 90px; }
	.dif-int__ttl img { width: 360px; }
	.dif-int__txt { font-size: 1.5rem; line-height: 2.866; letter-spacing: 0.1em; text-indent: 0.1em; }
	.dif-yt { padding-top: 40px; padding-bottom: 170px; }
	.dif-yt__ttl { margin-bottom: 40px; }
	.dif-yt__ttl__en { margin-bottom: 12px; font-size: 1.4rem; }
	.dif-yt__ttl__jp { font-size: 2.0rem; letter-spacing: 0.2em; text-indent: 0.2em; }
	.dif-yt__video { max-width: 750px; margin-left: auto; margin-right: auto; }
	
	.dif-wld-wrap { min-width: 1240px; width: 1240px; margin-left: auto; margin-right: auto; margin-bottom: 100px; }
	.dif-wld { display: flex; }
	.dif-wld:nth-last-of-type(odd) { flex-direction: row-reverse; }
	.dif-wld:nth-last-of-type(even) { flex-direction: row; }
	
	.dif-wld__img__ph { min-width: 600px; }
	/*.dif-wld__cont { margin-top: -10px; padding-top: 39px; }*/
	.dif-wld__cont__label { margin-bottom: 15px; }
	.dif-wld__cont__txt { font-size: 1.5rem; line-height: 2.4666; }
	
	.dif-wld--1 { justify-content: flex-start; align-items: flex-end; }
	.dif-wld--1 .dif-wld__img { width: 600px; }
	.dif-wld--1 .dif-wld__img__caption { top: -85px; right: -300px; }
	.dif-wld--1 .dif-wld__img__caption img { width: 430px; }
	.dif-wld--1 .dif-wld__cont { width: 524px; margin-left: 46px; }
	
	.dif-wld--2 { justify-content: flex-end; align-items: flex-start; margin-top: 119px; padding-left: 70px; }
	.dif-wld--2 .dif-wld__img__ph { width: 665px; }
	.dif-wld--2 .dif-wld__img__caption { top: -90px; right: -68px; }
	.dif-wld--2 .dif-wld__img__caption img { width: 308px; }
	.dif-wld--2 .dif-wld__cont { width: 385px; margin-right: 15px; padding-top: 32px; }
	
	.dif-wld--3 { margin-top: 89px; padding-right: 70px; }
	.dif-wld--3 .dif-wld__img { flex: 1; text-align: right; }
	.dif-wld--3 .dif-wld__img__caption { top: -80px; right: 475px; }
	.dif-wld--3 .dif-wld__img__caption img { width: 300px; }
	.dif-wld--3 .dif-wld__img__ph { width: 550px; }
	.dif-wld--3 .dif-wld__cont { width: 313px; margin-left: 46px; }
	
	.dif-wld--4 { justify-content: flex-end; align-items: center; margin-top: 104px; padding-left: 70px; }
	.dif-wld--4 .dif-wld__img__ph { width: 665px; }
	.dif-wld--4 .dif-wld__img__caption { top: -63px; left: -280px; }
	.dif-wld--4 .dif-wld__img__caption img { width: 430px; }
	.dif-wld--4 .dif-wld__cont { width: 550px; margin-right: 35px; padding-top: 112px; }
	
	.dif-wld--5 { align-items: flex-end; padding-right: 70px; }
	.dif-wld--5 .dif-wld__img { flex: 1; text-align: right; }
	.dif-wld--5 .dif-wld__img__caption { bottom: -70px; right: 330px; }
	.dif-wld--5 .dif-wld__img__caption img { width: 395px; }
	.dif-wld--5 .dif-wld__img__ph { width: 550px; }
	.dif-wld--5 .dif-wld__cont { width: 389px; margin-left: 52px; }
	
	.dif-wld:nth-last-of-type(odd).dif-wld--6 { flex-direction: row; align-items: flex-end; margin-top: 175px; }
	.dif-wld--6 { align-items: flex-start; padding-right: 70px; }
	.dif-wld:nth-of-type(odd).dif-wld--6 .dif-wld__img { text-align: left; }
	.dif-wld--6 .dif-wld__img__caption { top: -115px; right: -644px; }
	.dif-wld--6 .dif-wld__img__caption img { width: 560px; }
	.dif-wld--6 .dif-wld__img__ph { width: 550px; }
	.dif-wld--6 .dif-wld__cont { width: 452px; margin-left: 52px; }
	
	.dif-other { width: 1100px; margin-left: auto; margin-right: auto; }
	.dif-other__inner { padding-bottom: 12px; }
	.dif-other__ttl { margin-bottom: 29px; padding-top: 15px; padding-bottom: 18px; font-size: 1.5rem; }
	.dif-other__list { padding-left: 30px; }
	.dif-other__list__item { margin-bottom: 20px; padding-left: 12px; font-size: 1.5rem; }
	.dif-other__list__item:not(:last-of-type) { margin-right: 30px; }
	.dif-other__list__item:nth-of-type(6),
	.dif-other__list__item:last-of-type { margin-right: 0; }
	
	.dif-wrap .deco { min-width: 1300px; width: 100vw; height: 230px; margin-top: -100px; margin-left: -30px; margin-right: -30px; }
	.dif-wrap .deco:before,
	.dif-wrap .deco:after { width: 3000px; height: 400px; }
	.dif-wrap .deco:before { top: calc(100% - 342px); transform: rotate(-10deg) translateX(-50%); }
	.dif-wrap .deco:after { top: calc(100% + 16px); transform: rotate(3deg) translateX(-50%); }
}

@keyframes spin {
	from { transform: translate(-50%, -50%) rotate(0deg); }
	to { transform: translate(-50%, -50%) rotate(360deg); }
}



/*-------------
	Difference
-------------*/
.dfrc { background: #a91b49; padding-top: 20px; padding-bottom: 55px; overflow: hidden; }
.dfrc__ttl { margin-bottom: 24px; text-align: center; }
.dfrc__ttl img { width: calc(100% - 10px); }
.dfrc__list__item__img { position: relative; margin-bottom: 10px; }
.dfrc__list__item__img:before { position: absolute; display: block; background-repeat: no-repeat; background-position: center; background-size: contain; content: ""; }
.dfrc__list__item:nth-child(1) .dfrc__list__item__img:before { top: -5px; left: -15px; width: 120px; height: 32px; background-image: url("../img/obj_cloud_1.svg"); }
.dfrc__list__item:nth-child(2) .dfrc__list__item__img:before { top: -23px; right: -15px; width: 127px; height: 71px; background-image: url("../img/obj_cloud_2.svg"); }
.dfrc__list__item:nth-child(3) .dfrc__list__item__img:before { top: -5px; left: -38px; width: 130px; height: 35px; background-image: url("../img/obj_cloud_3.svg"); }
.dfrc__list__item:nth-child(4) .dfrc__list__item__img:before { bottom: -30px; right: -25px; width: 128px; height: 58px; background-image: url("../img/obj_cloud_4.svg"); }
.dfrc__list__item__ttl__label { display: inline-flex; justify-content: center; align-items: center; height: 18px; border-radius: 9px; background: #e9c242; padding-left: 15px; padding-right: 15px; font: 700 1.1rem 'dinpro-bold'; text-align: center; color: #a91b49; }
.dfrc__list__item__ttl__txt { display: block; font: 500 1.8rem YakuHanMP_Noto, "Noto Serif JP", serif; line-height: 1; letter-spacing: 0.1em; color: #fff; }
.dfrc__list__item__txt { margin-top: 9px; font-size: 1.4rem; line-height: 1.714; color: #fff; }

@media print, screen and (max-width:680px) {
	.dfrc__list__item:not(:last-child) { margin-bottom: 30px; }
	.dfrc__list__item__ttl__txt { margin-top: 6px; }
	
}

@media print, screen and (min-width:681px) {
	
	.dfrc { min-width: 1300px; padding-top: 20px; padding-bottom: 150px; }
	.dfrc__ttl { margin-bottom: 67px; }
	.dfrc__ttl img { width: 838px; }
	.dfrc__list { display: flex; justify-content: space-between; flex-wrap: wrap; }
	.dfrc__list__item { width: calc(50% - 41px); }
	.dfrc__list__item__img { position: relative; margin-bottom: 30px; }
	
	.dfrc__list__item:nth-child(1) .dfrc__list__item__img:before { top: auto; left: -64px; bottom: -15px; width: 230px; height: 62px; }
	.dfrc__list__item:nth-child(2) .dfrc__list__item__img:before { top: -78px; right: -98px; width: 280px; height: 156px; }
	.dfrc__list__item:nth-child(3) .dfrc__list__item__img:before { top: auto; bottom: -264px; left: -112px; width: 237px; height: 64px; }
	.dfrc__list__item:nth-child(4) .dfrc__list__item__img:before { bottom: -10px; right: -120px; width: 220px; height: 100px; }
	.dfrc__list__item:nth-child(-n+2) { margin-bottom: 70px; }
	.dfrc__list__item__ttl { display: flex; align-items: center; }
	.dfrc__list__item__ttl__label { height: 24px; border-radius: 12px; margin-right: 12px; padding-left: 20px; padding-right: 20px; font-size: 1.5rem; }
	
	.dfrc__list__item__ttl__txt { flex: 1; font-size: 2.0rem; }
	.dfrc__list__item__txt { margin-top: 12px; font-size: 1.5rem; line-height: 2.466; }
	

}


/*-------------
	Future
-------------*/
.future-outer { background: #a91b49; }
.future-inner { position: relative; margin-left: auto; margin-right: auto; }
.future-label-wrap { position: absolute; top: -25px; width: 100%; text-align: center; z-index: 10; }
.future-label {  width: calc(100% - 20px); background: #1f2c5c; border-radius: 25px; margin-left: auto; margin-right: auto; padding-top: 15px; padding-bottom: 18px; font: 500 1.7rem YakuHanMP_Noto, "Noto Serif JP", serif; line-height: 1; letter-spacing: 0.1em; text-indent: 0.1em; text-align: center; color: #fff; }
.future-label:before { position: absolute; bottom: -8px; left: 50%; transform: translateX(-50%); width: 0; height: 0; border-style: solid; border-width: 10px 8px 0 8px; border-color: #1f2c5c transparent transparent transparent; content: ""; }

.future-wrap { background: url("../img/bg_future_sp.jpg") no-repeat 0 0/cover; padding: 50px 0 40px; overflow: hidden; }

.future__ttl { display: flex; align-items: center; margin-bottom: 15px; padding-left: 30px; padding-right: 30px; color: #a91b49; }
.future__ttl__num { margin-right: 5px; font: 700 4.1rem 'dinpro-bold'; line-height: 1; }
.future__ttl__txt { font: 700 1.8rem YakuHanMP_Noto, "Noto Serif JP", serif; line-height: 1.166666; }
.future__list { display: flex; }
.future__list__item { position: relative; border: 2px solid #a91b49; border-radius: 10px; padding: 6px; }
.future__list__item:not(:last-of-type):before { position: absolute; width: 0; height: 0; border-style: solid; content: ""; }

.future__list__item dt { position: relative; background: #a91b49; padding-top: 6px; padding-bottom: 9px; font: 500 1.5rem YakuHanMP_Noto, "Noto Serif JP", serif; line-height: 1; letter-spacing: 0.1em; text-indent: 0.1em; text-align: center; color: #fff; }
.future__list__item dt span { position: relative; z-index: 10; }
.future__list__item dt:before { position: absolute; top: 0; left: 0; display: block; width: 100%; height: 100%; background: url("../img/ptn_jpn.svg") repeat 0 0/40px auto; content: ""; opacity: 0.2; }
.future__list__item dd { padding: 5px; font-size: 1.4rem; font-weight: 400; line-height: 1.642; }

/*	Slick	*/
.future-wrap .slick-prev,
.future-wrap .slick-next { border: none; top: 73px; width: 32px; height: 32px; background: #a91b49; z-index: 50; }
.future-wrap .slick-prev { left: 0; }
.future-wrap .slick-next { right: 0; }
.future-wrap .slick-prev:before,
.future-wrap .slick-next:before { position: absolute; top: 50%; left: 50%; width: 5px; height: 5px; border-right: 1px solid #fff; border-top: 1px solid #fff; content: ""; }
.future-wrap .slick-prev:before { transform: translate(-50%, -50%) rotate(225deg); }
.future-wrap .slick-next:before { transform: translate(-50%, -50%) rotate(45deg); }

.future-wrap .slick-dots { bottom: 10px; left: 50%; transform: translateX(-50%); }
.future-wrap .slick-dots li { margin: 0; }
.future-wrap .slick-dots li button::before { content: "\025cf"; color: #b3b3b3; opacity: 1; }
.future-wrap .slick-dots li.slick-active button::before { color: #a91b49; }

.dif-other--license { background-color: transparent; border: 1px solid #fff; margin: 20px 10px 0; }
.dif-other--license .dif-other__inner,
.dif-other--license .dif-other__ttl { border-color: #ca90a3; }

.dif-other--license .dif-other__list__item::before { border-color: transparent transparent transparent #fff; }

@media print, screen and (max-width:374px) {
	.future-label { font-size: 1.55rem; }
	.future__ttl__txt { font-size: 1.7rem; }
}
@media print, screen and (max-width:680px) {
	.future-inner { min-width: calc(100% - 20px); width: calc(100% - 20px); padding-bottom: 20px; }
	.future { margin-left: 10px; margin-right: 10px; }
	.future__list { flex-direction: column; }
	.future__list__item:not(:last-of-type) { margin-bottom: 18px; }
	.future__list__item:not(:last-of-type):before { bottom: -12px; left: 50%; transform: translateX(-50%); border-width: 10px 8px 0 8px; border-color: #a91b49 transparent transparent transparent; }
	.dif-other--license .dif-other__list__item:last-of-type { width: 100%; }
}

@media print, screen and (min-width:681px) {
	.future-outer { min-width: 1300px; padding-left: 30px; padding-right: 30px; }
	.future-inner { min-width: 1240px; padding-bottom: 110px; }
	.future-label { top: -35px; max-width: 730px; border-radius: 35px; padding-top: 15px; padding-bottom: 18px; font-size: 2.4rem; }

	.future-wrap { background-image: url("../img/bg_future_pc.jpg"); padding: 78px 10px 100px; }
	.future__ttl { display: flex; align-items: center; margin-bottom: 15px; padding: 0; }
	.future__ttl__num { margin-right: 10px; font-size: 5.0rem; }
	.future__ttl__txt { font-size: 2.5rem; line-height: 1; }
	
	.future-wrap { padding-left: 110px; padding-right: 110px; }
	.future-wrap .slick-list { max-width: 1024px; margin-left: auto; margin-right: auto; }
	.future__list { flex-direction: row; justify-content: space-between; }
	.future__list__item { width: 314px; padding: 10px; }
	.future__list__item:not(:last-of-type):before { position: absolute; width: 0; height: 0; border-style: solid; content: ""; }

	.future__list__item dt { padding-top: 8px; padding-bottom: 10px; font-size: 1.7rem; }
	.future__list__item dt span { position: relative; z-index: 10; }
	.future__list__item dd { padding: 10px; font-size: 1.6rem; font-weight: 400; line-height: 1.8125; }
	.future__list__item:not(:last-of-type):before { left: calc(100% + 15px); top: 50%; transform: translateY(-50%); border-width: 13px 0 13px 14px; border-color: transparent transparent transparent #a91b49; }
	
	/*	Slick	*/
	.future-wrap .slick-prev,
	.future-wrap .slick-next { top: 220px; width: 60px; height: 60px; }
	.future-wrap .slick-prev { left: 0; }
	.future-wrap .slick-next { right: 0; }
	.future-wrap .slick-prev:before,
	.future-wrap .slick-next:before { width: 10px; height: 10px; border-right: 2px solid #fff; border-top: 2px solid #fff; content: ""; }

	.future-wrap .slick-dots { bottom: 40px; }
	.future-wrap .slick-dots li { margin: 0; }
	.future-wrap .slick-dots li button::before { content: "\025cf"; color: #b3b3b3; opacity: 1; }
	.future-wrap .slick-dots li.slick-active button::before { color: #a91b49; }
	
	.dif-other--license { margin-top: 70px; margin-left: auto; margin-right: auto; }
}


/*-------------
	Footer
-------------*/
.footer { background: #1f2c5c; padding-top: 20px; padding-bottom: 24px; }
.footer-inner { width: calc(100% - 60px); margin-left: auto; margin-right: auto; }
.footer__btn a { display: flex; justify-content: center; align-items: center; height: 44px; background: #1f2c5c; border: 1px solid #a91b49; border-radius: 22px; font-size: 1.3rem; font-weight: 400; line-height: 1; letter-spacing: 0.1em; text-indent: 0.1em; text-align: center; color: #fff; }

.footer__bottom { display: flex; }
.footer__bottom__logo { display: flex; justify-content: center; align-items: center; }
.footer__bottom__logo__img { position: relative; width: 150px; margin-right: 24px; }
.footer__bottom__logo__img:before { position: absolute; top: 50%; transform: translateY(-50%); left: calc(100% + 13px); width: 1px; height: 80%; background: #fff; content: ""; }
.footer__bottom__logo__txt { width: 138px; }
.footer__bottom__sns { display: flex; justify-content: center; align-items: center; }
.footer__bottom__sns__btn:not(:last-of-type) { margin-right: 20px; }
.footer__bottom__sns__btn img { width: auto; height: 32px; }
.copyright { background: #000; padding-top: 16px; padding-bottom: 28px; font-size: 1.1rem; font-weight: 400; line-height: 1; letter-spacing: 0.05em; text-indent: 0.05em; text-align: center; color: #fff; }
.copyright__left{ margin: 0 0 5px 0; line-height: 1.3;}

@media print, screen and (max-width:680px) {
	.footer__btn:not(:last-of-type) { margin-bottom: 10px; }
	.footer__bottom { flex-direction: column-reverse; margin-top: 30px; }
	.footer__bottom__sns { margin-bottom: 30px; }
}

@media print, screen and (min-width:681px) {
	.footer { min-width: 1300px; background: #1f2c5c; padding-top: 65px; padding-bottom: 45px; }
	.footer-inner { position: relative; width: calc(100% - 60px); margin-left: auto; margin-right: auto; }
	.footer__btn-wrap { position: absolute; top: -90px; left: 50%; transform: translateX(-50%); display: flex; justify-content: space-between; align-items: center; width: 868px; }
	.footer__btn { width: 206px; }
	.footer__btn a {height: 50px; border: 3px solid #a91b49; border-radius: 25px; font-size: 1.5rem; transition: 0.4s; }
	.footer__btn a:hover { background: #a91b49; border-color: #1f2c5c; }
	.footer__bottom { justify-content: space-between; align-items: center; min-width: 1155px; max-width: 1155px; margin-left: auto; margin-right: auto; }
	.footer__bottom__logo__img { width: 244px; margin-right: 34px; }
	.footer__bottom__logo__img:before { left: calc(100% + 17px); }
	.footer__bottom__logo__txt { width: 223px; }
	.copyright { min-width: 1300px; height: 80px; position: relative;}
	.copyright__left{ position: absolute; top: 17px; left: 50px;}
	.copyright__right{ position: absolute; top: 17px; right: 50px;}
	.copyright__right:before { content: "Copyright ";}
}


.vortex { position: fixed; top: 0; left: 0; width: 100%; height: 100%; background: rgb(91,62,16); background: radial-gradient(circle, rgba(91,62,16,1) 0%, rgba(187,150,70,1) 95%); height: 100vh; overflow: hidden; z-index: -1; }
.vortex:before { position: absolute; top: 50%; left: 50%; display: block; width: 150%; height: 110%; background: url("../img/bg_dif_sp.png") no-repeat center/cover; content: ""; z-index: 0; animation: spin 40s infinite linear; opacity: 0.7; mix-blend-mode: lighten; } /*animation: spin 15s infinite ease-in-out;*/

@media print, screen and (min-width:681px) {
	.vortex { min-width: 1300px; }
	.vortex:before { width: 120%; height: 150%; background-image: url("../img/bg_dif_pc.png"); opacity: 0.5; }
}
@media all and (device-width: 768px) and (device-height: 1024px) and (orientation:portrait) {
	.vortex::before { width: 148%; height: 100%; }
}



.anime-float-1 { animation: float1_sp 5s linear infinite; }
.anime-float-2 { animation: float2_sp 7s ease-out infinite; }
.anime-float-3 { animation: float1_sp 6s cubic-bezier(0.93, 0.07, 0.48, 0.91) alternate-reverse infinite; }
.anime-float-4 { animation: float2_sp 6s ease-out alternate-reverse infinite; }
.anime-float-5 { animation: float1_sp 6s ease-in infinite; }

@media print, screen and (min-width:681px) {
	.anime-float-1 { animation: float1_pc 5s linear infinite; }
	.anime-float-2 { animation: float2_pc 6s ease-out infinite; }
	.anime-float-3 { animation: float1_pc 6s cubic-bezier(0.93, 0.07, 0.48, 0.91) alternate-reverse infinite; }
	.anime-float-4 { animation: float2_pc 6s ease-out alternate-reverse infinite; }
	.anime-float-5 { animation: float1_pc 6s ease-in infinite; }
}

@keyframes float1_sp {
	0% { transform: translateY(0); }
	50% { transform: translateY(-7px); }
	100% { transform: translateY(0); }
}
@keyframes float2_sp {
	0% { transform: translateY(0); }
	50% { transform: translateY(-5px) rotate(3deg); }
	100% { transform: translateY(0); }
}
@keyframes float1_pc {
	0% { transform: translateY(0); }
	50% { transform: translateY(-15px); }
	100% { transform: translateY(0); }
}
@keyframes float2_pc {
	0% { transform: translateY(0); }
	50% { transform: translateY(-10px) rotate(5deg); }
	100% { transform: translateY(0); }
}