@charset "UTF-8";
/**====================================
 * CSS information
 * file name	: common.css
 * author		: libretto works
====================================**/

@import url('https://fonts.googleapis.com/css2?family=Albert+Sans:wght@100..900&family=Cormorant+Garamond&family=Noto+Sans+JP:wght@100..900&family=Shippori+Mincho:wght@500&display=swap');

/* body
-------------------------------------------------- */
html {
	font-size: 62.5%;
}
body {
	font-size: 1.6em;
	line-height: 2.2;
	position: relative;
	font-family: "Noto Sans JP", sans-serif;
	font-weight: 400;
	letter-spacing: 0.10em;
	color: #1a1a1a;
	width: 100%;
	min-width: 1080px;
    background: #ffffff;
	-webkit-font-smoothing: antialiased;
	-moz-osx-font-smoothing: grayscale;
    font-feature-settings: "palt" 1;
    font-optical-sizing: auto;
}
body.fixed {
    position: fixed;
    width: 100%;
    height: 100%;
    left: 0;
}
body.fade {
    opacity: 0;
    transition: .3s;
}


/* link
-------------------------------------------------- */
a {
	color: #1a1a1a;
	text-decoration: none;
	transition: all .2s !important;
}
a._underline {
	text-decoration: underline;
}
a._blank::after {
    content: "";
	display: inline-block;
    width: 12px;
    height: 12px;
    background: url('data:image/svg+xml;charset=UTF-8,<svg xmlns="http://www.w3.org/2000/svg" version="1.1" width="12" height="12" viewBox="0 0 12 12"><path fill-rule="evenodd" fill="rgb(26, 26, 26)" d="M11,9H3V0h9v9h-1ZM11,1H4v7h7V1ZM9,11v1H0V3h1v8h8Z"/></svg>') no-repeat center center;
    background-size: 100% auto;
    margin-left: 6px;
    transform: translateY(2px);
}
@media screen and (min-width: 768px) {
	a:hover {
		opacity: 0.7;
	}
	a.btn-cont:hover {
		opacity: 1;
	}
}

/* clear
-------------------------------------------------- */
.clear:after {
	height: 0;
	visibility: hidden;
	content: ".";
	display: block;
	clear: both;
}

/* font
-------------------------------------------------- */
._en {
	font-family: "Albert Sans", "Noto Sans JP", sans-serif;
    font-weight: 500;
    letter-spacing: 0;
}
._serif {
	font-family: "Cormorant Garamond", serif;
    font-optical-sizing: auto;
    font-weight: 400;
    font-style: normal;
}
._min {
	font-family: "Shippori Mincho", serif;
	font-weight: 500;
	font-style: normal;
}
._nowrap {
    white-space: nowrap;
}
/* Responsive
-------------------------------------------------- */
.sp {
	display: none;
}

/* img
-------------------------------------------------- */
img {
	width: 100%;
	height: auto;
}
.thumb {
	display: block;
	overflow: hidden;
	position: relative;
	transition: .3s all;
    /*background: #cccccc;*/
}
.thumb::after {
	display: block;
	content: "";
}
.thumb img,
.thumb video,
.thumb iframe {
	position: absolute;
	top: 50%;
	left: 50%;
	transform: translate(-50%, -50%);
	width: 100%;
	height: 100%;
	object-fit: cover;
	transition: .3s all;
}
.thumb-b-wrap {
    border: 1px solid #d9d9d9;
    padding: 8px;
}
.thumb-b {
    position: relative;
}
.thumb-b:after {
    content: "";
    display: block;
}
.thumb-b img {
    width: 100%;
    height: 100%;
    position: absolute;
    top: 50%;
    left: 50%;
    object-fit: contain;
    transform: translate(-50%, -50%);
}
@media screen and (min-width: 768px) {
a:hover .thumb {
	transform: scale(0.96);
}
a:hover .thumb img {
	width: 115%;
	height: 115%;
	object-fit: cover;
}
}

/* svg
-------------------------------------------------- */
svg {
	display: block;
	width: 100%;
	height: auto;
}

/* bg
-------------------------------------------------- */
._bg {
    background: #f3f4f4;
}

/* align
-------------------------------------------------- */
._alignC {
    text-align: center;
}
._alignR {
    text-align: right;
}

.ttl {
    line-height: 1.6;
}
.en-ttl {
    letter-spacing: 0.08em;
}

/*/////////////////////////////////////////////////////////////////////////////


              // loading //
	  

/////////////////////////////////////////////////////////////////////////////*/
.loader {
	display: block;
	width: 100%;
	height: 100vh;
	position: fixed;
	top: 0;
	right: 0;
	z-index: 999999;
    pointer-events: none;
}
.loader.off {
    display: none;
}
.loader-bg {
	display: block;
	width: 100%;
	height: 100%;
	position: fixed;
	bottom: 0;
	right: 0;
	background: #ffffff;
    transition: opacity 1s .8s;
}
.off.loader-bg {
    opacity: 0;
}
.loader-logo {
	width: 180px;
	position: absolute;
	left: 50%;
	top: 50%;
	transform: translate(-50%,-55%);
	text-align: center;
	overflow: hidden;
}
.loader-logo p {
	transform: translateY(110%);
}
.on.loader-logo p {
    transition: transform 0.5s cubic-bezier(0.76, 0.09, 0.215, 1);
    transform: translateY(0);
}
.off.loader-logo {
    transition: 1s 0.8s;
    opacity: 0;
    filter: blur(10px);
}

/*/////////////////////////////////////////////////////////////////////////////


              // layout //
	  

/////////////////////////////////////////////////////////////////////////////*/

/* container
-------------------------------------------------- */
#container {
    width:100%;
    box-sizing: border-box;
    opacity: 0;
}
.motion  #container {
    transition: opacity 1s;
    opacity: 1;
}

/* section
-------------------------------------------------- */
.section-wrap {
    padding-right: 5.8565%;
	padding-left: 5.8565%;
	box-sizing: border-box;
}
.section-wrap._40 {
    padding-right: 40px;
	padding-left: 40px;
}
.section-wrap._80-0 {
	padding-left: 0;
}
.section-wrap._0-80 {
	padding-right: 0;
}
.section-wrap._130 {
	padding-left: 9.5168%;
    padding-top: 100px;
}
.section-wrap._130-130 {
    padding-right: 9.5168%;
	padding-left: 9.5168%;
    padding-top: 100px;
}
@media screen and (max-width: 1366px) {
    .section-wrap {
        padding-right: 80px;
        padding-left: 80px;
    }
}
#contents {
    position: relative;
}
.contents-inner {
    padding-bottom: 50px;
    margin-bottom: 40px;
    border-bottom: 1px solid #e3e5e5;
}
.contents-inner:last-child {
    margin-bottom: 0;
    border-bottom: none;
}
.contents-inner-txt p {
    margin-top: 1em;
}

