@charset "utf-8";

@font-face{
    font-family:'Noto Sans JP';
    font-style:normal;
    font-weight:400;
    src:url(../fonts/NotoSansCJKjp/NotoSansCJKjp-Regular.woff2) format('woff2'),
        url(../fonts/NotoSansCJKjp/NotoSansCJKjp-Regular.woff) format('woff'),
        url(../fonts/NotoSansCJKjp/NotoSansCJKjp-Regular.otf) format('opentype');
}
@font-face{
    font-family:'Noto Sans JP';
    font-style:normal;
    font-weight:700;
    src:url(../fonts/NotoSansCJKjp/NotoSansCJKjp-Bold.woff2) format('woff2'),
        url(../fonts/NotoSansCJKjp/NotoSansCJKjp-Bold.woff) format('woff'),
        url(../fonts/NotoSansCJKjp/NotoSansCJKjp-Bold.otf) format('opentype');
}


/*==============================
    基本設定
==============================*/
body{
    color:#333;
    font-size:12px;
    /* サイトに応じで使用するフォントを読込み */
    font-family:'YakuHanJP_Narrow','游ゴシック', YuGothic, 'ヒラギノ角ゴ Pro', 'Hiragino Kaku Gothic Pro', 'メイリオ', 'Meiryo', sans-serif;
    margin:0;
    padding:0;
    text-align:left;
    background:#fff;
    -webkit-text-size-adjust:100%;
    -webkit-tap-highlight-color:rgba(0,0,0,0.25);
    position:relative;
    word-break:break-all;
    min-width:1400px;
}
body a{
    font-family:'YakuHanJP_Narrow','游ゴシック', YuGothic, 'ヒラギノ角ゴ Pro', 'Hiragino Kaku Gothic Pro', 'メイリオ', 'Meiryo', sans-serif;
}
@media only screen and (max-width:767px){
    body{
        min-width:0;
    }
}

body *, body *::before, body *::after{box-sizing:border-box;}
img{vertical-align:bottom;}
h1,h2,h3,h4,h5,h6{font-weight:normal;}
th{
    font-weight:normal;
    text-align:left;
}

/*font layout*/
.fBold{font-weight:bold;}
.fOswald{font-family: "Oswald", sans-serif;}

/*rollover*/
.ro a:hover,
a.ro:hover,
a .ro:hover,
.cursorPointer:hover{ opacity:0.8; }
.ro a,
a.ro,
a .ro,
.cursorPointer{
    transition:opacity 0.2s ease-out;
}
.cursorPointer{cursor:pointer;}
@media only screen and (max-width:767px){
    .ro a:hover,
    a.ro:hover,
    a .ro:hover,
    .cursorPointer:hover{ opacity:1; }
}

/*rollover(brightnessによる変化)*/
.brt a:hover,a.brt:hover,a .brt:hover{ -webkit-filter: brightness(1.1);filter: brightness(1.1); }
.brt a,
a.brt,
a .brt{
    transition:filter 0.2s ease-out;
}
@media only screen and (max-width:767px){
    .brt a:hover,a.brt:hover,a .brt:hover{ filter:none; }
}

/*ro無効化*/
.ro .no_ro a:hover,
.ro a.no_ro:hover,
.ro .no_ro .cursorPointer:hover,
.ro .cursorPointer.no_ro:hover{ opacity:1; }

/* 電話リンクの無効化 */
a[href^="tel:"]{
    pointer-events:none;
    cursor:default;
}
@media only screen and (max-width:767px){
    a[href^="tel:"]{
        pointer-events:auto;
        cursor:pointer;
    }
}

/* container */
#container{
    overflow:hidden;
    max-width:1920px;
    margin:0 auto;
    width: 100%;
}

@media only screen and (max-width:767px){
    #container{
        max-width: 100%;
    }
}
#container.fixed{
    position: fixed;
}


/*========================================
    レスポンシブ用(不要な場合は削除)
========================================*/
.spOnly,
.brSp,
.imgSp{
    display:none;
}
.img100{
    width:100%;
    height:auto;
}
@media only screen and (max-width:767px){
    .spNone,
    .brPc,
    .imgPc{
        display:none;
    }
    .spOnly{
        display:block;
    }
    .brSp,
    .imgSp{
        display:inline;
    }
    .imgR{
        width:100%;
        height:auto;
    }
}

/*-----------------------------------------------
    imgCover
-----------------------------------------------*/
/* imgCover */
.imgCover,
.imgCont{
    position:relative;
}
.imgCover img {
    width:100%;
    height:100%;
    position:absolute;
    top:0;
    left:0;
    object-fit:cover;
    font-family:'object-fit:cover;';
}
.imgCont img{
    width:auto;
    height:auto;
    max-width:100%;
    max-height:100%;
    display:block;
    position:absolute;
    top:0;
    bottom:0;
    left:0;
    right:0;
    margin:auto;
}

.imgCenter{
    text-align:center;
}
.imgCenter img{
    width:auto;
    height:auto;
    max-width:100%;
    max-height:100%;
}

/*-----------------------------------------------
    wrapper
-----------------------------------------------*/
.wrapper1080{
    width: 1080px;
    margin: 0 auto;
    max-width: calc(100% - 40px);
}
.wrapper1100{
    width: 1100px;
    margin: 0 auto;
    max-width: calc(100% - 40px);
}
.wrapper1160{
    width: 1160px;
    margin: 0 auto;
    max-width: calc(100% - 40px);
}
.wrapper1200{
    width: 1200px;
    margin: 0 auto;
    max-width: calc(100% - 40px);
}
.wrapper1280{
    width: 1280px;
    margin: 0 auto;
    max-width: calc(100% - 40px);
}
.wrapper1400{
    width: 1400px;
    margin: 0 auto;
    max-width: calc(100% - 40px);
}
.wrapper1440{
    width: 1440px;
    margin: 0 auto;
    max-width: calc(100% - 40px);
}
.wrapper1500{
    width: 1500px;
    margin: 0 auto;
    max-width: calc(100% - 40px);
}
@media only screen and (max-width:1280px){
    .wrapperSpMin335{
        width: 89.334%;
        margin: 0 auto;
        max-width: none;
    }
}
@media only screen and (max-width:767px){
    .wrapper1080,
    .wrapper1100,
    .wrapper1160,
    .wrapper1200,
    .wrapper1280,
    .wrapper1400,
    .wrapper1440,
    .wrapper1500{
        width: 100%;
        margin: 0 auto;
        max-width: none;
    }
    .wrapperSp335{
        width: 89.334%;
        margin: 0 auto;
        max-width: none;
    }
}

