@charset "utf-8";
/* CSS Document */

/* ----------------------------------------------------------------------------------------------------
  base
* --------------------------------------------------------------------------------------------------*/
html{
    font-size: 62.5%;
}
body {
	font-family: "游ゴシック体", YuGothic, "游ゴシック Medium", "Yu Gothic Medium", "游ゴシック", "Yu Gothic", sans-serif;
	color: #000;
	font-size: 1.2rem;
	line-height:1.4;
    padding-top: 16.14vw;
}
header {
    position:fixed;
    width: 100%;
    top:0;
    z-index: 2000;
    margin: 0;
    padding: 0;
}
footer{
    background-color: #000;
}
img{
	vertical-align: bottom;
	max-width: 100%;
}
@media only screen and (min-width: 769px) {
    body {
        padding-top: 52px;
    }
}

@media all and (-ms-high-contrast:none) {
  *::-ms-backdrop, body {
  font-family:"メイリオ", Meiryo, Osaka, "sans-serif"
  }
}

*,
*:after,
*:before{
	box-sizing: border-box;
}

/* ----------------------------------------------------------------------------------------------------
  module
* --------------------------------------------------------------------------------------------------*/


.fs50 {
  font-size: 5rem !important; }

.fs49 {
  font-size: 4.9rem !important; }

.fs48 {
  font-size: 4.8rem !important; }

.fs47 {
  font-size: 4.7rem !important; }

.fs46 {
  font-size: 4.6rem !important; }

.fs45 {
  font-size: 4.5rem !important; }

.fs44 {
  font-size: 4.4rem !important; }

.fs43 {
  font-size: 4.3rem !important; }

.fs42 {
  font-size: 4.2rem !important; }

.fs41 {
  font-size: 4.1rem !important; }

.fs40 {
  font-size: 4rem !important; }

.fs39 {
  font-size: 3.9rem !important; }

.fs38 {
  font-size: 3.8rem !important; }

.fs37 {
  font-size: 3.7rem !important; }

.fs36 {
  font-size: 3.6rem !important; }

.fs35 {
  font-size: 3.5rem !important; }

.fs34 {
  font-size: 3.4rem !important; }

.fs33 {
  font-size: 3.3rem !important; }

.fs32 {
  font-size: 3.2rem !important; }

.fs31 {
  font-size: 3.1rem !important; }

.fs30 {
  font-size: 3rem !important; }

.fs29 {
  font-size: 2.9rem !important; }

.fs28 {
  font-size: 2.8rem !important; }

.fs27 {
  font-size: 2.7rem !important; }

.fs26 {
  font-size: 2.6rem !important; }

.fs25 {
  font-size: 2.5rem !important; }

.fs24 {
  font-size: 2.4rem !important; }

.fs23 {
  font-size: 2.3rem !important; }

.fs22 {
  font-size: 2.2rem !important; }

.fs21 {
  font-size: 2.1rem !important; }

.fs20 {
  font-size: 2rem !important; }

.fs19 {
  font-size: 1.9rem !important; }

.fs18 {
  font-size: 1.8rem !important; }

.fs17 {
  font-size: 1.7rem !important; }

.fs16 {
  font-size: 1.6rem !important; }

.fs15 {
  font-size: 1.5rem !important; }

.fs14 {
  font-size: 1.4rem !important; }

.fs13 {
  font-size: 1.3rem !important; }

.fs12 {
  font-size: 1.2rem !important; }

.fs11 {
  font-size: 1.1rem !important; }

.fs10 {
  font-size: 1rem !important; }

.fs9 {
  font-size: 0.9rem !important; }

.fs8 {
  font-size: 0.8rem !important; }

.fs7 {
  font-size: 0.7rem !important; }

.fs6 {
  font-size: 0.6rem !important; }