/*/////////////////////////////////////////////////////////////////////////////


              // header //
	  

/////////////////////////////////////////////////////////////////////////////*/

/* header
-------------------------------------------------- */
.header {
	width: 100%;
    box-sizing: border-box;
    position: relative;
}
.header-logo {
	width: 140px;
    position: absolute;
    left: 25px;
    top: 35px;
    transition: .3s;
    z-index: 99998;
    opacity: 0;
    box-sizing: border-box;
}
.motion .header-logo {
    opacity: 1;
}
.header-logo a {
	display: block;
}
.st0,
.st1 {
    fill: #ffffff;
}
.sub .header-logo .st0,
.sub .header-logo .st1 {
    fill: #1a1a1a;
}

/* header-fix-nav
-------------------------------------------------- */
.header-fix-nav {
    position: fixed;
    right: 2.5622%;
    top: 30px;
    z-index: 99998;
    transition: opacity .3s .1s;
    opacity: 0;
}
.motion .header-fix-nav {
    opacity: 1;
}
.header-fix-nav ul {
    display: flex;
    justify-content: flex-start;
    align-items: center;
}
.header-fix-nav ul a {
    display: block;
    width: 160px;
    font-size: 1.4rem;
    background: #1a1a1a;
    color: #ffffff;
    text-align: center;
    margin-left: 10px;
    padding: 5px 0 6px;
}

/* header-inner
-------------------------------------------------- */
.header-inner {
    position: absolute;
    top: 105px;
    right: 2.9282%;
    transition: .3s;
    z-index: 99997;
}

/* g-nav
-------------------------------------------------- */
.g-nav {
    width: 100%;
    position: relative;
    box-sizing: border-box;
}

/* g-nav-list
-------------------------------------------------- */
.g-nav .g-nav-list {
}
.g-nav .g-nav-list li {
    transform: translateY(20px);
	opacity: 0;
    text-align: right;
    line-height: 2.1;
}
.g-nav .g-nav-list li a {
	display: inline-block;
	position: relative;
    font-size: 1.5rem;
    line-height: 1.6;
    font-weight: 500;
    z-index: 2;
}
.g-nav .g-nav-list li a::before {
	content: "";
	width: 100%;
	height: 1px;
	background: #707273;
	position: absolute;
	right: 0;
	bottom: 0;
	transform: scaleX(0);
    transform-origin: right top;
	transition: .2s;
}
.g-nav .g-nav-list li.ac a::before {
	transform: scaleX(1);
}
.g-nav .g-nav-list li._contact a::before {
    display: none;
}
.motion .g-nav li:nth-child(1) {
	animation: nav-fadeup 0.5s cubic-bezier(0.02, 0.95, 0.4, 1) forwards 0.3s;
}
.motion .g-nav li:nth-child(2) {
	animation: nav-fadeup 0.5s cubic-bezier(0.02, 0.95, 0.4, 1) forwards 0.4s;
}
.motion .g-nav li:nth-child(3) {
	animation: nav-fadeup 0.5s cubic-bezier(0.02, 0.95, 0.4, 1) forwards 0.5s;
}
.motion .g-nav li:nth-child(4) {
	animation: nav-fadeup 0.5s cubic-bezier(0.02, 0.95, 0.4, 1) forwards 0.6s;
}
.motion .g-nav li:nth-child(5) {
	animation: nav-fadeup 0.5s cubic-bezier(0.02, 0.95, 0.4, 1) forwards 0.7s;
}
.motion .g-nav li:nth-child(6) {
	animation: nav-fadeup 0.5s cubic-bezier(0.02, 0.95, 0.4, 1) forwards 0.8s;
}
.motion .g-nav li:nth-child(7) {
	animation: nav-fadeup 0.5s cubic-bezier(0.02, 0.95, 0.4, 1) forwards 0.9s;
}
.motion .g-nav li:nth-child(8) {
	animation: nav-fadeup 0.5s cubic-bezier(0.02, 0.95, 0.4, 1) forwards 1.0s;
}
@keyframes nav-fadeup {
	0% {
		transform: translateY(20px);
		opacity: 0;
	}
	100% {
		transform: translateY(0px);
		opacity: 1;
	}
}
/* hover */
@media screen and (min-width: 768px) {
    .g-nav .g-nav-list li:not(._contact) a:hover {
        opacity: 1;
    }
    .g-nav .g-nav-list li:hover a::before {
        transform: scaleX(1);
    }
}

/* fixed-nav-btn
-------------------------------------------------- */
.fixed-nav-btn {
    width: 80px;
    height: 100vh;
    position: absolute;
    top: 0;
    top: 0;
}
.scroll {
    width: 1px;
    height: calc(100% - 170px); 
    position: absolute;
    right: 0;
    bottom: 40px;
}
.sub .scroll {
    display: none;
}
.scroll::before,
.scroll::after {
    content: "";
    width: 100%;
    height: 100%;
    position: absolute;
    right: 0;
    top: 0;
    z-index: 99997;
    transition: opacity .2s;
}
.scroll::before {
    background: rgba(255,255,255,0.40);
}
.scroll::after {
    background: rgba(255,255,255,1.00);
    transform: scaleY(0);
	transform-origin: top left;
	animation: scroll-bar 3s ease-in-out infinite forwards;
}
.open .scroll::before,
.open .scroll::after {
    opacity: 0;
}
@keyframes scroll-bar {
	0% {
		transform-origin: top left;
		transform: scaleY(0); }
	50% {
		transform-origin: top left;
		transform: scaleY(1); }
	75% {
		transform-origin: bottom left;
		transform: scaleY(1); }
	95% {
		transform-origin: bottom left;
		transform: scaleY(0); }
	100% {
		transform-origin: top left;
		transform: scaleY(0); }
}

/* menu-trigger
-------------------------------------------------- */
.menu-trigger,
.menu-trigger span {
    display: block;
    transition: all .3s;
    box-sizing: border-box;
}
.menu-trigger {
    width: 80px;
    height: 75px;
    pointer-events: auto;
    cursor: pointer;
    position: fixed;
    left: 0;
    top: 50%;
    transform: translateY(-50%);
    box-sizing: border-box;
    z-index: 99999;
    opacity: 0;
}
.on .menu-trigger,
.sub .menu-trigger {
    mix-blend-mode: difference;
}
.motion .menu-trigger {
    opacity: 1;
}
.navoff .menu-trigger {
    opacity: 0;
    pointer-events: none;
}
.menu-trigger span {
    position: absolute;
    left: 23px;
    width: 34px;
    height: 1px;
    background: #ffffff;
}
.menu-trigger span:nth-of-type(1) {
    top: 28px;
}
.menu-trigger span:nth-of-type(2) {
    top: 37px;
}
.menu-trigger span:nth-of-type(3) {
    bottom: 28px;
}
.open .menu-trigger span:nth-of-type(1) {
    top: 37px;
    transform: rotate(30deg);
}
.open .menu-trigger span:nth-of-type(2) {
    opacity: 0;
}
.open .menu-trigger span:nth-of-type(3) {
   bottom: 37px;
    transform: rotate(-30deg);
}

