@charset "UTF-8";
.tal {
  text-align: left
}

.tar {
  text-align: right
}

.tac {
  text-align: center
}

.fontXS {
  font-size: 9.888px;
  display: inline-block
}

.fontS {
  font-size: 12.8px;
  display: inline-block
}

.fontL {
  font-size: 25.888px;
  display: inline-block
}

.fontXL {
  font-size: 41.888px;
  display: inline-block
}

.fwb {
  font-weight: bold
}

.fwn {
  font-weight: normal
}

.col01 {
  color: #25A8D2
}

.col02 {
  color: #014F66
}

.col03 {
  color: #60E417
}

.col04 {
  color: #D62E03
}

.col05 {
  color: #dddddd
}

.col06 {
  color: #373737
}

.col07 {
  color: #D62E03
}

.col08 {
  color: #D62E03
}

.col09 {
  color: #D62E03
}

.blk {
  color: #373737
}

.red {
  color: #D62E03
}

.wht {
  color: #ffffff
}

.fontMin {
  font-family: "游明朝", YuMincho, "Hiragino Mincho ProN", "ヒラギノ明朝 ProN", "ヒラギノ明朝 ProN W3", "Hiragino Mincho Pro", "ヒラギノ明朝 Pro W3", "HiraMinProN-W3", "HGS明朝E", "HG明朝E", "メイリオ", Meiryo, serif
}

.fontSel {
  font-family: "Volkhov", "Bree Serif", "EB Garamond", "游明朝", YuMincho, "Hiragino Mincho ProN", "ヒラギノ明朝 ProN", "ヒラギノ明朝 ProN W3", "Hiragino Mincho Pro", "ヒラギノ明朝 Pro W3", "HiraMinProN-W3", "HGS明朝E", "HG明朝E", "メイリオ", Meiryo, serif
}

.fontGot {
  font-family: "Yantramanav"
}

.fontIta {
  font-style: italic
}

.photo {
  padding: 3px;
  -moz-box-shadow: 0px 2px 2px 0px rgba(0, 0, 0, 0.3);
  -webkit-box-shadow: 0px 2px 2px 0px rgba(0, 0, 0, 0.3);
  -ms-box-shadow: 0px 2px 2px 0px rgba(0, 0, 0, 0.3);
  box-shadow: 0px 2px 2px 0px rgba(0, 0, 0, 0.3)
}

.mgb0 {
  margin-bottom: 0
}

.mgt0 {
  margin-top: 0
}

.mgv0 {
  margin-bottom: 0;
  margin-top: 0
}

.mgl0 {
  margin-left: 0
}

.mgr0 {
  margin-right: 0
}

.mgb5 {
  margin-bottom: 5px
}

.mgt5 {
  margin-top: 5px
}

.mgl5 {
  margin-left: 5px
}

.mgr5 {
  margin-right: 5px
}

.mgv5 {
  margin-top: 5px;
  margin-bottom: 5px
}

.mgb10 {
  margin-bottom: 10px
}

.mgt10 {
  margin-top: 10px
}

.mgl10 {
  margin-left: 10px
}

.mgr10 {
  margin-right: 10px
}

.mgv10 {
  margin-top: 10px;
  margin-bottom: 10px
}

.mgb15 {
  margin-bottom: 15px
}

.mgt15 {
  margin-top: 15px
}

.mgl15 {
  margin-left: 15px
}

.mgr15 {
  margin-right: 15px
}

.mgv15 {
  margin-top: 15px;
  margin-bottom: 15px
}

.mgb20 {
  margin-bottom: 20px
}

.mgt20 {
  margin-top: 20px
}

.mgl20 {
  margin-left: 20px
}

.mgr20 {
  margin-right: 20px
}

.mgv20 {
  margin-top: 20px;
  margin-bottom: 20px
}

.mgb25 {
  margin-bottom: 25px
}

.mgt25 {
  margin-top: 25px
}

.mgl25 {
  margin-left: 25px
}

.mgr25 {
  margin-right: 25px
}

.mgv25 {
  margin-top: 25px;
  margin-bottom: 25px
}

.mgb30 {
  margin-bottom: 30px
}

.mgt30 {
  margin-top: 30px
}

.mgl30 {
  margin-left: 30px
}

.mgr30 {
  margin-right: 30px
}

.mgv30 {
  margin-top: 30px;
  margin-bottom: 30px
}

.mgb35 {
  margin-bottom: 35px
}

.mgt35 {
  margin-top: 35px
}

.mgl35 {
  margin-left: 35px
}

.mgr35 {
  margin-right: 35px
}

.mgv35 {
  margin-top: 35px;
  margin-bottom: 35px
}

.mgb40 {
  margin-bottom: 40px
}

.mgt40 {
  margin-top: 40px
}

.mgl40 {
  margin-left: 40px
}

.mgr40 {
  margin-right: 40px
}

.mgv40 {
  margin-top: 40px;
  margin-bottom: 40px
}

.mgb45 {
  margin-bottom: 45px
}

.mgt45 {
  margin-top: 45px
}

.mgl45 {
  margin-left: 45px
}

.mgr45 {
  margin-right: 45px
}

.mgv45 {
  margin-top: 45px;
  margin-bottom: 45px
}

.mgb50 {
  margin-bottom: 50px
}

.mgt50 {
  margin-top: 50px
}

.mgl50 {
  margin-left: 50px
}

.mgr50 {
  margin-right: 50px
}

.mgv50 {
  margin-top: 50px;
  margin-bottom: 50px
}

.pdb0 {
  padding-bottom: 0
}

.pdt0 {
  padding-top: 0
}

.pdv0 {
  padding-bottom: 0;
  padding-top: 0
}

.pdl0 {
  padding-left: 0
}

.pdr0 {
  padding-right: 0
}

.pdb5 {
  padding-bottom: 5px
}

.pdt5 {
  padding-top: 5px
}

.pdl5 {
  padding-left: 5px
}

.pdr5 {
  padding-right: 5px
}

.pdv5 {
  padding-top: 5px;
  padding-bottom: 5px
}

.pdb10 {
  padding-bottom: 10px
}

.pdt10 {
  padding-top: 10px
}

.pdl10 {
  padding-left: 10px
}

.pdr10 {
  padding-right: 10px
}

.pdv10 {
  padding-top: 10px;
  padding-bottom: 10px
}

.pdb15 {
  padding-bottom: 15px
}

.pdt15 {
  padding-top: 15px
}

.pdl15 {
  padding-left: 15px
}

.pdr15 {
  padding-right: 15px
}

.pdv15 {
  padding-top: 15px;
  padding-bottom: 15px
}

.pdb20 {
  padding-bottom: 20px
}

.pdt20 {
  padding-top: 20px
}

.pdl20 {
  padding-left: 20px
}

.pdr20 {
  padding-right: 20px
}

.pdv20 {
  padding-top: 20px;
  padding-bottom: 20px
}

.pdb25 {
  padding-bottom: 25px
}

.pdt25 {
  padding-top: 25px
}

.pdl25 {
  padding-left: 25px
}

.pdr25 {
  padding-right: 25px
}

.pdv25 {
  padding-top: 25px;
  padding-bottom: 25px
}

.pdb30 {
  padding-bottom: 30px
}

.pdt30 {
  padding-top: 30px
}

.pdl30 {
  padding-left: 30px
}

.pdr30 {
  padding-right: 30px
}

.pdv30 {
  padding-top: 30px;
  padding-bottom: 30px
}

.pdb35 {
  padding-bottom: 35px
}

.pdt35 {
  padding-top: 35px
}

.pdl35 {
  padding-left: 35px
}

.pdr35 {
  padding-right: 35px
}

.pdv35 {
  padding-top: 35px;
  padding-bottom: 35px
}

.pdb40 {
  padding-bottom: 40px
}

.pdt40 {
  padding-top: 40px
}

.pdl40 {
  padding-left: 40px
}

.pdr40 {
  padding-right: 40px
}

.pdv40 {
  padding-top: 40px;
  padding-bottom: 40px
}

.pdb45 {
  padding-bottom: 45px
}

.pdt45 {
  padding-top: 45px
}

.pdl45 {
  padding-left: 45px
}

.pdr45 {
  padding-right: 45px
}

.pdv45 {
  padding-top: 45px;
  padding-bottom: 45px
}

.pdb50 {
  padding-bottom: 50px
}

.pdt50 {
  padding-top: 50px
}

.pdl50 {
  padding-left: 50px
}

.pdr50 {
  padding-right: 50px
}

.pdv50 {
  padding-top: 50px;
  padding-bottom: 50px
}