/*-----------------------------------------------
	pnkz
-----------------------------------------------*/
#pnkz{
    font-size: 0;
    width: 100%;
    padding: 22px 0 25px;
    position: relative;
    z-index: 5;
    margin-top: 150px;
}
.secInsta + #pnkz{
    margin-top: 0;
}
#pnkz .boxList{
    position: relative;
}
#pnkz li{
	display: inline;
	font-size: 12px;
    letter-spacing: 1px;
    line-height: 1.5;
    color: #222;
}
#pnkz li:last-child{
    color: #1f85ba;
}
#pnkz li::after{
	content: ">";
	margin: 0 5px;
    color: #222;
}
#pnkz li:last-child::after{
	display: none;
}
#pnkz a{
    text-decoration: none;
    color: #222;
}
@media only screen and (max-width:767px){
    #pnkz{
        padding: 30px 0;
        width: calc((305 / 375)* 100%);
        margin: 70px auto 0;
    }
    #pnkz .boxList{
		white-space: nowrap;
		overflow-y: scroll;
	}
    #pnkz li{
        font-size: 12px;
        letter-spacing: 0px;
    }
    #pnkz li::after{
        margin: 0px 2px;
    }
}

/* secCmnTit */
.secCmnTit{
    padding-top: 228px;
    text-align: left;
    position: relative;
}
.secCmnTit::before{
    position: absolute;
    content: "";
    width: 100%;
    height: 1213px;
    top: 0;
    right: 0;
}
.secCmnTit.lazyloaded::before{
    background: url(../img/works/bgMain01.jpg) center top / cover;
}
.secCmnTit .tit{
    font-size: 100px;
    position: relative;
    letter-spacing: 7.5px;
    font-weight: 500;
}

.secCmnTit .spanColor{
    position: relative;
    color: #165e83;
}
.secCmnTit .spanColor.G{
    color: #16c45c;
}
.secCmnTit .txt{
    font-size: 40px;
    margin-top: 46px;
    font-weight: bold;
    letter-spacing: 6px;
   position: relative;
}
.secCmnTit .txt::before{
    position: absolute;
    content: "";
    background: #222;
    width: 230px;
    left: 0;
    bottom: -4px;
    height: 2px;
}


@media only screen and (max-width:767px){
    .secCmnTit{
        text-align:left;
        padding-top: 130px;
    }
    .secCmnTit::before{
        height: 357px;
    }
    .secCmnTit.lazyloaded::before{
        background: url(../img/works/bgMain01_sp.jpg) center top / cover;
    }
    .secCmnTit .topWrapper{
        width: calc((305 / 375)* 100%);
        margin: 0px auto;
    }
    .secCmnTit .tit{
        font-size: 30px;
        letter-spacing: 2.5px;
        margin-right: 0px;
    }
    .secCmnTit .txt{
        font-size: 20px;
        margin-top: 15px;
        letter-spacing: 1px;
    }

    .secCmnTit .txt::before {
        width: 106px;
        bottom: -2px;
    }
}

/* secCmnDetailsTit */
.secCmnDetailsTit{
    padding-top: 238px;
    text-align: left;
    position: relative;
}

.secCmnDetailsTit::before{
    position: absolute;
    content: "";
    width: 100%;
    height: 1213px;
    top: 0;
    right: 0;
    z-index: -10;
}
.secCmnDetailsTit.lazyloaded::before{
    background: url(../img/works/bgMain01.jpg) center bottom / cover;
}
.secCmnDetailsTit .tit{
    font-size: 24px;
    position: relative;
    letter-spacing: 1.5px;
    font-weight: 500;
}
.secCmnDetailsTit .spanColor{
    position: relative;
    color: #165e83;
}
.secCmnDetailsTit .spanColor.G{
    color: #16c45c;
}
.secCmnDetailsTit .txt{
    font-size: 45px;
    margin-top: 30px;
    font-weight: bold;
    letter-spacing: 7px;
    color: #165e83;
   position: relative;
}
.secCmnDetailsTit .txt::before{
    position: absolute;
    content: "";
    background: #165e83;
    width: 315px;
    left: 0;
    bottom: -3px;
    height: 2px;
}

@media only screen and (max-width:767px){
    .secCmnDetailsTit{
        text-align:left;
        padding-top: 130px;
    }
    .secCmnDetailsTit::before{
        height: 357px;
    }
    .secCmnDetailsTit.lazyloaded::before{
        background: url(../img/works/bgMain01_sp.jpg) center top / cover;
    }
    .secCmnDetailsTit .topWrapper{
        width: calc((305 / 375)* 100%);
        margin: 0px auto;
    }
    .secCmnDetailsTit .tit{
        font-size: 18px;
        letter-spacing: 1.5px;
    }
    .secCmnDetailsTit .txt{
        font-size: 22px;
        margin-top: 17px;
        letter-spacing: 1px;
    }
    .secCmnDetailsTit .txt::before {
        width: 140px;
        bottom: -2px;
    }
}

/*-----------------------------------------------
	jsHide
-----------------------------------------------*/
.jsHide{
    transition: opacity 1s cubic-bezier(0.25, 0.46, 0.45, 0.94), transform 1s cubic-bezier(0.25, 0.46, 0.45, 0.94);
}
.jsHide:not(.jsShow){
    opacity: 0;
    transform: translate(0px, 50px);
}

/* animeLoadLeft */
.animeLoadLeft{
    -webkit-clip-path: inset(0 100% 0 0);
    clip-path: inset(0 100% 0 0);
}
.isLoaded .animeLoadLeft{
    animation: animetionLeft 1s cubic-bezier(.785,.135,.15,.86) .5s normal forwards;
}
/* animeHideLeft */
.animeHideLeft{
    -webkit-clip-path: inset(0 100% 0 0);
    clip-path: inset(0 100% 0 0);
}
.animeHideLeft.jsShow{
    animation: animetionLeft 1s cubic-bezier(.785,.135,.15,.86) .5s normal forwards;
}
@keyframes animetionLeft{
    0% {
        -webkit-clip-path: inset(0 100% 0 0);
        clip-path: inset(0 100% 0 0);
    }
    to {
        -webkit-clip-path: inset(0);
        clip-path: inset(0);
    }
}

/* jsHideHero */
.jsHideHero{
    opacity: 0;
    transition: opacity 1s ease-out;
}
.jsHideHero.jsShow{
    opacity: 1;
}

