@charset "utf-8";

/* ==============================
    remの基準
============================== */
html{
    font-size: 10px;
}
@media only screen and (max-width:1500px){
    html{
        font-size: calc((10 / 1500) * 100vw);
    }
}
@media only screen and (max-width:1215px){
    html{
        font-size: 10px;
    }
}

/* ==============================
    変数設定
============================== */

/* 幅の基準 */
:root {
    --widthBase : 192rem;
}
@media only screen and (max-width:1920px){
    :root {
        --widthBase : 100vw;
    }
}
@media only screen and (max-width:1400px){
    :root {
        --widthBase : 1400px;
    }
}
@media only screen and (max-width:1215px){
    :root {
        --widthBase : 375px;
    }
}
@media only screen and (max-width:374px){
    :root {
        --widthBase : 100vw;
    }
}
:root {

    /* フッターの上の余白 */
    --footerPc: 15rem;
    --footerSp: 8rem;

    /* 色 */
    --textColor: #000;
    --keyColor: #182e5a;
    --linkColor: #1a5ee6;
    --whiteColor: #fff;
    --pnkzColor: #959494;
    --borderColor: rgba(0, 0, 0, 0.25);
    --orangeColor:#eb6100;
    --disabledColor: rgb(191, 191, 191);

    --colorBlack: #252729;

    /* フォントサイズ（PC） */
    --pcFontSize10: 1rem;
    --pcFontSize11: 1.1rem;
    --pcFontSize12: 1.2rem;
    --pcFontSize13: 1.3rem;
    --pcFontSize14: 1.4rem;
    --pcFontSize15: 1.5rem;
    --pcFontSize16: 1.6rem;
    --pcFontSize17: 1.7rem;
    --pcFontSize18: 1.8rem;
    --pcFontSize19: 1.9rem;
    --pcFontSize20: 2rem;
    --pcFontSize21: 2.1rem;
    --pcFontSize22: 2.2rem;
    --pcFontSize23: 2.3rem;
    --pcFontSize24: 2.4rem;
    --pcFontSize25: 2.5rem;
    --pcFontSize26: 2.6rem;
    --pcFontSize27: 2.7rem;
    --pcFontSize28: 2.8rem;
    --pcFontSize29: 2.9rem;
    --pcFontSize30: 3rem;
    --pcFontSize31: 3.1rem;
    --pcFontSize32: 3.2rem;
    --pcFontSize33: 3.3rem;
    --pcFontSize34: 3.4rem;
    --pcFontSize35: 3.5rem;
    --pcFontSize36: 3.6rem;
    --pcFontSize37: 3.7rem;
    --pcFontSize38: 3.8rem;
    --pcFontSize39: 3.9rem;
    --pcFontSize40: 4rem;
    --pcFontSize41: 4.1rem;
    --pcFontSize42: 4.2rem;
    --pcFontSize43: 4.3rem;
    --pcFontSize44: 4.4rem;
    --pcFontSize45: 4.5rem;
    --pcFontSize46: 4.6rem;
    --pcFontSize47: 4.7rem;
    --pcFontSize48: 4.8rem;
    --pcFontSize49: 4.9rem;
    --pcFontSize50: 5rem;
    --pcFontSize51: 5.1rem;
    --pcFontSize52: 5.2rem;
    --pcFontSize53: 5.3rem;
    --pcFontSize54: 5.4rem;
    --pcFontSize55: 5.5rem;
    --pcFontSize56: 5.6rem;
    --pcFontSize57: 5.7rem;
    --pcFontSize58: 5.8rem;
    --pcFontSize59: 5.9rem;
    --pcFontSize60: 6rem;
    --pcFontSize61: 6.1rem;
    --pcFontSize62: 6.2rem;
    --pcFontSize63: 6.3rem;
    --pcFontSize64: 6.4rem;
    --pcFontSize65: 6.5rem;
    --pcFontSize66: 6.6rem;
    --pcFontSize67: 6.7rem;
    --pcFontSize68: 6.8rem;
    --pcFontSize69: 6.9rem;
    --pcFontSize70: 7rem;
    --pcFontSize71: 7.1rem;
    --pcFontSize72: 7.2rem;
    --pcFontSize73: 7.3rem;
    --pcFontSize74: 7.4rem;
    --pcFontSize75: 7.5rem;
    --pcFontSize76: 7.6rem;
    --pcFontSize77: 7.7rem;
    --pcFontSize78: 7.8rem;
    --pcFontSize79: 7.9rem;
    --pcFontSize80: 8rem;
    --pcFontSize81: 8.1rem;
    --pcFontSize82: 8.2rem;
    --pcFontSize83: 8.3rem;
    --pcFontSize84: 8.4rem;
    --pcFontSize85: 8.5rem;
    --pcFontSize86: 8.6rem;
    --pcFontSize87: 8.7rem;
    --pcFontSize88: 8.8rem;
    --pcFontSize89: 8.9rem;
    --pcFontSize90: 9rem;
    --pcFontSize91: 9.1rem;
    --pcFontSize92: 9.2rem;
    --pcFontSize93: 9.3rem;
    --pcFontSize94: 9.4rem;
    --pcFontSize95: 9.5rem;
    --pcFontSize96: 9.6rem;
    --pcFontSize97: 9.7rem;
    --pcFontSize98: 9.8rem;
    --pcFontSize99: 9.9rem;
    --pcFontSize100: 10rem;

    /* letter-spacing（PC） */
    --pcLetterSpacing10: 0.01em;
    --pcLetterSpacing20: 0.02em;
    --pcLetterSpacing30: 0.03em;
    --pcLetterSpacing40: 0.04em;
    --pcLetterSpacing50: 0.05em;
    --pcLetterSpacing60: 0.06em;
    --pcLetterSpacing70: 0.07em;
    --pcLetterSpacing80: 0.08em;
    --pcLetterSpacing90: 0.09em;
    --pcLetterSpacing100: 0.1em;
    --pcLetterSpacing110: 0.11em;
    --pcLetterSpacing120: 0.12em;
    --pcLetterSpacing130: 0.13em;
    --pcLetterSpacing140: 0.14em;
    --pcLetterSpacing150: 0.15em;
    --pcLetterSpacing160: 0.16em;
    --pcLetterSpacing170: 0.17em;
    --pcLetterSpacing180: 0.18em;
    --pcLetterSpacing190: 0.19em;
    --pcLetterSpacing200: 0.2em;
    --pcLetterSpacing210: 0.21em;
    --pcLetterSpacing220: 0.22em;
    --pcLetterSpacing230: 0.23em;
    --pcLetterSpacing240: 0.24em;
    --pcLetterSpacing250: 0.25em;

    /* フォントサイズ（SP） */
    --spFontSize10: calc((10 / 375) * var(--widthBase));
    --spFontSize11: calc((11 / 375) * var(--widthBase));
    --spFontSize12: calc((12 / 375) * var(--widthBase));
    --spFontSize13: calc((13 / 375) * var(--widthBase));
    --spFontSize14: calc((14 / 375) * var(--widthBase));
    --spFontSize15: calc((15 / 375) * var(--widthBase));
    --spFontSize16: calc((16 / 375) * var(--widthBase));
    --spFontSize17: calc((17 / 375) * var(--widthBase));
    --spFontSize18: calc((18 / 375) * var(--widthBase));
    --spFontSize19: calc((19 / 375) * var(--widthBase));
    --spFontSize20: calc((20 / 375) * var(--widthBase));
    --spFontSize21: calc((21 / 375) * var(--widthBase));
    --spFontSize22: calc((22 / 375) * var(--widthBase));
    --spFontSize23: calc((23 / 375) * var(--widthBase));
    --spFontSize24: calc((24 / 375) * var(--widthBase));
    --spFontSize25: calc((25 / 375) * var(--widthBase));
    --spFontSize26: calc((26 / 375) * var(--widthBase));
    --spFontSize27: calc((27 / 375) * var(--widthBase));
    --spFontSize28: calc((28 / 375) * var(--widthBase));
    --spFontSize29: calc((29 / 375) * var(--widthBase));
    --spFontSize30: calc((30 / 375) * var(--widthBase));
    --spFontSize31: calc((31 / 375) * var(--widthBase));
    --spFontSize32: calc((32 / 375) * var(--widthBase));
    --spFontSize33: calc((33 / 375) * var(--widthBase));
    --spFontSize34: calc((34 / 375) * var(--widthBase));
    --spFontSize35: calc((35 / 375) * var(--widthBase));
    --spFontSize36: calc((36 / 375) * var(--widthBase));
    --spFontSize37: calc((37 / 375) * var(--widthBase));
    --spFontSize38: calc((38 / 375) * var(--widthBase));
    --spFontSize39: calc((39 / 375) * var(--widthBase));
    --spFontSize40: calc((40 / 375) * var(--widthBase));
    --spFontSize41: calc((41 / 375) * var(--widthBase));
    --spFontSize42: calc((42 / 375) * var(--widthBase));
    --spFontSize43: calc((43 / 375) * var(--widthBase));
    --spFontSize44: calc((44 / 375) * var(--widthBase));
    --spFontSize45: calc((45 / 375) * var(--widthBase));
    --spFontSize46: calc((46 / 375) * var(--widthBase));
    --spFontSize47: calc((47 / 375) * var(--widthBase));
    --spFontSize48: calc((48 / 375) * var(--widthBase));
    --spFontSize49: calc((49 / 375) * var(--widthBase));
    --spFontSize50: calc((50 / 375) * var(--widthBase));
    --spFontSize51: calc((51 / 375) * var(--widthBase));
    --spFontSize52: calc((52 / 375) * var(--widthBase));
    --spFontSize53: calc((53 / 375) * var(--widthBase));
    --spFontSize54: calc((54 / 375) * var(--widthBase));
    --spFontSize55: calc((55 / 375) * var(--widthBase));
    --spFontSize56: calc((56 / 375) * var(--widthBase));
    --spFontSize57: calc((57 / 375) * var(--widthBase));
    --spFontSize58: calc((58 / 375) * var(--widthBase));
    --spFontSize59: calc((59 / 375) * var(--widthBase));
    --spFontSize60: calc((60 / 375) * var(--widthBase));
    --spFontSize61: calc((61 / 375) * var(--widthBase));
    --spFontSize62: calc((62 / 375) * var(--widthBase));
    --spFontSize63: calc((63 / 375) * var(--widthBase));
    --spFontSize64: calc((64 / 375) * var(--widthBase));
    --spFontSize65: calc((65 / 375) * var(--widthBase));
    --spFontSize66: calc((66 / 375) * var(--widthBase));
    --spFontSize67: calc((67 / 375) * var(--widthBase));
    --spFontSize68: calc((68 / 375) * var(--widthBase));
    --spFontSize69: calc((69 / 375) * var(--widthBase));
    --spFontSize70: calc((70 / 375) * var(--widthBase));
    --spFontSize71: calc((71 / 375) * var(--widthBase));
    --spFontSize72: calc((72 / 375) * var(--widthBase));
    --spFontSize73: calc((73 / 375) * var(--widthBase));
    --spFontSize74: calc((74 / 375) * var(--widthBase));
    --spFontSize75: calc((75 / 375) * var(--widthBase));
    --spFontSize76: calc((76 / 375) * var(--widthBase));
    --spFontSize77: calc((77 / 375) * var(--widthBase));
    --spFontSize78: calc((78 / 375) * var(--widthBase));
    --spFontSize79: calc((79 / 375) * var(--widthBase));
    --spFontSize80: calc((80 / 375) * var(--widthBase));
    --spFontSize81: calc((81 / 375) * var(--widthBase));
    --spFontSize82: calc((82 / 375) * var(--widthBase));
    --spFontSize83: calc((83 / 375) * var(--widthBase));
    --spFontSize84: calc((84 / 375) * var(--widthBase));
    --spFontSize85: calc((85 / 375) * var(--widthBase));
    --spFontSize86: calc((86 / 375) * var(--widthBase));
    --spFontSize87: calc((87 / 375) * var(--widthBase));
    --spFontSize88: calc((88 / 375) * var(--widthBase));
    --spFontSize89: calc((89 / 375) * var(--widthBase));
    --spFontSize90: calc((90 / 375) * var(--widthBase));
    --spFontSize91: calc((91 / 375) * var(--widthBase));
    --spFontSize92: calc((92 / 375) * var(--widthBase));
    --spFontSize93: calc((93 / 375) * var(--widthBase));
    --spFontSize94: calc((94 / 375) * var(--widthBase));
    --spFontSize95: calc((95 / 375) * var(--widthBase));
    --spFontSize96: calc((96 / 375) * var(--widthBase));
    --spFontSize97: calc((97 / 375) * var(--widthBase));
    --spFontSize98: calc((98 / 375) * var(--widthBase));
    --spFontSize99: calc((99 / 375) * var(--widthBase));
    --spFontSize100: calc((100 / 375) * var(--widthBase));

    /* letter-spacing（SP） */
    --spLetterSpacing10: 0.01em;
    --spLetterSpacing20: 0.02em;
    --spLetterSpacing30: 0.03em;
    --spLetterSpacing40: 0.04em;
    --spLetterSpacing50: 0.05em;
    --spLetterSpacing60: 0.06em;
    --spLetterSpacing70: 0.07em;
    --spLetterSpacing80: 0.08em;
    --spLetterSpacing90: 0.09em;
    --spLetterSpacing100: 0.1em;
    --spLetterSpacing110: 0.11em;
    --spLetterSpacing120: 0.12em;
    --spLetterSpacing130: 0.13em;
    --spLetterSpacing140: 0.14em;
    --spLetterSpacing150: 0.15em;
    --spLetterSpacing160: 0.16em;
    --spLetterSpacing170: 0.17em;
    --spLetterSpacing180: 0.18em;
    --spLetterSpacing190: 0.19em;
    --spLetterSpacing200: 0.2em;
    --spLetterSpacing210: 0.21em;
    --spLetterSpacing220: 0.22em;
    --spLetterSpacing230: 0.23em;
    --spLetterSpacing240: 0.24em;
    --spLetterSpacing250: 0.25em;

}