bdr-l {
  border-left: 1px solid #eaeaea
}

bdr-r {
  border-right: 1px solid #eaeaea
}

bdr-t {
  border-top: 1px solid #eaeaea
}

bdr-b {
  border-bottom: 1px solid #eaeaea
}

bdr-all {
  border: 1px solid #eaeaea
}

.cf:after {
  content: " ";
  display: block;
  visibility: hidden;
  height: 1%;
  font-size: 0;
  line-height: 0;
  clear: both
}

.cf {
  zoom: 1
}

* html .cf {
  height: 1%
}

@media screen and (min-width:641px) {
  .pc_none {
    display: none
  }
  .sp_none {
    display: block
  }
}

@media screen and (max-width:641px) {
  .pc_none {
    display: block
  }
  .sp_none {
    display: none
  }
}



/*PC*/
@media screen and (min-width: 768px) {
	.pc_hide {
		display : none !important;
	}
	.pc_hide_inline {
		display : none !important;
	}
	.sp_hide_inline {
		display : inline !important;
	}
}

/*SP*/
@media screen and (max-width: 767px) {
	.sp_hide {
		display : none !important;
	}
	.sp_hide_inline {
		display : none !important;
	}
	.pc_hide_inline {
		display : inline !important;
	}
}


a, abbr, acronym, address, applet, article, aside, audio, b, big, blockquote, body, canvas, caption, center, cite, code, dd, del, details, dfn, div, dl, dt, em, embed, fieldset, figcaption, figure, footer, form, h1, h2, h3, h4, h5, h6, header, hgroup, html, i, iframe, img, ins, kbd, l, label, legend, li, mark, menu, nav, object, output, p, pre, q, ruby, s, samp, section, small, span, strike, strong, sub, summary, sup, table, tbody, td, tfoot, th, thead, time, tr, tt, u, ul, var, video {
  margin: 0;
  padding: 0
}

body {
  font-family: "Noto Sans Japanese", "メイリオ", Meiryo, MS PGothic, sans-serif, "ＭＳ Ｐゴシック";
  -webkit-text-size-adjust: 100%;
  font-weight: 300;
  color: #333333;
  font-size: 16px;
  letter-spacing: 1px;
  line-height: 1
}

*, :after, :before {
  -webkit-box-sizing: border-box;
  -moz-box-sizing: border-box;
  -o-box-sizing: border-box;
  -ms-box-sizing: border-box;
  box-sizing: border-box
}

h1, h2, h3, h4, h5, h6 {
  font-size: 100%;
  font-weight: inherit
}

input, select {
  font-family: "Noto Sans Japanese";
  padding: 5px
}

img {
  vertical-align: middle;
  border: none
}

::-moz-selection {
  background: 0
}

::selection {
  background: 0
}

::-moz-selection {
  background: 0
}

li {
  list-style: none
}

a img {
  border: none
}

a {
  outline: 0;
  cursor: pointer;
  text-decoration: none;
  -webkit-transition: all 0.2s ease 0s;
  -o-transition: all 0.2s ease 0s;
  transition: all 0.2s ease 0s;
  color: #3F7DC5
}

a:hover {
  opacity: 0.65;
  filter: alpha(opacity=65);
  text-decoration: none
}

i {
  vertical-align: middle
}

.mainContents .content dd, .mainContents .content dt, .mainContents .content li, .mainContents .content p, .mainContents .content td, .mainContents .content th, .mainContents .content tr {
  line-height: 2
}

.txt {
  line-height: 2
}

@media screen and (min-width:641px) {
  .boxContainerInner {
    padding-top: 45px;
    padding-bottom: 45px;
    width: 960px;
    min-width: 960px;
    margin-left: auto;
    margin-right: auto
  }
  .boxContainerInner:after {
    content: " ";
    display: block;
    visibility: hidden;
    height: 1%;
    font-size: 0;
    line-height: 0;
    clear: both
  }
  .boxContainerInner .left {
    float: left;
    width: 610px
  }
  .boxContainerInner .right {
    float: right;
    width: 305px
  }
  .boxContainerInner .wide {
    width: 100%
  }
  .sideLink {
    margin-top: 20px
  }
  .sideLink li {
    margin-bottom: 5px
  }
  .sideLink a {
    color: #25A8D2;
    font-weight: bold;
    font-size: 14px
  }
}

.sideLinkBnr img {
  width: 100%;
  height: auto
}

@media screen and (max-width:641px) {
  body {
    font-size: 0.85rem
  }
  .boxContainerInner {
    padding-top: 2em;
    padding-bottom: 2em
  }
  p img {
    width: 100%;
    height: auto
  }
  .boxContainerInner {
    width: 90%;
    padding: 0 5%
  }
  .sideLink {
    margin-top: 1em;
    padding-bottom: 10px
  }
  .sideLink li {
    margin-bottom: 0.5em
  }
  .sideLink a {
    color: #25A8D2;
    font-weight: bold;
    font-size: 14px
  }
}

.siteLoader {
  position: fixed;
  right: 0;
  top: 0;
  width: 100%;
  height: 100%;
  background: #25a8d2;
  z-index: 999
}

.siteLoaderInner {
  width: 100px;
  height: 100px;
  text-align: center;
  font-family: "Yantramanav";
  color: #fff;
  display: block;
  font-size: 14px;
  position: absolute;
  left: 47%;
  top: 45%
}

.siteLoaderInner img {
  margin-bottom: 10px
}

@media screen and (max-width:641px) {
  .siteLoader .siteLoaderInner {
    left: 37%
  }
}

.topMainvisualWrap {
  background : url(../images/mv/top_mv_bg.png) repeat-y scroll center center;
  background-size: cover;
  overflow: hidden;
}

.topMainvisual {
  max-width: 1050px;
  margin : 40px auto 20px;
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
}

.topMV  {
  margin-bottom:10px;
}

@media screen and (max-width:641px) {

  .topMV  {
    width: 100vw;
  }
}
.topMV img {
  width: 100%;
}

.topMv1 {
  max-width: 580px;
}
.topMv2 {
  max-width: 460px;
}

.topMv3 {
  max-width: 1050px;
}


#mainvisual {
  text-align: center
}

#mainvisual h2 {
  display: inline-block;
  -webkit-transition: .3s;
  -o-transition: .3s;
  transition: .3s;
  opacity: 0;
  transform: translate(-15px, 0px);
  -webkit-transform: translate(-15px, 0px);
  -ms-transform: translate(-15px, 0px)
}

#mainvisual a, #mainvisual p {
  -webkit-transition: .3s;
  -o-transition: .3s;
  transition: .3s;
  opacity: 0;
  transform: translate(50px, 0px);
  -webkit-transform: translate(50x, 0px);
  -ms-transform: translate(50px, 0px)
}

#mainvisual .mainvisualInner.visibilize h2 {
  opacity: 1.0;
  transform: translate(0, 0);
  -webkit-transform: translate(0, 0);
  -ms-transform: translate(0, 0)
}

#mainvisual .mainvisualInner.visibilize a, #mainvisual .mainvisualInner.visibilize p {
  opacity: 1.0;
  transform: translate(0, 0);
  -webkit-transform: translate(0, 0);
  -ms-transform: translate(0, 0)
}

#mainvisual a, #mainvisual h2, #mainvisual p {
  position: relative;
  z-index: 1
}

#mainvisual .mainvisualInner {
  background-size: cover;
  position: relative;
}

#mainvisual .mainvisualInner:before {
  content: " ";
  display: block;
  height: 100%;
  left: 0;
  position: absolute;
  top: 0;
  width: 100%;
  z-index: 0
}
#mainvisual .mainvisualInner2 img{
  width: 100%;
  position:relative;
  top:50%;
  /* transform: translateY(-50%); */
}

.olypara_bn {
  max-width: 400px;
  margin: 0 auto 40px auto;
}
.olypara_bn img{
  width: 100%;
}

@media screen and (max-width:641px) {
  .olypara_bn {
    max-width: 250px;
    margin:  0px auto;
    padding : 20px 0;
  }
  .olypara_bn img{
    width: 100%;
  }
}



#mainvisual {}

#mainvisual h2 {
  color: #fff;
  background: #25a8d2;
  font-size: 35px;
  font-weight: 900;
  padding: 13px 8px 15px
}

#mainvisual p {
  margin: 20px 0;
  line-height: 2;
  color: #fff
}

#mainvisual a {
  font-weight: bold;
  padding-left: 30px;
  padding-right: 30px
}

#mainvisual .mainvisualInner {
  padding: 100px 0
}