/*-----------------------------------------------
    spNavi
-----------------------------------------------*/
#spNavi{
    display: none;
}
@media only screen and (max-width:767px){
    #spNavi{
        position: relative;
        left: -100%;
        top: 0;
        width: 100%;
        min-height: 100vh;
        z-index: 99999;
        -webkit-transition: left .4s;
        transition: left .4s;
        padding: 111px 0 80px;
    }
    #spNavi.active{
        display: block;
    }
    #spNavi::before{
        content: '';
        position: absolute;
        top: 0;
        left: 0;
        z-index: -1;
        width: 100%;
        height: 100%;
        background-color: rgba(34, 34, 34, 0.902);
        opacity: 0;
        -webkit-transform-origin: right;
        transform-origin: right;
        -webkit-transform: scaleX(.266);
        transform: scaleX(.266);
        -webkit-transition: opacity .4s,-webkit-transform .4s cubic-bezier(.79,.17,.15,.96);
        transition: opacity .4s,-webkit-transform .4s cubic-bezier(.79,.17,.15,.96);
        transition: opacity .4s,transform .4s cubic-bezier(.79,.17,.15,.96);
        transition: opacity .4s,transform .4s cubic-bezier(.79,.17,.15,.96),-webkit-transform .4s cubic-bezier(.79,.17,.15,.96);
    }
    #spNavi.active{
        left: 0;
    }
    #spNavi.active::before{
        -webkit-transform: scaleX(1);
        transform: scaleX(1);
        opacity: 1;
        -webkit-transition: opacity .4s,-webkit-transform .3s cubic-bezier(.7,.3,.3,.9);
        transition: opacity .4s,-webkit-transform .3s cubic-bezier(.7,.3,.3,.9);
        transition: opacity .4s,transform .3s cubic-bezier(.7,.3,.3,.9);
        transition: opacity .4s,transform .3s cubic-bezier(.7,.3,.3,.9),-webkit-transform .3s cubic-bezier(.7,.3,.3,.9);
    }
    #spNavi .boxList{
        width: calc((305 / 375) * 100%);
        margin: 0 auto;
        display: flex;
    }
    #spNavi a{
        color: #fff;
        text-decoration: none;
        font-size: 15px;
        font-weight: bold;
        letter-spacing: 1px;
        position: relative;
        display: inline-block;
        min-width: 65px;
    }
    #spNavi .innerItem:nth-child(n+2){
        margin-top: 25px;
    }
    #spNavi .leftItem,#spNavi .rightItem{
        width: 50%;
    }
    #spNavi .bnrCover{
        margin-top: 20px;
    }
    #spNavi .bnrInner{
        width: calc((305 / 375)* 100%);
        margin: 59px auto 0;
        position: relative;
    }
    #spNavi .bnrInner::before{
        position: absolute;
        content: "";
        width: 83px;
        height: 34px;
        left: -11px;
        top: -13px;
    }
    #spNavi .bnrInner.lazyloaded::before{
        background: url(../img/common/iconSpNavi01.png) center top / cover;
    }
    #spNavi .flexBox{
        display: flex;
        align-items: center;
        width: calc((305 / 375)* 100%);
        margin: 40px auto 0;
        justify-content: space-between;
    }
    #spNavi .boxInner{
        font-size: 13px;
        font-weight: 400;
        letter-spacing: normal;
        min-width: 0;
    }
    #spNavi .boxInner:nth-child(1){
        margin-right: 30px;
    }
    #spNavi .linkCover{
        width: calc((305 / 375)* 100%);
        margin: 40px auto 0;
        border-top: 1px solid;
        border-color:rgb(255,255,255,0.078);
        padding-top: 38px;
    }
    #spNavi .topLinkBox{
        display: flex;
        flex-direction: column;
    }
    #spNavi .linkTit{
        font-size: 13px;
        color: #fff;
        font-weight: bold;
        letter-spacing: 0.5px;
    }
    #spNavi .entryInner{
        margin-top: 20px;
        width: 47.541%;
    }
    #spNavi .entryInner.mt20 {
        margin-top: 20px;
        margin-left: 15px;
    }
    #spNavi .undLinkBox {
        margin-top: 40px;
    }
    #spNavi .linkFlex {
        display: flex;
    }
    #spNavi .iconInner{
        width: 25px;
      min-width: 25px;
        display: block;
    }
    #spNavi .cover{
        display: flex;
    }
}
@media only screen and (max-width:359px){
    #spNavi a {
        font-size: 14px;
    }
}



/* secInsta */
.secInsta{
    margin-top: 220px;
    padding-bottom: 140px;
    position: relative;
}
.secInsta .topFlex{
    display: flex;
    justify-content: space-between;
    position: relative;
}
.secInsta .btnBox{
    width: 180px;
    position: relative;
}
.secInsta .btnInner{
    display: flex;
    justify-content: center;
    align-items: center;
    text-decoration: none;
    color: #888888;
    background: #fff;
    border-radius: 24px;
    height: 48px;
    position: relative;
    font-size: 14px;
    letter-spacing: 1px;
    border: solid 1px #888888;
}
.secInsta .btnInner::before{
    position: absolute;
    content: "";
    width: 14px;
    height: 8px;
    right: 15px;
    top: calc(50% - 4px);
}
.secInsta .btnInner.lazyloaded::before{
    background: url(../img/works/iconBtn.gif) center top / cover;
}
.secInsta .titBox{
    display: flex;
    align-items: center;
}
.secInsta .titEng{
    font-size: 40px;
    letter-spacing: 4.5px;
    font-weight: 500;
}
.secInsta .spanTit{
    position: relative;
}
.secInsta .spanTit::before{
    position: absolute;
    content: "";
    background: #222;
    right: -36px;
    top: calc(50% - -1.5px);
    width: 30px;
    height: 1px;
}
.secInsta .titJpn{
    font-size: 16px;
    margin: 7px 0 0 56px;
    letter-spacing: 0.5px;
}
.secInsta .list{
    display: flex;
    flex-wrap: wrap;
    margin-top: 54px;
    position: relative;
    z-index: 5;
}
.secInsta .item{
    width: 15.334%;
    margin-right: 1.5992%;
}
.secInsta .item:nth-child(6n){
    margin-right: 0;
}
.secInsta .item:nth-child(n+7){
    margin-top: 30px;
}
.secInsta .img{
    width: 100%;
    height: 0;
    padding-top: 100%;
}
@media only screen and (max-width:767px){
    .secInsta{
        margin-top: 60px;
        padding-bottom: 20px;
        width: calc((305 / 375)* 100%);
    }
    .secInsta .topFlex{
        display: block;
    }
    .secInsta .btnBox{
        width: 180px;
        margin: 25px auto 0;
    }
    .secInsta .btnInner{
        border-radius: 25px;
        height: 50px;
        font-size: 13px;
        letter-spacing: 1px;
    }
    .secInsta .btnInner::before{
        right: 15px;
        top: calc(50% - 4px);
    }
    .secInsta .titBox{
        display: block;
    }
    .secInsta .titEng{
        font-size: 30px;
        letter-spacing: 2.5px;
    }
    .secInsta .spanTit::before{
        display: none;
    }
    .secInsta .titJpn{
        font-size: 14px;
        margin: 14px 0 0 0px;
        letter-spacing: 0.5px;
    }
    .secInsta .list{
        margin-top: 29px;
    }
    .secInsta .item{
        width: 31.148%;
        margin-right: 3.278%;
    }
    .secInsta .item:nth-child(6n){
        margin-right: 3.278%;
    }
    .secInsta .item:nth-child(3n){
        margin-right: 0;
    }
    .secInsta .item:nth-child(n+7){
        margin-top: 0px;
    }
    .secInsta .item:nth-child(n+4){
        margin-top: 10px;
    }
}