@media all and (min-width: 1580px){

.pcfs50 {
  font-size: 5rem !important; }

.pcfs49 {
  font-size: 4.9rem !important; }

.pcfs48 {
  font-size: 4.8rem !important; }

.pcfs47 {
  font-size: 4.7rem !important; }

.pcfs46 {
  font-size: 4.6rem !important; }

.pcfs45 {
  font-size: 4.5rem !important; }

.pcfs44 {
  font-size: 4.4rem !important; }

.pcfs43 {
  font-size: 4.3rem !important; }

.pcfs42 {
  font-size: 4.2rem !important; }

.pcfs41 {
  font-size: 4.1rem !important; }

.pcfs40 {
  font-size: 4rem !important; }

.pcfs39 {
  font-size: 3.9rem !important; }

.pcfs38 {
  font-size: 3.8rem !important; }

.pcfs37 {
  font-size: 3.7rem !important; }

.pcfs36 {
  font-size: 3.6rem !important; }

.pcfs35 {
  font-size: 3.5rem !important; }

.pcfs34 {
  font-size: 3.4rem !important; }

.pcfs33 {
  font-size: 3.3rem !important; }

.pcfs32 {
  font-size: 3.2rem !important; }

.pcfs31 {
  font-size: 3.1rem !important; }

.pcfs30 {
  font-size: 3rem !important; }

.pcfs29 {
  font-size: 2.9rem !important; }

.pcfs28 {
  font-size: 2.8rem !important; }

.pcfs27 {
  font-size: 2.7rem !important; }

.pcfs26 {
  font-size: 2.6rem !important; }

.pcfs25 {
  font-size: 2.5rem !important; }

.pcfs24 {
  font-size: 2.4rem !important; }

.pcfs23 {
  font-size: 2.3rem !important; }

.pcfs22 {
  font-size: 2.2rem !important; }

.pcfs21 {
  font-size: 2.1rem !important; }

.pcfs20 {
  font-size: 2rem !important; }

.pcfs19 {
  font-size: 1.9rem !important; }

.pcfs18 {
  font-size: 1.8rem !important; }

.pcfs17 {
  font-size: 1.7rem !important; }

.pcfs16 {
  font-size: 1.6rem !important; }

.pcfs15 {
  font-size: 1.5rem !important; }

.pcfs14 {
  font-size: 1.4rem !important; }

.pcfs13 {
  font-size: 1.3rem !important; }

.pcfs12 {
  font-size: 1.2rem !important; }

.pcfs11 {
  font-size: 1.1rem !important; }

.pcfs10 {
  font-size: 1rem !important; }

.pcfs9 {
  font-size: 0.9rem !important; }

.pcfs8 {
  font-size: 0.8rem !important; }

.pcfs7 {
  font-size: 0.7rem !important; }

.pcfs6 {
  font-size: 0.6rem !important; }
}

