@charset "UTF-8";

/* ////////////////////////////////////////////////////////////////////
///// 全ページ共通CSS ///////////////////////////////////////////////////
//////////////////////////////////////////////////////////////////// */
body {
    font-family: 'Noto Sans JP',"游ゴシック体", YuGothic, "游ゴシック", "Yu Gothic", "メイリオ", "Hiragino Kaku Gothic ProN", "Hiragino Sans", sans-serif;
    font-weight: 500;
    font-style: normal;
    background: #fff;
    line-height: 1.7;
    letter-spacing: .15em;
    -ms-font-feature-settings: "normal";
    -webkit-font-feature-settings: "palt";
    font-feature-settings: "palt";
}

.fwBold {
    font-weight: 900;
}

.enGothic {
    font-family: 'Lato', sans-serif;
    font-weight: 100;
    font-style: normal;
}
.enSerif {
    font-family: 'Cormorant Infant', serif;
    font-weight: 300;
    font-style: normal;
}

.enGothic.fwBold {
    font-weight: 700;
    font-style: normal;
}
.enGothic.fwExBold {
    font-weight: 800;
    font-style: normal;
}


.itaric {
    font-style: italic;
}

p {
    line-height: 1.7;
}

.XlTitle {
    font-size: 10.75vw;
    line-height: 1.1;
    letter-spacing: .05em;
}
.LTitle {
    font-size: 8.75vw;
    line-height: 1.2;
    letter-spacing: .01em;
}
.MTitle {
    font-size: 6.25vw;
    line-height: 1.5;
    letter-spacing: .2em;
}
.STitle {
    font-size: 4.5vw;
    line-height: 1.5;
    letter-spacing: .2em;
}
.LTxt {
    font-size: 3.88vw;
}
.MTxt,
.MsTxt {
    font-size: 2.8vw;
}
.STxt {
    font-size: 1.88vw;
    letter-spacing: .05em;
}
.creditTxt{
    letter-spacing: .05em;
}
@media screen and (min-width:641px) {
    .XlTitle {
        font-size: 5.80vw;
    }
    .LTitle {
        font-size: 5.64vw;
    }
    .MTitle {
        font-size: 2.64vw;
    }
    .STitle {
        font-size: 2.0vw;
    }

    .LTxt {
        font-size: 16px;
    }
    .MTxt,
    .MsTxt {
        font-size: 13px;
    }
    .STxt {
        font-size: 10px;
    }
}
@media screen and (min-width:961px) {
     .XlTitle {
        font-size: 4.8vw;
        line-height: 1;
    }
    .LTxt {
        font-size: 1.39vw;
    }
    .MTxt {
        font-size: 1.17vw;
    }
    .MsTxt{
        font-size: 1.0vw;
    }
    .STitle {
        font-size: 1.5vw;
    }
    .STxt {
        font-size: .88vw;
    }
}
@media screen and (min-width:1366px) {
     
    .XlTitle {
        font-size: 72px;
    }
    .LTitle {
        font-size: 77px;
    }
    .MTitle {
        font-size: 36px;
    }
    .STitle {
        font-size: 20px;
    }
    .LTxt {
        font-size: 19px;
    }
    .MTxt {
        font-size: 16px;
    }
    .MsTxt,
    .STxt {
        font-size: 12px;
    }
}
.fs400 {
    font-size: 400%;
}

.fs300 {
    font-size: 300%;
}

.fs200 {
    font-size: 200%;
}

.fs180 {
    font-size: 180%;
}

.fs160 {
    font-size: 160%;
}

.fs150 {
    font-size: 150%;
}

.fs140 {
    font-size: 140%;
}

.fs130 {
    font-size: 130%;
}

.fs120 {
    font-size: 120%;
}

.fs110 {
    font-size: 110%;
}

.fs90 {
    font-size: 90%;
}

.fs80 {
    font-size: 80%;
}

.fs70 {
    font-size: 70%;
}

.fs60 {
    font-size: 60%;
}

.fs50 {
    font-size: 50%;
}

.fsItalic {
    font-style: italic;
}

