@charset "UTF-8";
/* =============================================
リセット・ボックスサイジング (Reset & Box Sizing)
============================================= */
html, body, div, span, object, iframe,
h1, h2, h3, h4, h5, h6, p, blockquote, pre,
abbr, address, cite, code, del, dfn, em, img, ins, kbd, q, samp,
small, strong, sub, sup, var, b, i,
dl, dt, dd, ol, ul, li,
fieldset, form, label, legend,
table, caption, tbody, tfoot, thead, tr, th, td,
article, aside, canvas, details, figcaption, figure,
footer, header, hgroup, menu, nav, section, summary,
time, mark, audio, video {
    margin: 0;
    padding: 0;
    border: 0;
    font-size: 100%;
    vertical-align: baseline;
    background: transparent;
}

/* HTML5の新しい要素をブロック要素として表示 */
article, aside, details, figcaption, figure,
footer, header, hgroup, menu, nav, section {
    display: block;
}

/* すべての要素にborder-boxを適用 (モダンな推奨設定) */
*, *::before, *::after {
    box-sizing: border-box;
}

/* 基本設定 */
html {
    font-size: 62.5%; /* 1rem = 10px 基準 */
}
body {
    line-height: 1.5; /* 行の高さを標準の1.5に設定 */
}

/* リスト・引用符の整理 */
nav ul {
    list-style: none;
}
blockquote, q {
    quotes: none;
}
blockquote:before, blockquote:after,
q:before, q:after {
    content: none;
}

/* テーブルの整理 */
table {
    border-collapse: collapse;
    border-spacing: 0;
}
a {
    margin:0;
    padding:0;
    font-size:100%;
    vertical-align: baseline;
    background:transparent;
    text-decoration: none;
    cursor: pointer;
}
body{
    font-size: 1.6rem;
    line-height: 1.75;
    color: #404040;
    font-family: 'Noto Sans JP', sans-serif, "游ゴシック体", YuGothic, "游ゴシック", "Yu Gothic", "ヒラギノ角ゴ Pro W3","Hiragino Kaku Gothic Pro", "メイリオ", sans-serif;
    word-break: break-word;
    font-weight: 400;
    position: relative;
    background: #EFF2F3;
    letter-spacing: 0.06em;
    overflow-x: hidden;
}
.NotoSansJP{
    font-family: 'Noto Sans JP', sans-serif;
}
.inter{
    font-family: "Inter", sans-serif;
}
/*remove highlight color touch on mobile*/
input,textarea,button,select,div,a,span {
    -webkit-tap-highlight-color: rgba(0,0,0,0);
}
a, input, div, select, textarea, img, button {
    outline: none;
}
a:focus, a:visited, input:focus, select:focus, textarea:focus, button:focus {
    outline: none !important;
    box-shadow: none;
}
ol, ul {
    list-style: none;
    margin: 0;
    padding: 0;
}
li{
    list-style: none;
}
/* change border colour to suit your needs */
hr {
    display:block;
    height:1px;
    border:0;
    border-top:1px solid #cccccc;
    margin:1em 0;
    padding:0;
}
button {
    font-family: inherit;
    cursor: pointer;
}
img {
    width /***/: auto;
    height: auto;
    border: none;
    vertical-align: bottom;
    max-width: 100%;
    image-rendering: -webkit-optimize-contrast;
}
a {
    text-decoration: none;
    cursor: pointer;
}
.hover:hover{
    transition: all .3s;
    opacity: 0.7;
    filter:alpha(opacity=70);
    -ms-filter: "alpha(opacity=70)";
}
.container {
    margin: 0 auto;
    max-width: 1080px;
    position: relative;
    z-index: 10;
    padding-left: 20px;
    padding-right: 20px;
}
.anchor-link{
    position: relative;
    top: -80px;
    display: block;
    line-height: 0;
}
.wrapper{
    position: relative;
    z-index: 1;
}
.text-left{
    text-align: left;
}
.text-center{
    text-align: center;
}
.text-right{
    text-align: right;
}
.hdn{
    display: none;
}
.no-cursor{
    cursor: auto !important;
}
b, strong{
    font-weight: 700;
}
.img-link {
    position: absolute;
    left: 0;
    right: 0;
    top: 0;
    bottom: 0;
    z-index: 10;
}
@media(max-width: 750px){
    .container {
        padding-left: 25px;
        padding-right: 25px;
    }
    .anchor-link{
        top: -55px;
    }
}

