@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=IBM+Plex+Sans+JP:wght@400;500;600;700&display=swap');

/* body
-------------------------------------------------- */
html {
	font-size: 62.5%;
}
body {
	font-size: 1.6em;
	line-height: 2;
	position: relative;
	font-family: "IBM Plex Sans JP", sans-serif;
	font-weight: 400;
	letter-spacing: 0.04em;
	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;
    transition: .8s;
}
body.fixed {
    position: fixed;
    width: 100%;
    height: 100%;
    left: 0;
}
body.fade {
    opacity: 0;
    transition: .3s;
}
body.onh {
    background: #2b2b2b;
    color: #ffffff;
}

/* link
-------------------------------------------------- */
a {
	color: #1a1a1a;
	text-decoration: none;
	transition: all .2s !important;
}
body.onh a {
    color: #ffffff;
}
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);
}
a._blank._wht::after {
    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(255, 255, 255)" d="M11,9H3V0h9v9h-1ZM11,1H4v7h7V1ZM9,11v1H0V3h1v8h8Z"/></svg>') no-repeat center center;
    background-size: 100% auto;
}
@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", "IBM Plex Sans JP", sans-serif;
    font-weight: 500;
    letter-spacing: 0;
}
._nowrap {
    white-space: nowrap;
}

/* Responsive
-------------------------------------------------- */
.sp {
	display: none;
}

/* img
-------------------------------------------------- */
img {
	width: 100%;
	height: auto;
}
.thumb {
	display: block;
	overflow: hidden;
	position: relative;
	transition: .3s all;
}
.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;
}
}
.change_img {
    display: flex;
    justify-content: center;
    align-items: center;
    width: 100%;
    height: 100%;
    position: absolute;
    left: 0;
    top: 0;
    background: rgba(0,0,0,0.60);
    color: #ffffff;
}
/* svg
-------------------------------------------------- */
svg {
	display: block;
	width: 100%;
	height: auto;
}

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

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

/* txt
-------------------------------------------------- */
.ttl {
    line-height: 1.6;
    font-weight: 500;
}
.txt-wrap p {
    margin-bottom: 1.5em;
}
.txt-wrap p:last-child {
    margin-bottom: 0;
}

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


              // 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: 220px;
	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%;
    padding-top: 130px;
    box-sizing: border-box;
    opacity: 0;
}
.fig #container {
    padding-top: 0;
}
.motion  #container {
    transition: opacity 1s;
    opacity: 1;
}
#container::after {
    content: "";
    width: 100%;
    height: 100vh;
    position: fixed;
    left: 0;
    top: 0;
    background: rgba(0,0,0,0.35);
    pointer-events: none;
    opacity: 0;
    transition: .35s;
}
.ddhovered #container::after {
    opacity: 1;
}

/* section  ---------------------------------------- */
.section-wrap {
    padding-right: 4.3923%;
	padding-left: 4.3923%;
	box-sizing: border-box;
}
.section-wrap._40 {
    padding-right: 40px;
	padding-left: 40px;
}
.section-wrap._60-0 {
	padding-left: 0;
}
.section-wrap._0-60 {
	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;
}
.section-low-wrap {
    padding-right: 10.2489%;
	padding-left: 10.2489%;
}
#contents {
    position: relative;
}
.contents-wrap {
    margin-bottom: 140px;
}
.contents-inner {
    margin-bottom: 48px;
}
.contents-inner:last-child {
    margin-bottom: 0;
}

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


              // header //
	  

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

/* header  ---------------------------------------- */
.header {
	width: 100%;
    box-sizing: border-box;
    position: relative;
}
.header-logo {
	width: 160px;
    position: absolute;
    left: 2.9282%;
    top: 38px;
    transition: .3s;
    z-index: 99998;
    opacity: 0;
    box-sizing: border-box;
}
.motion .header-logo {
    opacity: 1;
}
.header-logo a {
	display: block;
}
.header-inner {
    width: calc(94.1436% - 260px);
    position: absolute;
    top: 10px;
    right: 2.9282%;
    transition: .3s;
    z-index: 99997;
}
.header-inner::before {
    content: "";
    width: 100%;
    height: 1px;
    background: #d9d9d9;
    position: absolute;
    right: 0;
    bottom: 0;
    transform: scaleX(0);
    transform-origin: right center;
    transition: 1.0s cubic-bezier(0.04, 0.8, 0.35, 1) .3s;
}
.fig .header-inner::before {
    background: rgba(255,255,255,0.70);
}
.motion .header-inner::before {
    transform: scaleX(1);
}