/* fixed-sns-btn
-------------------------------------------------- */
.fixed-sns-btn {
    width: 24px;
    position: fixed;
    left: 27px;
    bottom: 50px;
    z-index: 99999;
    transition: opacity .3s;
    opacity: 0;
}
.motion .fixed-sns-btn {
    opacity: 1;
}
.on .fixed-sns-btn,
.sub .fixed-sns-btn {
    mix-blend-mode: difference;
}
.navoff .fixed-sns-btn {
    opacity: 0;
    pointer-events: none;
}
.fixed-sns-btn li {
    margin-top: 16px;
}
.fixed-sns-btn li a {
    display: block;
    width: 24px;
}

/* fixed nav
-------------------------------------------------- */
.fixed-nav {
	position: fixed;
	left: 0;
	top: 0;
	width: 100vw;
	height: 100vh;
	background: rgba(0,0,0,0.60);
	transition: all .3s;
	z-index: 99998;
	line-height: 2;
	opacity: 0;
	pointer-events: none;
}
.open .fixed-nav {
	opacity: 1;
	pointer-events: auto;
}
.fixed-nav a {
    color: #ffffff;
}
.fixed-inner {
	width: 70%;
	height: 100vh;
	box-sizing: border-box;
	overflow: scroll;
	-webkit-overflow-scrolling: touch;
	overflow-scrolling: touch;
	position: relative;
    transition: .3s;
}
.fixed-inner::before {
    content: "";
    width: 70%;
    height: 100%;
    background: #0d0d0d;
    position: fixed;
    left: 0;
    top: 0;
    transform: scaleX(0);
    transform-origin: left center;
    transition: 0.85s cubic-bezier(0,.93,.45,1);
}
.open .fixed-inner::before {
	transform: scaleX(1);
}
.fixed-nav nav {
	width: 100%;
    box-sizing: border-box;
    padding: 160px 80px 80px 170px;
    position: absolute;
	left: 0;
	top: 50%;
	transform: translateY(-50%);
}
.fixed-nav .m-nav-wrap {
    display: flex;
    justify-content: space-between;
    flex-wrap: wrap;
}
.fixed-nav .m-nav {
    width: 47%;
}
.fixed-nav .m-nav > li {
    margin: 0 0 26px;
}
.fixed-nav .m-nav > li a {
    display: block;
    line-height: 1.6;
}
.fixed-nav .m-nav > li a ._en {
    display: block;
    font-size: 2.4rem;
    letter-spacing: 0.04em;
}
.fixed-nav .m-nav-sub {
    padding: 0;
}
.fixed-nav .m-nav-sub > li {
    padding: 9px 0 0;
}
.fixed-nav .m-nav-sub > li a {
    font-size: 1.4rem;
    line-height: 1.5;
    color: #b3b3b3;
}
.m-nav-btm {
    border-top: 1px solid rgba(255,255,255,0.20);
    padding-top: 40px;
    margin-top: 35px;
}
.m-cv-nav {
    display: flex;
    justify-content: flex-start;
    align-items: center;
    padding-bottom: 20px;
}
.m-cv-nav li {
    margin-right: 10px;
}
.m-cv-nav li a {
    display: block;
    width: 210px;
    font-size: 1.5rem;
    text-align: center;
    border: 1px solid rgba(255,255,255,0.60);
    padding: 10px 0;
}
.m-subnav {
    font-size: 1.4rem;
    letter-spacing: 0.04em;
}
.fixed-nav .sns-link {
    display: none;
}

/* hover */
@media screen and (min-width: 768px) {
}

/*/////////////////////////////////////////////////////////////////////////////


              // footer //
	  

/////////////////////////////////////////////////////////////////////////////*/
.footer {
    background: #898d8f;
    color: #ffffff;
    overflow: hidden;
    position: relative;
}
.footer a {
    color: #ffffff;
    font-weight: 500;
}
.footer-inner {
    padding: 100px 4.3923% 20px;
}
.footer-col2 {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    margin-bottom: 100px;
}
.ft-cont {
    width: calc(100% - 260px);
}
.ft-nav {
    display: flex;
    justify-content: flex-start;
    flex-wrap: wrap;
    margin-bottom: 32px;
}
.ft-nav li {
    font-size: 1.5rem;
    margin: 0 32px 16px 0;
}
.ft-subnav {
    display: flex;
    justify-content: flex-start;
    flex-wrap: wrap;
    margin-bottom: 30px;
}
.ft-subnav li {
    font-size: 1.4rem;
    margin: 0 32px 0 0;
}
.sns-link {
    display: flex;
    justify-content: flex-start;
    flex-wrap: wrap;
}
.sns-link li {
    width: 26px;
    margin-right: 25px;
}
.ft-cv {
    width: 240px;
}
.ft-cv li {
    margin-bottom: 10px;
}
.ft-cv li a {
    display: block;
    font-size: 1.8rem;
    text-align: center;
    border: 1px solid #ffffff;
    padding: 14px 0;
}
.ft-shop {
    display: flex;
    justify-content: flex-start;
}
.ft-shop li {
    width: 220px;
    margin-right: 70px;
}
.ft-shop li .ttl {
    font-size: 1.7rem;
    border-bottom: 1px solid rgba(255,255,255,0.40);
    padding-bottom: 6px;
    margin-bottom: 6px;
}
.ft-shop li .txt {
    font-size: 1.4rem;
    line-height: 1.9;
}
.ft-logo {
    width: 71.7423%;
    margin: 0 0 0 1.4641%;
    transform: translateY(16px);
}
.copyright {
    position: absolute;
    right: 2.9282%;
    bottom: 30px;
}

/*/////////////////////////////////////////////////////////////////////////////


              // ctaArea //
	  

/////////////////////////////////////////////////////////////////////////////*/
.ctaArea {
    margin: 120px 0 60px;
}
.ctaArea-list {
    display: flex;
    justify-content: space-between;
    align-items: stretch;
    border-top: 1px solid #babdbe;
    padding: 48px 0 0;
}
.ctaArea-list li {
    width: 50%;
    box-sizing: border-box;
    text-align: center;
    padding: 148px 0 100px;
}
.ctaArea-list li:first-child {
    border-right: 1px solid #babdbe;
}
.ctaArea-list li .sec-ttl {
    margin-bottom: 48px;
}
.sec-movie + .ctaArea {
    margin-top: 0;
}
.sec-movie + .ctaArea .ctaArea-list {
    border-top: none;
    padding: 0;
}