/*
==============================================================
============================ Common ==========================
==============================================================
*/
.inline-block-pc {
    display: inline-block !important;
}
.lb-sp {
    display: none !important;
}
.lb-pc {
    display: block !important;
}
.header .btn,
.footer .btn {
    font-size: 1.2rem;
    font-weight: 700;
    letter-spacing: .08em;
    line-height: 1;
    min-width: 150px;
    background: #CBDBE3;
    border-radius: 50vh;
    color: #404040;
    display: inline-block;
    text-align: center;
    padding: 9px 15px;
    position: relative;
    transition: .2s;
    letter-spacing: 0.05em;
}
.btn.btn-1 {
    background: #99A5AA;
    color: #fff;
}

@media(max-width:750px){
    .lb-sp {
        display: block !important;
    }
    .inline-block-pc {
        display: none !important;
    }
    .lb-pc {
        display: none !important;
    }
    
}
main {
    position: relative;
    z-index: 1;
}
/*
==============================================================
========================== End common ========================
==============================================================
*/

/*
==============================================================
======================= hamburger menu =======================
==============================================================
*/
.hamburger-menu {
    position: absolute;
    right: 2.66vw;
    top: 50%;
    width: 82px;
    height: 18px;
    margin-top: -9px;
    cursor: pointer;
    z-index: 1000001;
    display: none;
    color: #fff;
    line-height: 1;
    font-family: "Inter", sans-serif;
    font-size: 1.4rem;
    font-weight: 700;
    letter-spacing: 0.05em;
}
.hamburger-menu .bar,
.hamburger-menu .bar:after,
.hamburger-menu .bar:before {
    width: 28px;
    height: 2px;
    top: 50%;
    margin-top: -1px;
}
.hamburger-menu span {
    transition: .3s;
}
.hamburger-menu .close {
    display: none;
}
.hamburger-menu.active .close {
    display: block;
}
.hamburger-menu.active .menu {
    display: none;
}
.hamburger-menu .bar {
    position: relative;
    transform: translateY(-5px);
    background:#00000000;
    transition: all 0ms 300ms;
    display: block;
}
.hamburger-menu .bar.active {
    background: none; 
}
.hamburger-menu .bar:before {
    content: "";
    position: absolute;
    left: 0;
    bottom: 0px;
    background: #fff;
    transition: bottom 300ms 300ms cubic-bezier(0.23, 1, 0.32, 1), transform 300ms cubic-bezier(0.23, 1, 0.32, 1);
}
.hamburger-menu .bar:after {
    content: "";
    position: absolute;
    left: 0;
    top: -8px;
    background:#fff;
    transition: top 300ms 300ms cubic-bezier(0.23, 1, 0.32, 1), transform 300ms cubic-bezier(0.23, 1, 0.32, 1);
}
.hamburger-menu.active {
    color: #404040;
}
.hamburger-menu.active .bar{
    background: none !important;
}
.hamburger-menu.active .bar::before,
.hamburger-menu.active .bar::after{
    top: -4px;
    bottom: 0;
    background: #404040;
}
.hamburger-menu.active .bar:before {
    transform: rotate(-26deg);
    transition: bottom 300ms cubic-bezier(0.23, 1, 0.32, 1), transform 300ms 300ms cubic-bezier(0.23, 1, 0.32, 1);;
}
.hamburger-menu.active .bar:after {
    transform: rotate(26deg);
    transition: top 300ms cubic-bezier(0.23, 1, 0.32, 1), transform 300ms 300ms cubic-bezier(0.23, 1, 0.32, 1);;
}
@media(max-width: 960px){
    .hamburger-menu {
        display: flex;
        align-items: center;
        justify-content: space-between;
    }
    header.low .hamburger-menu {
        color: inherit;
    }
    header.low .hamburger-menu .bar:after,
    header.low .hamburger-menu .bar::before {
        background: #404040;
    }
}
/*
==============================================================
====================== End hamburger menu ====================
==============================================================
*/
/*
==============================================================
========================== Animation =========================
==============================================================
*/
@-webkit-keyframes aniHeaderMenu {
    0% {-webkit-transform: translate3d(0, -80%, 0);transform: translate3d(0, -80%, 0);}
    100% {-webkit-transform: translate3d(0, 0, 0);transform: translate3d(0, 0, 0);}
}
@keyframes aniHeaderMenu {
    0% {-webkit-transform: translate3d(0, -80%, 0);transform: translate3d(0, -80%, 0);}
    100% {-webkit-transform: translate3d(0, 0, 0);transform: translate3d(0, 0, 0);}
}
/*
==============================================================
======================= End Animation ========================
==============================================================
*/