#mainvisual .mainvisualInner:before {
  background: #10202D none repeat scroll 0 0;
  opacity: 0.85
}

#mainvisual .g_btn02 {
  color: #fff;
  border: solid 1px #fff
}

@media screen and (max-width:641px) {
  #mainvisual {
    width: 100%;
    min-width: inherit
  }
  #mainvisual h2, #mainvisual p {
    width: 100%;
    padding-left: 5%;
    padding-right: 5%
  }
  #mainvisual p {}
  #mainvisual p strong {
    text-align: center
  }
  #mainvisual p br {
    display: none
  }
}

.btn01 {
  font-weight: 400;
  font-size: 0.85em;
  padding: 12px 1em 12px;
  display: inline-block;
  -webkit-transition: .3s;
  -o-transition: .3s;
  transition: .3s;
  position: relative;
  color: #25A8D2;
  vertical-align: middle;
  padding-bottom: 0.8em;
  padding-left: 0;
  padding-right: 0
}

.btn01 i {
  -webkit-transition: 0.3s ease;
  -moz-transition: 0.3s ease;
  -ms-transition: 0.3s ease;
  -o-transition: 0.3s ease;
  transition: 0.3s ease;
  position: absolute;
  font-size: 13px;
  vertical-align: middle
}

.btn01:before {
  position: absolute;
  -webkit-transition: .3s;
  -o-transition: .3s;
  transition: .3s;
  content: ''
}

.btn01:after {
  position: absolute;
  -webkit-transition: .3s;
  -o-transition: .3s;
  transition: .3s;
  content: ''
}

.btn01:hover {
  opacity: 1;
  filter: alpha(opacity=100)
}

.btn01:after {
  width: 0;
  left: 50%;
  bottom: 0;
  height: 2px;
  background: #25A8D2;
  right: 0;
  left: auto
}

.btn01:hover:after {
  width: 100%;
  left: 0
}

.btn02 {
  font-weight: 400;
  font-size: 0.85em;
  padding: 12px 1em 12px;
  display: inline-block;
  -webkit-transition: .3s;
  -o-transition: .3s;
  transition: .3s;
  position: relative;
  color: #25A8D2;
  vertical-align: middle;
  background: #014F66;
  color: #fff;
  padding-right: 2.45em
}

.btn02 i {
  -webkit-transition: 0.3s ease;
  -moz-transition: 0.3s ease;
  -ms-transition: 0.3s ease;
  -o-transition: 0.3s ease;
  transition: 0.3s ease;
  position: absolute;
  font-size: 13px;
  vertical-align: middle
}

.btn02:before {
  position: absolute;
  -webkit-transition: .3s;
  -o-transition: .3s;
  transition: .3s;
  content: ''
}

.btn02:after {
  position: absolute;
  -webkit-transition: .3s;
  -o-transition: .3s;
  transition: .3s;
  content: ''
}

.btn02:hover {
  opacity: 1;
  filter: alpha(opacity=100)
}

.btn02 i {
  display: block;
  right: 0.7em;
  top: 12px
}

.btn02:hover {
  background: #012833
}

.btn02:hover i {
  right: 0.4em
}

.btn03 {
  font-weight: 400;
  font-size: 0.85em;
  padding: 12px 1em 12px;
  display: inline-block;
  -webkit-transition: .3s;
  -o-transition: .3s;
  transition: .3s;
  position: relative;
  color: #25A8D2;
  vertical-align: middle;
  padding-right: 2.45em;
  z-index: 2;
  background: #4fd6fd
}

.btn03 i {
  -webkit-transition: 0.3s ease;
  -moz-transition: 0.3s ease;
  -ms-transition: 0.3s ease;
  -o-transition: 0.3s ease;
  transition: 0.3s ease;
  position: absolute;
  font-size: 13px;
  vertical-align: middle
}

.btn03:before {
  position: absolute;
  -webkit-transition: .3s;
  -o-transition: .3s;
  transition: .3s;
  content: ''
}

.btn03:after {
  position: absolute;
  -webkit-transition: .3s;
  -o-transition: .3s;
  transition: .3s;
  content: ''
}

.btn03:hover {
  opacity: 1;
  filter: alpha(opacity=100)
}

.btn03:before {
  z-index: -1;
  width: 0;
  left: 50%;
  bottom: 0;
  height: 100%;
  background: #fff;
  right: 0;
  left: auto
}

.btn03 i {
  display: block;
  right: 0.7em;
  top: 0.95em
}

.btn03:hover {
  opacity: 1;
  filter: alpha(opacity=100)
}

.btn03:hover:before {
  width: 100%;
  left: 0
}

.btn04 {
  font-weight: 400;
  font-size: 0.85em;
  padding: 12px 1em 12px;
  display: inline-block;
  -webkit-transition: .3s;
  -o-transition: .3s;
  transition: .3s;
  position: relative;
  color: #25A8D2;
  vertical-align: middle;
  color: #333333;
  border: 1px solid white;
  padding-right: 1em
}

.btn04 i {
  -webkit-transition: 0.3s ease;
  -moz-transition: 0.3s ease;
  -ms-transition: 0.3s ease;
  -o-transition: 0.3s ease;
  transition: 0.3s ease;
  position: absolute;
  font-size: 13px;
  vertical-align: middle
}

.btn04:before {
  position: absolute;
  -webkit-transition: .3s;
  -o-transition: .3s;
  transition: .3s;
  content: ''
}

.btn04:after {
  position: absolute;
  -webkit-transition: .3s;
  -o-transition: .3s;
  transition: .3s;
  content: ''
}

.btn04:hover {
  opacity: 1;
  filter: alpha(opacity=100)
}

