html { 
    font-family: "Noto Sans JP", sans-serif;
    color: #333;
    margin-top: 0 !important;
}

.grecaptcha-badge { visibility: hidden; }
#wpadminbar {
    top: unset;
    bottom: 0;
    position: fixed !important;
}

.inactive0501 {
    opacity: 0;
    pointer-events: none;
}

.inactive0501-02 {
    opacity: .4;
    pointer-events: none;
}

body {
    min-width: 390px;
}

body.js-active {
    overflow: hidden;
}

main {
    overflow: hidden;
}

span {
    display: inline-block;
}

picture {
    display: block;
}

img {
    width: 100%;
    height: auto;
    object-fit: contain;
}

a {
    display: inline-block;
}

.hover-underline-wrapper {
    position: relative;
}

.hover-underline {
    position: absolute;
    width: 100%;
    height: 1px;
    left: 0;
    position: absolute;
    bottom: -2px;
    width: 100%;
    overflow: hidden;
}
.hover-underline::before {
    background-color: #333;
    content: '';
    height: 100%;
    left: 0;
    position: absolute;
    top: 0;
    width: 100%;
    transform: translate(-101%, 0);
    transition: transform .4s 0s cubic-bezier(.44,.14,.09,1.02);
}

.hover-txt-wrapper {
    position: relative;
}

.hover-txt-en {
    position: absolute;
    top: 2px;
    left: 50%;
    transform: translate(-50%, 0);
    opacity: 0;
    transition: opacity .5s 0s cubic-bezier(.44,.14,.09,1.02);
}
.hover-txt-en.--right {
    left: unset;
    transform: translate(0, 0);
    right: 12px;
}

.hover-txt-ja {
    transition: opacity .5s 0s cubic-bezier(.44,.14,.09,1.02);
}

@media screen and (min-width: 769px) {
    a.--nomal {
        transition: opacity .5s;
    }

    a.--nomal:hover {
        opacity: 0.7;
    }

    .hover-underline-link:hover .hover-underline::before {
        transform: translate(0, 0);
    }

    .hover-txt-wrapper:hover .hover-txt-en {
        opacity: 1;
    }
    .hover-txt-wrapper:hover .hover-txt-ja {
        opacity: 0;
    }
}

/* utility */
.u-en {
    font-family: "Akshar", sans-serif;
}

.--green {
    color: #66cc00;
}

/* text */


/* layout */
.l-wrapper {
    padding-left: 30px;
    padding-right: 30px;
}

.l-inner {
    margin: 0 auto;
    max-width: 1000px;
}

@media screen and (max-width: 768px) {
    .l-wrapper {
        padding-left: 20px;
        padding-right: 20px;
    }

    /* .l-inner {
        max-width: 480px;
    } */
}

/* common */
.pc-only {
    display: block;
}

.br-pc-only {
    display: inline-block;
}

.sp-only {
    display: none;
}

.br-sp-only {
    display: none;
}

@media screen and (max-width: 768px) {
    .pc-only {
        display: none;
    }

    .br-pc-only {
        display: none;
    }

    .sp-only {
        display: block;
    }

    .br-sp-only {
        display: inline-block;
    }
}

.c-txt01 {
    font-size: 15px;
    line-height: 2.4;
    font-feature-settings: 'pwid' on, 'palt' on;
    letter-spacing: .06em;
}

@media screen and (max-width: 768px) {
    .c-txt01 {
        font-size: 15px;
        line-height: 2;
    }
}

.c-btn {
    width: 100%;
    max-width: 331px;
    padding: 17px 10px 18px;
    border: #66cc00 solid 1px;
    position: relative;
    color: #66cc00;
    border-radius: 100vh;
    text-align: center;
    font-size: 15px;
    line-height: 1;
    transition: all .4s 0s cubic-bezier(.44,.14,.09,1.02);
}
.c-btn.--white {
    border: #fff solid 1px;
    color: #66cc00;
    background-color: #fff;
}

.c-btn-arrow--wrapper {
    position: absolute;
    width: 22px;
    height: 22px;
    right: 20px;
    top: 50%;
    transform: translate(0, -50%);
    overflow: hidden;
}

.c-btn-arrow01 {
    position: absolute;
    width: 22px;
    right: 0;
    top: calc(50% - 2px);
    transform: translate(0, -50%);
    transition: transform .4s 0s cubic-bezier(.44,.14,.09,1.02);
}

.c-btn-arrow02 {
    position: absolute;
    width: 22px;
    right: 0;
    top: calc(50% - 2px);
    transform: translate(-120%, -50%);
    transition: transform .4s 0s cubic-bezier(.44,.14,.09,1.02);
}

.c-btn-more {
    display: inline-flex;
    align-items: center;
}

.c-btn-more-txt {
    font-size: 16px;
    font-weight: 500;
    line-height: 1;
    color: #999;
    margin-right: 10px;
    transition: color .4s 0s cubic-bezier(.44,.14,.09,1.02);
}

.c-btn-more-arrow {
    width: 41px;
    height: 41px;
    position: relative;
    border-radius: 100vh;
    border: #999 solid 1px;
    transition: all .4s 0s cubic-bezier(.44,.14,.09,1.02);
}

.c-btn-more-arrow-wrapper {
    position: absolute;
    width: 17px;
    height: 17px;
    left: 50%;
    top: 50%;
    transform: translate(-50%, -50%);
    overflow: hidden;
}

.c-btn-more-arrow01 {
    position: absolute;
    width: 17px;
    left: 0;
    top: 50%;
    transform: translate(0, -50%);
    transition: transform .4s 0s cubic-bezier(.44,.14,.09,1.02);
}
.c-btn-more-arrow02 {
    position: absolute;
    width: 17px;
    left: 0;
    top: 50%;
    transform: translate(-120%, -50%);
    transition: transform .4s 0s cubic-bezier(.44,.14,.09,1.02);
}

@media screen and (min-width: 769px) {
    .c-btn:hover {
        background-color: #66cc00;
        color: #fff;
    }

    .c-btn:hover .c-btn-arrow01 {
        transform: translate(120%, -50%);
    }
    .c-btn:hover .c-btn-arrow02 {
        transform: translate(0, -50%);
    }

    .c-btn-more:hover .c-btn-more-txt {
        color: #66cc00;
    }

    .c-btn-more:hover .c-btn-more-arrow {
        border-color: #66cc00;
    }

    .c-btn-more:hover .c-btn-more-arrow01 {
        transform: translate(120%, -50%);
    }

    .c-btn-more:hover .c-btn-more-arrow02 {
        transform: translate(0, -50%);
    }
}

@media screen and (max-width: 768px) {
    .c-btn {
        padding: 16px 10px 18px;
    }

    .c-btn.--small {
        max-width: 201px;
    }    
}

/*===========================================================================*/
/*  header  */
/*===========================================================================*/
.p-header {
    position: fixed;
    width: 100%;
    padding: 39px 60px;
    z-index: 90;
    background-color: #fff;
}

.p-header__inner {
    display: flex;
    justify-content: space-between;
    align-items: center;
    position: relative;
    z-index: 5;
}