/* ==============================
    基本設定
============================== */
body{
    color:var(--textColor);
    font-size:var(--pcFontSize12);
    font-family: "Zen Kaku Gothic New", 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:1180px;
}
@media only screen and (max-width:1215px){
    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;}
.fSerif{
    font-family:'YakuHanMP','游明朝体', YuMincho, '游明朝', 'Yu Mincho', 'ヒラギノ明朝 ProN W3', 'Hiragino Mincho ProN W3', HiraMinProN-W3, 'ヒラギノ明朝 ProN', 'Hiragino Mincho ProN', 'ヒラギノ明朝 Pro', 'Hiragino Mincho Pro', 'Noto Serif Japanese';
}
.fZenkaku{
    font-family: "Zen Kaku Gothic New", sans-serif;
}

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

/* rollover(brightnessによる変化) */
.cursorPointer.brt:hover,.cursorPointer .brt:hover,
.brt a:hover,a.brt:hover,a .brt:hover{ -webkit-filter: brightness(1.1);filter: brightness(1.1); }
.cursorPointer.brt,.cursorPointer .brt,
.brt a,
a.brt,
a .brt{
    transition:filter 0.2s ease-out;
}
@media only screen and (max-width:1215px){
    .cursorPointer.brt:hover,.cursorPointer .brt:hover,
    .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:1215px){
    a[href^="tel:"]{
        pointer-events:auto;
        cursor:pointer;
    }
}
a{color: inherit;text-decoration: none;}