.btn04:before {
  z-index: -1;
  width: 100%;
  left: 0;
  bottom: 0;
  height: 100%;
  background: #ffffff;
  background: -moz-linear-gradient(top, #ffffff 0%, #f2f2f2 100%);
  background: -webkit-linear-gradient(top, #ffffff 0%, #f2f2f2 100%);
  background: -webkit-gradient(linear, left top, left bottom, from(#ffffff), to(#f2f2f2));
  background: -o-linear-gradient(top, #ffffff 0%, #f2f2f2 100%);
  background: linear-gradient(to bottom, #ffffff 0%, #f2f2f2 100%);
  filter: progid:DXImageTransform.Microsoft.gradient( startColorstr='#ffffff', endColorstr='#f2f2f2', GradientType=0)
}

.btn04 i {
  color: #D62E03;
  vertical-align: middle;
  position: inherit;
  margin-right: 0.3em
}

.btn04:hover {
  opacity: 1;
  filter: alpha(opacity=100);
  background: #f2f2f2
}

.btn05 {
  font-weight: 400;
  font-size: 0.85em;
  padding: 12px 1em 12px;
  display: inline-block;
  -webkit-transition: .3s;
  -o-transition: .3s;
  transition: .3s;
  position: relative;
  color: #25A8D2;
  vertical-align: middle;
  font-size: 20px;
  padding: 20px 1.2em 20px;
  font-weight: 300;
  color: #ffffff
}

.btn05 i {
  -webkit-transition: 0.3s ease;
  -moz-transition: 0.3s ease;
  -ms-transition: 0.3s ease;
  -o-transition: 0.3s ease;
  transition: 0.3s ease;
  position: absolute;
  font-size: 13px;
  vertical-align: middle
}

.btn05:before {
  position: absolute;
  -webkit-transition: .3s;
  -o-transition: .3s;
  transition: .3s;
  content: ''
}

.btn05:after {
  position: absolute;
  -webkit-transition: .3s;
  -o-transition: .3s;
  transition: .3s;
  content: ''
}

.btn05:hover {
  opacity: 1;
  filter: alpha(opacity=100)
}

.btn05 i {
  vertical-align: middle;
  font-size: 1.2em;
  margin-right: 0.68em
}

.btn05:before {
  z-index: -1;
  width: 100%;
  left: 0;
  bottom: 0;
  height: 100%;
  background: #014F66;
  background: -moz-linear-gradient(top, #014F66 0%, #00141a 100%);
  background: -webkit-gradient(linear, left top, left bottom, color-stop(0%, #014F66), color-stop(100%, #00141a));
  background: -webkit-linear-gradient(top, #014F66 0%, #00141a 100%);
  background: -o-linear-gradient(top, #014F66 0%, #00141a 100%);
  background: -ms-linear-gradient(top, #014F66 0%, #00141a 100%);
  background: -webkit-gradient(linear, left top, left bottom, from(#014F66), to(#00141a));
  background: linear-gradient(to bottom, #014F66 0%, #00141a 100%);
  filter: progid:DXImageTransform.Microsoft.gradient( startColorstr='$start-color', endColorstr='$end-color', GradientType=0)
}

.btn05 i {
  color: #ffffff;
  font-size: 93%;
  font-size: 20px;
  position: inherit
}

.btn05:hover {
  opacity: 1;
  filter: alpha(opacity=100);
  background: #00141a
}

.g_btn01 {
  font-weight: 400;
  font-size: 0.85em;
  padding: 12px 1em 12px;
  display: inline-block;
  -webkit-transition: .3s;
  -o-transition: .3s;
  transition: .3s;
  position: relative;
  color: #25A8D2;
  vertical-align: middle;
  padding-right: 2.45em;
  color: #014F66;
  border: solid 1px #014F66;
  brackground-color: transparent;
  position: relative
}

.g_btn01 i {
  -webkit-transition: 0.3s ease;
  -moz-transition: 0.3s ease;
  -ms-transition: 0.3s ease;
  -o-transition: 0.3s ease;
  transition: 0.3s ease;
  position: absolute;
  font-size: 13px;
  vertical-align: middle
}

.g_btn01:before {
  position: absolute;
  -webkit-transition: .3s;
  -o-transition: .3s;
  transition: .3s;
  content: ''
}

.g_btn01:after {
  position: absolute;
  -webkit-transition: .3s;
  -o-transition: .3s;
  transition: .3s;
  content: ''
}

.g_btn01:hover {
  opacity: 1;
  filter: alpha(opacity=100)
}

.g_btn01 i {
  display: block;
  right: 0.7em;
  top: 12px
}

.g_btn01:hover {
  background: #4fd6fd;
  opacity: 1;
  filter: alpha(opacity=100)
}

.g_btn01:hover i {
  right: 0.4em
}

.g_btn02 {
  font-weight: 400;
  font-size: 0.85em;
  padding: 12px 1em 12px;
  display: inline-block;
  -webkit-transition: .3s;
  -o-transition: .3s;
  transition: .3s;
  position: relative;
  color: #25A8D2;
  vertical-align: middle;
  color: #014F66;
  border: solid 1px #014F66;
  brackground-color: transparent;
  background-size: 200% 100%;
  background-image: -webkit-gradient(linear, left top, right top, color-stop(50%, transparent), color-stop(50%, #014f66));
  background-image: -webkit-linear-gradient(left, transparent 50%, #014f66 50%);
  background-image: -o-linear-gradient(left, transparent 50%, #014f66 50%);
  background-image: linear-gradient(to right, transparent 50%, #014f66 50%);
  -webkit-transition: background-position 0.3s cubic-bezier(0.19, 1, 0.22, 1) 0.1s, color 0.5s ease 0s, background-color 0.5s ease;
  -o-transition: background-position 0.3s cubic-bezier(0.19, 1, 0.22, 1) 0.1s, color 0.5s ease 0s, background-color 0.5s ease;
  transition: background-position 0.3s cubic-bezier(0.19, 1, 0.22, 1) 0.1s, color 0.5s ease 0s, background-color 0.5s ease
}

.g_btn02 i {
  -webkit-transition: 0.3s ease;
  -moz-transition: 0.3s ease;
  -ms-transition: 0.3s ease;
  -o-transition: 0.3s ease;
  transition: 0.3s ease;
  position: absolute;
  font-size: 13px;
  vertical-align: middle
}

.g_btn02:before {
  position: absolute;
  -webkit-transition: .3s;
  -o-transition: .3s;
  transition: .3s;
  content: ''
}

.g_btn02:after {
  position: absolute;
  -webkit-transition: .3s;
  -o-transition: .3s;
  transition: .3s;
  content: ''
}

.g_btn02:hover {
  opacity: 1;
  filter: alpha(opacity=100)
}

.g_btn02:hover {
  color: white;
  background-color: #014f66;
  background-position: -100% 100%;
  border-color: #014F66;
  opacity: 1;
  filter: alpha(opacity=100)
}

.r_btn01 {
  font-weight: 400;
  font-size: 0.85em;
  padding: 12px 1em 12px;
  display: inline-block;
  -webkit-transition: .3s;
  -o-transition: .3s;
  transition: .3s;
  position: relative;
  color: #25A8D2;
  vertical-align: middle;
  color: #014F66;
  border: solid 2px #014F66;
  padding-left: 2em;
  padding-right: 2em;
  -moz-border-radius: 50px;
  -webkit-border-radius: 50px;
  border-radius: 50px;
  brackground-color: transparent
}

.r_btn01 i {
  -webkit-transition: 0.3s ease;
  -moz-transition: 0.3s ease;
  -ms-transition: 0.3s ease;
  -o-transition: 0.3s ease;
  transition: 0.3s ease;
  position: absolute;
  font-size: 13px;
  vertical-align: middle
}

.r_btn01:before {
  position: absolute;
  -webkit-transition: .3s;
  -o-transition: .3s;
  transition: .3s;
  content: ''
}

.r_btn01:after {
  position: absolute;
  -webkit-transition: .3s;
  -o-transition: .3s;
  transition: .3s;
  content: ''
}

.r_btn01:hover {
  opacity: 1;
  filter: alpha(opacity=100)
}

.r_btn01:hover {
  background: #014F66;
  color: #fff;
  opacity: 1;
  filter: alpha(opacity=100)
}

.r_btn02 {
  font-weight: 400;
  font-size: 0.85em;
  padding: 12px 1em 12px;
  display: inline-block;
  -webkit-transition: .3s;
  -o-transition: .3s;
  transition: .3s;
  position: relative;
  color: #25A8D2;
  vertical-align: middle;
  color: #014F66;
  border: solid 2px #014F66;
  padding-left: 2em;
  padding-right: 3em;
  -moz-border-radius: 50px;
  -webkit-border-radius: 50px;
  border-radius: 50px;
  brackground-color: transparent
}

.r_btn02 i {
  -webkit-transition: 0.3s ease;
  -moz-transition: 0.3s ease;
  -ms-transition: 0.3s ease;
  -o-transition: 0.3s ease;
  transition: 0.3s ease;
  position: absolute;
  font-size: 13px;
  vertical-align: middle
}

.r_btn02:before {
  position: absolute;
  -webkit-transition: .3s;
  -o-transition: .3s;
  transition: .3s;
  content: ''
}

.r_btn02:after {
  position: absolute;
  -webkit-transition: .3s;
  -o-transition: .3s;
  transition: .3s;
  content: ''
}

.r_btn02:hover {
  opacity: 1;
  filter: alpha(opacity=100)
}

.r_btn02 i {
  top: 12px;
  right: 1em
}

.r_btn02:hover {
  background: #014F66;
  color: #fff;
  opacity: 1;
  filter: alpha(opacity=100)
}

.r_btn02:hover i {
  right: 0.7em
}

.simpleTtl {
  text-align: center;
  padding-bottom: 30px;
  padding-top: 50px
}

.simpleTtl span {
  display: block;
  color: #25A8D2;
  font-size: 16px;
  margin-right: 10px;
  vertical-align: sub;
  font-weight: bold;
  margin-bottom: 10px
}

.simpleTtl p {
  font-size: 31px;
  font-weight: bold;
  color: #43768B;
  line-height: 1.85
}

.title {
  margin-bottom: 10px
}

.title span {
  font-family: "Yantramanav";
  font-weight: 900;
  letter-spacing: -0.03em
}

.title.ttl01 {
  font-size: 14px
}

.title.ttl01 span {
  color: #25A8D2;
  font-size: 23px;
  margin-right: 10px;
  vertical-align: sub
}

.title.ttl01 span.eng {
  font-size: 33px
}

.title.ttl02 {
  text-align: center;
  font-weight: bold
}

.title.ttl02 span {
  color: #25A8D2;
  font-size: 45px;
  display: block;
  margin-bottom: 10px
}

.title.ttl03 {
  text-align: center;
  font-weight: bold
}

.title.ttl03 span {
  color: #25A8D2;
  font-size: 28px;
  display: block;
  margin-bottom: 20px
}

.title.ttl04 {
  text-align: center;
  font-weight: bold;
  color: #333;
  font-size: 20px;
  letter-spacing: -0.02em;
  font-weight: bold;
  padding-top: 35px
}

.title.ttl04 a {
  color: #333;
  font-size: 20px
}

.title.ttl04 span {
  color: #25A8D2;
  font-size: 18px;
  display: block;
  padding-bottom: 10px;
  padding-top: 10px
}

.ttl05 {
  font-size: 24px;
  font-weight: bold;
  color: #43768B;
  line-height: 1.85
}

@media screen and (max-width:641px) {
  .title {
    margin-bottom: 1.5em;
    padding-top: 2em
  }
  .title.ttl01 {
    font-size: 12px
  }
  .title.ttl01 span {
    display: block;
    margin: 0;
    font-size: 25px
  }
  .ttl05 {
    margin-bottom: 0.5em;
    line-height: 1.3
  }
  .searchResult .lede02 {
    font-size: 100%;
    padding-left: 10px
  }
  .searchResult .resultItem.table {
    margin-bottom: 2em
  }
}

.lineUp2 .lineUpItem {
  float: left;
  width: 48%;
  margin-right: 4%
}

.lineUp2 .lineUpItem:nth-child(2n) {
  margin-right: 0
}

.lineUp2:after {
  content: " ";
  display: block;
  visibility: hidden;
  height: 1%;
  font-size: 0;
  line-height: 0;
  clear: both
}

.lineUp3 .lineUpItem {
  float: left;
  width: 31.33%;
  margin-right: 3%
}

.lineUp3 .lineUpItem:nth-child(3n) {
  margin-right: 0
}

.lineUp3:after {
  content: " ";
  display: block;
  visibility: hidden;
  height: 1%;
  font-size: 0;
  line-height: 0;
  clear: both
}

.lineUp3.lineUpFlex {
	display:flex;
	float : none;
	flex-wrap : wrap;
	align-items: stretch;
}


.lineUp3.lineUpFlex .lineUpItem {
  width: 31.33%;
  margin-right: 3%
}

.lineUp3.lineUpFlex .lineUpItem:nth-child(3n) {
  margin-right: 0
}




.lineUp4 .lineUpItem {
  float: left;
  width: 23.5%;
  margin-right: 2%
}

.lineUp4 .lineUpItem:nth-child(4n) {
  margin-right: 0
}

.lineUp4:after {
  content: " ";
  display: block;
  visibility: hidden;
  height: 1%;
  font-size: 0;
  line-height: 0;
  clear: both
}

.lineUp5 .lineUpItem {
  float: left;
  width: 20%
}

.lineUp5:after {
  content: " ";
  display: block;
  visibility: hidden;
  height: 1%;
  font-size: 0;
  line-height: 0;
  clear: both
}

@media screen and (max-width:641px) {
  .lineUp3 {
    padding-bottom: 1em
  }
  .lineUp3 .lineUpItem,
  .lineUp3.lineUpFlex .lineUpItem {
    margin-right: 0;
    margin-bottom: 1em;
    float: none;
    width: 100%;
    background: #fff;
    text-align: left
  }
  .lineUp3 .lineUpItem a {
    display: block;
    line-height: 1
  }
  .lineUp3 .lineUpItem h3 {
    font-size: 120%;
    text-align: left;
    margin-bottom: 0;
    padding: 0;
    padding-top: 1.5em
  }
  .lineUp3 .lineUpItem h3 span {
    padding: 0.5em 0 0.3em;
    font-size: inherit
  }
  .lineUp3 .lineUpItem img {
    width: 30%;
    float: left;
    margin-right: 10px
  }
  .lineUp3 .lineUpItem p {
    color: #333;
    font-size: 14px;
    letter-spacing: -0.03em
  }
  .lineUp3 .lineUpItem:after {
    content: " ";
    display: block;
    visibility: hidden;
    height: 1%;
    font-size: 0;
    line-height: 0;
    clear: both
  }
  .lineUp3 .lineUpItem img:first-child {
  	display:none;
  }
  
}

.copyright {
  background: #25A8D2;
  color: #fff;
  text-align: center;
  font-size: 11px;
  padding: 20px 0;
  margin-top: 20px
}

.footerNav li a {
  color: #25A8D2;
  font-size: 14px
}

.footerInfo {
  font-size: 12px;
  line-height: 2;
  letter-spacing: -0.01em;
  color: #848484
}

.footerInfo strong {
  font-weight: bold;
  display: block;
  font-size: 16px;
  color: #373737;
  margin-bottom: 5px
}

@media screen and (min-width:641px) {
  .copyright {
    min-width: 960px
  }
  .footerInfo {
    width: 960px;
    margin: auto;
    font-size: 12px
  }
  .footerInfo a {
    float: left;
    margin-right: 20px
  }
  .footerNav {
    border-bottom: 1px solid #E6E6E6;
    padding-bottom: 20px;
    margin-bottom: 20px;
    margin-top: 30px
  }
  .footerNav ul {
    -webkit-box-sizing: border-box;
    box-sizing: border-box;
    display: -webkit-flex;
    display: -ms-flexbox;
    display: -webkit-box;
    display: flex;
    -webkit-box-lines: multiple;
    -moz-box-lines: multiple;
    -webkit-flex-wrap: wrap;
    -moz-flex-wrap: wrap;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
    -webkit-justify-content: center;
    -moz-justify-content: center;
    -ms-flex-pack: center;
    -ms-justify-content: center;
    -webkit-box-pack: center;
    justify-content: center;
    -webkit-justify-content: center;
    justify-content: center
  }
  .footerNav li {
    border-right: 1px solid #E6E6E6;
    padding: 0 10px
  }
  .footerNav li:last-child {
    border: 0
  }
}

@media screen and (max-width:641px) {
  .footerNav {
    padding: 1em 0;
    text-align: center
  }
  .footerNav li {
    width: 19%;
    text-align: center;
    display: inline-block
  }
  .footerNav li a {
    padding: 0.5em 0;
    display: block;
    font-size: 98%;
    letter-spacing: -0.02em
  }
  .footerNav li:first-child {
    width: 16%
  }
  .footerNav li:last-child {
    width: 100%
  }
  .footerInfo {
    text-align: center;
    font-size: 0
  }
  .footerInfo a {
    display: block;
    border-top: 1px solid #E6E6E6;
    width: 100%;
    text-align: center
  }
  .footerInfo img {
    margin: 0;
    display: inline;
    height: auto;
    width: 40%;
    margin: auto;
    margin-top: 20px
  }
  .footerInfo strong {
    display: none
  }
}

#header {
  min-width: 960px;
  position: relative;
  z-index: 1
}

@media screen and (min-width:641px) {
  .headerAreaInner {
    -webkit-box-sizing: border-box;
    box-sizing: border-box;
    display: -webkit-flex;
    display: -ms-flexbox;
    display: -webkit-box;
    display: flex;
    -webkit-box-lines: multiple;
    -moz-box-lines: multiple;
    -webkit-flex-wrap: wrap;
    -moz-flex-wrap: wrap;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
    padding-top: 10px;
    padding-bottom: 10px;
    width: 960px;
    min-width: 960px;
    margin-left: auto;
    margin-right: auto
  }
}

.headerLogo {
  left: 0;
  width: 380px;
  width: 600px;
  width: 280px;
  font-size: 12px
}

.headerLogo a {
  display: block
}

.headerLogo img {
  height: auto;
  width: 100%
}

.headerNavWrapper {
  margin-left: auto;
  margin-right:auto;
  border-top: 1px solid #EDF1F4
}

.headerNav {
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: -webkit-box;
  display: flex;
  -webkit-box-lines: multiple;
  -moz-box-lines: multiple;
  -webkit-flex-wrap: wrap;
  -moz-flex-wrap: wrap;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
  justify-content: space-around;
  width: 960px;
  min-width: 960px;
  margin: 13px auto;
}

.headerNav li {
  padding-top: 6px;
  padding-bottom: 6px;
  width: 20%;
  text-align: center;
  border-right : 1px solid #25A8D2;
}
.headerNav li:first-child {
  border-left : 1px solid #25A8D2;

}

.headerNav a {
  color: #767676;
  display: block;
  font-weight: 400;
  font-size: 15px
}

.headerNav a i {
  color: #25A8D2;
  font-size: 80%;
  display: inline-block;
  margin-right: 5px
}

.headerNav a:hover {
  color: #25A8D2
}

.headerCatNav {
  width: 100%;
}

.headerCatNav:after {
  width: 100%;
  left: 0%;
  bottom: 0;
  height: 3px;
  background: #EDF1F4;
  content: "";
  z-index: -1;
  position: absolute;
  right: 0;
  left: auto
}

.headerCatNav ul {
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: -webkit-box;
  display: flex;
  -webkit-box-lines: multiple;
  -moz-box-lines: multiple;
  -webkit-flex-wrap: wrap;
  -moz-flex-wrap: wrap;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
  -webkit-justify-content: space-between;
  -moz-justify-content: space-between;
  -ms-flex-pack: justify;
  -ms-justify-content: space-between;
  -webkit-box-pack: justify;
  justify-content: space-between;
  position: relative;
  width: 960px;
  min-width: 960px;
  margin-left: auto;
  margin-right: auto
}

.headerCatNav .btn_cat {
  font-weight: 400;
  font-size: 0.85em;
  padding: 12px 1em 12px;
  display: inline-block;
  -webkit-transition: .3s;
  -o-transition: .3s;
  transition: .3s;
  position: relative;
  color: #25A8D2;
  vertical-align: middle;
  display: inline-block;
  transition: .3s;
  position: relative;
  font-size: 12px;
  font-weight: 100;
  padding-top: 10px;
  color: #323335;
  padding: 12px 13px 23px;
  /* margin-top: 11px */
}

.headerCatNav .btn_cat i {
  -webkit-transition: 0.3s ease;
  -moz-transition: 0.3s ease;
  -ms-transition: 0.3s ease;
  -o-transition: 0.3s ease;
  transition: 0.3s ease;
  position: absolute;
  font-size: 13px;
  vertical-align: middle
}

.headerCatNav .btn_cat:before {
  position: absolute;
  -webkit-transition: .3s;
  -o-transition: .3s;
  transition: .3s;
  content: ''
}

.headerCatNav .btn_cat:after {
  position: absolute;
  -webkit-transition: .3s;
  -o-transition: .3s;
  transition: .3s;
  content: ''
}

.headerCatNav .btn_cat:hover {
  opacity: 1;
  filter: alpha(opacity=100)
}

.headerCatNav .btn_cat:after {
  width: 0;
  left: 50%;
  bottom: 0;
  height: 3px;
  background: #25A8D2;
  right: 0;
  left: auto
}

.headerCatNav .btn_cat:hover {
  color: #333
}

.headerCatNav .btn_cat:hover:after {
  width: 100%;
  left: 0
}

.headerCatNav .current a {
  color: #25A8D2;
  cursor: inherit
}

.headerCatNav .current a:hover {
  color: #25A8D2
}

.headerCatNav .current a:after {
  width: 100%;
  left: 0
}





.burger span {
  background-color: #25A8D2
}

.burger.is-active span:first-of-type {
  -webkit-transform: translateY(20px) rotate(-45deg);
  -ms-transform: translateY(20px) rotate(-45deg);
  transform: translateY(20px) rotate(-45deg)
}

.burger.is-active span:nth-of-type(2) {
  opacity: 0
}

.burger.is-active span:nth-of-type(3) {
  -webkit-transform: translateY(-20px) rotate(45deg);
  -ms-transform: translateY(-20px) rotate(45deg);
  transform: translateY(-20px) rotate(45deg)
}

.burger, .burger span {
  display: inline-block;
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
  -webkit-transition: all 200ms cubic-bezier(0.25, 0.1, 0.25, 1);
  -moz-transition: all 200ms cubic-bezier(0.25, 0.1, 0.25, 1);
  -o-transition: all 200ms cubic-bezier(0.25, 0.1, 0.25, 1);
  transition: all 200ms cubic-bezier(0.25, 0.1, 0.25, 1);
  -webkit-transition-timing-function: cubic-bezier(0.25, 0.1, 0.25, 1);
  -moz-transition-timing-function: cubic-bezier(0.25, 0.1, 0.25, 1);
  -o-transition-timing-function: cubic-bezier(0.25, 0.1, 0.25, 1);
  transition-timing-function: cubic-bezier(0.25, 0.1, 0.25, 1)
}

.burger.is-active {
  z-index: 3
}

.burger.is-active:hover span:first-of-type {
  left: 0px
}

.burger.is-active:hover span:nth-of-type(3) {
  left: 0px
}

.burger {
  cursor: pointer;
  position: absolute;
  width: 25px;
  height: 25px
}

.burger span {
  position: absolute;
  left: 0;
  width: 100%;
  height: 2px;
  background-color: #25A8D2;
  border-radius: 0px
}

.burger span:first-of-type {
  top: 2px
}

.burger span:nth-of-type(2) {
  top: 10px
}

.burger span:nth-of-type(3) {
  bottom: 4px
}

.burger {
  position: absolute;
  z-index: 555;
  top: 2.1vh;
  right: 5%
}

.burger.is-active {
  top: 2.1vh;
  right: 5%
}

.burger.is-active span {
  background-color: #fff;
  width: 30px
}

@media screen and (max-width:639px) {
  .burger.is-active span {
    width: 30px
  }
}

.burger.is-active span:first-of-type {
  top: -6px
}

.burger.is-active span:nth-of-type(3) {
  bottom: 3px
}

@media screen and (max-width:639px) {
  .burger.is-active span:nth-of-type(3) {
    bottom: -11px
  }
}

.popUpWrapper {
  padding: 1rem 5%;
  width: 100%;
  height: 100%;
  z-index: 1;
  position: absolute;
  top: 0;
  right: 0;
  -webkit-transform: translateY(5%);
  -ms-transform: translateY(5%);
  transform: translateY(5%);
  opacity: 0;
  background: #25a8d2;
  -webkit-transition: all 500ms cubic-bezier(1, 0, 0, 1);
  -o-transition: all 500ms cubic-bezier(1, 0, 0, 1);
  transition: all 500ms cubic-bezier(1, 0, 0, 1);
  -webkit-transition-timing-function: cubic-bezier(1, 0, 0, 1);
  -o-transition-timing-function: cubic-bezier(1, 0, 0, 1);
  transition-timing-function: cubic-bezier(1, 0, 0, 1)
}


.popUpWrapper.is-closeMenu {
	pointer-events : none;
}


.popUpWrapper .popUpMenu {
  position: absolute;
  z-index: 0;
  width: 85%;
  padding-bottom: 20px
}

.popUpWrapper .popUpMenu a {
  display: block
}

.popUpWrapper .ppMenu02 li {
  display: inline-block;
  margin-right: 5px
}

.popUpWrapper .ppMenu02, .popUpWrapper .ppMenu03 {
  border-top: 1px solid rgba(255, 255, 255, 0.3);
  padding-top: 15px;
  margin-top: 15px
}

.popUpWrapper:after {
  content: "";
  display: block;
  position: fixed;
  bottom: 0;
  right: 0;
  left: auto;
  width: 100%;
  height: 100%;
  -webkit-transition-duration: .2s;
  -o-transition-duration: .2s;
  transition-duration: .2s;
  opacity: 0;
  duration: .500ms
}

.popUpWrapper ol {
  padding: 0
}

.popUpWrapper .btn01.head {
  font-weight: bold;
  color: #a1dcef;
  font-size: 1.2em
}
body.page-championship .popUpWrapper .btn01.head {

  font-size: 16px;
}

.popUpWrapper ol li a {
  color: #fff;
  font-size: 1.1em
}

body.page-championship .popUpWrapper ol li a  {
	font-size:15px !important;
}

body.is-nav_open {
  overflow-y: hidden;
  overflow-y: hidden-unscrollable;
  overflow-y: -moz-hidden-unscrollable
}

body.is-nav_open .onLogo {
  z-index: 0
}

body.is-nav_open .popUpWrapper {
  position: fixed;
  overflow-y: scroll;
  z-index: 2;
  -webkit-transform: translateY(0%);
  -ms-transform: translateY(0%);
  transform: translateY(0%);
  opacity: 1
}

body.is-nav_open .popUpWrapper .popUpMenu {
  visibility: visible;
  opacity: 1;
  z-index: 1
}

body.is-nav_open .popUpWrapper:after {
  opacity: 1
}

@media screen and (min-width:641px) {
  .burger, .popUpWrapper {
    display: none
  }
}

@media screen and (max-width:641px) {
  body {
    overflow-x: hidden!important
  }
  .headerCatNav, .headerNavWrapper {
    display: none
  }
  #header {
    position: relative;
    z-index: 1;
    width: 90%;
    min-width: 90%;
    max-width: 90%;
    padding-left: 5%;
    padding-right: 5%;
    padding: 0;
    width: 100%;
    max-width: 100%
  }
  #header .headerAreaInner {
    display: block;
    position: relative
  }
  #header .headerLogo {
    padding: 15px;
    padding-left: 3px;
    padding-right: 0;
    position: relative;
    z-index: 1;
    width: 83%;
    background: #fff;
    text-align: left
  }
  #header .headerNav {
    display: none;
    width: 100%;
    background: rgba(188, 21, 21, 0.9);
    position: absolute;
    top: -500px;
    left: 0;
    -webkit-transition: 0.3s ease;
    -moz-transition: 0.3s ease;
    -ms-transition: 0.3s ease;
    -o-transition: 0.3s ease;
    transition: 0.3s ease;
    overflow: hidden;
    padding: 0;
    z-index: 0
  }
  #header .headerNav ul {
    display: block;
    padding: 1em 5%;
    margin-top: -30px;
    -webkit-transition: 0.8s ease;
    -moz-transition: 0.8s ease;
    -ms-transition: 0.8s ease;
    -o-transition: 0.8s ease;
    transition: 0.8s ease
  }
  #header .headerNav ul .btn {
    padding: 0
  }
  #header .headerNav ul .btn a {
    padding: 1em 0;
    width: 100%;
    color: #fff;
    font-size: 1.8em;
    font-weight: 800
  }
  #header .headerNav ul .btn a:after {
    display: none;
    background: 0
  }
  #header .headerNav ul .btn:before {
    display: none
  }
  #header .headerNav .headerBtnSchedule {
    display: none
  }
  #header .headerBaga {
    background: #25A8D2;
    color: #fff;
    padding: 22px;
    text-align: center;
    position: absolute;
    top: 0;
    right: 0;
    z-index: 2
  }
  #header .headerBaga i {
    font-size: 150%
  }
  body.js-drawer-open #header .headerNav {
    left: 0;
    top: 60px;
    width: 100%;
    z-index: 0
  }
  body.js-drawer-open #header .headerNav ul {
    margin-top: 0px
  }
}

@media screen and (min-width:641px) {
  .footerInfo img {
    vertical-align: top;
    display: block;
    height: 95px;
    width: 293px;
    margin-top: 5px
  }
}

.link01 {
  color: #25A8D2;
  font-weight: bold;
  display: inline-block
}

.searchBtn {
  background: #25A8D2;
  color: #fff;
  font-weight: bold;
  border: 0;
  cursor: pointer;
  -webkit-transition: 0.3s ease;
  -moz-transition: 0.3s ease;
  -ms-transition: 0.3s ease;
  -o-transition: 0.3s ease;
  transition: 0.3s ease;
  padding: 10px 30px 7px;
  border-bottom: 2px solid #1d85a7;
  font-size: 15px;
  letter-spacing: 0.5em;
  -moz-text-shadow: 1px 1px 0px #1d85a7;
  -webkit-text-shadow: 1px 1px 0px #1d85a7;
  -ms-text-shadow: 1px 1px 0px #1d85a7;
  text-shadow: 1px 1px 0px #1d85a7;
  -moz-border-radius: 2px;
  -webkit-border-radius: 2px;
  border-radius: 2px;
  letter-spacing: .2rem
}

.searchBtn:hover {
  background: #1d85a7
}

.searchBtn.green {
  padding: 10px 20px 7px;
  padding-left: 26px;
  letter-spacing: .2rem;
  background-color: #60E417;
  border-color: #5ad616;
  text-shadow: 1px 1px 0px #56cd15
}

.searchBtn.green:hover {
  background: #56cd15;
  opacity: 1
}

.newsList .pager {
  margin-top: 30px;
  margin-bottom: -50px;
  text-align: center
}

.newsList .pager a {
  color: #b7b7b7;
  padding-bottom: 10px
}

.newsList .pager a:hover {
  color: #515151
}

.newsList .pager li {
  display: inline-block;
  font-family: "Yantramanav";
  font-size: 18px;
  margin-right: 25px;
  border-bottom: 0
}

.newsList .pager .active {
  border-bottom: 5px solid #25A8D2;
  padding-bottom: 10px
}

#mainvisual.subPageTtl h2 {
  background: 0;
  font-size: 16px;
  color: #76cce7
}

#mainvisual.subPageTtl h2 span {
  letter-spacing: 0
}

#mainvisual.subPageTtl h2 strong {
  font-size: 18px;
  position: relative;
  display: block;
  color: #fff;
  width: 230px;
  margin: auto;
  margin-bottom: 18px;
  letter-spacing: 0.5em;
  padding-left: 15px
}

#mainvisual.subPageTtl h2 strong:before {
  content: " ";
  display: block;
  position: absolute;
  left: 15px;
  top: 10px;
  height: 1px;
  width: 40px;
  background: #fff;
  font-size: 0;
  line-height: 0;
  clear: both
}

#mainvisual.subPageTtl h2 strong:after {
  content: " ";
  display: block;
  position: absolute;
  right: 10px;
  top: 10px;
  height: 1px;
  width: 40px;
  background: #fff;
  font-size: 0;
  line-height: 0;
  clear: both
}