.p-header__logo {
    display: flex;
    width: 220px;
    position: relative;
}
.p-header__logo>* {
    width: 100%;
}

.p-header__logo img {
    transition: opacity .4s 0s cubic-bezier(.44,.14,.09,1.02);
}

.p-header__logo img.--white {
    position: absolute;
    width: 220px;
    left: 0;
    top: 0;
    pointer-events: none;
    opacity: 0;
}

.p-header__nav {
    display: flex;
    align-items: center;
}

.p-header__nav--list {
    display: flex;
    font-size: 17px;
    font-weight: 500;
    line-height: 1;
    letter-spacing: .06em;
}
.p-header__nav--list .hover-txt-ja {
    font-size: 15px;
    font-weight: 700;
}
.p-header.js-active-pc .p-header__nav--list {
    color: #fff;
}
.p-header__nav--list>li {
    margin-left: 30px;
}

.p-header .--01 {
    position: relative;
    z-index: 3;
}

.p-header__nav--list>li .--parent {
    position: relative;
    padding-right: 12px;
}
.p-header__nav--list>li .--parent::before {
    background: url('../img/common/header-arrow.svg') no-repeat center center/contain;
    content: '';
    height: 5px;
    right: 0;
    position: absolute;
    top: 7px;
    width: 10px;
    transition: opacity .4s 0s cubic-bezier(.44,.14,.09,1.02);
}
.p-header__nav--list>li .--parent::after {
    background: url('../img/common/header-arrow-white.svg') no-repeat center center/contain;
    content: '';
    height: 5px;
    right: 0;
    position: absolute;
    top: 7px;
    width: 10px;
    opacity: 0;
    transition: opacity .4s 0s cubic-bezier(.44,.14,.09,1.02);
}

.p-header__btn {
    display: flex;
    position: relative;
    align-items: center;
    justify-content: center;
    text-align: center;
    flex-direction: column;
    font-size: 17px;
    font-weight: 500;
    line-height: 1;
    letter-spacing: .06em;
    width: 150px;
    height: 50px;
    margin-left: 50px;
    color: #fff;
    background-color: #66cc00;
    border-radius: 100vh;
    border: #66cc00 solid 2px;
    transition: background-color .4s 0s cubic-bezier(.44,.14,.09,1.02), color .4s 0s cubic-bezier(.44,.14,.09,1.02);
    z-index: 3;
}

.p-header__btn--txt {
    position: absolute;
    left: 50%;
    top: calc(50% + 2px);
    transform: translate(-50%, -50%);
    transition: opacity .4s 0s cubic-bezier(.44,.14,.09,1.02);
    opacity: 0;
}

.p-header__btn--txtJa {
    font-size: 15px;
    font-weight: 700;
    transition: opacity .4s 0s cubic-bezier(.44,.14,.09,1.02);
}

.sp-parent-btn {
    display: none;
}

.p-header__nav .list-children-wrapper {
    position: fixed;
    width: 100%;
    top: 0;
    left: 0;
    padding: 128px 30px 60px;
    z-index: 2;
    background-color: #333;
    color: #fff;
    transition: opacity .6s 0s cubic-bezier(.44,.14,.09,1.02);
    opacity: 0;
    pointer-events: none;
}

.p-header__nav .header-having-children:hover .list-children-wrapper {
    opacity: 1;
    pointer-events: all;
}

.p-header__nav .list-children {
    max-width: 1060px;
    display: flex;
    flex-wrap: wrap;
    margin: 0 auto;
    font-size: 14px;
}

.p-header__nav .list-children li {
    width: calc(25% - 21px);
    margin-right: 21px;
    margin-top: 21px;
}
.p-header__nav .list-children li.--4n {
    margin-right: 0;
}

.p-header__nav .list-children li a {
    width: 100%;
    position: relative;
    padding-bottom: 21px;
    padding-right: 21px;
    border-bottom: solid 1px #4d4d4d;
    transition: border-color .4s 0s cubic-bezier(.44,.14,.09,1.02);
}
.p-header__nav .list-children li a::before {
    background: url('../img/common/arrow01-green.svg') no-repeat center center/contain;
    content: '';
    height: 5px;
    right: 0;
    position: absolute;
    bottom: 21px;
    width: 21px;
    transition: transform .4s 0s cubic-bezier(.44,.14,.09,1.02);
}

.p-header.js-active-pc li .hover-underline::before {
    background-color: #fff;
}

@media screen and (min-width: 1036px) {
    .p-header__btn:hover {
        background-color: transparent;
        color: #66cc00;
    }

    .p-header__btn:hover .p-header__btn--txt {
        opacity: 1;
    }
    .p-header__btn:hover .p-header__btn--txtJa {
        opacity: 0;
    }

    .p-header__nav .list-children li a:hover {
        border-color: #fff;
    }

    .p-header__nav .list-children li a:hover:before {
        transform: translate(7px, 0);
    }

    .p-header__nav .list-children-wrapper {
        display: block !important;
    }

    .p-header.js-active-pc .p-header__logo img.--white {
        opacity: 1;
    }
    .p-header.js-active-pc .p-header__logo img.--black {
        opacity: 0;
    }

    .p-header.js-active-pc .p-header__nav--list>li .--parent::before {
        opacity: 0;
    }

    .p-header.js-active-pc .p-header__nav--list>li .--parent::after  {
        opacity: 1;
    }
}

@media screen and (max-width: 1035px) {
    .p-header {
        padding: 20px;
    }

    .p-header .sp-only {
        display: block;
    }
    
    .p-header__logo {
        width: 160px;
        padding-bottom: 13px;
    }

    .p-header__logo img.--white {
        width: 160px;
    }
    .p-header.js-active-sp .p-header__logo img.--white {
        opacity: 1;
    }
    .p-header.js-active-sp .p-header__logo img.--black {
        opacity: 0;
    }
    
    .p-header__nav {
        position: fixed;
        width: 100%;
        height: 100vh;
        flex-direction: column;
        justify-content: center;
        align-items: center;
        left: 0;
        top: 0;
        z-index: 0;
        overflow-y: scroll;
        padding: 110px 30px 80px;
        transition: opacity .6s 0s cubic-bezier(.44,.14,.09,1.02);
        pointer-events: none;
        opacity: 0;
        background-color: #333;
        color: #fff;
    }
    /* .p-header__nav.js-active {
        pointer-events: all;
        opacity: 1;
    } */
    
    .p-header__nav {
        display: block;
    }
    
    .p-header__nav--list {
        display: block;
        font-size: 16px;
        border-top: #4d4d4d solid 1px;
    }
    .p-header.js-active .p-header__nav--list {
        color: #fff;
    }
    .p-header__nav--list>li {
        margin-left: 0;
        padding: 24px 0 0;
        border-bottom: #4d4d4d solid 1px;
        position: relative;
    }
    .p-header__nav--list>li.--small {
        padding: 0;
        border-bottom: none;
        font-size: 13px;
        color: #999;
        margin-top: 32px;
    }
    
    .p-header__nav--list>li .--parent {
        display: none;
    }

    .p-header__nav--list>li .--01 {
        padding-bottom: 21px;
    }
    
    .sp-parent-btn {
        display: block;
        position: relative;
        width: 100%;
    }
    .sp-parent-btn .--plus {
        position: absolute;
        width: 10px;
        height: 10px;
        right: 10px;
        top: 2px;
    }
    .sp-parent-btn .--plus::before {
        background-color: #fff;
        content: '';
        height: 2px;
        left: 50%;
        position: absolute;
        top: 50%;
        width: 100%;
        transform: translate(-50%, -50%);
    }
    .sp-parent-btn .--plus::after {
        background-color: #fff;
        content: '';
        height: 100%;
        left: 50%;
        position: absolute;
        top: 50%;
        width: 2px;
        transform: translate(-50%, -50%);
    }
    .sp-parent-btn.js-active .--plus::after {
        opacity: 0;
    }
    
    .p-header__nav .list-children-wrapper {
        position: relative;
        padding: 0;
        z-index: 2;
        background-color: transparent;
        opacity: 1;
        pointer-events: all;
        display: none;
    }
    
    .p-header__nav .list-children {
        max-width: 1060px;
        display: flex;
        flex-wrap: wrap;
        margin: 0 auto;
        font-size: 14px;
        color: #999;
    }
    
    .p-header__nav .list-children li {
        width: 100%;
        margin-right: 0;
        margin-top: 0;
        border-top: #4d4d4d solid 1px;
        padding: 21px 0;
    }
    
    .p-header__nav .list-children li a {
        width: 100%;
        position: relative;
        padding-bottom: 0;
        padding-right: 0;
        border-bottom: none;
    }
    .p-header__nav .list-children li a::before {
        display: none;
    }
    
    .p-header__btn {
        display: none;
    }
}