/* g-nav  ---------------------------------------- */
.g-nav {
    width: 100%;
    padding-right: 120px;
    position: relative;
    box-sizing: border-box;
    pointer-events: none;
}
.motion .g-nav {
    pointer-events: auto;
}
.g-nav .g-nav-list {
    display: flex;
    justify-content: flex-end;
    align-items: stretch;
    position: relative;
}
.g-nav .g-nav-list li {
    padding: 30px 0;
    margin-left: 28px;
	opacity: 0;
    position: relative;
}
.g-nav .g-nav-list li > a {
	display: block;
	position: relative;
    font-size: 1.5rem;
    letter-spacing: 0.04em;
    line-height: 33px;
    font-weight: 600;
    z-index: 2;
}
.fig .g-nav .g-nav-list li a {
    color: #ffffff;
}
.g-nav .g-nav-list li._contact {
    margin-left: 40px;
}
.g-nav .g-nav-list li._contact a {
    width: 140px;
    text-align: center;
    background: #1a1a1a;
    color: #ffffff;
    border-radius: calc(infinity * 1px);
}
.g-nav .g-nav-list li a::before {
	content: "";
	width: 100%;
	height: 1px;
	background: #17509e;
	position: absolute;
	right: 0;
	bottom: -30px;
	transform: scaleX(0);
    transform-origin: center top;
	transition: .2s;
}
.g-nav .g-nav-list li.ac a {
	color: #17509e;
}
.fig .g-nav .g-nav-list li.ac a {
	color: #ffffff;
}
.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) {
    transition: 0.3s 0.3s;
    opacity: 1;
}
.motion .g-nav li:nth-child(2) {
	transition: 0.3s 0.4s;
    opacity: 1;
}
.motion .g-nav li:nth-child(3) {
	transition: 0.3s 0.5s;
    opacity: 1;
}
.motion .g-nav li:nth-child(4) {
	transition: 0.3s 0.6s;
    opacity: 1;
}
.motion .g-nav li:nth-child(5) {
	transition: 0.3s 0.7s;
    opacity: 1;
}
.motion .g-nav li:nth-child(6) {
	transition: 0.3s 0.8s;
    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);
    }
}

/* g-nav-sublist  ---------------------------------------- */
.g-nav .g-nav-sublist {
    width: 330px;
    position: absolute;
    left: 0;
    top: 78px;
    padding: 50px 24px 15px 20px;
    box-sizing: border-box;
    opacity: 0;
	pointer-events: none;
	transition: .4s;
    box-shadow: #97a4aa66 -10px 10px 10px -10px;
}
.g-nav .g-nav-sublist::before {
    content: "";
    width: 100%;
    height: calc(100% - 25px);
    background: #ffffff;
    position: absolute;
    left: 0;
    top: 25px;
    border-radius: 4px;
}
.g-nav .g-nav-sublist a,
.g-nav .g-nav-sublist a p {
    color: #1a1a1a !important;
    font-weight: 500;
    line-height: 1.6;
}
.g-nav .g-nav-sublist a::before {
    display: none;
}
.g-nav .g-nav-sublist ul {
    position: relative;
    z-index: 1;
    box-sizing: border-box;
    
}
.g-nav .g-nav-sublist ul::after {
    content: "";
    display: block;
    width: 30%;
}
.g-nav .g-nav-sublist ul li {
    padding: 0;
    margin: 0 0 10px;
}
.g-nav .g-nav-sublist ul li a {
    display: flex;
    justify-content: space-between;
    align-items: center;
}
.g-nav .g-nav-sublist ul li .thumb {
    width: 64px;
}
.g-nav .g-nav-sublist ul li .thumb::after {
    padding-top: 100%;
}
.g-nav .g-nav-sublist ul li p {
    width: calc(100% - 80px);
    font-size: 1.4rem;
    background: url('data:image/svg+xml;charset=UTF-8,<svg xmlns="http://www.w3.org/2000/svg" version="1.1" width="36" height="26" viewBox="0 0 36 26"><path fill="rgb(26, 26, 26)" d="M18.9,0l-1.4,1.5c.4.4,6.7,7,12.7,10.5H0v2.1h30.1c-5.9,3.5-12.3,10.1-12.7,10.5l1.4,1.5c3.2-3.3,12.4-12,17.1-12v-2.1c-4.8,0-14-8.6-17.1-12Z"/></svg>') right center no-repeat;
    background-size: 16px auto;
    padding-right: 24px;
    box-sizing: border-box;
}
/* hover */
@media screen and (min-width: 768px) {
	.dd-nav-btn:hover > .g-nav-sublist {
		opacity: 1;
		pointer-events: auto;
	}
}