#mainvisual.subPageTtl p {
  margin-left: auto;
  margin-right: auto;
  margin-bottom: 10px
}

#mainvisual.subPageTtl p strong {
  font-weight: bold;
  display: block;
  font-size: 31px;
  margin-bottom: 20px;
  line-height: 1.3
}

.pageSkislopguide #mainvisual.subPageTtl h2 strong {
  width: 300px
}

.siteLoaderInner {
  left: 46%
}

.pankuzu {
  font-weight: 300
}

.bg:before {
  opacity: 0.85;
  filter: alpha(opacity=85);
  background: #000
}

.bg00 {
  background: #CFECF4
}

.bg01 {
  background-image: url(../images/main02.jpg);
  background-size: cover
}

.bg02 {
  background-image: url(../images/main02.jpg);
  background-size: cover
}

.bg03 {
  background-image: url(../images/main03.jpg);
  background-size: cover;
  background-position: top center
}

.bg04 {
  background-image: url(../images/main03.jpg);
  background-size: cover
}

.bg05 {
  background-image: url(../images/main055.jpg);
  background-size: cover
}

.bg06 {
  background-image: url(../images/main03.jpg);
  background-size: cover
}

.bg07 {
  background-image: url(../images/main03.jpg);
  background-size: cover
}

.bg08 {
  background-image: url(../images/main08.jpg);
  background-size: cover
}