/*-----------------------------------------------
    secCmnNextLoad
    secCmnBack
-----------------------------------------------*/
.secCmnNextLoad,
.secCmnBack{
    width: 340px;
    height: 80px;
    margin: 24px auto 0;
    display: flex;
    align-items: center;
    justify-content: center;
    position: relative;
    z-index: 9999;
}
.secCmnNextLoad{
    margin: 310px auto 0;
}
.secCmnBack{
    margin: 24px auto 0;
}
.secCmnNextLoad .btnCmnInner,
.secCmnBack .btnCmnInner{
    position: relative;
    width: 100%;
    height: 100%;
    background:linear-gradient( -90deg, rgb(22,196,92) 0%, rgb(24,222,103) 100%);
    display: flex;
    align-items: center;
    justify-content: center;
    color: #fff;
    font-size: 24px;
    letter-spacing: 2.5px;
    text-decoration: none;
    border-radius: 40px;
}
.secCmnNextLoad .btnCmnInner::before{
    position: absolute;
    content: "";
    width: 8px;
    height: 14px;
    right: 34px;
    top: calc(50% - 7px);
}
.secCmnNextLoad .btnCmnInner.lazyloaded::before{
    background: url(../img/common/iconNextArrow.png) center top / cover;
}
.secCmnNextLoad #listLoading{
    display: none;
}

@media only screen and (max-width:767px){
    .secCmnNextLoad,
    .secCmnBack{
        width: 220px;
        height: 50px;
        margin: 24px auto 0;
    }
    .secCmnNextLoad{
        margin: 115px auto 0;
    }
    .secCmnBack{
        margin: 24px auto 0;
    }
    .secCmnNextLoad .btnCmnInner,
    .secCmnBack .btnCmnInner{
        font-size: 16px;
        letter-spacing: 1.5px;
        border-radius: 25px;
    }
    .secCmnNextLoad .btnCmnInner::before{
        right: 19px;
    }
  
}


/* detailsTitBox */
.detailsTitBox {
    text-align: center;
    position: relative;
    z-index: 1;
}
.detailsTitBox .tit{
    font-size: 40px;
    position: relative;
    letter-spacing: 4.5px;
    font-weight: 500;
}
.detailsTitBox .tit::before{
    position: absolute;
    content: "";
    background: #222;
    width: 30px;
    height: 1px;
    bottom: -20px;
    left: calc(50% - 15px);
    z-index: 9999;
}
.detailsTitBox .txt{
    font-size: 16px;
    margin-top: 40px;
}
@media only screen and (max-width:767px){
    .detailsTitBox .tit{
        font-size: 30px;
        letter-spacing: 3px;
    }
    .detailsTitBox .tit::before{
       display: none;
    }
    .detailsTitBox .txt{
        font-size: 14px;
        margin-top: 16px;
        letter-spacing: 1px;
    }
}


/*-----------------------------------------------
    header
-----------------------------------------------*/
#header{
    position: absolute;
    top: 46px;
    left: 0;
    z-index: 999999;
    width: 100%;
    display: flex;
    display: -webkit-flex;
    justify-content: space-between;
    -webkit-justify-content: space-between;
    padding: 0 70px 0 50px;
}
#header .logo{
   display: block;
}
#header.internal .logo{
    color: #fff;
}
#header.fBlack,
#header.fBlack.internal .logo{
    color: inherit;
}
#header .btnSpNavi{
    display: none;
}
#header .headFlex{
    display: flex;
    align-items: center;
}
#header .headTit{
    font-size: 12px;
    font-weight: bold;
    margin-left: 30px;
    letter-spacing: 0.5px;
}
#header .spanTit{
    background: #fff;
    padding: 5px 7px;
}
#header.internal .spanTit{
    color: #fff;
    background: #165e83;
}
/* 追記0801 */
.internal #header .menuOpen,.internal #header.naviOpen .menuClose{
    display: none;
}
.internal #header.naviOpen .menuOpen{
    display: block;
}
.internal #header.naviOpen .spanTit{
    color: #fff;
}
@media only screen and (max-width:767px){
    #header{
        top: 21px;
        padding: 0 20px;
    }
    #header .logo{
        width: 98px;
    }
    #header .btnSpNavi,
    #header .btnSpNavi span {
        display: inline-block;
        transition: all .4s;
        box-sizing: border-box;
    }
    #header .btnSpNavi {
        display: block;
        width: 40px;
        height: 10px;
        background: none;
        border: none;
        appearance: none;
        cursor: pointer;
        position: absolute;
        top: 11px;
        right: 20px;
        z-index: 9999;
    }
    #header .btnSpNavi span {
        position: absolute;
        left: 0;
        width: 100%;
        height: 1px;
        background-color: #fff;
    }
    .internal #header .btnSpNavi.active span,#header .btnSpNavi.active span{
		background:#fff;
	}
    #header .btnSpNavi span:nth-of-type(1) {
        top: 0;
    }
    #header .btnSpNavi span:nth-of-type(2) {
        bottom:0 ;
    }
    #header .btnSpNavi.active span:nth-of-type(1) {
        transform: translateY(5px) rotate(-30deg);
    }
    #header .btnSpNavi.active span:nth-of-type(2) {
        transform: translateY(-5px) rotate(30deg);
    }
    #header .spanTit {
        background:none;
        padding: 0;
    }
    #header .headTit {
        font-size: 10px;
        color: #fff;
        margin-left: 18px;
        letter-spacing: 0;
    }
    .internal #header .spanTit{
       color: #222;
       background: transparent;
    }
    .internal #header .btnSpNavi span {
        background-color: #222;
    }
}
@media only screen and (max-width:359px){
    #header .headTit {
        font-size: 9px;
        margin-left: 10px;
    }
}
/*-----------------------------------------------
    gNavi
-----------------------------------------------*/
#gNavi{
    display: flex;
    display: -webkit-flex;
    align-items: center;
    -webkit-align-items: center;
}
#gNavi .boxList{
    display: flex;
    display: -webkit-flex;
}
#gNavi li{
    padding: 0px 22.5px;
}
#gNavi a{
    color: #fff;
    text-decoration: none;
    font-size: 18px;
    font-weight: bold;
    letter-spacing: 0.5px;
    position: relative;
    display: inline-block;
    text-decoration: none;
}
#gNavi.fBlack a{
    color: inherit;
}
#gNavi a::after{
    position: absolute;
    bottom: -10px;
    left: 0;
    content: '';
    width: 100%;
    height: 2px;
    background: #fff;
    transform: scale(0, 1);
    transform-origin: left top;
    transition: transform .3s;
    -webkit-transform: scale(0, 1);
    -webkit-transform-origin: left top;
    -webkit-transition: transform .3s;
}
#gNavi.fBlack a::after{
    background: #222;
}
#gNavi a.active::after,
#gNavi a:hover::after{
    transform: scale(1, 1);
    -webkit-transform: scale(1, 1);
}