/* menu-trigger  ---------------------------------------- */
.menu-trigger,
.menu-trigger span {
    display: block;
    transition: all .3s;
    box-sizing: border-box;
}
.menu-trigger {
    width: 80px;
    height: 73px;
    pointer-events: auto;
    cursor: pointer;
    position: fixed;
    right: 2.9282%;
    top: 20px;
    box-sizing: border-box;
    z-index: 99999;
    opacity: 0;
    mix-blend-mode: difference;
}
.fig .menu-trigger {
    mix-blend-mode: normal;
}
.fig.on .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: 0;
    width: 100%;
    height: 1px;
    background: #ffffff;
}
.menu-trigger span:nth-of-type(1) {
    top: 30px;
}
.menu-trigger span:nth-of-type(2) {
    bottom: 30px;
}
.open .menu-trigger span:nth-of-type(1) {
    top: 36px;
    transform: rotate(20deg);
}
.open .menu-trigger span:nth-of-type(2) {
   bottom: 36px;
    transform: rotate(-20deg);
}

/* 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: 65%;
	height: 100vh;
	box-sizing: border-box;
	overflow: scroll;
	-webkit-overflow-scrolling: touch;
	overflow-scrolling: touch;
	position: relative;
    transition: .3s;
    margin-left: 35%;
}
.fixed-inner::before {
    content: "";
    width: 65%;
    height: 100%;
    background: #2a2c2e;
    position: fixed;
    right: -280px;
    top: 0;
    transform-origin: right center;
    transition: 0.85s cubic-bezier(0,.93,.45,1);
}
.open .fixed-inner::before {
	right: 0;
}
.fixed-nav nav {
	width: 100%;
    box-sizing: border-box;
    padding: 120px 100px 80px;
    position: absolute;
	left: 0;
	top: 50%;
	transform: translateY(-50%);
}
.fixed-nav .m-nav-wrap {
}
.fixed-nav .m-nav {
    width: 100%;
    display: flex;
    justify-content: flex-start;
    flex-wrap: wrap;
}
.fixed-nav .m-nav > li {
    width: 100%;
    margin: 0 0 26px;
}
.fixed-nav .m-nav > li._w50 {
    width: 35%;
}
.fixed-nav .m-nav > li a {
    display: block;
    font-size: 1.2rem;
    line-height: 1.35;
}
.fixed-nav .m-nav > li a ._en {
    display: block;
    font-size: 2.8rem;
    letter-spacing: 0.04em;
}
.fixed-nav .m-nav-sub {
    display: flex;
    justify-content: flex-start;
    flex-wrap: wrap;
    padding: 8px 0 0;
}
.fixed-nav .m-nav-sub > li {
    position: relative;
    padding: 4px 12px 4px 0;
    margin-right: 12px;
}
.fixed-nav .m-nav-sub > li::after {
    content: "";
    width: 1px;
    height: 12px;
    background: #999999;
    position: absolute;
    right: 0;
    top: 50%;
    transform: translateY(-50%) rotate(30deg);
}
.fixed-nav .m-nav-sub > li:last-child::after {
    display: none;
}
.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: 30px;
    margin-top: 20px;
}
.m-subnav {
    display: flex;
    justify-content: flex-start;
    align-items: center;
    font-size: 1.3rem;
}
.m-subnav li {
    margin-right: 20px;
}

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


              // footer //
	  

/////////////////////////////////////////////////////////////////////////////*/
.footer {
    padding: 60px 0 80px;
}
.footer._bd {
    padding-top: 0;
}

/* banner-list  ---------------------------------------- */
.banner-list {
    display: grid;
    grid-template-columns: repeat(7, 1fr);
    column-gap: 1.1235%;
    row-gap: 12px;
    padding: 0 0 48px;
    border-bottom: 1px solid #d9d9d9;
}
.footer._bd .banner-list {
    padding: 48px 0;
    border-top: 1px solid #d9d9d9;
}
.banner-list li a {
    display: block;
    border: 1px solid #ffffff;
}
.banner-list li._bd a {
    border: 1px solid #cccccc;
}

/* footer-col2  ---------------------------------------- */
.footer-col2 {
    display: flex;
    justify-content: space-between;
    flex-direction: row-reverse;
    margin: 70px 0 0;
    position: relative;
}
.ft-cont {
    width: 48%;
}
.ft-nav {
    display: flex;
    justify-content: flex-start;
    flex-wrap: wrap;
    margin-bottom: 32px;
}
.ft-nav > li {
    width: 100%;
    font-size: 1.7rem;
    margin-bottom: 28px;
}
.ft-nav > li.w50 {
    width: 30%;
}
.ft-nav > li > a {
    font-weight: 500;
    text-decoration: underline;
}
.ft-nav > li > ul {
    display: flex;
    justify-content: flex-start;
    flex-wrap: wrap;
    margin-top: 8px;
}
.ft-nav > li > ul li {
    position: relative;
    padding-right: 13px;
    margin-right: 12px;
}
.ft-nav > li > ul li::after {
    content: "";
    width: 1px;
    height: 12px;
    background: #999999;
    position: absolute;
    right: 0;
    top: 50%;
    transform: translateY(-40%) rotate(30deg);
}
.ft-nav > li > ul li:last-child::after {
    display: none;
}
.ft-nav > li > ul li a {
    font-size: 1.4rem;
}
.ft-subnav {
    display: flex;
    justify-content: flex-start;
    flex-wrap: wrap;
}
.ft-subnav li {
    margin: 0 40px 0 0;
}
.ft-subnav li a {
    font-size: 1.4rem;
    font-weight: 500;
    text-decoration: underline;
}
.ft-info {
    width: 48%;
}
.ft-logo {
    width: 200px;
    margin-bottom: 30px;
}
.ft-info dl dt {
    font-size: 1.4rem;
    font-weight: 500;
}
.ft-info dl dd p {
    font-size: 1.2rem;
    font-weight: 500;
    line-height: 1.75;
    margin-top: 10px;
}
.btn-contact a {
    display: block;
    font-size: 1.4rem;
    width: 180px;
    line-height: 38px;
    color: #ffffff;
    background: #1a1a1a;
    text-align: center;
    border-radius: calc(infinity * 1px);
    margin-top: 30px;
}
.copyright {
    font-size: 1.2rem;
    position: absolute;
    left: 0;
    bottom: 0;
}

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


              // ctaArea //
	  