/* ==================================================
color
================================================== */

body {
    color: #292929;
}

.mainColor {
    color: #231815;
}

.titColor {
    color: #231815;
}

.weakColor {
    color: #808080;
}

.backColor {
    color: #ffffff;
}

.attention {
    color: #a80028;
}

/* ==================================================
link
================================================== */

a:link {
    color: #333333;
    text-decoration: none;
}

a:visited {
    color: #333333;
    text-decoration: none;
}

a:active {
    color: #333333;
    text-decoration: none;
}

.weakColor a:link {
    color: #888888;
    text-decoration: underline;
}

.weakColor a:visited {
    color: #888888;
    text-decoration: underline;
}

.weakColor a:active {
    color: #888888;
    text-decoration: underline;
}

.tagList li a:link,
.tagList li a:visited,
.tagList li a:active {
    text-decoration: none;
}

.bnrmenuLists li a:link,
.bnrmenuLists li a:visited,
.bnrmenuLists li a:active {
    border-bottom: 2px solid #333333;
}

/* ==================================================
common
================================================== */

svg {
    fill: #000;
}

input {
    -webkit-appearance: none;
}

.scrollArrow span {
    width: 1px;
}

.slideIn {
    -webkit-transition: all 2.8s cubic-bezier(0.215, 0.61, 0.355, 1);
    transition: all 2.8s cubic-bezier(0.215, 0.61, 0.355, 1);
}

.nowPage {
    position: relative;
}

.nowPage::after {
    content: "";
    display: none;
    background: #000;
    width: 70%;
    height: 1px;
    position: absolute;
    bottom: 5px;
    left: 8vw;
}

@media screen and (min-width:641px) {
    .nowPage::after {
        left: 4vw;
    }
}

@media screen and (min-width:961px) {
    .nowPage::after {
        bottom: -5px;
        left: 50%;
        width: 80%;
        -webkit-transform: translate(-50%, 0);
        transform: translate(-50%, 0);
    }
}

@media screen and (min-width:1281px) {
    .menuOnline {
        display: none;
    }
}

/* ==================================================
BtnSet
================================================== */
.BtnCenter {
    -webkit-box-sizing: border-box;
    box-sizing: border-box;
    -webkit-transition: .8s all ease-in;
    transition: .8s all ease-in;
    text-align: center;
}

.BtnCenter svg {
    height: 1.2em;
    width: 1.2em;
    margin: 0 10px 0 0;
}

.BtnCenter a {
    padding: .8em 1.5em;
    -webkit-box-sizing: border-box;
    box-sizing: border-box;
    position: relative;
    z-index: 10;
    width: 100%;
    text-align: center;
    margin: 0 auto;
}

.BtnCenter a figure {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center;
}

.kadoRBtn {
    border-radius: 6px;
}

.roundBtn {
    border-radius: 4em;
}

.btnLine.mainBtn {
    background: rgba(255, 255, 255, 0);
    border: 1px solid #707070;
}

.btnLine.bkBtn {
    background: rgba(255, 255, 255, 1);
    border: 1px solid #222222;
    width: 100%;
    margin: 0 auto;
}

.btnLine.grBtn {
    background: #cccccc;
    border: 1px solid #cccccc;
    width: 100%;
    max-width: 230px;
    margin: 0 auto;
}

.btnLine.whBtn {
    background: rgba(220, 4, 42, 1);
    border: 1px solid #ffffff;
}

.btnLine.mainBtn a {
    color: #292929;
}

.btnLine.bkBtn a {
    color: #222222;
}

.btnLine.grBtn a {
    color: #ffffff;
}

.btnLine.whBtn a {
    color: #ffffff;
}

#ftr .btnLine.whBtn {
    background: rgba(255, 255, 255, 0);
    border: 1px solid rgba(255, 255, 255, .3);
}

.btnBeta {
    overflow: hidden;
    position: relative;
}