.internal #gNavi a{
    color: #222;
}
.internal #gNavi a::after {
    background: #222;
}
@media only screen and (max-width:767px){
    #gNavi{
        display: none;
    }
}


/*-----------------------------------------------
    btnNavi
-----------------------------------------------*/
@media only screen and (max-width:1280px){
    #btnNavi{
        position: absolute;
        right: 0;
        top: calc(50% - 10px);
        width: 30px;
        height: 20px;
        z-index: 9999;
    }
    #btnNavi .naviCover{
        display: flex;
        align-items: center;
        justify-content: center;
        flex-direction: column;
        text-decoration: none;
        width: 100%;
        height: 20px;
        color: #fff;
    }
    #btnNavi .border{
        width: 30px;
        height: 20px;
        position: relative;
    }
    #btnNavi .border .inner,
    #btnNavi .border .inner::before,
    #btnNavi .border .inner::after{
        display: block;
        width: 30px;
        height: 1px;
        background: #fff;
        left: 0;
        right: 0;
        margin: auto;
    }
    #btnNavi .border .inner{
        background: #fff;
        width: 30px;
        height: 1px;
    }
    .jsScroll #btnNavi .border .inner{
        background: #000;
    }
    #btnNavi .border .inner::before{
        content: '';
        position: absolute;
        transition: all 0.4s ease-out;
        top: 0;
        bottom: 0;
        left: 0;
        right: 0;
        margin: auto;
    }
    #btnNavi .border .inner::after{
        content: '';
        position: absolute;
        transition: all 0.4s ease-out;
        bottom: 0;
        left:0;
        right:0;
        margin: auto;
    }
    #btnNavi.naviOpen .border{
        width: 27px;
        height: 16px;
    }
    #btnNavi:not(.naviOpen) .txtClose,
    #btnNavi.naviOpen .txtMenu{
        display: none;
    }
    #btnNavi.naviOpen .border .inner{
        width: 0;
        height: 0;
    }
    #btnNavi.naviOpen .border .inner::before{
        transform: translateY(36px) rotate(-30deg);
        top: -30px;
        bottom: auto;
        width: 30px;
        height: 1px;
    }
    #btnNavi.naviOpen .border .inner::after{
        transform: translateY(11px) rotate(30deg);
        bottom: 20px;
        width: 30px;
        height: 1px;
    }
}

/*-----------------------------------------------
    menu
-----------------------------------------------*/
#menu,
#menuBg{
    display: none;
}
@media only screen and (max-width:1280px){
    #menu{
        display: none;
        position: relative;
        z-index: 9998;
        padding: 55px 0 70px;
        min-height: 100vh;
    }
    #menuBg{
        display: none;
        width: 100%;
        height: 100%;
        background: rgba(19, 32, 47, 0.949);
        position: fixed;
        top: 0;
        left: 0;
        z-index: 9997;
    }
    #menu .wrapper{
        border-top: solid 1px rgb(255, 255, 255 ,0.102);
    }
    #menu .listBox{
        margin: 40px 20px 0;
    }
    #menu .listInner{
        font-size: 14px;
        letter-spacing: 1px;
        text-decoration: none;
        font-weight: bold;
        display: inline-block;
        color: #fff;
    }
    #menu .listItem:nth-child(n+2){
        margin-top: 32px;
    }
    #menu .subListBox{
        margin: 30px 20px 0;
    }
    #menu .subListItem:nth-child(n+2){
        margin-top: 32px;
    }
    #menu .subListInner{
        font-size: 14px;
        letter-spacing: 1px;
        text-decoration: none;
        font-weight: bold;
        display: inline-block;
        color: #fff;
        position: relative;
        padding-left: 15px;
    }
    #menu .subListInner::after{
        position: absolute;
        content: "";
        width: 10px;
        height: 1px;
        left: 0;
        top: calc(50% - 0.5px);
        background: #fff;
    }
    #menu .listInner.icon,
    #menu .subListInner.icon{
        position: relative;
    }
    #menu .subListInner.icon::before,
    #menu .listInner.icon::before{
        position: absolute;
        content: "";
        width: 8px;
        height: 7px;
        right: -10px;
        top: -5px;
        background: url(../img/common/iconMenuList.png) center top / cover;
    }
    #menu .subInner{
        font-size: 12px;
    }
    #menu .entryList{
        margin-top: 40px;
        padding-top: 40px;
        border-top: solid 1px rgb(255, 255, 255 ,0.102);
    }
    #menu .entryItem{
        width: 88.06%;
        margin: 0 auto;
    }
    #menu .entryItem:nth-child(2){
        margin-top: 10px;
    }
    #menu .entryInner{
        height: 60px;
        display: flex;
        align-items: center;
        justify-content: center;
        font-size: 14px;
        font-weight: bold;
        text-decoration: none;
        color: #fff;
        border-radius: 0 6px 0 6px;
        overflow: hidden;
        position: relative;
    }
    #menu .entryInner::after{
        position: absolute;
        content: "";
        top: 0;
        left: 0;
        width: 100%;
        height: 100%;
        z-index: 10;
        background-image: -moz-linear-gradient( 0deg, rgb(0,105,181) 0%, rgb(3,159,233) 100%);
        background-image: -webkit-linear-gradient( 0deg, rgb(0,105,181) 0%, rgb(3,159,233) 100%);
        background-image: -ms-linear-gradient( 0deg, rgb(0,105,181) 0%, rgb(3,159,233) 100%);
    }
    #menu .entryItem:nth-child(2) .entryInner::after{
        background-image: -moz-linear-gradient( 0deg, rgb(0,181,55) 0%, rgb(28,215,120) 100%);
        background-image: -webkit-linear-gradient( 0deg, rgb(0,181,55) 0%, rgb(28,215,120) 100%);
        background-image: -ms-linear-gradient( 0deg, rgb(0,181,55) 0%, rgb(28,215,120) 100%);
    }
    #menu .entryInner::before{
        position: absolute;
        content: "";
        width: 22px;
        height: 22px;
        right: 20px;
        top: calc(50% - 11px);
        background: url(../img/common/iconMenu.png) center top / cover;
        z-index: 20;
    }
    #menu .entryTxt{
        position: relative;
        z-index: 20;
    }
    #menu .instBox{
        width: 56.717%;
        min-width: 190px;
        margin: 40px auto 0;
    }
    #menu .instInner{
        display: block;
    }
    #menu .instInner .instImg{
        text-align: center;
    }
}
@media only screen and (max-width:767px){
    #menu .subListInner{
        letter-spacing: normal;
    }
}
@media only screen and (max-width:360px){
    #menu .subInner {
        display: block;
        margin-top: 6px;
    }
}
/*-----------------------------------------------
    footer
-----------------------------------------------*/