/*
==============================================================
============================ Header ==========================
==============================================================
*/
header{
    position: fixed;
    left: 0;
    right: 0;
    top: 0;
    z-index: 10000000;
    line-height: 1;
    padding: 0 30px !important;
}
header .inner{
    display: flex;
    padding: 26px 0;
    align-items: center;
    position: relative;
    max-width: unset;
}
header .logo{
    display: inline-block;
}
header .logo img{
    width: 128px;
}
header .logo .img2 {
    display: none;
} 
header nav {
    padding-left: 20px;
    width: 100%;
    display: flex;
    justify-content: flex-end;
    align-items: center;
}
header ul a{
    text-align: center;
    line-height: 1.2;
    color: #fff;
    font-size: 1.5rem;
    font-weight: 700;
    letter-spacing: .05em;
    font-family: "Inter", sans-serif;
}
header ul a .sm{
    font-size: 1.2rem;
    display: block;
    font-weight: 500;
    line-height: 1.66;
    padding-top: 2px;
    font-family: 'Noto Sans JP', sans-serif, "游ゴシック体", YuGothic, "游ゴシック", "Yu Gothic", "ヒラギノ角ゴ Pro W3","Hiragino Kaku Gothic Pro", "メイリオ", sans-serif;
}
header nav > ul{
    display: flex;
    align-items: center;
}
header nav > ul > li{
    position: relative;
    transition: .3s ease;
}
header nav > ul > li:last-child{
    padding-right: 0;
}
header nav > ul > li > a{
    display: inline-block;
    padding: 0 16px;
    position: relative;
    transition: .3s;
}
header nav .btn-box {
    padding-left: 25px;
}
header nav .btn-box li {
    padding: 0 6px;
}
header nav .btn-box li:last-child {
    padding-right: 0;
}
header nav .btn-box li:first-child {
    padding-left: 0;
}
.fixed-nav header{
    position: fixed;
    left: 0;
    right: 0;
    z-index: 10000000;
    background: rgba(255, 255, 255, 0.9);
    -webkit-transform: translate3d(0, 0, 0);
            transform: translate3d(0, 0, 0);
    /* -webkit-animation: aniHeaderMenu .3s ease forwards;
            animation: aniHeaderMenu .3s ease forwards; */
    -webkit-box-shadow: 0px 6px 12px 0px rgba(0, 0, 0, 0.1);
            box-shadow: 0px 6px 12px 0px rgba(0, 0, 0, 0.1);
}
.fixed-nav header .logo .img1 {
    display: none;
}
.fixed-nav header .logo .img2 {
    display: block;
}
.fixed-nav header a {
    color: #404040;
}

header {
    transition: transform 0.3s ease;
}

/* 下スクロール時に隠す */
header.hide {
    transform: translateY(-130%);
}

