@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: none;
    }
}
#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;
}
.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;
}

/*-----------------------------------------------
    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);
}
.wrapper1280{
    width: 1280px;
    margin: 0 auto;
    max-width: calc(100% - 40px);
}
.wrapper1400{
    width: 1400px;
    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,
    .wrapper1280,
    .wrapper1400,
    .wrapper1500{
        width: 100%;
        margin: 0 auto;
        max-width: none;
    }
    .wrapperSp335{
        width: 89.334%;
        margin: 0 auto;
        max-width: none;
    }
    .wrapperSp310{
        width: calc((310 / 375) * 100%);
        margin: 0 auto;
    }
    .wrapperSp305{
        width: 81.334%;
        margin: 0 auto;
        max-width: none;
    }
}

/*-----------------------------------------------
    header
-----------------------------------------------*/
#header{
    position: absolute;
    top: 46px;
    left: 0;
    z-index: 9999;
    width: 100%;
    display: flex;
    display: -webkit-flex;
    justify-content: space-between;
    -webkit-justify-content: space-between;
    padding: 0 60px 0 50px;
}
#header .logo{
   display: block;
}
#header.internal .logo{
    color: #fff;
}
#header.fBlack,
#header.fBlack.internal .logo{
    color: inherit;
}
#header .btnSpNavi{
    display: none;
}


@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;
    }
    #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.internal .btnSpNavi span {
        background-color: #222;
    }
    #header.internal .btnSpNavi.active span {
        background-color: #fff;
    }
}

/*-----------------------------------------------
    gNavi
-----------------------------------------------*/
#gNavi{
    display: flex;
    display: -webkit-flex;
    align-items: center;
    -webkit-align-items: center;
}
#gNavi .boxList{
    display: flex;
    display: -webkit-flex;
}
#gNavi li{
    padding: 0 30px;
}
#gNavi a{
    color: #fff;
    text-decoration: none;
    font-size: 18px;
    font-weight: bold;
    letter-spacing: 1.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;
    background: #222222;
    color: #fff;
    padding: 180px 0 54px;
}
#footer .wrapper{
    position: relative;
    z-index: 10;
}
#footer .footerLogo{
    display: block;
}
#footer .footerTit{
    font-size: 14px;
    margin-top: 28px;
}
#footer .flexBox{
    display: flex;
    margin-top: 39px;
}
#footer .txtFlex{
    display: flex;
    margin: 21px 0 0 0px;
    font-size: 12px;
}
#footer .rightBox{
    margin: 40px 0px 0 auto;
}
#footer .naviList{
    display: flex;
    justify-content: flex-end;
}

#footer .naviItem:nth-child(n+2){
    margin-left: 68px;
}
#footer .naviInner{
    display: inline-block;
    text-decoration: none;
    color: #fff;
    font-size: 20px;
    font-weight: bold;
    letter-spacing: 1.5px;
}
#footer .copy{
    font-size: 14px;
    letter-spacing: 1.5px;
}
#footer .topBox{
    display: flex;
    justify-content: space-between;
    align-items: center;
}
#footer .leftBox{
    display: flex;
    flex-wrap: wrap;
    margin-top: 42px;
    width: 100%;
}
#footer .cBox{
    width: 100%;
}
#footer .addressBox{
    display: flex;
}
#footer .cBox:nth-child(n+2){
    margin-top: 40px;
}
#footer .cTit{
    font-size: 16px;
    letter-spacing: 1.5px;
    font-weight: bold;
}
#footer .cTxt{
    font-size: 14px;
    margin-top: 15px;
    letter-spacing: 0.5px;
}
#footer .cTxt + .cTxt{
    margin-left: 40px;
}
#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 #393939;
    margin-top: 80px;
    padding-top: 53px;
}
#footer .linkList{
    display: flex;
}
#footer .linkInner{
    display: block;
    color: #fff;
    text-decoration: none;
    font-size: 14px;
    letter-spacing: 1px;
    font-weight: 200;
}
#footer .cover{
    display: flex;
    justify-content: space-between;
}
#footer .linkItem:nth-child(1){
    margin-right: 45px;
}
#footer .naviList.spOnly{
    display: none;
}
@media only screen and (max-width:767px){
    #footer{
        padding: 98px 0 102px;
    }
    #footer .wrapper{
        position: relative;
        width: calc((305 / 375)* 100%);
        z-index: 10;
    }
    #footer .footerLogo{
        display: block;
        width: 164px;
        margin-top: 80px;
    }
    #footer .footerTit{
        font-size: 14px;
        margin-top: 28px;
    }
    #footer .flexBox{
        display: flex;
        margin-top: 30px;
    }
    #footer .leftItem{
        margin-right: 44px;
    }
    #footer .txtFlex{
        display: flex;
        margin: 21px 0 0 0px;
        font-size: 12px;
    }
    #footer .rightBox{
        margin: 61px auto 0;
    }
    #footer .naviList{
        margin: 0 auto;
        display: flex;
        justify-content: unset;
    }
    #footer .naviList.spNone{
        display: none;
    }
    #footer .naviList.spOnly{
        display: flex;
    }
    #footer .naviItem:nth-child(n+2){
        margin-left: 68px;
    }
    #footer .naviInner{
        display: inline-block;
        font-size: 18px;
        letter-spacing: 1.5px;
    }
    #footer .itemCover:nth-child(n+2){
        margin-top: 22px;
    }
    #footer .copy{
        font-size: 11px;
        letter-spacing: 1px;
    }
    #footer .topBox{
        display: flex;
        justify-content: space-between;
        align-items: center;
    }
    #footer .leftBox{
        display: block;
        margin-top: 0px;
        width: 100%;
    }
    #footer .cBox:nth-child(n+2){
        margin-top: 25px;
    }
    #footer .addressBox{
        display: block;
    }
    #footer .cTit{
        font-size: 14px;
        letter-spacing: 0.5px;
    }
    #footer .cTxt{
        font-size: 12px;
        margin-top: 7px;
        line-height: 1.83;
        letter-spacing: 0px;
    }
    #footer .cTxt + .cTxt{
        margin: 2px 0 0;
    }
    #footer .bnrInner::before{
        width: 83px;
        height: 34px;
        top: -13px;
        left: -12px;
    }
    #footer .bnrInner.lazyloaded::before{
        background: url(../img/common/iconSpNavi01.png) center top / cover;
    }
    #footer .undBox{
        border-top: none;
        margin-top: 34px;
        padding-top: 0px;
    }
    #footer .linkList{
        display: flex;
    }
    #footer .linkInner{
        font-size: 11px;
        letter-spacing: 1px;
    }
    #footer .linkItem:nth-child(1){
        margin-right: 13px;
    }
}
@media (orientation: landscape) and (max-width:767px){
    #footer .naviList{
        justify-content: center;
    }
}