/////////////////////////////////////////////////////////////////////////////*/
.ctaArea {
    padding: 190px 0 180px;
    position: relative;
}
.ctaArea-fig {
    width: 100%;
    height: 100%;
    position: absolute;
    left: 0;
    top: 0;
}
.ctaArea-fig::after {
    content: "";
    width: 100%;
    height: 100%;
    background: rgba(42,44,46,0.70);
    position: absolute;
    left: 0;
    top: 0;
}
.ctaArea-fig .thumb {
    height: 100%;
}
.ctaArea-list {
    display: flex;
    justify-content: space-between;
    align-items: stretch;
}
.ctaArea-list li {
    box-sizing: border-box;
    color: #ffffff;
    position: relative;
}
.ctaArea-list li:nth-child(1) {
    width: 61.4767%;
}
.ctaArea-list li:nth-child(2) {
    width: 32.1027%;
}
.ctaArea-list li .sec-ttl {
    margin-bottom: 80px;
}
.ctaArea-list li .txt {
    font-weight: 500;
    line-height: 1.6;
    margin-bottom: 50px;
}

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


              // common parts //
	  

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

/* ==================================================
    breadcrumb
================================================== */
.breadcrumb {
    display: flex;
    justify-content: flex-end;
    align-items: center;
    flex-wrap: wrap;
    padding: 0 2.9282%;
    position: relative;
    transition: opacity 1s .5s;
    opacity: 0;
    z-index: 1;
}
.motion .breadcrumb {
    opacity: 1;
}
.breadcrumb li {
    font-size: 1.3rem;
    font-weight: 500;
    position: relative;
    padding-right: 17px;
    margin-right: 12px;
}
.breadcrumb li::after {
    content: "";
    width: 6px;
    height: 6px;
    background: #bababa;
    position: absolute;
    right: 0;
    top: 50%;
    transform: translateY(-50%);
    border-radius: 50%;
}
.breadcrumb li:last-child {
    padding-right: 0;
    margin-right: 0;
}
.breadcrumb li:last-child::after {
    display: none;
}
.breadcrumb li a {
    text-decoration: underline;
}

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

/* page-ttl  ---------------------------------------- */
.page-ttl {
    padding: 32px 0 80px;
}
.page-ttl-cont {
    position: relative;
}
.page-ttl-cont .en-ttl {
    margin-bottom: 40px;
}
.page-ttl-cont .en-ttl p {
    font-size: 12.0rem;
    font-weight: 560;
    line-height: 1.15;
    letter-spacing: -0.045em;
    margin-bottom: -0.22em;
}
.page-ttl-cont .ttl,
.subpage-ttl-cont .ttl {
    font-size: 2.0rem;
    letter-spacing: 0.08em;
    color: #17509e;
    padding-left: 65px;
    margin-top: 24px;
    position: relative;
}
.subpage-ttl-cont .ttl {
    margin-top: 36px;
}
.page-ttl-cont .ttl::before,
.subpage-ttl-cont .ttl::before {
    content: "";
    width: 40px;
    height: 1px;
    background: #17509e;
    position: absolute;
    left: 0;
    bottom: 34%;
}
.page-ttl-cont-fig {
    width: 15.3139%;
    position: absolute;
    right: 2.9282%;
    bottom: 0;
    z-index: 1;
    opacity: 0;
    transition: opacity .4s .5s;
}
.motion .page-ttl-cont-fig {
    opacity: 1;
}
.page-ttl-cont-fig .thumb::after {
    padding-top: 100%;
}
.page-ttl-col2 {
    display: flex;
    justify-content: space-between;
    align-items: stretch;
    flex-direction: row-reverse;
    padding: 75px 0 40px;
}
.page-ttl-col2-fig {
    width: 67.3813%;
    position: relative;
}
.page-ttl-col2-fig::after {
    content: "";
    width: calc(100% + 1px);
    height: calc(100% + 1px);
    background: #ffffff;
    position: absolute;
    top: -1px;
    right: 0;
    transform-origin: right bottom;
}
.motion .page-ttl-col2-fig::after {
    transition: 0.8s cubic-bezier(0.76, 0.09, 0.215, 1);
    transform: scaleX(0);
}
.page-ttl-col2-fig .thumb::after {
    padding-top: 64.4444%;
}
.page-ttl-col2-side {
    width: 22.9709%;
    display: flex;
    justify-content: space-between;
    flex-direction: column;
}
.page-ttl-col2-side-fig .thumb::after {
    padding-top: 75%;
}
.page-ttl-col2-fig-list {
    display: flex;
    justify-content: flex-start;
    flex-wrap: wrap;
}
.page-ttl-col2-fig-list .thumb {
    width: 33.3333%;
}
.page-ttl-col2-fig-list .thumb::after {
    padding-top: 96.6666%;
}
.page-ttl-col2-fig-list .parallax-img.thumb img {
    height: 120%;
}