@media(hover:hover){
    header nav > ul > li > a:hover{
        opacity: .6;
    }
}
@media(hover:none){
    header nav > ul > li > a:active{
        opacity: .6;
    }
}
@media(max-width: 1250px){
    header {
        padding: 0 20px;
    }
    header nav > ul > li > a {
        padding: 0 10px;
    }
    header nav .btn-box {
        padding-left: 10px;
    }
}
@media(max-width: 1150px){
    header {
        padding: 0 20px;
    }
    header nav > ul > li > a {
        padding: 0 10px;
    }
    header nav .btn-box .btn {
        min-width: 120px;
    }
    header ul a {
        font-size: 1.2rem;
    }
    header ul a .sm {
        font-size: 1rem;
    }
}
@media(max-width:1000px){
    header .logo img {
        width: 100px;
        transition: .3s;
    }
    header ul a {
        font-size: 1.1rem;
    }
}
@media(max-width:960px){
    header .logo img {
        width: 95px;
    }
    header.open-menu {
        background: rgba(255, 255, 255, 0.9);
    }
    header.open-menu .logo {
        opacity: 0;
    }
    header nav {
        position: fixed;
        right: 0;
        left: 100%;
        top: 49px;
        bottom: 0;
        background: #fff;
        /* background: rgba(255, 255, 255, 0.95); */
        width: 100%;
        transition: 0.5s;
        z-index: 1000;
        padding: 0 0 30px;
        overflow: auto;
        align-items: unset;
        display: none;
    }
    header.open-menu nav{
        left: 0;
        z-index: 10000;
        justify-content: flex-start;
        display: flex;
        flex-direction: column;
    }
    header nav > ul{
        width: 100%;
        flex-wrap: wrap;
        /* overflow: auto; */
        padding-top:15px !important;
    }
    header nav ul li {
        padding: 0;
        width: 100%;
        margin-right: 0;
    }
    header nav > ul > li > a {
        display: flex;
        font-size: 2.2rem;
        align-items: center;
        padding: 20px 25px;
    }
    header ul a .sm{
        font-size: 1.2rem;
        padding-left: 10px;
        padding-top: 0;
    }
    header{
        position: fixed;
        height: 50px;
        padding: 0 !important;
    }
    .fixed-nav header{
        position: fixed;
        background: unset;
        /* -webkit-transform: unset;
                transform: unset;
        -webkit-animation: unset;
                animation: unset; */
        -webkit-box-shadow: unset;
                box-shadow: unset;
                transition: auto;
                background: unset

    }
    .fixed-nav header .logo .img2 {
        display: none;
    }
    .fixed-nav header .logo .img1 {
        display: block;
    }
    header .inner  {
        padding: 12px;
    }
    header.open-menu {
        background: rgba(255, 255, 255, 0.9);
        transform: unset !important;
    }
    header nav > ul > li > a {
        color: #404040;
    }
    header nav .btn-box .btn {
        min-width: unset;
        width: 100%;
    }
    header .inner::before {
        content: "";
        position: absolute;
        top: 0;
        left: 0;
        right: 0;
        height: 75px;
        background: linear-gradient(to top, rgba(217, 217, 217, 0) 0%, rgb(0, 0, 0, .4) 100%);
        z-index: -1;
    }
    header.open-menu .inner::before {
        display: none;
    }
    header nav .btn-box li:first-child,
    header nav .btn-box li:last-child {
        padding: 0 25px;
    }
    header nav .btn-box li:first-child {
        margin-bottom: 25px;
        margin-top: 25px;
    }
    header nav .btn-box {
        padding: 0;
    }
    header nav .btn-box .btn {
        font-size: 1.6rem;
        padding: 17px 15px;
    }
    header.low .inner::before {
        content: none;
    }
}
@media(max-width:374px){
    header ul a .sm, header .sns-box .txt{
        font-size: 1.2rem;
    }
}
/*
==============================================================
========================= End header =========================
==============================================================
*/
/*
==============================================================
============================= Footer =========================
==============================================================
*/
.parallax{
    overflow: hidden;
}
.footer {
    position: relative;
    z-index: 0; /* 数値なし(auto)やマイナスよりは強く、1よりは弱い */
    background: #fff;
    width: 100%;
    overflow: hidden;
    /* transform: translateY(calc(-100px + var(--footerMove, 0px)));
    transition: transform 0.1s linear; */
}
.footer-inner {
    padding-top: 100px;
    padding-bottom: 25px;
    min-height: 300px;
}
footer .container {
    max-width: 1300px;
}
footer .content {
    display: flex;
    flex-wrap: wrap;
    padding-bottom: 120px;
}
footer .left {
    width: 50%;
}
footer .left ul {
    display: flex;
    flex-wrap: wrap;
    padding-top: 70px;
}
footer .left ul li {
    width: 30px;
    margin-right: 20px;
}
footer .left .logo a {
    display: block;
}
footer .left a {
    transition: .3s;
}
footer .left a:hover {
    opacity: .7;
}
footer .left .logo img {
    width: 218px;
}
footer .right {
    flex: 1;
    display: flex;
}
footer .right ul li a {
    display: block !important;
    color: #404040;
    font-size: 700;
    font-family: "Inter", sans-serif; 
    font-weight: 700;
    letter-spacing: 0.05em;
    transition: 0.3s;
}
footer .right ul li a:hover {
    opacity: .7;
}
footer .right ul {
    width: 33.33%;
}
footer .right ul li {
    padding-bottom: 35px;
}
footer .right ul li .ja {
    display: block;
    font-size: 1.2rem;
    font-weight: 500;
    line-height: 1.2;
    font-family: 'Noto Sans JP', sans-serif, "游ゴシック体", YuGothic, "游ゴシック", "Yu Gothic", "ヒラギノ角ゴ Pro W3","Hiragino Kaku Gothic Pro", "メイリオ", sans-serif;
}
footer .right ul:last-child li {
    padding-bottom: 20px;
}
footer .right ul li:last-child {
    padding-bottom: 0;
}
footer .bottom-nav ul {
    display: flex;
    flex-wrap: wrap;    
}
footer .bottom-nav li {
    margin-right: 15px;
}
footer .bottom-nav a {
    color: #404040;
    /* font-size: 1.4rem; */
    font-size: clamp(1rem, .99vw, 1.4rem);
    transition: .3s;
}
footer .bottom-nav a:hover {
    opacity: .7;
}
footer .bottom-nav li:last-child {
    margin-right: 0;
}
footer .copy-right {
    text-align: right;
    font-size: 1.4rem;
    letter-spacing: 0.05em;
    font-family: "Inter", sans-serif; 
    padding-top: 20px;
    color: #959595;
}
@media(max-width: 768px){
    footer {
        padding-top: 100px;
        transform: unset !important;
    }
    .footer-inner {
        padding-top: 0;
    }
    footer .left {
        width: 100%;
    }
    footer .right {
        flex: auto;
    }
    footer .left ul {
        padding-bottom: 50px;
    }
    footer .content {
        padding-bottom: 50px;
    }
    footer .left .logo img {
        width: 135px;
    }
    footer .left ul {
        padding-top: 30px;
    }
    footer .right ul {
        width: 100%;
    }
    footer .right {
        flex-wrap: wrap;
    }
    footer .right ul li .ja {
        display: inline-block;
        margin-left: 8px;
        font-size: 1.3rem;
    }
    footer .right ul li,
    footer .right ul li:last-child {
        padding: 15px 0;
    }
    footer .right ul:last-child li {
        padding: 0 0 25px;
    }
    footer .right ul:last-child {
        padding-top: 30px;
    }
    footer .bottom-nav a {
        font-size: 1.2rem;
        font-weight: 500;
    }
    footer .bottom-nav li {
        padding-bottom: 15px;
    }
    footer .copy-right {
        text-align: left;
        font-size: 1.2rem;
        padding-top: 30px;
    }
    footer .right ul li a.btn {
        font-size: 1.6rem;
        padding: 17px 15px;
        width: 100%;
        min-width: unset;
    }
}
/*
==============================================================
=========================== End Footer =======================
==============================================================
*/
/*
==============================================================
========================== Animation =========================
==============================================================
*/
@-webkit-keyframes aniHeaderMenu {
    0% {-webkit-transform: translate3d(0, -80%, 0);transform: translate3d(0, -80%, 0);}
    100% {-webkit-transform: translate3d(0, 0, 0);transform: translate3d(0, 0, 0);}
}
@keyframes aniHeaderMenu {
    0% {-webkit-transform: translate3d(0, -80%, 0);transform: translate3d(0, -80%, 0);}
    100% {-webkit-transform: translate3d(0, 0, 0);transform: translate3d(0, 0, 0);}
}
@-webkit-keyframes backgroundIMG{
    0% {opacity: 0;}
    20% {opacity: 0.2;}
    40% {opacity: 0.4;}
    60% {opacity: 0.6;}
    80% {opacity: 0.8;}
    100% {opacity: 1; }
}
@keyframes backgroundIMG {
    0% {opacity: 0;}
    20% {opacity: 0.2;}
    40% {opacity: 0.4;}
    60% {opacity: 0.6;}
    80% {opacity: 0.8;}
    100% {opacity: 1;}
}
@-webkit-keyframes aniFade {
    0% {opacity: 0.5;}
    100% {opacity: 1;}
}
@keyframes aniFade {
  0% {opacity: 0.5;}
  100% {opacity: 1;}
}
@-webkit-keyframes fadezoom {
    0% {transform: scale(1);}
    100% {transform: scale(1.1);}
}
@keyframes fadezoom {
    0% {transform: scale(1);}
    100% {transform: scale(1.1);}
}
.fade-in {
    opacity: 0;
    filter: blur(4px) brightness(105%);
    transition: opacity 2s ease, filter 2s ease;
}
.fade-in.is-view {
    opacity: 1;
    filter: blur(0) brightness(100%);
}
.fade-up {
    opacity: 0;
    transform: translateY(60px);
    -webkit-transform: translateY(60px);
    filter: blur(4px) brightness(105%);
    transition: opacity 1.5s ease, transform 1.5s ease, filter 1.5s ease;
}
.fade-up.is-view {
    opacity: 1;
    transform: translateY(0);
    -webkit-transform: translateY(0);
    filter: blur(0) brightness(100%);
}
.fade-down {
    opacity: 0;
    transform: translateY(-40px);
    -webkit-transform: translateY(-40px);
    filter: blur(5px) brightness(105%);
    transition: opacity 1.5s ease, transform 1.5s ease, filter 1.5s ease;
}
.fade-down.is-view {
    opacity: 1;
    transform: translateY(0);
    -webkit-transform: translateY(0);
    filter: blur(0) brightness(100%);
}
.fade-left {
    opacity: 0;
    transform: translateX(-40px);
    -webkit-transform: translateX(-40px);
    filter: blur(5px) brightness(105%);
    transition: opacity 1.5s ease, transform 1.5s ease, filter 1.5s ease;
}
.fade-left.is-view {
    opacity: 1;
    transform: translateY(0);
    -webkit-transform: translateY(0);
    filter: blur(0) brightness(100%);
}
.fade-right {
    opacity: 0;
    transform: translateX(40px);
    -webkit-transform: translateX(40px);
    filter: blur(5px) brightness(105%);
    transition: opacity 1.5s ease, transform 1.5s ease, filter 1.5s ease;
}
.fade-right.is-view {
    opacity: 1;
    transform: translateY(0);
    -webkit-transform: translateY(0);
    filter: blur(0) brightness(100%);
}
.zoom-in {
    opacity: 0;
    overflow: hidden;
    transform: scale(0.7, 0.7);
    -webkit-transform: scale(0.7, 0.7);
    transition: opacity 1.5s ease, transform 1.5s ease;
}
.zoom-in.is-view {
    opacity: 1;
    transform: scale(1, 1);
    -webkit-transform: scale(1, 1);
}
.zoom-out {
    opacity: 0;
    overflow: hidden;
    transform: scale(1.2, 1.2);
    -webkit-transform: scale(1.2, 1.2);
    transition: opacity 1.5s ease, transform 1.5s ease;
}
.zoom-out.is-view {
    opacity: 1;
    transform: scale(1, 1);
    -webkit-transform: scale(1, 1);
}
.roll-left {
    position: relative;
    overflow: hidden;
}
.roll-left img {
    opacity: 0;
    transition: opacity 1.5s ease .5s;
}
.roll-left:after {
    content: '';
    position: absolute;
    top: 0;
    bottom: 0;
    background: #f0ebe4;
}
.roll-left.is-view img {
    opacity: 1;
}
.roll-left.is-view:after {
    animation: rollLeft 1.5s ease;
}
@keyframes rollLeft {
    0% {
        left: 0;
        right: 100%;
    }
    50% {
        left: 0;
        right: 0;
    }
    100% {
        left: 100%;
        right: 0;
    }
}
@-webkit-keyframes rollLeft {
    0% {
        left: 0;
        right: 100%;
    }
    50% {
        left: 0;
        right: 0;
    }
    100% {
        left: 100%;
        right: 0;
    }
}
.roll-right {
    position: relative;
    overflow: hidden;
}
.roll-right img {
    opacity: 0;
    transition: opacity 1.5s ease .5s;
}
.roll-right:after {
    content: '';
    position: absolute;
    top: 0;
    bottom: 0;
    background: #3a6531;
}
.roll-right.is-view img {
    opacity: 1;
}
.roll-right.is-view:after {
    animation: rollRight 1.5s ease;
}
@keyframes rollRight {
    0% {
        right: 0;
        left: 100%;
    }
    50% {
        right: 0;
        left: 0;
    }
    100% {
        right: 100%;
        left: 0;
    }
}
@-webkit-keyframes rollRight {
    0% {
        right: 0;
        left: 100%;
    }
    50% {
        right: 0;
        left: 0;
    }
    100% {
        right: 100%;
        left: 0;
    }
}
@media (min-width: 768px) {
    .delay1 {
        transition-delay: .4s;
    }
    .delay2 {
        transition-delay: .6s;
    }
    .delay3 {
        transition-delay: .8s;
    }
    .delay4 {
        transition-delay: 1.2s;
    }
}
/*
==============================================================
========================= End Animation ======================
==============================================================
*/
.show_sp{
    display: none !important;
}
@media (max-width: 768px) {
    .show_pc {
        display: none !important;
    }
    .show_sp {
        display: block !important;
    }
    header.open-menu .inner {
        background-color: #fff;
    }
}
body.no-scroll {
    overflow: hidden;
}