.bg09 {
  background-image: url(../images/main03.jpg);
  background-size: cover
}

.bg10 {
  background-image: url(../images/main03.jpg);
  background-size: cover
}

.bg11 {
  background-image: url(../images/main03.jpg);
  background-size: cover
}

.bg12 {
  background-image: url(../images/main03.jpg);
  background-size: cover
}

.bg13 {
  background-image: url(../images/main03.jpg);
  background-size: cover
}

.bg14 {
  background-image: url(../images/main03.jpg);
  background-size: cover
}

.bg15 {
  background-image: url(../images/main03.jpg);
  background-size: cover
}

.bg16 {
  background-image: url(../images/main03.jpg);
  background-size: cover
}

.bg17 {
  background-image: url(../images/main03.jpg);
  background-size: cover
}

.bg18 {
  background-image: url(../images/main03.jpg);
  background-size: cover
}

.bg19 {
  background-image: url(../images/main03.jpg);
  background-size: cover
}

.bg20 {
  background-image: url(../images/main03.jpg);
  background-size: cover
}

.bgWht {
  background: rgba(255, 255, 255, 0.975)
}

.bgBlu {
  background: #CFEBF6
}

#mainvisual {
  overflow: hidden;
  position: relative
}

#mainvisual .mainvisualInner {
  padding: 130px 0 120px;
  background-image: url(../images/main00.jpg);
  background-image: url(../images/main2020.jpg);
  background-position: center center
}