/* container */
#container{
    overflow:hidden;
    max-width:1920px;
    width: 100%;
    margin:0 auto;
}
#container.isBgNavy {
    background: var(--keyColor);
}

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

/* -----------------------------------------------
    icon
----------------------------------------------- */
.cmnIconEvent01 {
    background-color: var(--colorEvent01);
}
.cmnIconEvent02 {
    background-color: var(--colorEvent02);
}
.cmnIconEvent03 {
    background-color: var(--colorEvent03);
}

/* -----------------------------------------------
    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
----------------------------------------------- */
.wrapper1400{
    max-width:calc(100% - 10rem);
    width: 140rem;
    margin-inline: auto;
}
@media only screen and (max-width:1215px){
    .wrapper1400{
        max-width:none;
        width: 100%;
    }
    .wrapperSp{
        width: calc((335 / 375) * 100%);
        margin-inline: auto;
    }
    .wrapperSp335 {
        width: 89.336%;
        margin: 0 auto;
    }
    .wrapperFit{
        max-width: 40rem;
        margin: 0 auto;
	}
    .wrapperSp335 {
        width: 89.336%;
        margin: 0 auto;
    }
}

/*-----------------------------------------------
	jsHide
-----------------------------------------------*/
.jsHide,
.ro a.jsHide{
    /* filter: blur(20px) brightness(4); */
    transform: translateY(50px);
    opacity: 0;
    transition: transform 3s cubic-bezier(0.19, 1, 0.22, 1),filter 3s cubic-bezier(0.19, 1, 0.22, 1),opacity 3s cubic-bezier(0.19, 1, 0.22, 1);
    transform-origin: center top;
}
.jsHide.jsShow,
.ro a.jsHide.jsShow{
    /* filter: blur(0) brightness(1); */
    transform: translateY(0);
    opacity: 1;
}
.jsHideFade,
.ro a.jsHideFade{
    opacity: 0;
    transition: opacity 0.3s cubic-bezier(0.19, 1, 0.22, 1);
}
.jsHideFade.jsShow,
.ro a.jsHide.jsShow{
    opacity: 1;
}