/* subpage-ttl  ---------------------------------------- */
.subpage-ttl {
    padding: 40px 0 120px;
}
.subpage-ttl-cont {
    display: flex;
    justify-content: space-between;
    align-items: flex-end;
    margin-bottom: 70px;
}
.subpage-ttl-cont-inner {
    width: 68%;
}
.subpage-ttl-cont .en-subttl {
    margin-bottom: 8px;
}
.subpage-ttl-cont .en-ttl p {
    font-size: 11.0rem;
    font-weight: 560;
    line-height: 1.15;
    letter-spacing: -0.045em;
    margin-bottom: -0.22em;
}
.subpage-ttl-cont-txt {
    width: 30.4975%;
    line-height: 1.9;
}
.subpage-ttl-col2 {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
}
.subpage-ttl-col2-fig {
    width: calc(100% - 216px);
    position: relative;
}
.subpage-ttl-col2-fig::after {
    content: "";
    width: calc(100% + 1px);
    height: calc(100% + 1px);
    background: #ffffff;
    position: absolute;
    top: -1px;
    left: 0;
    transform-origin: right bottom;
}
.motion .subpage-ttl-col2-fig::after {
    transition: 0.8s cubic-bezier(0.76, 0.09, 0.215, 1);
    transform: scaleX(0);
}
.subpage-ttl-col2-fig .thumb::after {
    padding-top: 53.2110%;
}

/* figpage-ttl  ---------------------------------------- */
.figpage-ttl {
    width: 100%;
    height: 100vh;
    position: relative;
    color: #ffffff;
    padding-top: 130px;
    margin-bottom: 10px;
    box-sizing: border-box;
}
.figpage-ttl a {
    color: #ffffff;
}
.figpage-ttl-fig {
    width: 100%;
    height: 100%;
    position: absolute;
    left: 0;
    top: 0;
}
.figpage-ttl-fig .thumb {
    width: 100%;
    height: 100%;
}
.figpage-ttl-fig::before,
.figpage-ttl-fig::after {
    content: "";
    width: 100%;
    height: 100%;
    position: absolute;
    left: 0;
    top: 0;
}
.figpage-ttl-fig::before {
    background: rgba(32,34,36,0.55);
    z-index: 1;
}
.figpage-ttl-fig::after {
    background: #ffffff;
    transform-origin: right center;
    z-index: 1;
}
.motion .figpage-ttl-fig::after {
    transition: 0.8s cubic-bezier(0.76, 0.09, 0.215, 1);
    transform: scaleX(0);
}
.figpage-ttl-col2 {
    width: 100vw;
    display: flex;
    justify-content: space-between;
    align-items: flex-end;
    position: absolute;
    left: 0;
    bottom: 10%;
    box-sizing: border-box;
    padding: 0 4.3923%;
    z-index: 1;
}
.figpage-ttl-cont {
    width: 72.2311%;
    padding: 0 0 0 50px;
    box-sizing: border-box;
    position: relative;
}
.figpage-ttl-cont .numb {
    font-size: 1.2rem;
    font-weight: 500;
    line-height: 1;
    writing-mode: vertical-lr;
    position: absolute;
    left: 0;
    top: 0;
}
.figpage-ttl-cont .en-subttl {
    font-weight: 600;
    line-height: 1;
}
.figpage-ttl-cont .ttl {
    font-size: 4.4rem;
    padding: 22px 0 10px;
}
.figpage-ttl-cont .txt {
    font-weight: 500;
}
.figpage-ttl-cont-btm {
    border-top: 1px solid rgba(255,255,255,0.60);
    margin-top: 22px;
    padding-top: 24px;
}
.figpage-ttl-cont-btm p {
    font-size: 1.7rem;
    font-weight: 500;
}