/*/////////////////////////////////////////////////////////////////////////////


              // common parts //
	  

/////////////////////////////////////////////////////////////////////////////*/

/* ==================================================
    breadcrumb
================================================== */
.breadcrumb {
    display: flex;
    justify-content: flex-start;
    align-items: center;
    flex-wrap: wrap;
    padding: 0 0 75px;
    position: relative;
    transition: opacity 1s .5s;
    opacity: 0;
}
.motion .breadcrumb {
    opacity: 1;
}
.page-ttl-col2 .breadcrumb {
    position: absolute;
    left: 0;
    top: 13.6718%;
    padding-bottom: 0;
}
.breadcrumb li {
    font-size: 1.2rem;
    font-weight: 500;
    position: relative;
    padding-right: 55px;
    margin-right: 15px;
}
.breadcrumb li:last-child::after {
    display: none;
}
.breadcrumb li::after {
    content: "";
    width: 40px;
    height: 1px;
    background: #babdbe;
    position: absolute;
    right: 0;
    top: 50%;
}
.breadcrumb li.ja {
    font-size: 1.1rem;
    font-weight: 400;
}

/* ==================================================
    title
================================================== */

/* page-ttl
-------------------------------------------------- */
.page-ttl {
    padding: 130px 5.8565% 0 9.5168%;
}
.page-ttl-col2 {
    display: flex;
    justify-content: space-between;
    align-items: stretch;
    height: 100vh;
    min-height: 640px;
}
.page-ttl-fig {
    width: 38.7994%;
    height: 100%;
    position: relative;
}
.page-ttl-fig::before,
.page-ttl-fig::after {
    content: "";
    width: 100%;
    height: 100%;
    position: absolute;
    left: 0;
    top: 0;
}
.page-ttl-fig::before {
    background: rgba(25,25,26,0.28);
    z-index: 1;
}
.page-ttl-fig::after {
    background: #ffffff;
    transform-origin: left bottom;
    z-index: 2;
}
.motion .page-ttl-fig::after {
    transition: 0.8s cubic-bezier(0.76, 0.09, 0.215, 1);
    transform: scaleY(0);
}
.page-ttl-fig .thumb {
    width: 100%;
    height: 100%;
}
.page-ttl-inner {
    display: flex;
    justify-content: flex-start;
    align-items: center;
    width: 37.9209%;
    padding: 15px 13.9092% 0 0;
    position: relative;
}
.page-ttl-cont .ttl {
    font-size: 1.8rem;
    margin-bottom: 10px;
    transition: opacity 1s .3s;
    opacity: 0;
}
.motion .page-ttl-cont .ttl {
    opacity: 1;
}
.page-ttl-cont .en-ttl {
    font-size: 9.8rem;
    line-height: 1;
    letter-spacing: 0.02em;
    white-space: nowrap;
}
.page-ttl-cont .en-ttl ._ty {
    display: inline-block;
    transform: translateY(-4%) scaleY(92%);
}
.page-ttl-cont .ja-ttl {
    font-size: 5.8rem;
    line-height: 1.5;
    padding: 6px 0 7px;
}
.motion .page-ttl-cont .en-ttl .txtef-wrap .txtef,
.motion .page-ttl-cont .ja-ttl .txtef-wrap .txtef {
    transition: transform 0.65s cubic-bezier(0.76, 0.09, 0.215, 1) 0.1s;
    transform: translateY(0);
}
.page-ttl-cont .lead {
    margin-top: 26px;
    transition: opacity 1s .4s;
    opacity: 0;
}
.page-ttl-cont .note-txt {
    margin: 56px 0 -20px;
    transition: opacity 1s .4s;
    opacity: 0;
}
.motion .page-ttl-cont .note-txt,
.motion .page-ttl-cont .lead {
    opacity: 1;
}
.page-ttl-cont-fig {
    width: 58.2743%;
    position: absolute;
    right: 2.5622vw;
    top: 86.71875%;
}
.page-ttl-cont-fig .thumb::after {
    padding-top: 75%;
}

/* news  ---- */
.page-ttl-cont .en-subttl {
    font-size: 1.8rem;
    line-height: 1;
}
.page-ttl-cont .news-ttl {
    font-size: 4.6rem;
    line-height: 1.6;
    margin: 16px 0 26px;
}

/* page-ttl-btm
-------------------------------------------------- */
.page-ttl-btm {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    flex-direction: row-reverse;
}
.page-ttl-btm-fig {
    width: 30.1610%;
    padding: 0 2.5622% 0 0;
    margin-top: -100px;
    transition: opacity 1s .5s;
    opacity: 0;
}
.motion .page-ttl-btm-fig {
    opacity: 1;
}
.page-ttl-btm-fig .thumb::after {
    padding-top: 75%;
}

/* anchor-link
-------------------------------------------------- */
.anchor-link {
    width: 56.6617%;
    padding: 64px 0 0 7.3206%;
}
.anchor-link ul {
    display: flex;
    justify-content: flex-start;
    align-items: center;
    flex-wrap: wrap;
}
.anchor-link ul li {
    width: 25.9067%;
    margin: 0 3.886% 0 0;
}
.anchor-link ul li a {
    display: block;
    width: 100%;
    border-bottom: 1px solid #babdbe;
    line-height: 1.5;
    padding: 30px 0;
    position: relative;
}
.anchor-link ul li a::after {
    content: "";
    width: 11px;
    height: 6px;
    background: url('data:image/svg+xml;charset=UTF-8,<svg xmlns="http://www.w3.org/2000/svg" version="1.1" width="11" height="6" viewBox="0 0 11 6"><path fill="rgb(26, 26, 26)" d="M.7,0l-.7.7,5.5,5.3L11,.7l-.7-.7-4.8,4.6L.7,0Z"/></svg>') right center no-repeat;
    background-size: 100% auto;
    position: absolute;
    right: 10px;
    top: 50%;
    transform: translateY(-50%);
}
.anchor-link .lead {
    font-size: 2.0rem;
    line-height: 2;
    margin-top: 64px;
}
.anchor-link._fig ul li {
    width: 36.5%;
}
.anchor-link._fig ul li a {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 15px 0;
}
.anchor-link._fig ul li a .thumb {
    width: 60px;
    height: 60px;
}
.anchor-link._fig ul li a p {
    width: calc(100% - 80px);
}