@media only screen and (min-width: 769px) and (max-width: 1579px){
	
.mfs50 {
	font-size: 3.165vw !important;
}
.mfs49 {
	font-size: 3.101vw !important;
}
.mfs48 {
	font-size: 3.038vw !important;
}
.mfs47 {
	font-size: 2.975vw !important;
}
.mfs46 {
	font-size: 2.911vw !important;
}
.mfs45 {
	font-size: 2.848vw !important;
}
.mfs44 {
	font-size: 2.785vw !important;
}
.mfs43 {
	font-size: 2.722vw !important;
}
.mfs42 {
	font-size: 2.658vw !important;
}
.mfs41 {
	font-size: 2.595vw !important;
}
.mfs40 {
	font-size: 2.532vw !important;
}
.mfs39 {
	font-size: 2.468vw !important;
}
.mfs38 {
	font-size: 2.405vw !important;
}
.mfs37 {
	font-size: 2.342vw !important;
}
.mfs36 {
	font-size: 2.278vw !important;
}
.mfs35 {
	font-size: 2.215vw !important;
}
.mfs34 {
	font-size: 2.152vw !important;
}
.mfs33 {
	font-size: 2.089vw !important;
}
.mfs32 {
	font-size: 2.025vw !important;
}
.mfs31 {
	font-size: 1.962vw !important;
}
.mfs30 {
	font-size: 1.899vw !important;
}
.mfs29 {
	font-size: 1.835vw !important;
}
.mfs28 {
	font-size: 1.772vw !important;
}
.mfs27 {
	font-size: 1.709vw !important;
}
.mfs26 {
	font-size: 1.646vw !important;
}
.mfs25 {
	font-size: 1.582vw !important;
}
.mfs24 {
	font-size: 1.519vw !important;
}
.mfs23 {
	font-size: 1.456vw !important;
}
.mfs22 {
	font-size: 1.392vw !important;
}
.mfs21 {
	font-size: 1.329vw !important;
}
.mfs20 {
	font-size: 1.266vw !important;
}
.mfs19 {
	font-size: 1.203vw !important;
}
.mfs18 {
	font-size: 1.139vw !important;
}
.mfs17 {
	font-size: 1.076vw !important;
}
.mfs16 {
	font-size: 1.013vw !important;
}
.mfs15 {
	font-size: 0.949vw !important;
}
.mfs14 {
	font-size: 0.886vw !important;
}
.mfs13 {
	font-size: 0.823vw !important;
}
.mfs12 {
	font-size: 0.759vw !important;
}
.mfs11 {
	font-size: 0.696vw !important;
}
.mfs10 {
	font-size: 0.633vw !important;
}
.mfs9 {
	font-size: 0.570vw !important;
}
.mfs8 {
	font-size: 0.506vw !important;
}
.mfs7 {
	font-size: 0.443vw !important;
}
.mfs6 {
	font-size: 0.380vw !important;
}
.mfs5 {
	font-size: 0.316vw !important;
}
.mfs4 {
	font-size: 0.253vw !important;
}
.mfs3 {
	font-size: 0.190vw !important;
}
.mfs2 {
	font-size: 0.127vw !important;
}
.mfs1 {
	font-size: 0.063vw !important;
}
.mfs0 {
	font-size: 0.000vw !important;
}
	
}

@media screen and (max-width: 768px) {
  .spfs50 {
    font-size: 6.6666666667vw !important; }

  .spfs49 {
    font-size: 6.5333333333vw !important; }

  .spfs48 {
    font-size: 6.4vw !important; }

  .spfs47 {
    font-size: 6.2666666667vw !important; }

  .spfs46 {
    font-size: 6.1333333333vw !important; }

  .spfs45 {
    font-size: 6vw !important; }

  .spfs44 {
    font-size: 5.8666666667vw !important; }

  .spfs43 {
    font-size: 5.7333333333vw !important; }

  .spfs42 {
    font-size: 5.6vw !important; }

  .spfs41 {
    font-size: 5.4666666667vw !important; }

  .spfs40 {
    font-size: 5.3333333333vw !important; }

  .spfs39 {
    font-size: 5.2vw !important; }

  .spfs38 {
    font-size: 5.0666666667vw !important; }

  .spfs37 {
    font-size: 4.9333333333vw !important; }

  .spfs36 {
    font-size: 4.8vw !important; }

  .spfs35 {
    font-size: 4.6666666667vw !important; }

  .spfs34 {
    font-size: 4.5333333333vw !important; }

  .spfs33 {
    font-size: 4.4vw !important; }

  .spfs32 {
    font-size: 4.2666666667vw !important; }

  .spfs31 {
    font-size: 4.1333333333vw !important; }

  .spfs30 {
    font-size: 4vw !important; }

  .spfs29 {
    font-size: 3.8666666667vw !important; }

  .spfs28 {
    font-size: 3.7333333333vw !important; }

  .spfs27 {
    font-size: 3.6vw !important; }

  .spfs26 {
    font-size: 3.4666666667vw !important; }

  .spfs25 {
    font-size: 3.3333333333vw !important; }

  .spfs24 {
    font-size: 3.2vw !important; }

  .spfs23 {
    font-size: 3.0666666667vw !important; }

  .spfs22 {
    font-size: 2.9333333333vw !important; }

  .spfs21 {
    font-size: 2.8vw !important; }

  .spfs20 {
    font-size: 2.6666666667vw !important; }

  .spfs19 {
    font-size: 2.5333333333vw !important; }

  .spfs18 {
    font-size: 2.4vw !important; }

  .spfs17 {
    font-size: 2.2666666667vw !important; }

  .spfs16 {
    font-size: 2.1333333333vw !important; }

  .spfs15 {
    font-size: 2vw !important; }

  .spfs14 {
    font-size: 1.8666666667vw !important; }

  .spfs13 {
    font-size: 1.7333333333vw !important; }

  .spfs12 {
    font-size: 1.6vw !important; }

  .spfs11 {
    font-size: 1.4666666667vw !important; }

  .spfs10 {
    font-size: 1.3333333333vw !important; }

  .spfs9 {
    font-size: 1.2vw !important; }

  .spfs8 {
    font-size: 1.0666666667vw !important; }

  .spfs7 {
    font-size: 0.9333333333vw !important; }

  .spfs6 {
    font-size: 0.8vw !important; } }