.jsHideFadeP .jsHideFadeC,
.ro a.jsHideFadeP .jsHideFadeC{
    opacity: 0;
    transition: opacity 5s cubic-bezier(0.19, 1, 0.22, 1);
}
.jsHideFadeP .jsHideFadeC:nth-child(2){
    transition-delay: 0.2s;
}
.jsHideFadeP .jsHideFadeC:nth-child(3){
    transition-delay: 0.4s;
}
.jsHideFadeP .jsHideFadeC:nth-child(4){
    transition-delay: 0.6s;
}
.jsHideFadeP .jsHideFadeC:nth-child(5){
    transition-delay: 0.8s;
}
.jsHideFadeP .jsHideFadeC:nth-child(6){
    transition-delay: 1.0s;
}
.jsHideFadeP .jsHideFadeC:nth-child(7){
    transition-delay: 1.2s;
}
.jsHideFadeP .jsHideFadeC:nth-child(8){
    transition-delay: 1.4s;
}
.jsHideFadeP .jsHideFadeC:nth-child(9){
    transition-delay: 1.6s;
}
.jsHideFadeP .jsHideFadeC:nth-child(10){
    transition-delay: 1.8s;
}

.jsHideFadeP.jsShow .jsHideFadeC,
.ro a.jsHideFadeP.jsShow .jsHideFadeC{
    opacity: 1;
}