/* page-link
-------------------------------------------------- */
.page-link {
    width: 56.6617%;
    padding: 74px 0 0 7.3206%;
}
.page-link ul {
    display: flex;
    justify-content: flex-start;
    align-items: center;
    flex-wrap: wrap;
}
.page-link ul li {
    width: 25.9067%;
    margin: 0 3.886% 0 0;
}
.page-link ul li a {
    display: block;
    width: 100%;
    border-top: 1px solid #babdbe;
    border-bottom: 1px solid #babdbe;
    line-height: 1.5;
    padding: 25px 0;
    position: relative;
}
.page-link ul li a::after {
    content: "";
    width: 18px;
    height: 11px;
    position: absolute;
    right: 10px;
    top: 50%;
    transform: translateY(-50%);
    transition: .2s;
    transform-origin: center center;
    background: url('data:image/svg+xml;charset=UTF-8,<svg xmlns="http://www.w3.org/2000/svg" version="1.1" width="18" height="11" viewBox="0 0 18 11"><path fill="rgb(26, 26, 26)" d="M12.721,-0.000 L12.000,0.692 L16.127,4.993 L-0.000,4.993 L-0.000,5.992 L16.140,5.992 L12.000,10.307 L12.721,11.000 L18.000,5.500 L12.721,-0.000 Z"/></svg>') right center no-repeat;
    background-size: 100% auto;
}

/* sec-ttl
-------------------------------------------------- */
.sec-ttl {
    position: relative;
    line-height: 1.9;
}
.sec-ttl._center {
    text-align: center;
}
.sec-ttl .subttl {
    font-size: 1.8rem;
    margin-bottom: 10px;
    opacity: 0;
    transition: opacity 1s .1s;
}
.sec-ttl .en-ttl {
    opacity: 0;
    transition: opacity 1s .1s;
}
.sec-ttl .ttl {
    font-size: 3.2rem;
    line-height: 1.9;
    letter-spacing: 0.12em;
}
.sec-ttl .lead {
    margin-top: 24px;
    opacity: 0;
    transition: opacity 1s .3s;
}
.sec-ttl .txt {
    margin-top: 32px;
    text-align: left;
    opacity: 0;
    transition: opacity 1s .3s;
}
.sec-ttl.on .subttl,
.sec-ttl.on .en-ttl,
.sec-ttl.on .lead,
.sec-ttl.on .txt {
    opacity: 1
}
.sec-ttl .ttl._large {
    font-size: 3.8rem;
}
.sec-ttl .sub {
    font-size: 1.7rem;
    letter-spacing: 0.04em;
    margin-top: 4px;
}
.sec-ttl._col2 {
    display: flex;
    justify-content: space-between;
    padding: 70px 0 0;
}
.sec-ttl._col2::before {
    content: "";
    width: 100%;
    height: 1px;
    background: #babdbe;
    position: absolute;
    left: 0;
    top: 0;
    transform: scaleX(0);
    transform-origin: left center;
    transition: 1.2s cubic-bezier(0.04, 0.8, 0.35, 1) .1s;
}
.sec-ttl._col2.on::before {
    transform: scaleX(1);
}
.sec-ttl._col2 .en-ttl {
    padding: 14px 0 0;
}
.sec-ttl._col2 .sec-ttl-inner {
    width: 45.6053%;
}
.sec-ttl._col2._flex .en-ttl {
    width: 140px;
}
.sec-ttl._col2._flex .sec-ttl-inner {
    width: calc(100% - 160px);
}

/* sec-ttl-bd
-------------------------------------------------- */
.sec-ttl-bd {
    position: relative;
    padding: 30px 0 0;
}
.sec-ttl-bd::before {
    content: "";
    width: 100%;
    height: 1px;
    background: #babdbe;
    position: absolute;
    left: 0;
    top: 0;
    transform: scaleX(0);
    transform-origin: left center;
    transition: 1.2s cubic-bezier(0.04, 0.8, 0.35, 1) .1s;
}
.sec-ttl-bd.on::before {
    transform: scaleX(1);
}
.sec-ttl-bd .en-ttl {
    letter-spacing: 0.08em;
    opacity: 0;
    transition: opacity 1s .1s;
}
.sec-ttl-bd.on .en-ttl {
    opacity: 1
}
.sec-ttl-bd .ttl {
    font-size: 2.8rem;
    line-height: 1.6;
    letter-spacing: 0.08em;
    margin-top: 20px;
}
.sec-ttl-bd .en-ttl + .ttl {
    margin-top: 40px;
}
.sec-ttl-bd .ttl ._pr {
    display: inline-block;
    font-size: 3.4rem;
    text-align: left;
    padding-right: 6.6334%;
}

/* ===============================================
    btn
=============================================== */

/* btn
-------------------------------------------------- */
.btn {
    margin-top: 32px;
    position: relative;
    z-index: 1;
}
.btn a {
    display: inline-block;
    width: 220px;
    position: relative;
    font-size: 1.5rem;
    font-weight: 500;
    padding: 15px 2px;
    text-align: left;
}
.btn a::before {
    content: "";
    width: 100%;
    height: 1px;
    background: #babdbe;
    position: absolute;
    left: 0;
    bottom: 0;
}
.btn a::after {
    content: "";
    width: 18px;
    height: 11px;
    position: absolute;
    right: 10px;
    top: 50%;
    transform: translateY(-50%);
    transition: .2s;
    transform-origin: center center;
    background: url('data:image/svg+xml;charset=UTF-8,<svg xmlns="http://www.w3.org/2000/svg" version="1.1" width="18" height="11" viewBox="0 0 18 11"><path fill="rgb(26, 26, 26)" d="M12.721,-0.000 L12.000,0.692 L16.127,4.993 L-0.000,4.993 L-0.000,5.992 L16.140,5.992 L12.000,10.307 L12.721,11.000 L18.000,5.500 L12.721,-0.000 Z"/></svg>') center center no-repeat;
    background-size: 100% auto;
}
.btn._wht a {
    color: #ffffff;
}
.btn._wht a::before {
    background: #ffffff;
}
.btn._wht a::after {
    background: url('data:image/svg+xml;charset=UTF-8,<svg xmlns="http://www.w3.org/2000/svg" version="1.1" width="18" height="11" viewBox="0 0 18 11"><path fill="rgb(255, 255, 255)" d="M12.721,-0.000 L12.000,0.692 L16.127,4.993 L-0.000,4.993 L-0.000,5.992 L16.140,5.992 L12.000,10.307 L12.721,11.000 L18.000,5.500 L12.721,-0.000 Z"/></svg>') center center no-repeat;
    background-size: 100% auto;
}
.btn._min a {
    width: 310px;
    font-size: 1.6rem;
    padding: 18px 2px;
}