/* hamburger */
.p-hamburger {
    width: 50px;
    height: 50px;
    display: none;
    align-items: center;
    justify-content: center;
    background-color: #66cc00;
    border-radius: 100vh;
    position: relative;
    z-index: 3;
}
.p-hamburger:focus {
    outline: none;
}
.p-header.js-active-sp .p-hamburger {
    background-color: #4d4d4d;
}

.p-hamburger__trigger {
    cursor: pointer;
    height: 16px;
    width: 22px;
    z-index: 99;
    position: relative;
}

.p-hamburger__trigger span {
    background-color: #fff;
    height: 2px;
    left: 0;
    position: absolute;
    width: 100%;
}

.p-hamburger__trigger, 
.p-hamburger__trigger span {
    display: inline-block;
    transition: all .3s;
    box-sizing: border-box;
    -webkit-transition: all .3s;
    -moz-transition: all .3s;
    -ms-transition: all .3s;
    -o-transition: all .3s;
}

.p-hamburger__trigger span:nth-of-type(1) {
    top: 0;
}

.p-hamburger__trigger span:nth-of-type(2) {
    top: 7px;
}

.p-hamburger__trigger span:nth-of-type(3) {
    bottom: 0;
}

.p-hamburger__trigger.js-active-sp span:nth-of-type(1) {
    transform: translateY(7px) rotate(-45deg);
    -webkit-transform: translateY(7px) rotate(-45deg);
    -moz-transform: translateY(7px) rotate(-45deg);
    -ms-transform: translateY(7px) rotate(-45deg);
    -o-transform: translateY(7px) rotate(-45deg);
}

.p-hamburger__trigger.js-active-sp span:nth-of-type(2) {
    opacity: 0;
}

.p-hamburger__trigger.js-active-sp span:nth-of-type(3) {
    transform: translateY(-7px) rotate(45deg);
    -webkit-transform: translateY(-7px) rotate(45deg);
    -moz-transform: translateY(-7px) rotate(45deg);
    -ms-transform: translateY(-7px) rotate(45deg);
    -o-transform: translateY(-7px) rotate(45deg);
}

@media screen and (max-width: 1035px) {
    .p-header__nav.js-active-sp {
        opacity: 1;
        pointer-events: all;
    }

    .p-hamburger {
        display: flex !important;
    }
}

/*===========================================================================*/
/*  footer  */
/*===========================================================================*/
.p-footer {
    background-color: #333;
    padding-top: 68px;
    padding-bottom: 140px;
}

.p-footer__nav--list {
    display: flex;
    justify-content: space-between;
}

.p-footer__nav--list>li {
    width: 21%;
}

.p-footer__nav--list>li .--01 {
    color: #fff;
    font-size: 16px;
    font-weight: 500;
}

.p-footer__nav--list>li .--01 .hover-underline::before {
    background-color: #fff;
}

.p-footer .sp-parent-btn {
    display: none;
}

.p-footer .list-children {
    margin-top: 15px;
    padding-top: 4px;
    border-top: #4d4d4d solid 1px;
    color: #999;
    font-size: 14px;
    line-height: 1.3;
}

.p-footer .list-children li {
    margin-top: 18px;
}

.p-footer .list-children li .hover-underline::before {
    background-color: #999;
}

.p-footer .list-children li.--child {
    position: relative;
    padding-left: 15px;
}
.p-footer .list-children li.--child::before {
    background-color: #999;
    content: '';
    height: 1px;
    left: 5px;
    position: absolute;
    top: 9px;
    width: 5px;
}

.p-footer__lower {
    margin-top: 40px;
    padding-top: 36px;
    border-top: #4d4d4d solid 1px;
    display: flex;
    justify-content: space-between;
    align-items: center;
}

.p-footer__lower .hover-underline::before {
    background-color: #999;
}

.p-footer__lower--left {
    display: flex;
    align-items: center;
}

.p-footer__lower--logo {
    width: 170px;
}

.p-footer__lower--insta {
    width: 25px;
    margin-left: 40px;
    position: relative;
    transform: translate(0, 7px);
}
.p-footer__lower--insta::before {
    background-color: #4d4d4d;
    content: '';
    height: 100%;
    left: -20px;
    position: absolute;
    top: 0;
    width: 1px;
}

.p-footer__lower--nav {
    color: #999;
    margin-left: 40px;
    display: flex;
    transform: translate(0, 7px);
}
.p-footer__lower--nav ul {
    display: flex;
    font-size: 14px;
    line-height: 1.3;
}

.p-footer__lower--nav ul li:nth-of-type(2) {
    margin-left: 20px;
}

.p-footer__lower--copyRight {
    color: #999;
    font-size: 10px;
    line-height: 1.3;
    transform: translate(0, 7px);
}

@media screen and (min-width: 769px) {
    .p-footer .list-children {
        display: block !important;
    }
}