#footer{
    position: relative;
    color: #fff;
    z-index: 9999;
}
#footer .wrapper{
    position: relative;
    z-index: 10;
    padding-bottom: 0;
}
#footer .footerLogo{
    display: block;
}
#footer .footerTit{
    font-size: 14px;
    margin-top: 28px;
}
#footer .flexBox{
    display: flex;
    align-items: flex-end;
    margin-top: 39px;
}
#footer .txtFlex{
    display: flex;
    margin: 21px 0 0 0px;
    font-size: 12px;
}

#footer .naviList{
    display: flex;
    flex-wrap: wrap;
    width: 550px;
}

#footer .naviItem:nth-child(n+2){
    margin-left: 68px;
}
#footer .naviInner{
    display: inline-block;
    text-decoration: none;
    color: #fff;
    font-size: 18px;
    font-weight: bold;
    letter-spacing: 1px;
    margin-right: 37px;
}
#footer .naviInner:nth-child(n+5){
    margin-top:28px;
}
#footer .copy{
    font-size: 13px;
    letter-spacing: 2px;
}
#footer .topBox{
    margin-top: 70px;
}
#footer .leftBox{
    margin-top: 22px;
    width: calc(100% - 110px);
}
#footer .cBox{
    width: 100%;
}
#footer .cBox:nth-child(n+2){
    margin-top: 28px;
}
#footer .addressBox{
    display: flex;
}
#footer .cTit{
    font-size: 14px;
    font-weight: bold;
    letter-spacing: 1.5px;
}
#footer .cTxt{
    font-size: 12px;
    margin-top: 10px;
    letter-spacing: 0.5px;
    line-height: 1.5;
}
#footer .cTxt + .cTxt{
    margin-left: 20px;
}
/* instagram */
#footer .underWrap{
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    flex-wrap: wrap;
    margin-top: 28px;
}
#footer .underWrap .cBox{
    width: auto;
    margin-right: 20px;
}
#footer .iconBox{
    display: flex;
    margin: 30px 0 0 auto;
}
#footer .linkInsta{
    display: block;
    color: #fff;
    text-decoration: none;
    font-size: 12px;
    font-weight: 700;
    position: relative;
    padding-left: 36px;
}
#footer .linkInsta:nth-child(2){
    margin-left: 15px;
}
#footer .linkInsta::before{
    position: absolute;
    content: "";
    width: 26px;
    height: 26px;
    top: calc(50% - 13px);
    left: 0;
}
#footer .linkInsta.lazyloaded::before{
    background: url(../img/common/iconInsta.png) center top / cover;
}
#footer .bnrInner{
    position: relative;
    display: block;
}
#footer .bnrInner::before{
    position: absolute;
    content: "";
    width: 128px;
    height: 52px;
    top: -17px;
    left: -18px;
}
#footer .bnrInner.lazyloaded::before{
    background: url(../img/common/iconFooter01.png) center top / cover;
}
#footer .undBox{
    border-top: 1px solid #464c54;
    margin-top: 38px;
    padding-top: 43px;
    width: calc(100% - 110px);
}
#footer .linkList{
    display: flex;
}
#footer .linkInner{
    display: block;
    color: #fff;
    text-decoration: none;
    font-size: 14px;
    letter-spacing: 1px;
}
#footer .cover{
    display: flex;
    justify-content: space-between;
}
#footer .linkItem:nth-child(1){
    margin-right: 45px;
}
#footer .naviList.spOnly{
    display: none;
}

#footer .box{
    display: flex;
}
#footer .boxLeft{
    background: #313841;
    width: calc(100% - 750px);
    padding: 140px 0px 72px 210px;
}
#footer .rightBox{
    width: 750px;
    background: #222;
}
#footer .telBox{
    margin-left: 40px;
    padding-bottom: 10px;
}
#footer .telTxt{
    font-size: 30px;
    font-weight: 100;
    letter-spacing: 3px;
}
#footer .span20{
    font-size: 20px;
    font-weight: normal;
    letter-spacing: 2px;
    margin-right: 5px;
}
#footer .span14{
    font-size: 14px;
    font-weight: normal;
    letter-spacing: 1.5px;
    margin-left: 3px;
}
#footer .linkBox{
    display: flex;
    justify-content: flex-end;
}
#footer .topInner{
    width: 150px;
    height: 100px;
    display: block;
    background: #313841;
    color: #fff;
    font-size:14px ;
    text-decoration: none;
    display: flex;
    justify-content: center;
    align-items: center;
    padding-top: 27px;
    letter-spacing: 2px;
    position: relative;
}
#footer .topInner::before{
    position: absolute;
    content: "";
    width: 10px;
    height: 16px;
    left: calc(50% - 5px);
    top: calc(50% - 20px);

}
#footer .topInner.lazyloaded::before{
    background: url(../img/common/iconFoot01.gif) center top / cover;
}
#footer .linkCover{
    margin-top: 30px;
}
#footer .topLinkBox{
    display: flex;
    flex-direction: column;
    align-items: center;
}
#footer .linkTit{
    font-size: 16px;
    font-weight: bold;
    margin-left: -115px;
}
#footer .entryInner{
    display: inline-block;
    margin-top: 28px;
}
#footer .entryInner.mt20{
    margin-top: 20px;
}
#footer .undLinkBox{
    display: flex;
    flex-direction: column;
    align-items: center;
    margin-top: 80px;
}
#footer .linkFlex{
    display: contents;
}
#footer .topCover{
    display: flex;
    align-items: center;
}