/* page-nav  ---------------------------------------- */
.page-nav {
    width: 220px;
    text-align: right;
}
.page-nav .en-ttl {
    font-size: 1.2rem;
    line-height: 1.5;
    position: relative;
    padding: 50px 0 25px;
}
.page-nav .en-ttl::before {
    content: "";
    width: 40px;
    height: 1px;
    background: #17509e;
    position: absolute;
    right: 0;
    top: 0;
}
.fig .page-nav .en-ttl::before {
    background: #ffffff;
}
.page-nav ul li {
    margin: 20px 0 0;
}
.page-nav ul li a {
    display: block;
    font-size: 1.5rem;
    font-weight: 500;
    line-height: 1.25;
    position: relative;
    opacity: 0.6;
}
.page-nav ul li a::after {
    content: "";
    width: 20px;
    height: 20px;
    background: #17509e;
    position: absolute;
    right: 0;
    top: 50%;
    transform: translateY(-54%);
    border-radius: 50%;
    opacity: 0;
}
.page-nav ul li a span {
    display: inline-block;
    position: relative;
}
.page-nav ul li a span::after {
    content: "";
    width: 100%;
    height: 1px;
    background: #333333;
    position: absolute;
    left: 0;
    bottom: 0;
    transform: scaleX(0);
    transform-origin: right top;
	transition: .2s;
}
.page-nav ul li.ac a {
    padding-right: 28px;
    color: #17509e;
}
.fig .page-nav ul li.ac a {
    color: #ffffff;
}
.page-nav ul li.ac a,
.page-nav ul li.ac a::after {
    opacity: 1;
}
.page-nav ul li.ac a span::after {
    background: #17509e;
    transform: scaleX(1);
}
.fig .page-nav ul li a span::after,
.fig .page-nav ul li.ac a span::after {
    background: #ffffff;
}
/* hover */
@media screen and (min-width: 768px) {
    .page-nav ul li a:hover {
        opacity: 1;
    }
    .page-nav ul li a:hover span::after {
        transform: scaleX(1);
    }
}

/* anchor-link  ---------------------------------------- */
.anchor-link {
    padding: 48px 4.3923%;
    background: #f8f7f8;
    position: relative;
}
.anchor-link::before {
    content: "";
    width: 100%;
    height: 221px;
    background: #f8f7f8;
    position: absolute;
    left: 0;
    top: -220px;
    z-index: -1;
}
.anchor-link ul {
    display: flex;
    justify-content: flex-start;
    align-items: center;
    position: relative;
}
.anchor-link ul li {
    margin-right: 40px;
}
.anchor-link ul li a {
    display: block;
    position: relative;
    padding-left: 35px;
    font-weight: 500;
}
.anchor-link ul li a::before {
    content: "";
    width: 14px;
    height: 22px;
    position: absolute;
    left: 0;
    top: 50%;
    transform: translateY(-60%);
    background: url('data:image/svg+xml;charset=UTF-8,<svg xmlns="http://www.w3.org/2000/svg" version="1.1" width="14" height="22" viewBox="0 0 14 22"><path fill="rgb(26, 26, 26)" d="M13.3,11.8c-.2.2-3.9,3.8-5.8,7.1V0h-1v18.9c-1.8-3.3-5.6-6.9-5.8-7.1l-.7.7c1.8,1.7,6.5,6.8,6.5,9.5h1c0-2.7,4.7-7.7,6.5-9.5l-.7-.7Z"/></svg>') center center no-repeat;
    background-size: 100% auto;
}

/* sec-ttl  ---------------------------------------- */
.sec-ttl {
    position: relative;
    line-height: 1.9;
    padding: 28px 0 0;
}
.sec-ttl::before {
    content: "";
    width: 380px;
    height: 1px;
    background: #cccccc;
    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;
}
body.onh .sec-ttl::before,
.sec-pagelink .sec-ttl::before {
    opacity: .4;
}
.sec-ttl._w100::before {
    width: 100%;
}
.sec-ttl .ttl {
    font-size: 3.8rem;
    font-weight: 500;
    margin-top: 20px;
}
.sec-ttl.on::before {
    transform: scaleX(1);
}

/* bd-ttl  ---------------------------------------- */
.bd-ttl {
    margin-bottom: 65px;
}
.bd-ttl span {
    display: inline-block;
    position: relative;
    font-size: 1.4rem;
    font-weight: 500;
    line-height: 1.5;
    letter-spacing: 0.06em;
    padding-right: 80px;
}
.bd-ttl span::after {
    content: "";
    width: 60px;
    height: 1px;
    background: #17509e;
    position: absolute;
    right: 0;
    top: 50%;
}