@media screen and (max-width: 768px) {
    .p-footer {
        padding-top: 40px;
        padding-bottom: 58px;
    }
    
    .p-footer__nav--list {
        display: block;
        border-top: #4d4d4d solid 1px;
    }
    
    .p-footer__nav--list>li {
        width: 100%;
        padding-top: 21px;
        border-bottom: #4d4d4d solid 1px;
    }
    .p-footer__nav--list>li.--small {
        padding-top: 0;
        border-bottom: none;
        margin-top: 32px;
        color: #999;
        font-size: 13px;
    }
    
    .p-footer__nav--list>li .--01 {
        color: #fff;
        font-size: 16px;
        font-weight: 500;
        padding-bottom: 21px;
    }

    .p-footer .--parent {
        display: none;
    }
    
    .p-footer .sp-parent-btn {
        display: block;
    }
    
    .p-footer .list-children {
        margin-top: 0;
        padding-top: 0;
        border-top: none;
        line-height: 1;
        display: none;
    }
    
    .p-footer .list-children li {
        margin-top: 0;
        padding: 21px 0;
        border-top: #4d4d4d solid 1px;
    }
    
    .p-footer .list-children li.--child {
        position: relative;
        padding-left: 15px;
    }
    .p-footer .list-children li.--child::before {
        background-color: #999;
        content: '';
        height: 1px;
        left: 5px;
        position: absolute;
        top: 28px;
        width: 5px;
    }
    
    .p-footer__lower {
        margin-top: 40px;
        padding-top: 0;
        border-top: none;
        display: block;
    }

    .p-footer__lower--left {
        flex-wrap: wrap;
    }
    
    .p-footer__lower--nav {
        width: 100%;
        margin-left: 0;
        margin-top: 40px;
        transform: translate(0, 0);
    }
    .p-footer__lower--nav ul {
        display: flex;
        font-size: 13px;
    }
    
    .p-footer__lower--nav ul li:nth-of-type(1) {
        display: none;
    }
    .p-footer__lower--nav ul li:nth-of-type(2) {
        margin-left: 0;
    }
    
    .p-footer__lower--copyRight {
        margin-top: 10px;
        transform: translate(0, 0);
    }
}

/*===========================================================================*/
/*  cta  */
/*===========================================================================*/
.c-cta {
    display: block;
    padding-top: 90px;
    padding-bottom: 80px;
    background-color: #66cc00;
    transition: background-color .6s 0s cubic-bezier(.44,.14,.09,1.02);
}

.c-cta__headEn {
    font-size: 58px;
    font-weight: 500;
    line-height: 1;
    text-align: center;
    color: #fff;
}

.c-cta__headJa {
    text-align: center;
    font-size: 16px;
    font-weight: 700;
    color: #fff;
    line-height: 1;
    margin-top: 8px;
}

.c-cta__btn {
    text-align: center;
    margin-top: 50px;
    pointer-events: none;
}

@media screen and (min-width: 769px) {
    .c-cta:hover {
        background-color: #4f9e00;
    } 

    .c-cta:hover .c-btn-arrow01 {
        transform: translate(120%, -50%);
    }
    .c-cta:hover .c-btn-arrow02 {
        transform: translate(0, -50%);
    }
}

@media screen and (max-width: 768px) {
    .c-cta {
        padding-top: 50px;
        padding-bottom: 60px;
    }
    
    .c-cta__headEn {
        font-size: 40px;
    }
    
    .c-cta__headJa {
        font-size: 15px;
        margin-top: 8px;
    }
    
    .c-cta__btn {
        margin-top: 32px;
    }
}

/*===========================================================================*/
/*  breadcrumb  */
/*===========================================================================*/
.c-breadcrumb {
    margin-top: 166px;
    font-size: 11px;
    line-height: 1;
    padding: 0 60px;
    text-align: right;
    color: #999;
}

.c-breadcrumb a {
    transition: opacity .4s 0s cubic-bezier(.44,.14,.09,1.02);
}

.c-breadcrumb__inner>span>span {
    position: relative;
    padding-right: 30px;
}
.c-breadcrumb__inner>span>span.breadcrumb_last {
    padding-right: 0;
    color: #333;
    font-weight: 700;
}

.c-breadcrumb__inner>span>span::before {
    content: '/';
    right: 13px;
    position: absolute;
    top: 0;
}
.c-breadcrumb__inner>span>span.breadcrumb_last::before {
    display: none;
}

@media screen and (min-width: 769px) {
    .c-breadcrumb a:hover {
        opacity: .6;
    }
}

@media screen and (max-width: 1000px) {
    .c-breadcrumb {
        margin-top: 92px;
        padding: 0 20px;
    }
}

@media screen and (max-width: 768px) {
    .c-breadcrumb {
        font-size: 10px;
    }
    
    .c-breadcrumb__inner>span>span {
        position: relative;
        padding-right: 25px;
    }
    
    .c-breadcrumb__inner>span>span::before {
        right: 11px;
    }
}

/*===========================================================================*/
/*  lower mv  */
/*===========================================================================*/
.c-lowerMv {
    margin-top: 39px;
    padding-top: 214px;
    padding-bottom: 257px;
    position: relative;
}
.c-lowerMv.--lower {
    padding-top: 180px;
    padding-bottom: 260px;
}
.c-lowerMv.--02 {
    padding-top: 40px;
    padding-bottom: 0;
}

.c-lowerMv__inner {
    position: relative;
    z-index: 2;
}

.c-lowerMv__head {
    position: relative;
    font-size: 50px;
    line-height: 1;
    font-weight: 500;
    text-align: center;
    padding-bottom: 24px;
    color: #fff;
}
.c-lowerMv__head--border {
    content: '';
    height: 2px;
    left: calc(50% - 35px);
    position: absolute;
    bottom: 0;
    width: 70px;
}

.c-lowerMv__subHead {
    margin-top: 24px;
    font-size: 13px;
    line-height: 1.4;
    text-align: center;
    font-weight: 500;
    color: #fff;
}

.c-lowerMv.--02 .c-lowerMv__head,
.c-lowerMv.--02 .c-lowerMv__subHead {
    color: #333;
}

.c-lowerMv__subHead02 {
    color: #66cc00;
    text-align: center;
    font-size: 25px;
    line-height: 1;
    font-weight: 500;
    padding-bottom: 14px;
    position: relative;
}
.c-lowerMv__subHead02--border {
    height: 2px;
    left: calc(50% - 35px);
    position: absolute;
    bottom: 0;
    width: 70px;
}

.c-lowerMv__head02 {
    margin-top: 22px;
    text-align: center;
    font-size: 35px;
    line-height: 1;
    font-weight: 700;
    color: #fff;
    font-feature-settings: 'pwid' on, 'palt' on;
    letter-spacing: .06em;
}

.c-lowerMv__txt02 {
    text-align: center;
    color: #fff;
    margin-top: 20px;
    font-size: 20px;
    line-height: 1;
    font-weight: 500;
}

.c-lowerMv__bg01 {
    position: absolute;
    z-index: 1;
    width: calc(50% + 449px);
    max-width: calc(100% - 60px);
    height: calc(100% - 80px);
    right: 0;
    overflow: hidden;
    border-radius: 50px 0 0 0;
    bottom: 80px;
}
.c-lowerMv__bg01::before {
    background-color: #333;
    content: '';
    height: 100%;
    left: 0;
    position: absolute;
    top: 0;
    width: 100%;
    opacity: .3;
}

.c-lowerMv__bg01 img {
    height: 100%;
    object-fit: cover;
}

.c-lowerMv__bg02 {
    position: absolute;
    z-index: 0;
    width: calc(50% + 449px);
    max-width: calc(100% - 60px);
    height: calc(100% - 80px);
    left: 0;
    overflow: hidden;
    border-radius: 0 50px 50px 0;
    bottom: 0;
}