/* -----------------------------------------------
    サイト共通（全ページ）
----------------------------------------------- */
/* cmnHeader */
.cmnHeader {
    background: var(--whiteColor);
    height: 10rem;
    display: flex;
    align-items: center;
    padding-left: 3rem;
    position: fixed;
    width: 100%;
}
.cmnHeader .boxHeaderInner{
    display: flex;
    align-items: center;
    justify-content: space-between;
    width: 100%;
}
.cmnHeader .boxHeaderLeft {
    display: flex;
    align-items: center;
    gap: 0 3rem;
}
.cmnHeader .boxHeaderRight {
    display: flex;
    align-items: center;
}
.cmnHeader .btnHeaderContact {
    width: 22rem;
}
.cmnHeader .txtHeaderTitle {
    font-size: var(--pcFontSize14);
    letter-spacing: 0.04em;
}

@media only screen and (max-width: 1215px) {
    .cmnHeader {
        height: 6rem;
        padding: 0 2rem;
        position: static;
    }
    .cmnHeader .boxHeaderRight {
        display: none;
    }
    .cmnHeader .imgLogo {
        width: 12.6rem;
    }
    .cmnHeader .txtHeaderTitle {
        font-size: var(--spFontSize11);
        letter-spacing: 0;
    }
    .cmnHeader .boxHeaderLeft {
        justify-content: space-between;
        gap: 0 1.5rem;
        width: 100%;
    }
}
@media only screen and (max-width: 370px) {
    .cmnHeader {
        padding: 0 1rem;
    }
}
/* cmnFooter */
.cmnFooter {
    background-color: var(--colorBlack);
    color: #fff;
    height: 38rem;
    display: flex;
    align-items: center;
}
.cmnFooter .boxFooterColumns {
    display: flex;
    justify-content: space-between;
    align-items: center;
}
.cmnFooter .boxFooterInfo {
    margin-bottom: 5rem;
}
.cmnFooter .txtFooterNote {
    font-size: var(--pcFontSize12);
    line-height: calc(30 / 12);
    letter-spacing: 0.04em;
}

@media only screen and (max-width: 1215px) {
    .cmnFooter {
        padding: 7.2rem 0 4rem;
        height: 50rem;
        align-items: flex-start;
    }
    .cmnFooter .boxFooterColumns {
        flex-direction: column-reverse;
    }
    .cmnFooter .txtFooterNote {
        font-size: var(--pcFontSize11);
        line-height: calc(22 / 11);
        letter-spacing: 0;
    }
    .cmnFooter .txtFooterCompany {
        font-size: var(--pcFontSize11);
        line-height: calc(22 / 11);
        letter-spacing: 0;
        text-align: center;
    }
    .cmnFooter .imgFooterLogo {
        width: 21.5rem;
        display: block;
        margin: 0 auto;
    }
    .cmnFooter .boxFooterRight {
        margin-bottom: 5.4rem;
    }
    .cmnFooter .boxFooterInfo {
        margin-bottom: 3.5rem;
    }
}

/* sp fixed contact */
.spContact {
    display: none;
}

@media only screen and (max-width: 1215px) {
    .spContact {
        display: flex;
        justify-content: center;
        position: fixed;
        left: 0;
        right: 0;
        bottom: 0;
        z-index: 100;
        opacity: 0;
        visibility: hidden;
        pointer-events: none;
        transition: opacity 0.25s ease, visibility 0.25s ease;
    }
    .spContact .btnSpContact {
        display: block;
        max-width: 40rem;
    }
    .spContact.isVisible {
        opacity: 1;
        visibility: visible;
        pointer-events: auto;
    }
}