#mainvisual .mainvisualInner:before {
  background: #10202D none repeat scroll 0 0;
  opacity: 0.7
}

.pageGeneral #mainvisual .mainvisualInner {
  background-image: url(../images/main04.jpg);
  background-position: top center
}

.pageConpetition #mainvisual .mainvisualInner.bg01 {
  background-image: url(../images/comp01.jpg);
  background-position: top center
}

.pageConpetition #mainvisual .mainvisualInner.bg02 {
  background-image: url(../images/comp02.jpg);
  background-position: top center
}

.pageConpetition #mainvisual .mainvisualInner.bg03 {
  background-image: url(../images/comp03.jpg);
  background-position: top center
}

.pageConpetition #mainvisual .mainvisualInner.bg04 {
  background-image: url(../images/comp04.jpg);
  background-position: top center
}

.pageConpetition #mainvisual .mainvisualInner.bg05 {
  background-image: url(../images/comp05.jpg);
  background-position: top center
}

.pageConpetition #mainvisual .mainvisualInner.bg06 {
  background-image: url(../images/comp06.jpg);
  background-position: top center
}

.pageEducational #mainvisual .mainvisualInner {
  background-image: url(../images/main06.jpg);
  background-position: top center
}

.pageTournament #mainvisual .mainvisualInner {
  background-image: url(../images/main09.jpg);
  background-position: top center
}