.c-lowerMv__bg02 .fade-border {
    border-radius: 0 50px 50px 0;
}

@media screen and (max-width: 900px) {
    .c-lowerMv {
        margin-top: 29px;
        padding-top: 86px;
        padding-bottom: 127px;
    }
    .c-lowerMv.--lower {
        padding-top: 74px;
        padding-bottom: 10px;
        min-height: 287px;
    }
    .c-lowerMv.--02 {
        padding-top: 40px;
    }
    
    .c-lowerMv__head {
        font-size: 32px;
        padding-bottom: 19px;
    }
    .c-lowerMv__head--border {
        left: calc(50% - 24px);
        width: 48px;
    }
    
    .c-lowerMv__subHead {
        margin-top: 18px;
        font-size: 10px;
    }

    .c-lowerMv__subHead02 {
        font-size: 22px;
        padding-bottom: 13px;
    }
    .c-lowerMv__subHead02--border {
        left: calc(50% - 25px);
        width: 50px;
    }
    
    .c-lowerMv__head02 {
        margin-top: 20px;
        font-size: 24px;
    }
    
    .c-lowerMv__txt02 {
        margin-top: 17px;
        font-size: 15px;
    }
    
    .c-lowerMv__bg01 {
        width: calc(100% - 20px);
        max-width: unset;
        height: calc(100% - 38px);
        border-radius: 25px 0 0 0;
        bottom: 38px;
    }
    
    .c-lowerMv__bg02 {
        width: 100%;
        max-width: unset;
        height: 211px;
        border-radius: 0;
    }

    .c-lowerMv__bg02 .fade-border {
        border-radius: 0;
    }
}

/*===========================================================================*/
/*  lower menu  */
/*===========================================================================*/
.c-lowerMenu{
    padding-bottom: 100px;
}

.c-lowerMenu__list{
    padding-top: 40px;
    border-top: 1px solid #ccc;
    display: flex;
    gap: 20px;
}
.c-lowerMenu.--recruit .c-lowerMenu__list {
    flex-wrap: wrap;
    gap: 18px;
}

.c-lowerMenu__list li{
    width: 100%;
}
.c-lowerMenu.--recruit .c-lowerMenu__list li {
    width: calc(33.33333% - 12px);
}

.c-lowerMenu__list li a{
    display: block;
    border: 1px solid #ccc;
    border-radius: 0 0 30px 0;
    padding: 30px 20px;
    position: relative;
    transition: all .4s 0s cubic-bezier(.44,.14,.09,1.02);
}

.c-lowerMenu__list li a.--active{
    background: #66cc00;
    border-color: #66cc00;
    color: #fff;
}
/* .c-lowerMenu.--recruit.--top .c-lowerMenu__list li a.--active{
    background: #fff;
    border-color: #66cc00;
    color: #66cc00;
} */

.c-lowerMenu__list--ttl{
    font-size: 20px;
    font-weight: 500;
}

.c-lowerMenu__list--txt{
    font-size: 11px;
    margin-top: 5px;
}
.c-lowerMenu.--recruit.--top .c-lowerMenu__list--txt{
    color: #999;
}

.c-lowerMenu-btn-arrow-wrapper {
    overflow: hidden;
    position: absolute;
    width: 32px;
    height: 9px;
    right: 30px;
    bottom: 30px;
}

.c-lowerMenu-btn-arrow01 {
    position: absolute;
    width: 32px;
    left: 0;
    top: 50%;
    transform: translate(0, -50%);
    transition: transform .4s 0s cubic-bezier(.44,.14,.09,1.02);
}
.c-lowerMenu-btn-arrow02 {
    position: absolute;
    width: 32px;
    left: 0;
    top: 50%;
    transform: translate(-120%, -50%);
    transition: transform .4s 0s cubic-bezier(.44,.14,.09,1.02);
}

.c-lowerMenu__list .c-lowerMenu-btn-arrow-wrapper {
    width: 22px;
    height: 6px;
    right: 20px;
    bottom: 30px;
}

.c-lowerMenu__list .c-lowerMenu-btn-arrow01,
.c-lowerMenu__list .c-lowerMenu-btn-arrow02 {
    width: 22px;
    right: 20px;
}

.c-lowerMenu__list li a.--active .c-lowerMenu-btn-arrow01 {
    opacity: 0;
}
.c-lowerMenu__list li a.--active .c-lowerMenu-btn-arrow02 {
    opacity: 1;
}

@media screen and (min-width: 769px) {
    .c-lowerMenu-btn:hover .c-lowerMenu-btn-arrow01 {
        transform: translate(120%, -50%);
    }
    .c-lowerMenu-btn:hover .c-lowerMenu-btn-arrow02 {
        transform: translate(0, -50%);
    }

    .c-lowerMenu__list .c-lowerMenu-btn:hover {
        background: #66cc00;
        color: #fff;
    }
    .c-lowerMenu.--recruit.--top .c-lowerMenu__list .c-lowerMenu-btn:hover {
        background: #fff;
        color: #66cc00;
        border-color: #66cc00;
    }
}

@media screen and (max-width: 768px){
    .c-lowerMenu__list{
        padding-top: 30px;
        flex-wrap: wrap;
        gap: 10px;
    }
    .c-lowerMenu.--recruit .c-lowerMenu__list {
        gap: 10px;
    }

    .c-lowerMenu__list li{
        width: calc(50% - 5px);
    }
    .c-lowerMenu.--recruit .c-lowerMenu__list li {
        width: calc(50% - 5px);
    }

    .c-lowerMenu__list li a{
        padding: 22px 10px;
    }

    .c-lowerMenu__list--ttl{
        font-size: 15px;
        letter-spacing: 0;
        white-space: nowrap;
    }

    .c-lowerMenu__list--txt{
        font-size: 10px;
        margin-top: 5px;
        letter-spacing: 0;
    }

    .c-lowerMenu-btn-arrow-wrapper {
        width: 22px;
        height: 6px;
        right: 25px;
        bottom: 13px;
    }
    .c-lowerMenu__list .c-lowerMenu-btn-arrow-wrapper {
        bottom: 13px;
    }

    .c-lowerMenu-btn-arrow01,
    .c-lowerMenu-btn-arrow02 {
        width: 22px;
    }
}

/*===========================================================================*/
/*  philosophy btns  */
/*===========================================================================*/
.p-philosophyValue__contents {
    position: relative;
    max-width: 960px;
    margin: 48px auto 0;
}

.p-philosophyValue__contents--inner {
    position: relative;
    z-index: 2;
    max-width: 494px;
    margin: 0 auto;
}

.p-philosophyValue__contents--btn {
    background-color: #effae5;
    display: flex;
    align-items: center;
    justify-content: center;
    flex-direction: column;
    height: 100px;
    width: calc(50% - 210px);
    border-radius: 0 100vh 100vh 0;
    position: absolute;
    z-index: 0;
    right: 0;
    top: 24px;
}