.efBtn::after {
    content: "";
    width: 0;
    position: absolute;
    left: -10%;
    top: 0;
    height: 100px;
    background: #000;
    opacity: .1;
    -webkit-transform: skewX(15deg);
    transform: skewX(15deg);
    -webkit-transition: .3s width ease-in-out;
    transition: .3s width ease-in-out;
}

.btnBeta.whBtn {
    background: #ffffff;
    border: 1px solid #ffffff;
}

.btnBeta.bkBtn {
    background: #a0a0a0;
    border: 1px solid #a0a0a0;
}

.btnBeta.efBtn a {
    text-decoration: none;
}

.btnBeta.efBtn::after {
    width: 0%;
}

.efBtn.efOn::after {
    width: 150%;
    -webkit-transition: .6s width ease-out;
    transition: .6s width ease-out;
}

.btnBeta.grBtn {
    background: #a0a0a0;
    border: 1px solid #a0a0a0;
}

.btnBeta.mainBtn {
    background: #dc042a;
    border: 1px solid #dc042a;
}

.btnBeta.mainBtn a,
.btnBeta.grBtn a,
.btnBeta.bkBtn a {
    color: #ffffff;
}

.btnBeta.whBtn a {
    color: #dc042a;
}

.btnBeta.mainBtn svg,
.btnBeta.bkBtn svg {
    fill: #ffffff;
}

.btnBeta.whBtn svg {
    fill: #dc042a;
}

.mainBtn p,
.grBtn p,
.bkBtn p,
.whBtn p {
    position: relative;
    padding: 0;
    display: inline-block;
    line-height: 1;
    width: 90%;
}

.mainBtn p::after,
.grBtn p::after,
.bkBtn p::after,
.whBtn p::after {
    display: block;
    content: "";
    position: absolute;
    top: 50%;
    right: 0;
    width: 8px;
    height: 8px;
    -webkit-transform: translate(0, -50%) rotate(-45deg);
    transform: translate(0, -50%) rotate(-45deg);
    -webkit-transition: .8s all ease-in;
    transition: .8s all ease-in;
}

.btnBeta.grBtn p::after,
.btnBeta.mainBtn p::after .btnBeta.bkBtn p::after {
    border-right: 1px solid #ffffff;
    border-bottom: 1px solid #ffffff;
}

.btnBeta.whBtn p::after {
    border-right: 1px solid #dc042a;
    border-bottom: 1px solid #dc042a;
}

.btnLine.bkBtn p::after {
    border-right: 1px solid #222222;
    border-bottom: 1px solid #222222;
}
/*
.btnLine.mainBtn p::after {
border-right: 1px solid #dc042a;
border-bottom: 1px solid #dc042a;
} */

.btnLine.whBtn p::after {
    border-right: 1px solid #ffffff;
    border-bottom: 1px solid #ffffff;
}

#ftr .whBtn p::after {
    border-right: 1px solid rgba(255, 255, 255, .7);
    border-bottom: 1px solid rgba(255, 255, 255, .7);
}

.innerLinkBtn a p {
    letter-spacing: .15em;
    border-bottom: 1px solid #999999;
    padding: 0 10px 8px;
    margin: 0 auto;
    -webkit-transition: all .8s;
    transition: all .8s;
}

@media screen and (min-width:641px) {
    .btnLine.bkBtn {
        max-width: 230px;
    }
}

#cnts {
    max-width: 100%;
    margin: 0 auto;
    min-height: calc(100vh - 12rem);
    /* overflow: hidden; */
}
.swiper-container-vertical > .swiper-pagination-bullets {
    right: 5px;
    top: 45vh;
    -webkit-transform: translate3d(0,-50%,0);
    transform: translate3d(0,-50%,0);
}
.swiper-container-vertical > .swiper-pagination-bullets .swiper-pagination-bullet{
    margin: 6px auto;
}
.swiper-pagination-bullet {
    width: 100%;
    height: 2px;
    display: inline-block;
    border-radius: 0;
    background: #292929;
    opacity: .2;
}
.swiper-pagination-bullet-active{
    width: 100%;
    height: 2px;
    display: inline-block;
    border-radius: 0;
    background: none;
    opacity: 1;
}