/* mac */
::-webkit-full-page-media, :future, :root #footer .leftBox {
    width: 100%;
}

/*-----------------------------------------------
	pnkz
-----------------------------------------------*/
#pnkz{
    width: 100%;
    font-size: 0;
    padding: 67px 20px 15px;
    position: relative;
}
#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: 50px 0 10px;
        width: calc((305 / 375)* 100%);
        margin: 0 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: 348px;
    text-align: right;
}
.secCmnTit .tit{
    font-size: 100px;
    position: relative;
    letter-spacing: 10px;
    margin-right: -13px;
}
.secCmnTit .spanTit::before{
    position: absolute;
    content: "";
    width: 59px;
    height: 48px;
    left: -18px;
    top: 10px;
    z-index: -1;
}
.secCmnTit .spanTit.lazyloaded::before{
   background: url(../img/cantact/iconTit01.png) center top / cover;
}
.secCmnTit .spanTit{
    position: relative;
}
.secCmnTit .txt{
    font-size: 22px;
    margin-top: 42px;
    letter-spacing: 5px;
    font-weight: 700;
}

@media only screen and (max-width:767px){
    .secCmnTit{
        text-align:left;
        width: calc((305 / 375)* 100%);
        margin: 0px auto;
        padding-top: 140px;
    }
    .secCmnTit .tit{
        font-size: 30px;
        letter-spacing: 3.5px;
        margin-right: 0px;
    }
    .secCmnTit .spanTit::before{
        width: 26px;
        height: 23px;
        left: -13px;
        top: -2px;
        z-index: -1;
    }
    .secCmnTit .spanTit.lazyloaded::before{
       background: url(../img/cantact/iconTit01_sp.png) center top / cover;
    }
    .secCmnTit .txt{
        font-size: 14px;
        margin-top: 21px;
        letter-spacing: 3px;
    }
}

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


/*-----------------------------------------------
    spNavi
-----------------------------------------------*/
#spNavi{
    display: none;
}
@media only screen and (max-width:767px){

    #spNavi.active{
        display: block;
    }
    #spNavi{
        position: relative;
        left: -100%;
        top: 0;
        width: 100%;
        min-height: 100vh;
        z-index: 9998;
        -webkit-transition: left .4s;
        transition: left .4s;
        padding: 111px 0 50px;
    }
    #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: 18px;
        font-weight: bold;
        letter-spacing: 1.5px;
        position: relative;
        display: block;
    }
    #spNavi .menuItem:nth-child(n+2){
        margin-top: 22px;
    }
    #spNavi .leftItem{
        margin-right: 44px;
    }
    #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;
        justify-content: center;
        margin-top: 39px;
    }
    #spNavi .boxInner{
        font-size: 13px;
        font-weight: 300;
        letter-spacing: 1.5px;
    }
    #spNavi .boxInner:nth-child(1){
        margin-right: 40px;
    }
}
@media (orientation: landscape) and (max-width:767px){
    #spNavi .boxList{
        justify-content: center;
    }
}