#value-btn02.p-philosophyValue__contents--btn {
    left: unset;
    top: unset;
    bottom: 24px;
}
#value-btn03.p-philosophyValue__contents--btn {
    border-radius: 100vh 0 0 100vh;
    left: 0;
    top: unset;
    bottom: 24px;
    right: unset;
}
#value-btn04.p-philosophyValue__contents--btn {
    border-radius: 100vh 0 0 100vh;
    right: unset;
    left: 0;
}

.p-philosophyValue__contents--btnTxt {
    font-size: 18px;
    font-weight: 700;
    line-height: 1.2;
    font-feature-settings: 'pwid' on, 'palt' on;
    letter-spacing: .06em;
}

.p-philosophyValue__contents--btnMore {
    line-height: 1;
    font-size: 15px;
    position: relative;
    padding-right: 20px;
    margin-top: 12px;
}

.p-philosophyValue__contents--btnMore::before {
    background: url('../img/company/philosophy/icon-more.png') no-repeat center center/contain;
    content: '';
    height: 12px;
    right: 0;
    position: absolute;
    top: 1px;
    width: 14px;
}

@media screen and (max-width: 900px) {
    .p-philosophyValue__contents--btnTxt {
        font-size: 12px;
    }
}

@media screen and (max-width: 768px) {
    .p-philosophyValue__contents {
        max-width: 350px;
        margin: 155px auto 0;
    }
    
    .p-philosophyValue__contents--inner {
        max-width: 295px;
    }
    
    .p-philosophyValue__contents--btn {
        border-radius: 20px;
        height: 160px;
        width: 160px;
        position: absolute;
        z-index: 0;
        right: 0;
        top: -107px;
        padding-bottom: 30px;
    }
    
    #value-btn02.p-philosophyValue__contents--btn {
        bottom: -107px;
        padding-bottom: 0;
        padding-top: 30px;
    }
    #value-btn03.p-philosophyValue__contents--btn {
        border-radius: 20px;
        bottom: -107px;
        padding-bottom: 0;
        padding-top: 30px;
    }
    #value-btn04.p-philosophyValue__contents--btn {
        border-radius: 20px;
    }
    
    .p-philosophyValue__contents--btnTxt {
        font-size: 17px;
        line-height: 1;
    }
    
    .p-philosophyValue__contents--btnMore {
        line-height: 1;
        font-size: 15px;
        margin-top: 10px;
    }
}

.p-philosophyValue__popup--wrapper {
    position: fixed;
    z-index: 95;
    width: 100vw;
    height: 100vh;
    top: 0;
    left: 0;
    padding: 80px 10px;
    display: flex;
    align-items: center;
    justify-content: center;
    transition: opacity .6s 0s cubic-bezier(.44,.14,.09,1.02);
    opacity: 0;
    pointer-events: none;
}
.p-philosophyValue__popup--wrapper.js-active {
    opacity: 1;
    pointer-events: all;
}

.p-philosophyValue__popup--close {
    position: absolute;
    width: 100%;
    height: 100%;
    left: 0;
    top: 0;
    background-color: rgba(51,51,51,.8);
}

.p-philosophyValue__popup--inner {
    width: 100%;
    max-width: 1100px;
    position: relative;
    padding: 0 50px;
    z-index: 2;
}

.p-philosophyValue__popup--contents {
    overflow: hidden;
}

.p-philosophyValue__popup--contentsInner {
    display: flex;
}
.p-philosophyValue__popup--contentsInner.js-num-01 {
    transform: translate(0, 0);
}
.p-philosophyValue__popup--contentsInner.js-num-02 {
    transform: translate(-100%, 0);
}
.p-philosophyValue__popup--contentsInner.js-num-03 {
    transform: translate(-200%, 0);
}
.p-philosophyValue__popup--contentsInner.js-num-04 {
    transform: translate(-300%, 0);
}
.p-philosophyValue__popup--contentsInner.js-num-01-btn {
    transform: translate(0, 0);
    transition: transform .6s 0s cubic-bezier(.44,.14,.09,1.02);
}
.p-philosophyValue__popup--contentsInner.js-num-02-btn {
    transform: translate(-100%, 0);
    transition: transform .6s 0s cubic-bezier(.44,.14,.09,1.02);
}
.p-philosophyValue__popup--contentsInner.js-num-03-btn {
    transform: translate(-200%, 0);
    transition: transform .6s 0s cubic-bezier(.44,.14,.09,1.02);
}
.p-philosophyValue__popup--contentsInner.js-num-04-btn {
    transform: translate(-300%, 0);
    transition: transform .6s 0s cubic-bezier(.44,.14,.09,1.02);
}

.p-philosophyValue__popup--content {
    background-color: #66cc00;
    padding: 60px 60px 50px;
    border-radius: 50px 0 50px 0;
    width: 100%;
    min-width: 100%;
    max-height: calc(100vh - 160px);
    overflow-y: scroll;
    -ms-overflow-style: none;
    scrollbar-width: none;
}
.p-philosophyValue__popup--content::-webkit-scrollbar {
    display: none;
}

.p-philosophyValue__popup--contentImg {
    height: 290px;
    overflow: hidden;
}

.p-philosophyValue__popup--contentImg img {
    height: 100%;
    object-fit: cover;
}

.p-philosophyValue__popup--contentTxts {
    position: relative;
    color: #fff;
    margin-top: 50px;
}

.p-philosophyValue__popup--contentBadge {
    position: absolute;
    width: 144px;
    height: 144px;
    border-radius: 100vh;
    text-align: center;
    background-color: #fff;
    color: #333;
    font-size: 17px;
    line-height: 1.2;
    font-weight: 500;
    display: flex;
    align-items: center;
    justify-content: center;
    padding-top: 3px;
    left: -10px;
    top: -28px;
}
.p-philosophyValue__popup--contentBadge::before {
    width: 130px;
    height: 130px;
    border-radius: 100vh;
    content: '';
    left: 50%;
    position: absolute;
    top: 50%;
    transform: translate(-50%, -50%);
    border: #66cc00 solid 7px;
}

.p-philosophyValue__popup--contentHead {
    padding-left: 161px;
    font-size: 34px;
    line-height: 1;
    font-weight: 700;
    letter-spacing: .04em;
}

.p-philosophyValue__popup--contentSubHead {
    padding-left: 161px;
    font-size: 20px;
    line-height: 1;
    font-weight: 500;
    letter-spacing: -.008em;
    margin-top: 14px;
}

.p-philosophyValue__popup--contentList {
    padding-left: 161px;
    padding-top: 28px;
    font-size: 15px;
    line-height: 1.6;
    font-weight: 500;
    font-feature-settings: 'pwid' on, 'palt' on;
    letter-spacing: .06em;
}

.p-philosophyValue__popup--contentList li {
    margin-top: 10px;
    position: relative;
    padding-left: 16px;
}
.p-philosophyValue__popup--contentList li::before {
    content: '・';
    left: 0;
    position: absolute;
    top: 0;
}