/* ipad */
.isDesktopIpad #footer .cTxt {
    font-size: 10px;
}

@media only screen and (max-width:1750px){
    #footer .boxLeft {
        padding: 140px 0px 72px 110px;
    }
}
@media only screen and (max-width:1670px){
    #footer .boxLeft {
        padding: 140px 0px 72px 100px;
        width: calc(100% - 600px);
    }
    #footer .rightBox {
        width: 600px;
    }
    #footer .cTxt {
        font-size: 11px;
        margin-top: 10px;
    }
}
@media only screen and (max-width:1580px){
    #footer .leftBox{
        width: calc(100% - 70px);
    }
    #footer .undBox {
        width: calc(100% - 70px);
    }

}
@media only screen and (max-width:767px){

    #footer .wrapper{
        width: calc((305 / 375)* 100%);
        margin: 0 auto;
    }
    #footer .footerLogo{
        width: 164px;
        margin-top: 24px;
    }
    #footer .footerTit{
        font-size: 14px;
        margin-top: 28px;
    }
    #footer .flexBox{
        display: block;
        align-items: flex-end;
        margin-top: 31px;
    }
    #footer .txtFlex{
        display: flex;
        margin: 21px 0 0 0px;
        font-size: 12px;
    }
    #footer .iconInner{
        display: block;
        width: 25px;
    }
    #footer .naviList{
        display: flex;
        flex-wrap: wrap;
        width: calc((305 / 375)* 100%);
        position: relative;
        margin: 0 auto;
    }

    #footer .naviItem:nth-child(n+2){
        margin-left: 68px;
    }
    #footer .naviInner{
        font-size: 14px;
        letter-spacing: 1px;
        margin-right: 27px;
    }
    #footer .naviInner:nth-child(n+5){
        margin-top:0px;
    }
    #footer .naviInner:nth-child(n+4){
        margin-top:21px;
    }
    #footer .naviInner:nth-child(3n){
        margin-right:0px;
    }
    #footer .copy{
        font-size: 10px;
        letter-spacing: 1px;
        margin-right: 17px;
    }
    #footer .topBox{
        margin-top: 51px;
        border-top: 1px solid #464c54;
    }
    #footer .topCover {
        width: calc((305 / 375)* 100%);
        margin: 48px auto 0;
        flex-direction: column-reverse;
        align-items: baseline;
    }
    #footer .leftBox{
        display: block;
        width: calc((305 / 375)* 100%);
        margin: 0 auto 0;
    }
    #footer .cBox:nth-child(n+2){
        margin-top: 23px;
    }
    #footer .cTit{
        font-size: 14px;
        letter-spacing: 0px;
    }
    #footer .cTxt{
        font-size: 12px;
        margin-top: 7px;
        letter-spacing: 0px;
        line-height: 1.83;
    }
    #footer .addressBox{
        display: block;
    }
    #footer .cTxt + .cTxt{
        margin: 2px 0 0;
    }
    #footer .bnrInner{
        position: relative;
        display: block;
    }
    #footer .bnrInner::before{
        position: absolute;
        content: "";
        width: 128px;
        height: 52px;
        top: -17px;
        left: -18px;
    }
    #footer .bnrInner.lazyloaded::before{
        background: url(../img/common/iconFooter01.png) center top / cover;
    }
    #footer .undBox{
        margin-top: 30px;
        padding: 30px 0px;
        width:100%;
    }
    #footer .linkList{
        display: flex;
    }
    #footer .linkInner{
        font-size: 10px;
        letter-spacing: 0.5px;
    }
    #footer .cover{
        display: flex;
        justify-content: normal;
    }
    #footer .linkItem:nth-child(1){
        margin-right:13px;
    }
    #footer .naviList.spOnly{
        display: none;
    }
    
    #footer .box{
        flex-direction: column-reverse;
    }
    #footer .boxLeft{
        width: 100%;
        padding: 70px 0 0;
    }
    #fNavi + #footer .boxLeft{
        padding-bottom: 70px;
    }
    #footer .rightBox{
        width: 100%;
        padding-bottom: 70px;
        
    }
    #footer .telBox{
        margin-left: 0px;
        padding-bottom: 10px;
    }
    #footer .telTxt{
        font-size: 22px;
        letter-spacing: 2.5px;
    }
    #footer .span20{
        font-size: 16px;
        letter-spacing: 1px;
        margin-right: 5px;
    }
    #footer .span14{
        font-size: 12px;
        letter-spacing: 1.5px;
        margin-left: 5px;
    }
    #footer .linkBox{
        display: flex;
        justify-content: flex-end;
    }
    #footer .topInner{
        width: 110px;
        height: 50px;
        font-size:12px ;
        padding-top: 0px;
        letter-spacing: 1.5px;
        padding-left: 20px;
    }
    #footer .topInner::before{
        width: 8px;
        height: 12px;
        left: calc(50% - 33px);
        top: calc(50% - 6px);
    }
    #footer .topInner.lazyloaded::before{
        background: url(../img/common/iconFoot01.gif) center top / cover;
    }
    #footer .linkCover{
        width: calc((305 / 375)* 100%);
        margin: 20px auto 0;
    }
    #footer .topLinkBox{
        display: flex;
        flex-direction: column;
        align-items: flex-start;
    }
    #footer .linkTit{
        font-size: 13px;
        letter-spacing: 0.5px;
        margin-left: 0;
    }
    #footer .entryInner{
        margin-top: 20px;
    }
    #footer .entryInner.mt20{
        margin-top: 20px;
        margin-left: 15px;
    }
    #footer .undLinkBox{
        margin-top: 40px;
        align-items: flex-start;
    }
    #footer .linkFlex {
        display: flex;
    }
    #footer .flexCover{

        margin: 0 auto;
    }
    /* instagram */
    #footer .underWrap{
        display: block;
        flex-wrap: wrap;
        margin-top: 23px;
    }
    #footer .underWrap .cBox{
        margin-right: 0;
    }
    #footer .iconBox{
        display: flex;
        margin: 30px 0 0;
    }
    #footer .linkInsta{
        font-size: 12px;
        padding-left: 36px;
    }
    #footer .linkInsta:nth-child(2){
        margin-left: 23px;
    }
    #footer .linkInsta::before{
        width: 25px;
        height: 25px;
        top: calc(50% - 12px);
    }
}