/* hover */
@media screen and (min-width: 768px) {
    .btn a:hover {
        opacity: 1;
    }
    .btn a:hover::before {
        animation: btn .5s 1 ease;
    }
    .btn a:hover::after {
        right: 0;
    }
}
@keyframes btn {
  0% {
	  transform-origin: right top;
  }
  50% {
	  transform-origin: right top;
	  transform: scaleX(0);
  }
  51% {
	  transform-origin: left top;
	  transform: scaleX(0);
  }
  100% {
	  transform-origin: left top;
	  transform: scaleX(1);
  }
}

/* btn-center
-------------------------------------------------- */
.btn-center {
    text-align: center;
}
.btn-center a {
    display: inline-block;
    width: 280px;
    font-size: 3.8rem;
    font-weight: 400;
    line-height: 1.6;
    position: relative;
}
.btn-center a::before {
    content: "";
    width: 100%;
    height: 1px;
    background: #babdbe;
    position: absolute;
    left: 0;
    bottom: 0;
}

/* hover */
@media screen and (min-width: 768px) {
    .btn-center a:hover {
        opacity: 1;
    }
    .btn-center a:hover::before {
        animation: btn .5s 1 ease;
    }
}

/* btn-txt
-------------------------------------------------- */
.btn-box {
    text-align: center;
}
.btn-box a {
    display: inline-block;
    width: 280px;
    background: #1a1a1a;
    color: #ffffff;
    text-align: center;
    line-height: 1.5;
    padding: 18px 10px;
    box-sizing: border-box;
}

/* arrow
-------------------------------------------------- */
.arrow,
.arrow::before,
.arrow::after {
    display: block;
    content: "";
    width: 75px;
    height: 75px;
    border-radius: 50%;
    position: absolute;
    right: 0;
    top: 50%;
    transform: translateY(-50%);
    transition: .2s;
    box-sizing: border-box;
}
.arrow::before {
    border: 1px solid #ffffff;
}
.arrow::after {
    background: url('data:image/svg+xml;charset=UTF-8,<svg xmlns="http://www.w3.org/2000/svg" version="1.1" width="18" height="11" viewBox="0 0 18 11"><path fill="rgb(255, 255, 255)" d="M12.721,-0.000 L12.000,0.692 L16.127,4.993 L-0.000,4.993 L-0.000,5.992 L16.140,5.992 L12.000,10.307 L12.721,11.000 L18.000,5.500 L12.721,-0.000 Z"/></svg>') center center no-repeat;
    background-size: 18px auto;
}

/* hover */
@media screen and (min-width: 768px) {
    a.box-link:hover {
        opacity: 1;
    }
    a.box-link:hover .arrow::before {
        transform: translateY(-50%) scale(1.5);
    }
}



/* ===============================================
    sec-pagelink
=============================================== */
.sec-pagelink {
    position: relative;
}
.sec-pagelink-fig {
    width: 100%;
    height: 100%;
    position: absolute;
    left: 0;
    top: 0;
}
.sec-pagelink-fig::after {
    content: "";
    width: 100%;
    height: 100%;
    background: rgba(42,44,46,0.70);
    position: absolute;
    left: 0;
    top: 0;
}
.sec-pagelink-fig .thumb {
    width: 100%;
    height: 100%;
}
.sec-pagelink-block {
    padding: 190px 0 175px 60.8623%;
    color: #ffffff;
}


/* ===============================================
    parallax
=============================================== */
.parallax01,
.parallax02,
.parallax03 {
    position: relative;
}
.parallax-inner {
    width: 100%;
    position: absolute;
    top: 0;
    left: 0;
}
.parallax-img {
	transition: none !important;
	position: relative;
}
.parallax-img span {
	width: 100%;
	height: 100%;
	display: block;
	position: absolute;
	top: 0;
	left: 0;
	transition: none !important;
}
.parallax-img.thumb img {
	height: 110%;
}
/* ===============================================
    table
=============================================== */
dl.table {
	width: 100%;
	display: flex;
	flex-wrap: wrap;
    box-sizing: border-box;
    border-bottom: 1px solid #d6d7d8;
}
dl.table dt {
	width: 20%;
	border-top: 1px solid #d6d7d8;
	padding: 20px 0;
}
dl.table dd {
	width: 75%;
	border-top: 1px solid #d6d7d8;
	padding: 20px 0 10px 5%;
    position: relative;
}
dl.table dd p {
	padding-bottom: 10px;
}
dl.table .list li {
    display: flex;
    justify-content: flex-start;
}
dl.table .list li p {
    width: 82%;
}
dl.table .list li p:nth-child(1) {
    width: 18%;
}

/* ===============================================
    list-disc 
=============================================== */
.list-disc-ttl {
	margin-bottom: 5px;
}
.list-disc > li {
    position: relative;
    line-height: 1.5;
	padding: 5px 0 5px 20px;
}
.list-disc > li::before {
    content: "";
    width: 8px;
    height: 8px;
    background: #babdbe;
    position: absolute;
    left: 0;
    top: 0.9em;
    border-radius: 50%;
}
.list-note > li {
	text-indent: -1.5em;
	font-size: 1.4rem;
	line-height: 1.5;
	padding: 4px 0 4px 1.5em;
}
.list-note > li::before {
	content: "※ ";
}
.list-note > li ul {
    padding: 4px 0 4px 1.5em;
}
.list-note > li ul li {
    padding: 4px 0;
}
.list-note > li ul li .dot {
    color: #8e9294;
}