.p-philosophyValue__popup--btnPrev {
    position: absolute;
    width: 20px;
    left: 0;
    top: 50%;
    transform: translate(0, -50%);
}
.p-philosophyValue__popup--btnPrev.js-prev-01 {
    opacity: .3;
    pointer-events: none;
}
.p-philosophyValue__popup--btnNext {
    position: absolute;
    width: 20px;
    right: 0;
    top: 50%;
    transform: translate(0, -50%);
}
.p-philosophyValue__popup--btnNext.js-next-04 {
    opacity: .3;
    pointer-events: none;
}

.p-philosophyValue__popup--btnNext img {
    transform: rotate(180deg);
}

@media screen and (max-width: 768px) {
    .p-philosophyValue__popup--wrapper {
        padding: 80px 20px 135px;
    }
    
    .p-philosophyValue__popup--inner {
        width: 100%;
        padding: 0;
    }
    
    .p-philosophyValue__popup--content {
        padding: 20px 20px 35px;
        border-radius: 20px 0 20px 0;
        max-height: calc(100vh - 215px);
    }
    
    .p-philosophyValue__popup--contentImg {
        height: 232px;
    }
    
    .p-philosophyValue__popup--contentTxts {
        margin-top: 44px;
    }
    
    .p-philosophyValue__popup--contentBadge {
        width: 106px;
        height: 106px;
        font-size: 14px;
        padding-top: 3px;
        left: -5px;
        top: -28px;
    }
    .p-philosophyValue__popup--contentBadge::before {
        width: 100px;
        height: 100px;
        border: #66cc00 solid 5px;
    }
    
    .p-philosophyValue__popup--contentHead {
        padding-left: 121px;
        font-size: 20px;
    }
    
    .p-philosophyValue__popup--contentSubHead {
        padding-left: 121px;
        font-size: 14px;
        margin-top: 12px;
        letter-spacing: 0;
    }
    
    .p-philosophyValue__popup--contentList {
        padding-left: 0;
        padding-top: 28px;
    }
    
    .p-philosophyValue__popup--contentList li {
        margin-top: 10px;
        position: relative;
        padding-left: 16px;
    }
    
    .p-philosophyValue__popup--btnPrev {
        width: 15px;
        left: unset;
        right: calc(50% + 18px);
        top: unset;
        bottom: -50px;
        transform: translate(0, 0);
    }
    .p-philosophyValue__popup--btnNext {
        width: 15px;
        left: calc(50% + 18px);
        top: unset;
        bottom: -50px;
        transform: translate(0, 0);
    }
}

/*===========================================================================*/
/*  404  */
/*===========================================================================*/
.p-404 {
    padding-top: 200px;
    padding-bottom: 200px;
}

.p-404__head {
    text-align: center;
    position: relative;
    padding-bottom: 27px;
}
.p-404__head::before {
    background-color: #66cc00;
    content: '';
    height: 2px;
    left: calc(50% - 35px);
    position: absolute;
    bottom: 0;
    width: 70px;
}

.p-404__head .--large {
    display: block;
    font-size: 134px;
    font-weight: 500;
    line-height: 1;
}
.p-404__head .--small {
    display: block;
    font-size: 30px;
    font-weight: 500;
    line-height: 1;
    margin-top: -7px;
}

.p-404__subHead {
    font-size: 35px;
    line-height: 1.6;
    text-align: center;
    font-weight: 700;
    margin-top: 25px;
}

.p-404__txt {
    margin-top: 20px;
    text-align: center;
    line-height: 2;
}

.p-404__btns {
    text-align: center;
    margin-top: 60px;
}

.p-404__btns .c-btn {
    max-width: 300px;
}

.p-404__btns .c-btn:nth-of-type(2) {
    margin-left: 20px;
    background-color: #66cc00;
    color: #fff;
}

@media screen and (min-width: 769px) {
    .p-404__btns .c-btn:nth-of-type(2):hover {
        background-color: #fff;
        color: #66cc00;
    }
}

@media screen and (max-width: 768px) {
    .p-404 {
        padding-top: 150px;
        padding-bottom: 120px;
    }
    
    .p-404__head {
        padding-bottom: 20px;
    }
    .p-404__head::before {
        left: calc(50% - 25px);
        width: 50px;
    }
    
    .p-404__head .--large {
        font-size: 93px;
    }
    .p-404__head .--small {
        font-size: 21px;
        margin-top: -3px;
    }
    
    .p-404__subHead {
        font-size: 28px;
        line-height: 1.5;
        margin-top: 22px;
    }
    
    .p-404__txt {
        margin-top: 28px;
    }
    
    .p-404__btns {
        text-align: center;
        margin-top: 50px;
        display: flex;
        align-items: center;
        justify-content: center;
        flex-direction: column;
    }
    
    .p-404__btns .c-btn {
        max-width: 240px;
    }
    
    .p-404__btns .c-btn:nth-of-type(2) {
        margin-left: 0;
        margin-top: 24px;
    }
}

/*===========================================================================*/
/*  animation  */
/*===========================================================================*/
.fade-wrap {
    display: inline-flex;
    flex-direction: column;
}

.fade-wrapper {
    overflow: hidden;
}

.fade-nomal {
    opacity: 0;
    transition: opacity .9s 0s cubic-bezier(.24,.91,.57,.97);
}

.fade-bottom {
    opacity: 0;
    transform: translate3d(0, 100%, 0);
    transition: transform .9s 0s cubic-bezier(.44,.14,.09,1.02), opacity .9s 0s cubic-bezier(.24,.91,.57,.97);
}
.fade-bottom02 {
    opacity: 0;
    transform: translate3d(0, 24px, 0);
    transition: transform .7s 0s cubic-bezier(.44,.14,.09,1.02), opacity .7s 0s cubic-bezier(.24,.91,.57,.97);
}
.fade-bottom03 {
    opacity: 0;
    transform: translate3d(0, 30px, 0);
    transition: transform .7s 0s cubic-bezier(.44,.14,.09,1.02), opacity .7s 0s cubic-bezier(.24,.91,.57,.97);
}
.fade-top-header {
    opacity: 0;
    transform: translate3d(0, -20%, 0);
    transition: transform .7s 0s cubic-bezier(.44,.14,.09,1.02), opacity .7s 0s cubic-bezier(.24,.91,.57,.97);
}
.fade-top {
    opacity: 0;
    transform: translate3d(0, -100%, 0);
    transition: transform .9s 0s cubic-bezier(.44,.14,.09,1.02), opacity .9s 0s cubic-bezier(.24,.91,.57,.97);
}
.fade-left {
    opacity: 0;
    transform: translate3d(-105%, 0, 0);
    transition: transform .7s 0s cubic-bezier(.44,.14,.09,1.02), opacity .7s 0s cubic-bezier(.24,.91,.57,.97);
}
.fade-right {
    opacity: 0;
    transform: translate3d(105%, 0, 0);
    transition: transform .7s 0s cubic-bezier(.44,.14,.09,1.02), opacity .7s 0s cubic-bezier(.24,.91,.57,.97);
}
.fade-ttlEn {
    opacity: 0;
    transform: translate3d(105%, 0, 0);
    transition: transform .7s 0s cubic-bezier(.44,.14,.09,1.02), opacity .7s 0s cubic-bezier(.24,.91,.57,.97);
}
.fade-border-wrapper {
    overflow: hidden;
}
.fade-border {
    transition: width .7s 0s cubic-bezier(.44,.14,.09,1.02);
    width: 0;
    height: 100%;
    display: block;
}
.fade-border.border-green {
    background-color: #66cc00;
}
.fade-border.border-black {
    background-color: #333;
}
@media screen and (max-width: 900px) {
    .fade-lower-content {
        transform: translate3d(0, 77px, 0);
    }

    .fade-ttlEn {
        transform: translate3d(-105%, 0, 0);
    }
}