/* line-ttl  ---------------------------------------- */
.line-ttl span {
    display: inline-block;
    position: relative;
    line-height: 1.2;
}
.line-ttl span::after {
    content: "";
    width: 100%;
    height: 1px;
    background: #1a1a1a;
    position: absolute;
    left: 0;
    bottom: 0;
}
/* hover */
@media screen and (min-width: 768px) {
    .btn-cont:hover .line-ttl span::after {
        animation: btn .5s 1 ease;
    }
}

/* cont-ttl  ---------------------------------------- */
.cont-ttl {
    font-size: 2.6rem;
    font-weight: 600;
    line-height: 1.6;
    margin-bottom: 0.25em;
}
.cont-subttl {
    font-size: 1.8rem;
    font-weight: 600;
    line-height: 1.6;
    margin: 1em 0 0.25em;
}

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

/* btn  ---------------------------------------- */
.btn {
    margin-top: 32px;
    position: relative;
    z-index: 1;
}
.btn a {
    display: inline-block;
    width: 280px;
    position: relative;
    padding: 8px 2px 6px;
    color: #ffffff;
    text-align: center;
    background: #1a1a1a;
    border: 1px solid #1a1a1a;
    border-radius: calc(infinity * 1px);
}
.btn._wht a {
    background-color: transparent;
    border: 1px solid #ffffff;
}
.btn-wrap-bd {
    position: relative;
}
.btn-wrap-bd::before {
    content: "";
    width: calc(100% - 340px);
    height: 1px;
    background: #cccccc;
    position: absolute;
    left: 0;
    top: 50%;
}
.btn-wrap-bd .btn {
    margin-top: 0;
}
body.onh .btn-wrap-bd::before {
    opacity: .4;
}