#mainvisual.subPageTtl p a {
  color: #D1D1D1;
  font-weight: normal;
  padding: 0 10px
}

#mainvisual.subPageTtl p a:hover {
  text-decoration: underline
}

#mainvisual.subPageTtl p span {
  color: #B9BABC
}

.newsList {
  position: relative
}

.newsList .catLink {
  display: inline-block;
  padding: 0
}

.newsList li {
  border-bottom: 1px dotted #c9c9c9;
  margin-bottom: 1em
}

.newsList li:last-child {
  border-bottom: 0;
  margin-bottom: 0
}

.newsList a {
  color: #43768B;
  font-weight: bold;
  display: block;
  padding: 0.65em 0 1em;
  line-height: 1.6
}

.newsList .tagNew {
  color: #fff;
  font-size: 11px;
  background: #60E417;
  padding: 0px 5px 1px;
  margin-right: 5px
}

.newsList time {
  font-size: 13px;
  color: #757575;
  margin-right: 10px
}

.newsList .tagCat {
  color: #25A8D2;
  font-size: 12px
}

.newsList .tagCat a {
  color: inherit;
  display: inline;
  margin: 0
}

.newsList .noLink {
  display: block;
  padding: 0.65em 0 1em;
  color: #727171
}

.btnMore {
  position: absolute;
  right: 0;
  top: -29px;
  background: #014F66
}

.btnMore a {
  color: #fff;
  font-weight: normal;
  font-size: 11px;
  padding: 7px 5px 5px 12px
}

.btnMore a:hover {
  background: #013b4d
}

.btnMore i {
  color: #25A8D2;
  font-size: 14px;
  margin-left: 4px
}

.sideBnr {
  margin-bottom: 20px;
  padding: 20px;
  background: #F9F9F9;
  border: 1px solid #EEEEEE
}

.sideBnr .title {
  font-size: 14px
}

.sideBnr .title span {
  font-size: 24px;
  margin-bottom: 5px
}

.compe .title.ttl03, .feature .title.ttl03, .movie .title.ttl03 {
  color: #DADADA
}

.compe .title.ttl03 span, .feature .title.ttl03 span, .movie .title.ttl03 span {
  color: #fff
}

.movie {
  color: #fff
}

.movie .title.ttl03 span {
  color: #fff
}

.movie p {
  color: #fff;
  font-weight: bold;
  text-align: center
}

.lede {
  color: #43768B;
  font-size: 14px;
  font-weight: bold;
  line-height: 2;
  margin-bottom: 20px
}

.lede strong {
  font-size: 20px
}

.table {
  border: 1px solid #DEE2E3;
  margin: 20px 0
}

.table dt {
  font-weight: 600;
  border-bottom: 1px solid #DEE2E3;
  text-align: center;
  font-size: 15px;
  color: #43768B;
  padding-top: 18px;
  padding-bottom: 18px;
  background: #F6FAFB;
  line-height: 1.3
}

.table dt:first-child {
  border-top: 0
}

.table dd {
  padding: 1em 0 0.8em;
  padding-left: 3%;
  padding-right: 3%;
  border-bottom: 1px solid #DEE2E3;
  line-height: 2
}

.table dd a {
  color: #25A8D2;
  text-decoration: underline
}

@media screen and (min-width:641px) {
  .table {
    -webkit-box-sizing: border-box;
    box-sizing: border-box;
    display: -webkit-flex;
    display: -ms-flexbox;
    display: -webkit-box;
    display: flex;
    -webkit-box-lines: multiple;
    -moz-box-lines: multiple;
    -webkit-flex-wrap: wrap;
    -moz-flex-wrap: wrap;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
    -webkit-box-align: stretch;
    -moz-box-align: stretch;
    -ms-flex-align: stretch;
    -webkit-align-items: stretch;
    -moz-align-items: stretch;
    align-items: stretch
  }
  .table dt {
    width: 26%;
    padding-left: 2%;
    padding-right: 2%;
    border-right: 1px solid #DEE2E3
  }
  .table dd {
    width: 74%
  }
}

@media screen and (min-width:641px) {
  #mainvisual {
    min-width: 960px
  }
  #mainvisual.subPageTtl p {
    width: 960px
  }
  .feature .lineUp3 {
    margin-top: 40px
  }
  .feature .lineUp3 .lineUpItem {
    background: #fff;
    text-align: center
  }
  .feature .lineUp3 .lineUpItem img {
    width: 100%;
    height: auto
  }
  .feature .lineUp3 .lineUpItem p {
    color: #333;
    padding-bottom: 40px;
    font-size: 14px
  }
  .varietyInfo {
    position: relative;
    color: #333;
    font-weight: bold;
    margin-top: 40px;
    border-top: 1px solid #E6E6E6;
    padding-top: 30px
  }
  .varietyInfo .lineUp3 {
    margin-top: 40px
  }
  .varietyInfo .lineUpItem {
    text-align: left;
    margin-bottom: 30px
  }
  .varietyInfo .lineUpItem img {
    width: 100%;
    height: auto;
    margin-bottom: 20px
  }
  .varietyInfo .lineUpItem a {
    font-weight: normal;
    color: #43768B;
    font-size: 14px;
    text-decoration: underline
  }
  .varietyInfo .lineUpItem p {
    margin-top: 10px;
    line-height: 1
  }
  .varietyInfo .lineUpItem p img {
    width: 20px;
    margin-left: 8px;
    margin-bottom: 0
  }
  .varietyInfo .planningSheat {
    position: absolute;
    right: 0;
    top: 30px
  }
  .searchBtn {
    margin-top: 10px
  }
}

@media screen and (max-width:641px) {
  #mainvisual .mainvisualInner {
    /* padding: 5em 0 */
    padding: 1.55em 0;
    height : calc(100vw * 0.381);
  }

  body:not(.index)   #mainvisual .mainvisualInner {
    
    padding: 5em 0;
    height : auto;
  }

  .boxContainerInner {
    padding: 0;
    margin: auto
  }
  .btnMore {
    top: -52px;
    -moz-border-radius: 3px;
    -webkit-border-radius: 3px;
    border-radius: 3px;
    padding: 0.3em
  }
  #mainvisual.subPageTtl h2 span {
    font-size: 95%;
    letter-spacing: -0.1em!important
  }
}


.footer_sponsor {
  margin:40px 0;
  border-top : 1px solid #2e9fc5;
}

.footer_sponsor_inner {
  text-align: center;
  padding : 2.4rem 0 0;
}

.sponsor_title  {
  height: 26px;
  max-width: 320px;
  margin : auto;
}
.sponsor_title img{
  width: 100%;
  height:100%;
}

.sponsor_list {
  display: flex;
  justify-content: center;
  align-items: center;
  padding : 1.6rem 0;
}
.sponsor_list .__item {
  margin: 0 1.5rem;
}
.sponsor_list .__item img{
  width: 100%;
  height:100%;
}
.sponsor_list .__item.__sps11 {
  width: 600px;
}
.sponsor_list .__item.__sps21 {
  width: 212px;
}
.sponsor_list .__item.__sps22 {
  width: 210px;
}

.sponsor_list .__item.__sps31 {
  width: 97px;
}
.sponsor_list .__item.__sps32 {
  width: 184px;
}
.sponsor_list .__item.__sps33 {
  width: 88px;
}
.sponsor_list .__item.__sps34 {
  width: 153px;
}




.spponsor_2025 .sponsor_list .__item.__sps11 {
	width: 350px;
  }
  .spponsor_2025  .sponsor_list .__item.__sps12 {
	width: 335px;
  }
  .spponsor_2025 .sponsor_list .__item.__sps21 {
	width: 240px;
  }
  .spponsor_2025 .sponsor_list .__item.__sps22 {
	width: 210px;
  }
  
  .spponsor_2025 .sponsor_list .__item.__sps31 {
	width: 97px;
  }
  .spponsor_2025 .sponsor_list .__item.__sps32 {
	width: 184px;
  }
  .spponsor_2025 .sponsor_list .__item.__sps33 {
	width: 139px;
  }
  .spponsor_2025 .sponsor_list .__item.__sps34 {
	width: 153px;
  }



@media screen and (max-width:641px) {

  .sponsor_title  {
    height: 1.4rem;
  }
  .sponsor_list {
    padding : 1.6rem ;
  }
  .sponsor_list .__item {
    margin: 0 0.4rem;
  }
}


/* 
.sponsor_list.__silver .__item {
  width: calc(960px * 0.2);
}
.sponsor_list.__bronze .__item {
  width: calc(960px * 0.1);
} */

/*# sourceMappingURL=base2020.css.map */