/*/////////////////////////////////////////////////////////////////////////////


              // Slider //
	  

/////////////////////////////////////////////////////////////////////////////*/
.slick-slider {
    position: relative;
    display: block;
    box-sizing: border-box;
    -webkit-user-select: none;
    -moz-user-select: none;
    -ms-user-select: none;
    user-select: none;
    -webkit-touch-callout: none;
    -khtml-user-select: none;
    -ms-touch-action: pan-y;
    touch-action: pan-y;
    -webkit-tap-highlight-color: transparent;
}
.slick-list {
    position: relative;
    display: block;
    overflow: hidden;
    margin: 0;
    padding: 0;
}
.slick-list:focus {
    outline: none;
}
.slick-list.dragging {
    cursor: pointer;
    cursor: hand;
}
.slick-slider .slick-track,
.slick-slider .slick-list {
    -webkit-transform: translate3d(0, 0, 0);
    -moz-transform: translate3d(0, 0, 0);
    -o-transform: translate3d(0, 0, 0);
    transform: translate3d(0, 0, 0);
}
.slick-track {
    position: relative;
    top: 0;
    left: 0;
    display: block;
}
.slick-track:before,
.slick-track:after {
    display: table;
    content: '';
}
.slick-track:after {
    clear: both;
}
.slick-loading .slick-track {
    visibility: hidden;
}
.slick-slide {
    display: none;
    float: left;
    height: 100%;
    min-height: 1px;
}
[dir='rtl'] .slick-slide {
    float: right;
}
.slick-slide img {
    display: block;
}
.slick-slide.slick-loading img {
    display: none;
}
.slick-slide.dragging img {
    pointer-events: none;
}
.slick-initialized .slick-slide {
    display: block;
}
.slick-loading .slick-slide {
    visibility: hidden;
}
.slick-vertical .slick-slide {
    display: block;
    height: auto;
    border: 1px solid transparent;
}
.slick-arrow.slick-hidden {
    display: none;
}
/* Arrows */
.slick-prev,
.slick-next {   
    position:  absolute;
	top: 32%;
	width: 55px;
	height: 55px;
	overflow: hidden;
	font-size: 0;
    line-height: 0;
	display: block;
	cursor: pointer;
    border: 1px solid #babdbe;
	background-position: center center;
	background-repeat: no-repeat;
	background-size: 18px auto;
    background-color: #ffffff;
    background-image: url('data:image/svg+xml;charset=UTF-8,<svg xmlns="http://www.w3.org/2000/svg" version="1.1" width="18" height="11" viewBox="0 0 18 11"><path fill="rgb(26, 26, 26)" d="M12.721,-0.000 L12.000,0.692 L16.127,4.993 L-0.000,4.993 L-0.000,5.992 L16.140,5.992 L12.000,10.307 L12.721,11.000 L18.000,5.500 L12.721,-0.000 Z"/></svg>');
	z-index: 999;
	transition: .2s;
	border-radius: 50%;
    box-sizing: border-box;
}
.slick-prev {
    left: -30px;
    transform: rotate(180deg);
}
.slick-next {
    right: 6.4724%;
}
.gallery-slider .slick-prev,
.gallery-slider .slick-next {
    top: -35px;
}
.gallery-slider .slick-prev {
    left: inherit;
    right: 6.4724%;
    margin-right: 65px;
}
.item-slider .slick-prev,
.item-slider .slick-next {
    top: inherit;
    bottom: 0;
}
.item-slider .slick-prev {
    left: 68%;
}
.item-slider .slick-next {
    right: inherit;
    left: 68%;
    margin-left: 65px;
}
.slick-prev:active,
.slick-prev:focus,
.slick-next:active,
.slick-next:focus,
.slick-slide a {
    outline: none;
}
.slick-next.slick-arrow.slick-disabled {
    opacity: 0;
    pointer-events: none;
}

/* Dots */
.slick-dotted.slick-slider {
    margin-bottom: 0;
}
.slick-dots {
    position: absolute;
    bottom: 15px;
    left: 71.3102%;
    display: block;
    width: auto;
    padding: 0;
    margin: 0 0 0 140px;
    list-style: none;
    text-align: left;
}
.slick-dots li {
    position: relative;
    display: inline-block;
    width: 5px;
    height: 5px;
    margin: 0 7px 0 0 !important;
    padding: 0 !important;
    cursor: pointer;
}
.slick-dots li button {
    font-size: 0;
    line-height: 0;
    display: block;
    width: 5px;
    height: 5px;
	padding: 0;
    cursor: pointer;
    color: transparent;
    border: 0;
    outline: none;
    background: #1f2a30;
	border-radius: 50%;
    opacity: 0.4;
}
.slick-dots li.slick-active button {
    opacity: 1;
}

/*/////////////////////////////////////////////////////////////////////////////


              // modal //
	  

/////////////////////////////////////////////////////////////////////////////*/
.modal-overlay {
	width: 100%;
	height: 100vh;
	position: fixed;
	left: 0;
	top: 0;
	background: rgba(0,0,0,0.60);
	z-index: 999998;
	display: none;
}
.modal-contents {
	width: 100%;
	height: 100vh;
	position: fixed;
	left: 0;
	top: 0;
	z-index: 999999;
	display: none;
	overflow: scroll;
	-webkit-overflow-scrolling: touch;
	overflow-scrolling: touch;
}
.modal-contents .modal-block {
	width: 980px;
	height: auto;
	position: absolute;
	left: 50%;
	top: 50%;
	z-index: 999999;
	transform: translate(-50%,-50%);
	margin: 0 auto;
    box-sizing: border-box;
}
.modal-contents .modal-block-inner {
    width: 100%;
    display: flex;
    justify-content: space-between;
    background: #ffffff;
    padding: 40px;
    box-sizing: border-box;
}
.modal-contents .close {
	display: inline-block;
	position: absolute;
	width: 55px;
	height: 55px;
	cursor: pointer;
    background: #ffffff;
	right: 20px;
	top: 14px;
    box-sizing: border-box;
    transition: .2s;
}
.modal-contents .close.sp {
    display: none;
}
.modal-contents .close::before,
.modal-contents .close::after {
	content: "";
	width: 34px;
	height: 1px;
	background: #1a1a1a;
	position: absolute;
	top: 27px;
	left: 10px;
	transform-origin: center center;
    transition: .2s;
}
.modal-contents .close::before {
	transform: rotate(-30deg);
}
.modal-contents .close::after {
	transform: rotate(30deg);
}
.modal-contents .modal-block .thumb {
    width: 42%;
}
.modal-contents .modal-block .thumb::after {
    padding-top: 118.3333%;
}
.modal-contents .modal-block .block-cont {
    width: 52%;
}
.modal-contents .modal-block .block-cont-ttl {
    margin-bottom: 16px;
    border-top: 1px solid #babdbe;
}
.modal-contents .modal-block .block-cont-ttl .en-ttl {
    font-size: 1.2rem;
    line-height: 1.5;
    padding: 4px 0 20px;
}
.modal-contents .modal-block .block-cont-ttl-logo {
    width: 190px;
    margin: 0 auto;
}
.modal-contents .modal-block .block-cont-txt .ttl {
    font-size: 1.8rem;
    text-align: center;
    margin-bottom: 12px;
}
.modal-contents .modal-block .block-cont-txt .txt {
    font-size: 1.4rem;
    line-height: 2;
}

/*/////////////////////////////////////////////////////////////////////////////


              // motion //
	  

/////////////////////////////////////////////////////////////////////////////*/