.fade-nomal.js-active {
    opacity: 1;
}
.fade-bottom.js-active,
.fade-bottom02.js-active,
.fade-bottom03.js-active,
.fade-bottom-header.js-active,
.fade-top-header.js-active,
.fade-top.js-active,
.fade-left.js-active,
.fade-right.js-active,
.fade-ttlEn.js-active {
    opacity: 1;
    transform: translate3d(0, 0, 0);
}
.fade-border.js-active {
    width: 100%;
}

.fade-media-img-wrapper {
    position: relative;
    opacity: 0;
    transition: opacity .6s 0s cubic-bezier(.44,.14,.09,1.02);
    overflow: hidden;
}
.fade-media-img-bg {
    background-color: #66cc00;
    content: '';
    height: 100%;
    left: 0;
    position: absolute;
    top: 0;
    width: 100%;
    z-index: 3;
    transition: left .6s 0s cubic-bezier(.44,.14,.09,1.02);
}
.fade-media-imgWrapper {
    overflow: hidden;
}
.fade-media-img {
    scale: 1.23;
    transition: scale .6s 0s cubic-bezier(.44,.14,.09,1.02);
}
.fade-media-img-wrapper.js-active {
    opacity: 1;
}
.fade-media-img-bg.js-active {
    left: calc(100% + 10px);
}
.fade-media-img.js-active {
    scale: 1.03;
}

.fade-scaleUp {
    scale: .8;
    transition: scale .6s 0s cubic-bezier(.44,.14,.09,1.02);
}
.fade-scaleDown {
    scale: 1.23;
    transition: scale .6s 0s cubic-bezier(.44,.14,.09,1.02);
}

.fade-scaleUp.js-active,
.fade-scaleDown.js-active {
    scale: 1;
}

.delay01.js-active {
    transition-delay: .1s !important;
}
.delay02.js-active {
    transition-delay: .2s !important;
}
.delay03.js-active {
    transition-delay: .3s !important;
}
.delay04.js-active {
    transition-delay: .4s !important;
}
.delay05.js-active {
    transition-delay: .5s !important;
}
.delay06.js-active {
    transition-delay: .6s !important;
}
.delay07.js-active {
    transition-delay: .7s !important;
}
.delay08.js-active {
    transition-delay: .8s !important;
}
.delay09.js-active {
    transition-delay: .9s !important;
}
.delay10.js-active {
    transition-delay: 1s !important;
}
.delay11.js-active {
    transition-delay: 1.1s !important;
}
.delay12.js-active {
    transition-delay: 1.2s !important;
}
.delay13.js-active {
    transition-delay: 1.3s !important;
}
.delay14.js-active {
    transition-delay: 1.4s !important;
}
.delay15.js-active {
    transition-delay: 1.5s !important;
}
.delay16.js-active {
    transition-delay: 1.6s !important;
}
.delay17.js-active {
    transition-delay: 1.7s !important;
}
.delay18.js-active {
    transition-delay: 1.8s !important;
}
.delay19.js-active {
    transition-delay: 1.9s !important;
}
.delay20.js-active {
    transition-delay: 2s !important;
}
.delay21.js-active {
    transition-delay: 2.1s !important;
}
.delay22.js-active {
    transition-delay: 2.2s !important;
}
.delay23.js-active {
    transition-delay: 2.3s !important;
}
.delay24.js-active {
    transition-delay: 2.4s !important;
}
.delay25.js-active {
    transition-delay: 2.5s !important;
}
.delay26.js-active {
    transition-delay: 2.6s !important;
}
.delay27.js-active {
    transition-delay: 2.7s !important;
}
.delay28.js-active {
    transition-delay: 2.8s !important;
}
.delay29.js-active {
    transition-delay: 2.9s !important;
}
.delay30.js-active {
    transition-delay: 3s !important;
}
.delay31.js-active {
    transition-delay: 3.1s !important;
}
.delay32.js-active {
    transition-delay: 3.2s !important;
}
.delay33.js-active {
    transition-delay: 3.3s !important;
}
.delay34.js-active {
    transition-delay: 3.4s !important;
}
.delay35.js-active {
    transition-delay: 3.5s !important;
}
.delay36.js-active {
    transition-delay: 3.6s !important;
}
.delay37.js-active {
    transition-delay: 3.7s !important;
}
.delay38.js-active {
    transition-delay: 3.8s !important;
}
.delay39.js-active {
    transition-delay: 3.9s !important;
}
.delay40.js-active {
    transition-delay: 4s !important;
}
.delay41.js-active {
    transition-delay: 4.1s !important;
}
.delay42.js-active {
    transition-delay: 4.2s !important;
}
.delay43.js-active {
    transition-delay: 4.3s !important;
}
.delay44.js-active {
    transition-delay: 4.4s !important;
}
.delay45.js-active {
    transition-delay: 4.5s !important;
}
.delay46.js-active {
    transition-delay: 4.6s !important;
}
.delay47.js-active {
    transition-delay: 4.7s !important;
}
.delay48.js-active {
    transition-delay: 4.8s !important;
}
.delay49.js-active {
    transition-delay: 4.9s !important;
}
.delay50.js-active {
    transition-delay: 5s !important;
}

/*===========================================================================*/
/*  pagination  */
/*===========================================================================*/
.c-pagination {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    justify-content: center;
    padding-top: 30px;
}

.c-pagination .page-numbers.prev,
.c-pagination .page-numbers.next {
    display: none;
}

.c-pagination .page-numbers {
    width: 40px;
    height: 40px;
    margin: 20px 10px 0;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 16px;
    font-weight: 500;
    line-height: 1;
    border: #66cc00 solid 1px;
    background-color: #fff;
    transition: all .4s 0s cubic-bezier(.44,.14,.09,1.02);
    border-radius: 100vh;
    padding-bottom: 2px;
}
.c-pagination .page-numbers.dots {
    width: auto;
    height: auto;
    border: none;
    pointer-events: none;
    padding-bottom: 0;
    margin: 20px 5px 0;
}

.c-pagination .page-numbers.current {
    pointer-events: none;
    background-color: #66cc00;
    color: #fff;
}

@media screen and (min-width: 769px) {
    .c-pagination .page-numbers:hover {
        background-color: #66cc00;
        color: #fff;
    }
}

@media screen and (max-width: 768px) {
    .c-pagination .page-numbers {
        width: 36px;
        height: 36px;
        margin: 18px 9px 0;
        font-size: 15px;
    }
    .c-pagination .page-numbers.dots {
        margin: 18px 3px 0;
    }
}