/* hover */
@media screen and (min-width: 768px) {
    .btn a:hover {
        opacity: 1;
        color: #1a1a1a;
        background: #ffffff;
    }
    .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-txt  ---------------------------------------- */
.btn-txt {
    margin-top: 16px;
}
.btn-txt a,
.btn-txt span {
    display: inline-block;
    text-align: center;
    font-weight: 500;
    line-height: 1.5;
    box-sizing: border-box;
    position: relative;
    padding-right: 65px;
}
.btn-txt a::before,
.btn-txt a::after,
.btn-txt span::before,
.btn-txt span::after {
    display: block;
    content: "";
    width: 47px;
    height: 47px;
    border-radius: 50%;
    position: absolute;
    right: 0;
    top: 50%;
    transform: translateY(-50%);
    transition: .2s;
    box-sizing: border-box;
}
.btn-txt a::before,
.btn-txt span::before {
    background: #1a1a1a;
    transform-origin: center center;
}
.btn-txt a::after,
.btn-txt span::after{
    background: url('data:image/svg+xml;charset=UTF-8,<svg xmlns="http://www.w3.org/2000/svg" version="1.1" width="36" height="26" viewBox="0 0 36 26"><path fill="rgb(255, 255, 255)" d="M18.9,0l-1.4,1.5c.4.4,6.7,7,12.7,10.5H0v2.1h30.1c-5.9,3.5-12.3,10.1-12.7,10.5l1.4,1.5c3.2-3.3,12.4-12,17.1-12v-2.1c-4.8,0-14-8.6-17.1-12Z"/></svg>') center center no-repeat;
    background-size: 18px auto;
}
/* hover */
@media screen and (min-width: 768px) {
    .btn-txt a:hover::before {
        transform: translateY(-50%) scale(1.25);
    }
    .btn-cont:hover .btn-txt span::before {
        transform: translateY(-50%) scale(1.25);
    }
}

/* 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);
    }
}

/* btn-box  ---------------------------------------- */
.btn-box {
    margin-top: 32px;
}
.btn-box a {
    display: inline-block;
    width: 300px;
    font-size: 1.5rem;
    font-weight: 500;
    position: relative;
    padding: 10px 24px 7px;
    border: 1px solid #cccccc;
    border-radius: calc(infinity * 1px);
    box-sizing: border-box;
    background: url('data:image/svg+xml;charset=UTF-8,<svg xmlns="http://www.w3.org/2000/svg" version="1.1" width="36" height="26" viewBox="0 0 36 26"><path fill="rgb(26, 26, 26)" d="M18.9,0l-1.4,1.5c.4.4,6.7,7,12.7,10.5H0v2.1h30.1c-5.9,3.5-12.3,10.1-12.7,10.5l1.4,1.5c3.2-3.3,12.4-12,17.1-12v-2.1c-4.8,0-14-8.6-17.1-12Z"/></svg>') right 16px center no-repeat;
    background-size: 18px auto;
}
/* hover */
@media screen and (min-width: 768px) {
    .btn-box a:hover {
        opacity: 1;
        color: #ffffff;
        border: 1px solid #1a1a1a;
        background: #1a1a1a url('data:image/svg+xml;charset=UTF-8,<svg xmlns="http://www.w3.org/2000/svg" version="1.1" width="36" height="26" viewBox="0 0 36 26"><path fill="rgb(255, 255, 255)" d="M18.9,0l-1.4,1.5c.4.4,6.7,7,12.7,10.5H0v2.1h30.1c-5.9,3.5-12.3,10.1-12.7,10.5l1.4,1.5c3.2-3.3,12.4-12,17.1-12v-2.1c-4.8,0-14-8.6-17.1-12Z"/></svg>') right 11px center no-repeat;
        background-size: 18px auto;
    }
}

/* ===============================================
    sec-pagelink
=============================================== */
.sec-pagelink {
    position: relative;
    background: #2b2b2b;
    padding: 120px 0 200px;
    overflow: hidden;
    color: #ffffff;
}
.sec-pagelink a {
    color: #ffffff;
}
.pagelink-logo {
    width: 79%;
    position: absolute;
    right: -35px;
    bottom: 100px;
    opacity: 0.04;
}
.pagelink-list {
    display: flex;
    justify-content: space-between;
    flex-wrap: wrap;
    position: relative;
}
.pagelink-list::after {
    content: "";
    display: block;
    width: 29.6950%;
}
.pagelink-list .item {
    width: 29.6950%;
    border-top: 1px solid #6b6b6b;
    margin-bottom: 20px;
}
.pagelink-list .item a {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 25px 0;
    color: #ffffff;
    position: relative;
}
.pagelink-list .item a::before {
    content: "";
    width: 100%;
    height: 1px;
    background: rgba(255,255,255,0.60);
    position: absolute;
    left: 0;
    top: -1px;
    transform: scaleX(0);
    transform-origin: left center;
    transition: .3s;
}
.pagelink-list .item a .thumb {
    width: 90px;
}
.pagelink-list .item a .thumb::after {
    padding-top: 100%;
}
.pagelink-list .item a .item-inner {
    width: calc(100% - 122px);
}
.pagelink-list .item a .ttl {
    font-size: 1.8rem;
}
.pagelink-list .item a .en-ttl {
    font-size: 1.2rem;
    line-height: 1.9;
}

/* hover */
@media screen and (min-width: 768px) {
    .pagelink-list .item a:hover::before {
        transform: scaleX(1);
    }
}

/* ===============================================
    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;
}
dl.table dt {
	width: 20%;
    font-weight: 500;
	border-bottom: 1px solid #d6d7d8;
	padding: 20px 0;
}
dl.table dd {
	width: 75%;
	border-bottom: 1px solid #d6d7d8;
	padding: 20px 0 10px 5%;
    position: relative;
    word-wrap: break-word;
}
dl.table dt:nth-last-child(2) {
    border-bottom: none;
}
dl.table dd:last-child {
    border-bottom: none;
}
dl.table dd p {
	padding-bottom: 10px;
}
dl.table dd p.note {
	font-size: 1.4rem;
    color: #666666;
}
dl.table .list li {
    border-bottom: 1px solid #d6d7d8;
    padding-bottom: 10px;
    margin-bottom: 16px;
}
dl.table .list li:last-child {
    border-bottom: none;
    padding-bottom: 0;
    margin-bottom: 6px;
}
dl.table .list li p {
    font-size: 1.4rem;
}
dl.table .list li p.ttl {
    font-size: 1.6rem;
    font-weight: 700;
    padding-top: 3px;
}

/* ===============================================
    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: 6px;
    height: 6px;
    background: #1a1a1a;
    position: absolute;
    left: 0;
    top: 0.8em;
    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;
}


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


              // motion //
	  

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

/* ef futxt
-------------------------------------------------- */
.futxt {
    overflow: hidden;
}
.futxt span {
    display: inline-block;
    transform: translateY(95%);
}

/* fade
-------------------------------------------------- */
.mf {
	opacity:0;
}
.mf.on {
	transition: opacity 1s !important;
	opacity: 1;
}

/* fade
-------------------------------------------------- */
.mfb {
	opacity:0;
    filter: blur(20px);
}
.mfb.on {
	transition: 1s !important;
	opacity: 1;
    filter: blur(0);
}

/* 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 up
-------------------------------------------------- */
.mfus {
	opacity: 0;
    transform-origin: top center;
	transform: translateY(40px) scale(0.9);
}
.mfus.on {
    transition: 1.4s cubic-bezier(0.075, 0.82, 0.165, 1) !important;
    opacity: 1;
    transform: translateY(0) scale(1);
}


/* 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.90);
	position: absolute;
	left: 0;
	top: 0;
	transform-origin: right center;
    transition: 1.2s cubic-bezier(.08,.42,.32,.99) .1s;
}
.mtm._gry::after {
	background: rgba(248,248,248,0.80);
}
.mtm._blk::after {
	background: rgba(42,44,46,0.80);
}
.mtm.on::after  {
    transform: scaleX(0);
}

/* ef scale
-------------------------------------------------- */
.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); }
}