/* ef txtef
-------------------------------------------------- */
.txtef-wrap {
	display: block;
	overflow: hidden;
}
.txtef {
	display: block;
	transform: translateY(100%);
}
.sec-ttl.on .txtef-wrap .txtef,
.sec-ttl-bd.on .txtef-wrap .txtef,
.ef.on .txtef-wrap:nth-child(1) .txtef {
    transition: 0.7s cubic-bezier(0.04, 0.8, 0.35, 1) .28s;
    transform: translateY(0);
}
.ef.on .txtef-wrap:nth-child(2) .txtef {
    transition: 0.7s cubic-bezier(0.04, 0.8, 0.35, 1) .38s;
    transform: translateY(0);
}
.ef.on .txtef-wrap:nth-child(3) .txtef {
    transition: 0.7s cubic-bezier(0.04, 0.8, 0.35, 1) .48s;
    transform: translateY(0);
}
.ef.on .txtef-wrap:nth-child(4) .txtef {
    transition: 0.7s cubic-bezier(0.04, 0.8, 0.35, 1) .58s;
    transform: translateY(0);
}

/* ttl-overlay
-------------------------------------------------- */
@keyframes ttl-overlay {
	0% {
		transform: scaleX(1);
	}
	100% {
		transform: scaleX(0);
	}
}

/* ttl-fadeup
-------------------------------------------------- */
@keyframes ttl-fadeup {
	0% {
		transform: translateY(100%);
	}
	100% {
		transform: translateY(0);
	}
}

/* fade
-------------------------------------------------- */
.mf {
	opacity:0;
}
.mf.on {
	transition: opacity 1s !important;
	opacity: 1;
}
@-webkit-keyframes fade {
	0% {
		opacity: 0; }
	100% {
		opacity: 1; }
}
@keyframes fade {
	0% {
		opacity: 0; }
	100% {
		opacity: 1; }
}

/* fade up
-------------------------------------------------- */
.mfu {
	opacity:0;
	transform:translateY(80px);
}
span.mfu {
	display: block;
}
.mfu.on {
    transition: 2s cubic-bezier(0.075, 0.82, 0.165, 1) !important;
    opacity: 1;
    transform: translateY(0);
}

/* fade up list
-------------------------------------------------- */
.mful li {
	opacity: 0;
	transform: translateY(80px);
}
.mful.on li:nth-child(1) {
    transition: 2s cubic-bezier(0.075, 0.82, 0.165, 1);
    opacity: 1;
    transform: translateY(0);
}
.mful.on li:nth-child(2) {
    transition: 2s cubic-bezier(0.075, 0.82, 0.165, 1) .2s;
    opacity: 1;
    transform: translateY(0);
}
.mful.on li:nth-child(3) {
    transition: 2s cubic-bezier(0.075, 0.82, 0.165, 1) .4s;
    opacity: 1;
    transform: translateY(0);
}
.mful.on li:nth-child(4) {
    transition: 2s cubic-bezier(0.075, 0.82, 0.165, 1) .6s;
    opacity: 1;
    transform: translateY(0);
}
.mful.on li:nth-child(5) {
    transition: 2s cubic-bezier(0.075, 0.82, 0.165, 1) .8s;
    opacity: 1;
    transform: translateY(0);
}
.mful.on li:nth-child(6) {
    transition: 2s cubic-bezier(0.075, 0.82, 0.165, 1) 1.0s;
    opacity: 1;
    transform: translateY(0);
}
.mful.on li:nth-child(7) {
    transition: 2s cubic-bezier(0.075, 0.82, 0.165, 1) 1.2s;
    opacity: 1;
    transform: translateY(0);
}
.mful.on li:nth-child(8) {
    transition: 2s cubic-bezier(0.075, 0.82, 0.165, 1) 1.4s;
    opacity: 1;
    transform: translateY(0);
}
@-webkit-keyframes ef-fadeup {
	0% {
		opacity:0;
		transform:translateY(80px); }
	100% {
		opacity:1;
		transform:translateY(0%); }
}
@keyframes ef-fadeup {
	0% {
		opacity:0;
		transform:translateY(80px); }
	100% {
		opacity:1;
		transform:translateY(0%); }
}

/* fade down
-------------------------------------------------- */
.mfd {
	opacity:0;
	-webkit-transform:translateY(-80px);
	transform:translateY(-80px);
}
span.mfd {
	display: block;
}
.mfd.on {
	-webkit-animation: ef-fadedown 2s cubic-bezier(0.075, 0.82, 0.165, 1) forwards;
	animation: ef-fadedown 2s cubic-bezier(0.075, 0.82, 0.165, 1) forwards;
}
@-webkit-keyframes ef-fadedown {
	0% {
		opacity:0;
		transform:translateY(-80px); }
	100% {
		opacity:1;
		transform:translateY(0%); }
}
@keyframes ef-fadedown {
	0% {
		opacity:0;
		transform:translateY(-80px); }
	100% {
		opacity:1;
		transform:translateY(0%); }
}

/* fade left
-------------------------------------------------- */
.mfl {
	opacity: 0;
	transform: translateX(-40px);
}
.mfl.on {
	animation: ef-fadeleft 2s cubic-bezier(0.075, 0.82, 0.165, 1) forwards;
}
@keyframes ef-fadeleft {
	0% {
		opacity: 0;
		transform: translateX(-40px); }
	100% {
		opacity: 1;
		transform: translateY(0%); }
}

/* fade right
-------------------------------------------------- */
.mfr {
	opacity: 0;
	transform: translateX(40px);
}
.mfr.on {
	animation: ef-faderight 2s cubic-bezier(0.075, 0.82, 0.165, 1) forwards;
}
@keyframes ef-faderight {
	0% {
		opacity: 0;
		transform: translateX(40px); }
	100% {
		opacity: 1;
		transform: translateY(0%); }
}

/* ef txtef mask
-------------------------------------------------- */
.mtm {
	display: inline-block;
	position: relative;
}
.mtm::after {
	content: "";
	width: 100%;
	height: 100%;
	background: rgba(255,255,255,0.80);
	position: absolute;
	left: 0;
	top: 0;
	transform-origin: right center;
}
.mtm._gry::after {
	background: rgba(248,248,248,0.80);
}
.mtm._blk::after {
	background: rgba(42,44,46,0.80);
}
.mtm.on::after  {
	animation: ef-scaleX 1.4s cubic-bezier(0.04, 0.8, 0.35, 1) forwards;
}

/* ef scaleX
-------------------------------------------------- */
.ef .thumb::before {
	content: "";
	width: calc(100% + 2px);
	height: calc(100% + 2px);
	position: absolute;
	left: 0;
	top: 0;
	background: #FFFFFF;
	z-index: 2;
	transform-origin: right center;
}
.ef._gry .thumb::before {
    background: #53595d;
}
.ef.on .thumb::before {
    transition: 0.70s cubic-bezier(0.76, 0.09, 0.215, 1);
    transform: scaleX(0);
}
@keyframes ef-scaleX {
	0% {
		transform: scaleX(1); }
	100% {
		transform: scaleX(0); }
}