@media only screen and (max-width:359px) {
    #footer .naviInner {
        margin-right: 13px;
    }
    #footer .linkInsta:nth-child(2){
        margin-left: 17px;
    }
    #fNavi + #footer .boxLeft {
        padding-bottom: 90px;
    }
}
@media (orientation: landscape) and (max-width: 767px){
    #footer .naviInner:nth-child(3n) {
        margin-right: 27px;
    }
}
/* noneTxt */
.noneTxt{
    font-size: 16px;
    text-align: center;
    padding: 50px 0;
}

@media only screen and (max-width:767px){
    .noneTxt{
        font-size: 12px;
        line-height: 1.5;
        padding: 30px 0;
    }
}

/* 240730 */
#fNavi{
    bottom: 40px;
    height: 150px;
    position: fixed;
    right: 40px;
    width: 150px;
    z-index: 99999;
}
#fNavi .fixedBnr{
    align-items: center;
    display: flex;
    justify-content: center;
    height: 100%;
    width: 100%;
    text-decoration: none;
    color: #fff;
    position: relative;
}
#fNavi .fixedBnr::before{
    content: '';
    height: 100%;
    left: 0;
    position: absolute;
    top: 0;
    width: 100%;
    animation:20s linear infinite rotation1;
}
#fNavi .fixedBnr.lazyloaded::before{
    background: url(../img/index/menu.png) center center / cover no-repeat;
}
@keyframes rotation1{
    0%{ transform:rotate(0);}
    100%{ transform:rotate(360deg); }
}
#fNavi .fixedBnr::after{
    position: absolute;
    content: "";
    width: 110px;
    height: 110px;
    border-radius: 50%;
}
#fNavi .fixedBnr.lazyloaded::after{
    background: url(../img/index/bgMenu.png) center center / cover no-repeat;
}
#fNavi .spanEntry{
    font-size: 18px;
    font-weight: 500;
    letter-spacing: 2px;
    position: relative;
    z-index: 1;
}
@media only screen and (max-width:767px){
    #fNavi{
        bottom: 10px;
        height: 102px;
        right: 10px;
        width: 102px;
    }
    #fNavi .fixedBnr::after{
        width: 70px;
        height: 70px;
    }
    #fNavi .spanEntry{
        font-size: 13px;
        letter-spacing: 1.5px;
    }
}

/* secCmnBtnView */
.secCmnBtnView .btnInner{
    color: #222;
    text-decoration: none;
    position: relative;
    display: inline-flex;
    align-items: center;
    font-weight: 500;
}
.secCmnBtnView .flexBox{
    display: flex;
    align-items: center;
}
.secCmnBtnView .spanTxt{
    font-size: 24px;
    position: relative;
    margin-left: 27px;
    letter-spacing: 2.5px;
}
.secCmnBtnView .spanTxt::before{
    content: '';
    width: 100%;
    height: 1px;
    position: absolute;
    bottom: -5px;
    right: 0;
    background: #222;
    transform: scale(0, 1);
    transform-origin: left top;
    transition: transform .3s;
}
.secCmnBtnView .btnInner:hover .spanTxt::before{
    transform: scale(1, 1);
}
.secCmnBtnView .spanIcon{
    width: 80px;
    height: 80px;
    border-radius: 50%;
    background: linear-gradient( -90deg, rgb(22,196,92) 0%, rgb(24,222,103) 100%);
    transition: 0.5s ease-in-out;
    overflow: hidden;
}
.secCmnBtnView.color02 .spanIcon{
    background: linear-gradient(-90deg, rgb(22, 94, 131) 0%, rgb(26, 113, 156) 100%);
}
.secCmnBtnView.color03 .spanIcon{
    background: linear-gradient(-90deg, rgb(34, 34, 34) 0%, rgb(104, 102, 102) 100%);
}
.secCmnBtnView .btnInner:hover .spanIcon{
    background: #fff;
    border: solid 1px rgb(22,196,92);
}
.secCmnBtnView.color02 .btnInner:hover .spanIcon{
    background: #fff;
    border: solid 1px rgb(22, 94, 131);
}
.secCmnBtnView.color03 .btnInner:hover .spanIcon{
    background: #fff;
    border: solid 1px rgb(34, 34, 34);
}
.secCmnBtnView .spanIcon{
    position: relative;
}
.secCmnBtnView .spanIcon::before,.secCmnBtnView .spanIcon::after{
    position: absolute;
    content: "";
    width: 34px;
    height: 20px;
    top: calc(50% - 10px);
    left: calc(50% - 17px);
    transition: all .2s linear;
}
.secCmnBtnView .spanIcon.lazyloaded::before{
    background: url(../img/index/iconArrow01.png) center center / cover;
}
.secCmnBtnView .btnInner:hover .spanIcon::before{
    opacity: 0;
    left: 200%;
}
.secCmnBtnView .spanIcon::after{
    left: -100%;
}
.secCmnBtnView .spanIcon.lazyloaded::after{
    background: url(../img/index/iconArrow03.png) center center / cover;
}
.secCmnBtnView.color02 .spanIcon.lazyloaded::after{
    background-image: url(../img/index/iconArrow02.png);
}
.secCmnBtnView.color03 .spanIcon.lazyloaded::after{
    background-image: url(../img/index/iconArrow04.png);
}
.secCmnBtnView .btnInner:hover .spanIcon::after{
    left: calc(50% - 17px);
    opacity: 1;
}
@media only screen and (max-width:767px){
    .secCmnBtnView .spanTxt{
        font-size: 16px;
        margin-left: 15px;
        letter-spacing: 1.5px;
    }
    .secCmnBtnView .spanTxt::before{
        bottom: -4px;
        transform: scale(1, 1);
    }
    .secCmnBtnView .spanIcon{
        width: 50px;
        height: 50px;
    }
    .secCmnBtnView .btnInner:hover .spanIcon{
        background: linear-gradient(-90deg, rgb(22, 196, 92) 0%, rgb(24, 222, 103) 100%);
        border: none;
    }
    .secCmnBtnView.color02 .btnInner:hover .spanIcon{
        background: linear-gradient(-90deg, rgb(22, 94, 131) 0%, rgb(26, 113, 156) 100%);
        border: none;
    }
    .secCmnBtnView.color03 .btnInner:hover .spanIcon{
        background: linear-gradient(-90deg, rgb(34, 34, 34) 0%, rgb(104, 102, 102) 100%);
        border: none;
    }
    .secCmnBtnView .spanIcon::before,.secCmnBtnView .spanIcon::after{
        width: 16px;
        height: 9px;
        top: 20px;
        left: 17px;
    }
    .secCmnBtnView .btnInner:hover .spanIcon::before{
        opacity: 1;
        left: 17px;
    }
    .secCmnBtnView .spanIcon::after{
        display: none;
    }
}