/* secContact */
.secContact{
    position: relative;
    background: #fff;
    padding-top: 100px;
}
.secContact .contactCover{
    padding: 239px 0 0;
    position: relative;
}
.secContact .contactCover::before{
    position: absolute;
    content: "";
    width: 100%;
    height:151px;
    left: 0;
    top: 0;
}
.secContact .contactCover.lazyloaded::before{
    background: url(../img/index/iconContact.gif) center top / cover;
}
.secContact .titBox{
    text-align: center;
}
.secContact .tit{
    font-size: 100px;
    letter-spacing: 10px;
}
.secContact .txt{
    font-size: 16px;
    line-height: 2.25;
    margin-top: 36px;
    letter-spacing: 1px;
}
.secContact .flexBox{
    display: flex;
    justify-content: space-between;
    padding: 84px 174px 51px 217px;
    position: relative;
}
.secContact .flexBox::before{
    position: absolute;
    content: "";
    background: #222;
    width: 1px;
    height: 237px;
    left: calc(50% - 0.5px);
    top: 38px;
}
.secContact .telBox{
    text-align: center;
}
.secContact .telTit{
    font-size: 32px;
    letter-spacing: 3px;
}
.secContact .telInner{
    display: block;
    height: 100%;
    text-decoration: none;
    color: #222;
    font-size: 50px;
    margin-top: 18px;
    letter-spacing: 4.5px;
}
.secContact .time{
    font-size: 16px;
    margin-top: 23px;
    letter-spacing: 1.5px;
}
.secContact .mailBox{
    text-align: center;
}
.secContact .mailTit{
    font-size: 32px;
    letter-spacing: 3px;
}
.secContact .btnInner{
    font-size: 18px;
    color:#fff;
    display: flex;
    justify-content: center;
    align-items: center;
    text-decoration: none;
    width: 400px;
    height: 80px;
    border-radius: 40px;
    position: relative;
    margin-top: 28px;
    background-image: -moz-linear-gradient( -90deg, rgb(22,94,131) 0%, rgb(26,113,156) 100%);
    background-image: -webkit-linear-gradient( -90deg, rgb(22,94,131) 0%, rgb(26,113,156) 100%);
    background-image: -ms-linear-gradient( -90deg, rgb(22,94,131) 0%, rgb(26,113,156) 100%);
    font-weight: 700;
}
.secContact .btnInner::before{
    position: absolute;
    content: "";
    width: 20px;
    height: 12px;
    top: calc(50% - 6px);
    right: 41px;
}
.secContact .btnInner.lazyloaded::before{
    background: url(../img/index/iconContactBtn.png) center top / cover;
}
.secContact .boxCover{
    background: #222222;
}
.secContact .undBox{
    background: #fff;
    padding-bottom: 100px;
}

@media only screen and (max-width:767px){
    .secContact{
        padding-top: 70px;
    }
    .secContact .contactCover{
        padding: 105px 0 100px;
    }
    .secContact .contactCover::before{
        width: 100%;
        height: 10.135vw;
    }
    .secContact .contactCover.lazyloaded::before{
        background: url(../img/index/iconContact_sp.gif) center top / cover;
    }
    .secContact .tit{
        font-size: 30px;
        letter-spacing: 3.5px;
    }
    .secContact .txt{
        font-size: 12px;
        line-height: 1.83;
        margin-top: 18px;
        letter-spacing: 0px;
    }
    .secContact .flexBox{
        display: block;
        padding: 0px;
    }
    .secContact .flexBox::before{
        width: 35px;
        height: 1px;
        left: calc(50% - 17.5px);
        top: 24px;
    }
    .secContact .topBox{
        display: flex;
        justify-content: center;
        align-items: baseline;
    }
    .secContact .telTit{
        font-size: 16px;
        letter-spacing: 3px;
    }
    .secContact .telInner{
        font-size: 28px;
        margin-top: 52px;
        letter-spacing: 2.5px;
    }
    .secContact .time{
        font-size: 14px;
        margin-top: 11px;
    }
    .secContact .btnInner{
        font-size: 14px;
        width: calc((305 / 375)* 100%);
        height: 60px;
        border-radius: 30px;
        margin: 22px auto 0;
    }
    .secContact .btnInner::before{
        width: 16px;
        height: 10px;
        top: calc(50% - 5px);
        right: 29px;
    }
    
    .secContact .undBox{
        padding-bottom: 0px;
    }
    
}
@media only screen and (max-width:359px){
    .secContact .txt {
        font-size: 11px;
    }
}


.internal .secContact{
    padding-top: 20px;
}
.internal .secContact .undBox {
    padding-bottom: 0px;
}

@media only screen and (max-width:767px){
    .internal .secContact .contactCover {
        padding: 105px 0 20px;
    }
}