/* ----------------------------------------------------------------------------------------------------
  layout
* --------------------------------------------------------------------------------------------------*/
.l-header{ 
    padding: 0 3.9vw;
    height: 16.14vw;
    position:relative;
    background-color:#fff;
    
    max-width: 1580px;
}
.l-footer{
    padding-top: 8vw;
    position: relative;
}
.l-wrapper{
    max-width: 1580px;
}
@media only screen and (min-width: 769px) {
    .l-header{ 
        margin: 0 auto;
        padding:0;
        height: 52px;
    }
    .l-footer{
        padding-top: 30px;
    }
    .l-wrapper{
        margin: 0 auto;
    }
}

/* ----------------------------------------------------------------------------------------------------
  module
* --------------------------------------------------------------------------------------------------*/
.m-content{
    padding: 0 3.9vw;
}

@media only screen and (min-width: 769px) {
    .m-content{
        padding: 0 6.32vw;
    }
}
@media only screen and (min-width: 1580px) {
    .m-content{
        padding: 0 100px;
    }
}


/* ----------------------------------------------------------------------------------------------------
  header
* --------------------------------------------------------------------------------------------------*/
.l-header-logo{
    width: 29.94vw;
    position: absolute;
    top: 3.38vw;
}
.l-header-butEntry{
    display: block;
    background-color: #be0000;
    width: 26.82vw;
    height: 16.14vw;
    position: absolute;
    right: 16.14vw;
    color: #fff;
    text-decoration: none;
    text-align: center;
    font-size: 4.53vw;
    font-weight: bold;
    line-height: 16.14vw;
}
.l-header-navbutton{
    height: 16.14vw;
    width: 16.14vw;
    position: absolute;
    right: 0;
    text-align: center;
}
.is-nav-open{
    margin-top: 4.9vw;
    width: 7.8vw;
    cursor: pointer;
}

@media only screen and (min-width: 769px) {
    .l-header-logo{
        width: 120px;
        top: 6px;
        left: 16px;
    }
    .l-header-butEntry{
        width: 150px;
        height:52px;
        right: 68px;
        font-size: 1.8rem;
        line-height: 52px;
    }
    .l-header-navbutton{
        height: 52px;
        width: 68px;
    }
    .is-nav-open{
        margin-top: 12px;
        width: 40px;
    }
    .l-header-txt{
        position: absolute;
        left: 160px;
        top:12px;
        font-size: 2rem;
    }
}


/* ----------------------------------------------------------------------------------------------------
  navigation
* --------------------------------------------------------------------------------------------------*/
.l-header-navigation{
    display: none;
    background-color: rgba(255,255,255,0.9);
    position: absolute;
    top:16.14vw;
    right:0;
    height: 100vh;
    width: 100%;
    max-width: 768px;
}
.l-header-navigation > div{
    padding: 0 4vw;
}
.l-header-navigation-ul{
    font-size: 5.06vw;
    font-weight:bold;
    margin-bottom: 11.2vw;
    list-style: none;
}
.l-header-navigation-ul li{
    border-bottom: 2px solid #be0000;
    padding: 0.7em 0.5em 0.5em;
}
.l-header-navigation-ul a:link,
.l-header-navigation-ul a:visited{
    color: #000;
    text-decoration: none;
    display: block;
}
.l-header-navigation-entry{
    display: block;
    line-height: 1.6;
    background-color: #be0000;
    font-size: 9.73vw;
    font-weight: bold;
    color: #fff;
    text-align: center;
}
a.l-header-navigation-entry:link,
a.l-header-navigation-entry:visited{
    text-decoration: none;
}

@media only screen and (min-width: 769px) {
    .l-header-navigation{
        top:52px;
        right:0;
        height:auto;
        padding-bottom: 40px;
    }
    .l-header-navigation > div{
        padding: 0 30px;
    }
    .l-header-navigation-ul{
        font-size: 2.4rem;
        margin-bottom: 40px;
    }
    .l-header-navigation-entry{
        line-height: 1.6;
        font-size: 4.6rem;
    }
}


/* ----------------------------------------------------------------------------------------------------
  footer
* --------------------------------------------------------------------------------------------------*/
.l-footer-copy{
    color: #fff;
    text-align: center;
    font-size: 3vw;
    padding: 2em 0;
}
.l-footer-navigation-ul{
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
    border-top: 1px solid #808080;
    list-style: none;
}
.l-footer-navigation-ul li{
    display: block;
    width: 50%;
    border-bottom: 1px solid #808080;
    font-size: 4vw;
    line-height: 1.2;
}
.l-footer-navigation-ul li a{
    width: 100%;
    height: 17.33vw;
    display: flex;
    align-items: center;
    justify-content: center;
    text-align: center;
    color: #fff;
    text-decoration: none;
}
.l-footer-navigation-ul li:nth-child(odd) a{
    border-right: 1px solid #808080;
}
.l-footer-sns-ul {
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
    width: 41.66vw;
    margin: 0 auto 8vw;
    list-style: none;
}
.l-footer-sns-ul li{
    width: 10.67vw;
}
.but-pagetop{
    width: 15vw;
    position: absolute;
    top: -7.5vw;
    right: 3.9vw;
    cursor: pointer;
}
@media only screen and (min-width: 769px) {
    .l-footer-copy{
        text-align: center;
        font-size: 1rem;
        padding: 2em 0;
    }
    .l-footer-navigation-ul{
        display:block;
        border-top: none;
        list-style: none;
        
        text-align: center;
    }
    .l-footer-navigation-ul li{
        display:inline-block;
        width:auto;
        border-bottom: none;
        font-size: 1.2rem;
        
        border-left: 1px solid #808080;
    }
    .l-footer-navigation-ul li a{
        width: 100%;
        height:auto;
        display:inline;
        padding: 0 1em;
    }
    .l-footer-navigation-ul li:nth-child(odd) a{
        border-right: none;
    }
    .l-footer-navigation-ul li:first-child {
        border-left: none;
    }
    .l-footer-navigation-ul li:last-child {
        display: none;
    }
    .l-footer-sns-ul {
        width: 156px;
        margin: 0 auto 30px;
        list-style: none;
    }
    .l-footer-sns-ul li{
        width: 40px;
    }
    .but-pagetop{
        width: 70px;
        top: 44px;
        right: 54px;
    }
}


/* ----------------------------------------------------------------------------------------------------

* --------------------------------------------------------------------------------------------------*/
.is-fadein {
  opacity: 0;
  transform : translate(0, 60px);
  /*transition : all 1000ms;*/
	transition : opacity 1000ms,transform 1000ms;
}

.w100{width: 100%;}
.sp-only{display: block;}
.pc-only{display: none;}
.sp-br{display: inline-block;}
.pc-br{display: none;}
.txtCenter{text-align: center}

.bold{
  font-family: "游ゴシック体", YuGothic, "游ゴシック", "Yu Gothic", sans-serif;
  font-weight: bold;
}

@media only screen and (min-width: 769px) {
    .sp-only{display: none;}
    .pc-only{display: block;}
    .sp-br{display: none;}
    .pc-br{display: inline-block;}
}

.clearfix:before,
.clearfix:after {
    content: " "; /* 1 */
    display: table; /* 2 */
}

.clearfix:after {
    clear: both;
}

