@charset "UTF-8";
@import url(https://fonts.googleapis.com/earlyaccess/notosansjapanese.css);
@import url('https://fonts.googleapis.com/css2?family=Noto+Serif+JP:wght@400;700&display=swap');
@import url(https://fonts.googleapis.com/css?family=Lato);
@font-face {
  font-family: icomoon;
  src: url(../fonts/icomoon.eot?ti9k2d);
  src: url(../fonts/icomoon.eot?ti9k2d#iefix) format("embedded-opentype"), url(../fonts/icomoon.ttf?ti9k2d) format("truetype"), url(../fonts/icomoon.woff?ti9k2d) format("woff"), url(../fonts/icomoon.svg?ti9k2d#icomoon) format("svg");
  font-weight: 400;
  font-style: normal
}

a, abbr, acronym, address, applet, article, aside, b, big, blockquote, body, caption, center, cite, code, dd, del, dfn, div, dl, dt, em, fieldset, figure, font, footer, form, h1, h2, h3, h4, h5, h6, header, html, i, iframe, img, ins, kbd, label, legend, li, object, ol, p, pre, q, s, samp, section, small, span, strike, strong, sub, sup, table, tbody, td, tfoot, th, thead, tr, tt, u, ul, var {
  margin: 0;
  padding: 0;
  border: 0;
  outline: 0
}

body {
  line-height: 100%
}

li, ol, ul {
  list-style: none
}

img {
  -ms-interpolation-mode: bicubic;
  vertical-align: bottom
}

ins {
  text-decoration: none
}

del {
  text-decoration: line-through
}

table {
  border-collapse: collapse;
  border-spacing: 0
}

:focus {
  outline: 0
}

caption, td, th {
  text-align: left;
  font-weight: 400
}

.clear, div .clear {
  width: 0;
  height: 0;
  font-size: 0;
  line-height: 0;
  text-indent: -9999px;
  clear: both
}

.clearFix {
  zoom: 1
}

.clearFix:after {
  content: ".";
  clear: both;
  display: block;
  height: 0;
  visibility: hidden
}

@media print {
  body {
    zoom: 60%
  }
}

body.home {background: #efefef;}/**/


#pageFooter #footerInner .sns>li a:before, #pageHeader #navGlobal .snsArea .search dd button span:before, #pageHeader #navGlobal .snsArea .sns>li a:before, #pageHeader #navOpen span:before {
  font-family: icomoon!important;
  speak: none;
  font-style: normal;
  font-weight: 400;
  font-variant: normal;
  text-transform: none;
  line-height: 1;
  vertical-align: top;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale
}

#pageHeader #navGlobal .snsArea .sns {
  margin-top: 0;
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
  -webkit-justify-content: center;
  -ms-flex-pack: center;
  justify-content: center;
  -webkit-box-align: center;
  -webkit-align-items: center;
  -ms-flex-align: center;
  align-items: center;
  text-align: center;
  letter-spacing: -.4em;
}
#pageFooter #footerInner .sns {
  margin-top: 0;
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
  -webkit-justify-content: center;
  -ms-flex-pack: center;
  justify-content: center;
  -webkit-box-align: center;
  -webkit-align-items: center;
  -ms-flex-align: center;
  align-items: center;
  text-align: center;
  letter-spacing: -.4em;
	background: #efefef;/**/
	/*border-top:1px solid #ccc;*/
	padding: 10px 0 !important;/* どこでパディングを設定しているのかわからなかったので */
}

#pageFooter #footerInner .sns>li, #pageHeader #navGlobal .snsArea .sns>li {
  width: 40px;
  text-align: center;

}

#pageFooter #footerInner .sns>li a, #pageHeader #navGlobal .snsArea .sns>li a {
  height: 40px;
  text-indent: 200%;
  white-space: nowrap;
  overflow: hidden;
  display: block;
  position: relative
}

#pageFooter #footerInner .sns>li a:before, #pageHeader #navGlobal .snsArea .sns>li a:before {
  width: 40px;
  height: 40px;
  display: block;
  position: absolute;
  top: 0;
  left: 0;
  bottom: 0;
  right: 0;
  margin: auto;
  color: #000;
  font-size: 18px;
  line-height: 40px;
  text-align: center;
  text-indent: 0
}

@media screen and (max-width:1024px) {
  #pageFooter #footerInner .sns>li a:before, #pageHeader #navGlobal .snsArea .sns>li a:before {
    font-size: 14px
  }
}

#pageFooter #footerInner .sns>li a[href*=twitter]:before, #pageHeader #navGlobal .snsArea .sns>li a[href*=twitter]:before {
  content: "\ea96";
	color:#000;
}

#pageFooter #footerInner .sns>li a[href*=facebook]:before, #pageHeader #navGlobal .snsArea .sns>li a[href*=facebook]:before {
  content: "\ea90";
	color:#000;
}

#pageFooter #footerInner .sns>li a[href*=line]:before, #pageHeader #navGlobal .snsArea .sns>li a[href*=line]:before {
  content: "\e900"
}

#pageFooter #footerInner .sns>li a[href*=instagram]:before, #pageHeader #navGlobal .snsArea .sns>li a[href*=instagram]:before {
  content: "\ea92";
	color:#000;
}

#pageFooter #footerInner .sns>li a[href*=youtube]:before, #pageHeader #navGlobal .snsArea .sns>li a[href*=youtube]:before {
  content: "\e90e"
}

#pageFooter #footerInner .sns>li a[href*=plus]:before, #pageHeader #navGlobal .snsArea .sns>li a[href*=plus]:before {
  content: "\ea8b"
}

#pageHeader #navGlobal>ul>li .megamenu .inner .linkArea .toppage>a:after {
  content: "";
  width: 10px;
  height: 10px;
  position: absolute;
  right: 10px;
  top: 50%;
  margin-top: -5px;
  border-style: solid;
  border-width: 2px 2px 0 0;
  border-color: #fff;
  -webkit-transform: rotateZ(45deg);
  -ms-transform: rotate(45deg);
  transform: rotateZ(45deg)
}

body {
  font-family: "Noto Sans Japanese", serif, "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", "メイリオ", Meiryo, sans-serif;
  font-size: 100%
}

@media screen and (max-width:767px) {
  .pc {
    display: none!important
  }
}

@media screen and (min-width:960px) {
  .tb {
    display: none!important
  }
}

@media screen and (min-width:1024px) {
  .sp2 {
    display: none!important
  }
}

@media screen and (min-width:767px) {
  .sp {
    display: none!important
  }
}

#container {
  min-width: 960px;
  margin: 0 auto;
  /*padding-top: 140px;*/
	padding-top: 100px;/**/
  overflow: hidden
}

@media screen and (max-width:1024px) {
  #container {
    min-width: 100%;
    padding-top: 100px
  }
}

@media screen and (max-width:767px) {
  #container {
    padding-top: 60px
  }
}

#pageHeader {
  background: #fff;
  width: 100%;
  height: 100px/*140px*/;/**/
/*  position: absolute;*/
    position: fixed; /*240809*/   
  top: 0;
  left: 0;
  z-index: 1000;
  color: #fff;
	border-bottom:1px solid #ccc;
}


@media screen and (max-width:1024px) {
  #pageHeader {
    position: fixed;
    height: 101px/*100*/;
    padding: 20px 0;
    box-sizing: border-box
  }
}

@media screen and (max-width:767px) {
  #pageHeader {
    height: 61px/*60*/;
    padding: 10px 0
  }
}

#headerInner {width:960px; margin: 0 auto;}/**/
@media screen and (max-width:1024px) {
	#headerInner {width: auto;}
}/**/

#pageHeader #headerInner .logo a {
  background: url(../images/common/logo.svg) center center no-repeat #fff;
  width: 171px;
  height: 50px;
  /*margin: 25px auto 0;*/
	margin:10px 0px 0px 15px;
  background-size: contain;
  display: block;
  position: relative;
  overflow: hidden;
  text-indent: 100%;
  text-decoration: none;
  white-space: nowrap
}

@media screen and (max-width:1024px) {
  #pageHeader #headerInner .logo a {
    height: 60px;
    width: 40%;
    margin: 0 auto
  }
}

@media screen and (max-width:767px) {
  #pageHeader #headerInner .logo a {
    height: 35px;
    width: 40%;
    margin: 0 auto
  }
}

#pageHeader #navOpen {
  display: none
}

@media screen and (max-width:1024px) {
  #pageHeader #navOpen {
    -webkit-appearance: none;
    background: #fff;
    width: 100px;
    height: 100px;
    margin: 0;
    padding: 0;
    border: none;
    display: block;
    position: absolute;
    top: 0;
    right: 0;
    overflow: hidden;
    text-indent: 100%
  }
}

@media screen and (max-width:767px) {
  #pageHeader #navOpen {
    width: 60px;
    height: 60px
  }
}

#pageHeader #navOpen span {
  width: 100%;
  height: 100px;
  display: block;
  position: absolute;
  top: 0;
  bottom: 0;
  left: 0;
  right: 0;
  margin: auto
}

#pageHeader #navOpen span:before {
  display: block;
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  margin: auto;
  color: #000;
  font-size: 20px;
  text-indent: 0;
  text-align: center;
  line-height: 100px;
  content: "\e901"
}

@media screen and (max-width:767px) {
  #pageHeader #navOpen span {
    height: 60px
  }
  #pageHeader #navOpen span:before {
    font-size: 14px;
    line-height: 60px
  }
}

#pageHeader #navOpen.open span:before {
  content: "\e902"
}

#pageHeader #navGlobal {
  margin: 0 auto;
	/*border:1px solid #f00; kakuni用*/
  position: relative;
}

@media screen and (min-width:1025px) {
  #pageHeader #navGlobal {
    max-width: 960px;
    display: block!important
  }
}

@media screen and (max-width:1024px) {
  #pageHeader #navGlobal {
    background: rgba(0, 0, 0, .8);
    width: 100%;
    height: calc(100vh - 100px);
    padding: 30px 0 50px;
    box-sizing: border-box;
    display: none;
    position: fixed;
    top: 100px;
    overflow: auto
  }
}

@media screen and (max-width:767px) {
  #pageHeader #navGlobal {
    top: 60px;
    height: calc(100vh - 60px)
  }
}

#pageHeader #navGlobal>ul {
  margin-top: 5px;
  display: block;
  /*text-align: center;*/
	text-align: right;
  letter-spacing: -.4em
}

@media screen and (max-width:1024px) {
  #pageHeader #navGlobal>ul {
    margin-top: 0;
    text-align: left
  }
}

#pageHeader #navGlobal>ul>li {
  display: inline-block;
  letter-spacing: normal;
  position: relative;
  vertical-align: top;
border-right:1px solid #999;/**/
}
#pageHeader #navGlobal>ul>li:last-child {
	border:none;
}

@media screen and (max-width:1024px) {
  #pageHeader #navGlobal>ul>li {
    width: 100%;
    padding: 0 40px;
    display: block;
    box-sizing: border-box;
    position: relative;
  }
}

#pageHeader #navGlobal>ul>li .menu {
  display: block;
  /*height: 60px;*/
	height: auto;/**/
  padding: 0 30px;
  color: #000;
  font-size: 14px;
  font-weight: 700;
  text-decoration: none;
  /*line-height: 60px;*/
  position: relative;
  -webkit-transition: all .3s ease;
  transition: all .3s ease;
  cursor: pointer
}

@media screen and (max-width:1024px) {
  #pageHeader #navGlobal>ul>li .menu {
    width: 80%;
    height: 40px;
    padding: 0;
    font-size: 12px;
    color: #fff;
    line-height: 40px
  }
}

#pageHeader #navGlobal>ul>li .menu:hover {
  color: #e7311b
}

@media screen and (max-width:1024px) {
  #pageHeader #navGlobal>ul>li .menu:hover {
    color: #fff
  }
}

#pageHeader #navGlobal>ul>li .megamenu {
  background-color: rgba(0, 0, 0, .85);
  width: 100%;
  height: 628px;
  padding: 90px 0;
  box-sizing: border-box;
  overflow: auto;
  position: fixed;
  top: 140px;
  left: 0;
  display: none
}

@media screen and (max-width:1024px) {
  #pageHeader #navGlobal>ul>li .megamenu {
    position: static;
    height: auto;
    background-color: transparent;
    padding: 0
  }
}

#pageHeader #navGlobal>ul>li .megamenu .inner {
  max-width: 940px;
  margin: 0 auto;
  text-align: left
}

@media screen and (max-width:1024px) {
  #pageHeader #navGlobal>ul>li .megamenu .inner {
    max-width: 100%
  }
}

#pageHeader #navGlobal>ul>li .megamenu .inner h2 {
  display: block;
  color: #fff;
  font-size: 36px;
  font-weight: 700;
  position: relative;
  line-height: 1
}

@media screen and (max-width:1024px) {
  #pageHeader #navGlobal>ul>li .megamenu .inner h2 {
    display: none
  }
}

#pageHeader #navGlobal>ul>li .megamenu .inner h2:after {
  content: "";
  background: #fff;
  width: 30px;
  height: 3px;
  position: absolute;
  top: -30px;
  left: 0
}

#pageHeader #navGlobal>ul>li .megamenu .inner .linkArea {
  margin-top: 70px;
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
  -webkit-justify-content: space-between;
  -ms-flex-pack: justify;
  justify-content: space-between
}

@media screen and (max-width:1024px) {
  #pageHeader #navGlobal>ul>li .megamenu .inner .linkArea {
    margin-top: 0;
    display: block
  }
}

#pageHeader #navGlobal>ul>li .megamenu .inner .linkArea .toppage {
  width: 360px
}

@media screen and (max-width:1024px) {
  #pageHeader #navGlobal>ul>li .megamenu .inner .linkArea .toppage {
    display: none
  }
}

#pageHeader #navGlobal>ul>li .megamenu .inner .linkArea .toppage>a {
  height: 60px;
  display: block;
  border: 1px solid #fff;
  text-align: center;
  color: #fff;
  font-size: 16px;
  font-weight: 500px;
  line-height: 60px;
  text-decoration: none;
  position: relative;
  -webkit-transition: all .3s ease;
  transition: all .3s ease
}

#pageHeader #navGlobal>ul>li .megamenu .inner .linkArea .toppage>a:after {
  width: 14px;
  height: 14px;
  right: 20px;
  margin-top: -7px
}

#pageHeader #navGlobal>ul>li .megamenu .inner .linkArea .toppage>a:hover {
  background: #fff;
  color: #000
}

#pageHeader #navGlobal>ul>li .megamenu .inner .linkArea .toppage>a:hover:after {
  border-top: 1px solid #000;
  border-right: 1px solid #000
}

#pageHeader #navGlobal>ul>li .megamenu .inner .linkArea ul {
  width: 480px;
  display: block;
  text-align: left;
  letter-spacing: -.4em
}

@media screen and (max-width:1024px) {
  #pageHeader #navGlobal>ul>li .megamenu .inner .linkArea ul {
    width: 100%
  }
}

#pageHeader #navGlobal>ul>li .megamenu .inner .linkArea ul li {
  width: 50%;
  display: inline-block
}

@media screen and (max-width:1024px) {
  #pageHeader #navGlobal>ul>li .megamenu .inner .linkArea ul li {
    width: 100%;
    display: block
  }
}

#pageHeader #navGlobal>ul>li .megamenu .inner .linkArea ul li a {
  color: #fff;
  font-size: 18px;
  font-weight: 500;
  text-decoration: none;
  letter-spacing: normal;
  position: relative;
  -webkit-transition: all .3s ease;
  transition: all .3s ease
}

@media screen and (max-width:1024px) {
  #pageHeader #navGlobal>ul>li .megamenu .inner .linkArea ul li a {
    width: 70%;
    height: 40px;
    padding: 0;
    font-size: 12px;
    color: #fff;
    line-height: 40px
  }
}

#pageHeader #navGlobal>ul>li .megamenu .inner .linkArea ul li a:before {
  content: "-";
  margin-right: 10px
}

#pageHeader #navGlobal>ul>li .megamenu .inner .linkArea ul li a:hover {
  opacity: .8
}

#pageHeader #navGlobal>ul>li .megamenu .inner .linkArea ul li:nth-child(n+3) {
  margin-top: 40px
}

@media screen and (max-width:1024px) {
  #pageHeader #navGlobal>ul>li .megamenu .inner .linkArea ul li:nth-child(n+3) {
    margin-top: 0
  }
}

@media screen and (max-width:1024px) {
  #pageHeader #navGlobal>ul>li.js-gnav p {
    background: #fff;
    width: 14px;
    height: 2px;
    margin-top: -1px;
    display: block;
    position: absolute;
    top: 20px;
    right: 30px
  }
}

@media screen and (max-width:1024px) {
  #pageHeader #navGlobal>ul>li.js-gnav p:before {
    background: #fff;
    width: 100%;
    height: 100%;
    display: block;
    position: absolute;
    top: 0;
    left: 0;
    -webkit-transition: -webkit-transform .5s ease;
    transition: -webkit-transform .5s ease;
    transition: transform .5s ease;
    transition: transform .5s ease, -webkit-transform .5s ease;
    -webkit-transform: rotate(90deg);
    -ms-transform: rotate(90deg);
    transform: rotate(90deg);
    content: ""
  }
}

#pageHeader #navGlobal>ul>li.open p:before {
  -webkit-transform: rotate(0);
  -ms-transform: rotate(0);
  transform: rotate(0)
}

#pageHeader #navGlobal>ul .hello {
  margin-top: 15px
}

@media screen and (max-width:1024px) {
  #pageHeader #navGlobal>ul .hello {
    margin-top: 0
  }
}

#pageHeader #navGlobal>ul .hello a {
  height: 30px;
  padding: 0 40px;
  line-height: 30px
}

@media screen and (max-width:1024px) {
  #pageHeader #navGlobal>ul .hello a {
    background: 0 0;
    padding: 0
  }
}

#pageHeader #navGlobal>ul .hello a:hover {
  opacity: .8
}

@media screen and (max-width:1024px) {
  #pageHeader #navGlobal>ul .hello a:hover {
    opacity: 1
  }
}

#pageHeader #navGlobal .snsArea {
  position: absolute;
  right: 140px/*0*/;
  top: -45px/*-70*/;
  display: flex
}
#pageHeader #navGlobal .cgArea {
  position: absolute;
  right: 0;
  top: -70px;
	background: #000;
	padding: 0.5em 1.5em;
}/*2022*/

@media screen and (max-width:1024px) {
  #pageHeader #navGlobal .snsArea {
    position: static;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -webkit-flex-direction: column;
    -ms-flex-direction: column;
    flex-direction: column
  }
}

#pageHeader #navGlobal .snsArea .toggleLanguage {
  width: 40px;
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
  -webkit-justify-content: center;
  -ms-flex-pack: center;
  justify-content: center;
  -webkit-box-align: center;
  -webkit-align-items: center;
  -ms-flex-align: center;
  align-items: center;
  text-decoration: none;
  color: #000
}

@media screen and (max-width:1024px) {
  #pageHeader #navGlobal .snsArea .toggleLanguage {
    width: 80%;
    display: table;
    border: 1px solid #fff;
    height: 30px;
    border-radius: 15px 15px;
    -webkit-box-ordinal-group: 4;
    -webkit-order: 3;
    -ms-flex-order: 3;
    order: 3;
    position: relative;
    margin: 0 auto;
    margin-top: 10px;
    box-sizing: border-box
  }
  #pageHeader #navGlobal .snsArea .toggleLanguage span {
    display: block;
    position: absolute;
    width: 50%;
    height: 30px;
    overflow: hidden;
    white-space: nowrap;
    text-indent: 100%;
    border-radius: 15px 15px;
    background: #fff;
    top: -1px;
    right: -1px;
    box-sizing: border-box;
    z-index: 0
  }
  #pageHeader #navGlobal .snsArea .toggleLanguage:after, #pageHeader #navGlobal .snsArea .toggleLanguage:before {
    display: table-cell;
    width: 50%;
    text-align: center;
    vertical-align: middle;
    position: relative;
    z-index: 1
  }
  #pageHeader #navGlobal .snsArea .toggleLanguage:before {
    content: "EN";
    color: #fff
  }
  #pageHeader #navGlobal .snsArea .toggleLanguage:after {
    content: "JP";
    color: #000
  }
}

@media screen and (max-width:1024px) {
  #pageHeader #navGlobal .snsArea .sns {
    margin-top: 40px;
    -webkit-box-ordinal-group: 3;
    -webkit-order: 2;
    -ms-flex-order: 2;
    order: 2
  }
  #pageHeader #navGlobal .snsArea .sns li a:before {
    color: #fff!important
  }
}

#pageHeader #navGlobal .snsArea .search {
  width: 150px;
  margin-left: 20px;
  display: block;
  position: relative;
  background-color: transparent;
  border-bottom: 1px solid #000
}

@media screen and (max-width:1024px) {
  #pageHeader #navGlobal .snsArea .search {
    -webkit-box-ordinal-group: 2;
    -webkit-order: 1;
    -ms-flex-order: 1;
    order: 1;
    width: 80%;
    margin: 50px auto 0;
    border: 1px solid #fff
  }
}

#pageHeader #navGlobal .snsArea .search dt {
  margin-right: 40px
}

#pageHeader #navGlobal .snsArea .search dt input {
  width: 100%;
  height: 40px;
  line-height: 40px;
  background: 0 0;
  border: none
}

#pageHeader #navGlobal .snsArea .search dd {
  position: absolute;
  bottom: 0;
  right: 0
}

#pageHeader #navGlobal .snsArea .search dd button {
  display: block;
  background: 0 0;
  border: none
}

#pageHeader #navGlobal .snsArea .search dd button span {
  display: block;
  width: 40px;
  height: 40px;
  text-indent: 100%;
  white-space: nowrap;
  overflow: hidden;
  position: relative
}

#pageHeader #navGlobal .snsArea .search dd button span:before {
  content: "\e986";
  width: 40px;
  height: 40px;
  display: block;
  position: absolute;
  top: 0;
  left: 0;
  bottom: 0;
  right: 0;
  margin: auto;
  color: #000;
  font-size: 14px;
  line-height: 40px;
  text-align: center;
  text-indent: 0
}

@media screen and (max-width:1024px) {
  #pageHeader #navGlobal .snsArea .search dd button span:before {
    color: #fff
  }
}

#pageHeader #navGlobal .text_hello span {
  letter-spacing: -2px
}

#pageHeader #navGlobal .text_hello span:nth-child(1) {
  color: #e4007f
}

#pageHeader #navGlobal .text_hello span:nth-child(2) {
  color: #cd108a
}

#pageHeader #navGlobal .text_hello span:nth-child(3) {
  color: #b62094
}

#pageHeader #navGlobal .text_hello span:nth-child(4) {
  color: #a0309f
}

#pageHeader #navGlobal .text_hello span:nth-child(5) {
  color: #8940a9
}

#pageHeader #navGlobal .text_hello span:nth-child(6) {
  color: #7250b4
}

#pageHeader #navGlobal .text_hello span:nth-child(7) {
  color: #5b60bf
}

#pageHeader #navGlobal .text_hello span:nth-child(8) {
  color: #4470c9
}

#pageHeader #navGlobal .text_hello span:nth-child(9) {
  color: #2e80d4
}

#pageHeader #navGlobal .text_hello span:nth-child(10) {
  color: #1790de
}

#pageHeader #navGlobal .text_hello span:nth-child(11) {
  color: #00a0e9
}

#pageFooter {
  background: /*#e7311b*/#333;
  width: 100%;
  margin-top: 140px
}/* footerの背景色*//* footerの上のマージン180 */

@media screen and (max-width:1024px) {
  #pageFooter {
    margin-top: 100px
  }
}

#pageFooter #footerInner {
  margin: 0 auto;
  /*padding: 60px 0 0;*/
  position: relative;
}

@media screen and (max-width:1024px) {
  #pageFooter #footerInner {
    /*padding: 40px 0 0*/
  }
}

#pageFooter #footerInner .sns {
  padding-bottom: 60px;
  border-bottom: 1px solid #fff
}

@media screen and (max-width:1024px) {
  #pageFooter #footerInner .sns {
    /*width: 90%;*/
    margin: 0 auto;
    padding: 0 0 40px
  }
}

#pageFooter #footerInner .sns>li {
  width: 40px
}

#pageFooter #footerInner .sns>li a {
  height: 40px
}

#pageFooter #footerInner .sns>li a:before {
  width: 40px;
  height: 40px;
  font-size: 20px;
  line-height: 40px;
  color: #fff
}

#pageFooter #footerInner .sns li+li {
  margin-left: 40px
}

#pageFooter #footerInner .navFooter {
  width: 960px;
  margin: 40px auto
}

@media screen and (max-width:1024px) {
  #pageFooter #footerInner .navFooter {
    width: 100%
  }
}

#pageFooter #footerInner .navFooter>ul {
	display: flex;
	flex-wrap: wrap;
	flex-direction: column;
	gap:0 1%;
	height: 240px;
}
.navFooter>ul>li {
	/*width:25%;*/
		/*border:1px solid #f00;*/
	margin-bottom: 20px;
	box-sizing: border-box;
}
.navFooter>ul>li:nth-child(4){
	height: 180px;
}

@media screen and (max-width:1024px){
	.navFooter>ul>li {width: 100%; margin-bottom: 0;}
	.navFooter>ul>li:nth-child(4){height: auto;}
}

/*#pageFooter #footerInner .navFooter>ul {
	display: grid;
}
.navFooter>ul>li {border:1px solid #f00;}

.navFooter>ul>li:nth-child(1){
	grid-row: 1 / 3;
	grid-column: 1 / 2;
}
.navFooter>ul>li:nth-child(2){
	grid-row: 1 / 3;
	grid-column: 2 / 3;
}
.navFooter>ul>li:nth-child(3){
	grid-row: 1 / 2;
	grid-column: 3 / 4;
}
.navFooter>ul>li:nth-child(4){
	grid-row: 2 / 3;
	grid-column: 3 / 4;
}
.navFooter>ul>li:nth-child(5){
	grid-row: 1 / 2;
	grid-column: 4 / 5;
}
.navFooter>ul>li:nth-child(6){
	grid-row: 2 / 3;
	grid-column: 4 / 5;
}*/

/*#pageFooter #footerInner .navFooter>ul {

  -webkit-column-count: 4;
  column-count: 4;
  -webkit-column-fill: auto;
  column-fill: auto;
  height: 240px
}*/

/*.navFooter>ul>li {
	padding: 1px;
	break-inside:avoid;
}
*/
@media screen and (max-width:1024px) {
  #pageFooter #footerInner .navFooter>ul {
   /* -webkit-column-count: 1;
    column-count: 1;
    height: auto*/
	  display: block;
	  height: auto;
  }
}

@media screen and (max-width:1024px) {
  #pageFooter #footerInner .navFooter>ul>li {
    padding: 0 40px;
    box-sizing: border-box
  }
}

#pageFooter #footerInner .navFooter>ul>li>a {
	font-size: 15px;
  font-weight: 500;
  color: #fff;
  text-decoration: none
}

@media screen and (max-width:1024px) {
  #pageFooter #footerInner .navFooter>ul>li>a {
    font-size: 12px;
    display: block;
    height: 40px;
    line-height: 40px
  }
}

#pageFooter #footerInner .navFooter>ul>li>a:before {
  content: "-";
  margin-right: 5px
}

@media screen and (max-width:1024px) {
  #pageFooter #footerInner .navFooter>ul>li>a:before {
    display: none
  }
}

#pageFooter #footerInner .navFooter>ul>li>a:hover {
  text-decoration: underline
}

@media screen and (max-width:1024px) {
  #pageFooter #footerInner .navFooter>ul>li.acc {
    position: relative
  }
  #pageFooter #footerInner .navFooter>ul>li.acc span {
    background: #fff;
    width: 14px;
    height: 2px;
    margin-top: -1px;
    display: block;
    position: absolute;
    top: 20px;
    right: 30px
  }
  #pageFooter #footerInner .navFooter>ul>li.acc span:before {
    background: #fff;
    width: 100%;
    height: 100%;
    display: block;
    position: absolute;
    top: 0;
    left: 0;
    -webkit-transition: -webkit-transform .5s ease;
    transition: -webkit-transform .5s ease;
    transition: transform .5s ease;
    transition: transform .5s ease, -webkit-transform .5s ease;
    -webkit-transform: rotate(90deg);
    -ms-transform: rotate(90deg);
    transform: rotate(90deg);
    content: ""
  }
}

#pageFooter #footerInner .navFooter>ul>li.acc.active span:before {
  -webkit-transform: rotate(0);
  -ms-transform: rotate(0);
  transform: rotate(0)
}

@media screen and (max-width:1024px) {
  #pageFooter #footerInner .navFooter>ul>li.acc a {
    width: 80%
  }
}

@media screen and (max-width:1024px) {
  #pageFooter #footerInner .navFooter>ul>li.acc ul li a {
    width: 100%
  }
}


#pageFooter #footerInner .navFooter>ul>li>ul {
  margin-top: 10px;
  padding-left: 1em
}

@media screen and (max-width:1024px) {
  #pageFooter #footerInner .navFooter>ul>li>ul {
    margin: 20px 0;
    display: none
  }
}

@media screen and (max-width:767px) {
  #pageFooter #footerInner .navFooter>ul>li>ul {
    margin: 10px 0;
    display: none
  }
}

#pageFooter #footerInner .navFooter>ul>li>ul>li a {
  width: 100%;
  height: 30px;
  display: block;
  font-size: 12px;
  color: #fff;
  text-decoration: none;
  position: relative;
  line-height: 30px
}

@media screen and (max-width:1024px) {
  #pageFooter #footerInner .navFooter>ul>li>ul>li a:before {
    content: "";
    width: 10px;
    height: 10px;
    position: absolute;
    right: 10px;
    top: 50%;
    margin-top: -5px;
    -webkit-transform: rotateZ(45deg);
    -ms-transform: rotateZ(45deg);
    transform: rotateZ(45deg);
    border-top: 2px solid #fff;
    border-right: 2px solid #fff
  }
}

#pageFooter #footerInner .navFooter>ul>li>ul>li a:hover {
  text-decoration: underline
}

#pageFooter #footerInner .navFooter>ul>li>ul>li+li {
  margin-top: 0
}

@media screen and (max-width:1024px) {
  #pageFooter #footerInner .navFooter>ul>li>ul>li+li {
    margin-top: 10px
  }
}

/*#pageFooter #footerInner .navFooter>ul>li+li {
  margin-top: 20px
}*/

@media screen and (max-width:1024px) {
  #pageFooter #footerInner .navFooter>ul>li+li {
    margin: 0
  }
}

#pageFooter #footerInner .subFooter {
  background: #000;
  width: 100%;
  padding: 15px 60px;
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
  -webkit-justify-content: space-between;
  -ms-flex-pack: justify;
  justify-content: space-between;
  box-sizing: border-box
}

@media screen and (max-width:1024px) {
  #pageFooter #footerInner .subFooter {
    padding: 15px 0;
    -webkit-box-pack: start;
    -webkit-justify-content: flex-start;
    -ms-flex-pack: start;
    justify-content: flex-start;
    -webkit-box-align: center;
    -webkit-align-items: center;
    -ms-flex-align: center;
    align-items: center;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -webkit-flex-direction: column;
    -ms-flex-direction: column;
    flex-direction: column
  }
}

#pageFooter #footerInner .subFooter ul {
  display: block;
  text-align: left;
  letter-spacing: -.4em
}

#pageFooter #footerInner .subFooter ul li {
  display: inline-block;
  vertical-align: middle;
  letter-spacing: normal
}

#pageFooter #footerInner .subFooter ul li a {
  color: #fff;
  font-size: 12px;
  text-decoration: none
}

#pageFooter #footerInner .subFooter ul li a:hover {
  text-decoration: underline
}

#pageFooter #footerInner .subFooter ul li+li {
  border-left: 1px solid #fff;
  margin-left: 20px;
  padding-left: 20px
}

#pageFooter #footerInner .subFooter #copyright {
  color: #fff;
  font-size: 12px
}

@media screen and (max-width:1024px) {
  #pageFooter #footerInner .subFooter #copyright {
    margin-top: 10px
  }
}

.pageTop {
  position: fixed;
  right: 100px;
  bottom: 80px;
  display: block;
  z-index: 999
}

@media screen and (max-width:1024px) {
  .pageTop {
    right: 20px;
    bottom: 60px
  }
}

.pageTop a {
  display: block;
  width: 60px;
  height: 60px;
  background: #000;
  border-radius: 50%;
  text-indent: 100%;
  white-space: nowrap;
  overflow: hidden;
  box-shadow: 5px 5px 10px rgba(0, 0, 0, .2);
  -webkit-transition: all .3s ease;
  transition: all .3s ease
}

.pageTop a:after {
  content: "";
  display: block;
  position: absolute;
  width: 10px;
  height: 10px;
  border-top: 2px solid #fff;
  border-right: 2px solid #fff;
  -webkit-transform: rotate(-45deg);
  -ms-transform: rotate(-45deg);
  transform: rotate(-45deg);
  top: 28px;
  right: 0;
  left: 0;
  margin: auto
}

.pageTop a:hover {
  background: #e7311b
}

.mb-l {
  margin-bottom: 170px
}

@media screen and (max-width:1024px) {
  .mb-l {
    margin-bottom: 0
  }
}


/* main visual */
.mv_wrap {
	width:100%;
	/*height:600px;*/
	background: url("../images/index/mv_img_r.jpg") center top no-repeat; 
	background-size: cover;
}
.mv_wrap .inner {
	width:960px;
	height:600px;
	margin-left: auto; 
	margin-right: auto; 
	display: flex; 
	justify-content: center; 
	align-items: center;
}


.mv_gg_wrap {
	width:100%;
	height: 470px;
	padding: 60px 0;
	/*background-blend-mode: multiply;
	background-color: rgba(255,255,255,1);*/
	background-image: url("../images/index/mv_gg_img.jpg");
	background-position: center;
	background-repeat: no-repeat;
	background-size: cover;
	box-sizing: border-box;
}
.mv_bus_wrap {
	width:100%;
	height: 470px;
	padding: 60px 0;
	/*background-blend-mode: multiply;
	background-color: rgba(255,255,255,1);	*/
	background-image: url("../images/index/mv_bus_img.jpg");
	background-position: center;
	background-repeat: no-repeat;
	background-size: cover;
	box-sizing: border-box;
}
.mv_gg_wrap .inner {
	width:960px;
	margin-left: auto; 
	margin-right: auto; 
	display: flex; 	
}
.mv_bus_wrap .inner {
	width:960px;
	margin-left: auto; 
	margin-right: auto; 
	display: flex; 
	flex-direction: row-reverse;
}
.mv_tit {
	width:/*340px*/35.4166%;
	min-height: 350px;
	box-sizing: border-box;
	display: flex;
	flex-direction: column;
	justify-content: center;
}
.mv_tit h2 {
	font-size: 24px;
	font-weight: 700;
	line-height: 1.2;
}
.mv_tit h2 small {font-size:18px; font-weight: 400;}

.mv_bs_wrap {
	overflow: hidden;
	display: flex;
}/**/
.bus_wrap {
	width:50%;
	height: 470px;
	background-image: url("../images/index/mv_bus_left.jpg");
	background-position: center;
	background-repeat: no-repeat;
	background-size: cover;
	display: flex;
	justify-content: center;
	align-items: center;
}/**/
.sea_wrap {
	width:50%;
	height: 470px;
	background-image: url("../images/index/mv_bus_img.jpg");
	background-position: center;
	background-repeat: no-repeat;
	background-size: cover;	
	display: flex;
	justify-content: center;
	align-items: center;	
}/**/

.bs_mat {
	background: rgba(255,255,255,0.8);
	/*min-height: 350px;*/
	padding: 40px 10px;
	width:440px;
	box-sizing: border-box;
}

.mv_sea_wrap {
	padding: 60px 0;
}
.mv_sea_wrap h2 {
	font-size: 24px;
	font-weight: 700;
	line-height: 1.2;
}

/* 2022 sea */

.mv__bg--333 {
	/*background: #333;*/
	padding-top: 120px;
}
@media screen and (max-width:480px){
.mv__bg--333 {
	padding-top: 60px;
}	
}

.mv_sea-wrap {
	background: url("../images/index/mv_sea_bg2.jpg")  no-repeat center #333;
	background-size: cover;
	width:960px;
	margin-left: auto;
	margin-right: auto;
}/**/
.mv_sea-wrap .inner {
	width:960px;
	min-height: 247px;	
	margin-left: auto; 
	margin-right: auto; 
	display: flex;
	flex-flow: row-reverse;
	/*justify-content: center;*/
	align-items: center;
}
.mv_sea-wrap.arena {
    background: url("../images/index/mv_arena_bg.jpg")  no-repeat center #333;
    background-size: cover;
}/* 24-10-09 */

.mv_rec-wrap {
	background: url("../images/index/mv_rec_bg2.jpg")  no-repeat center #333;
	background-size: cover;
	width:960px;
	margin-left: auto;
	margin-right: auto;
}/**/
.mv_rec-wrap .inner {
	width:960px;
	min-height: 247px;	
	margin-left: auto; 
	margin-right: auto; 
	display: flex;
	/*justify-content: center;*/
	align-items: center;
}

.mv__rec {
	width:30%;
	box-sizing: border-box;
	margin: 0 2%;
	/*margin-left: 8%;*/
}/**/
.mv__rec h2 {
	font-size: 24px;
	font-weight: 700;
	line-height: 1.2;
}
.mv__rec h2 small {font-size:18px; font-weight: 400;}
/*.mv_rec p {line-height: 1.7;}*/

@media screen and (max-width:480px){
.arena .mv__rec {
	width:40%;
	box-sizing: border-box;
	margin: 0 0%;
/*    border:1px solid #f00;*/
}    
.arena .mv__rec h2 {
	font-size: 18px;
	font-weight: 700;
	line-height: 1.2;
}
.arena .mv__rec h2 small {font-size:12px; font-weight: 400;}
}/* 24-10-09 */

/* 2023-03-09 hello-glion */
.mv__hg-wrap {
	background: url("../images/hello_glion/bg_mv.jpg") center left -60% no-repeat #f5f5f5;
	background-size: cover;
	width:960px;
	margin-left: auto;
	margin-right: auto;
	min-height: 247px;
	display: flex;
	align-items: center;
	padding: 10px 20px 10px 40px;
}
@media screen and (max-width:480px){
	.mv__hg-wrap {
		width:100%;
		justify-content: center;
		background: url("../images/hello_glion/bg_mv.jpg") left 20% top -30px no-repeat #f5f5f5;
		background-size: auto 50%;
		min-height: 300px
	}
	.mv__hg-wrap.hello {
		width:100%;
		justify-content: center;
		align-items: flex-end;
		background: url("../images/hello_glion/bg_mv.jpg") left 10% top no-repeat #f5f5f5;
		background-size: auto 50%;
		min-height: 200px !important;
	}	
	.mv__hg-wrap div{
		text-align: center
	}
}

@media screen and (max-width:1024px){
	.mv_sea-wrap,.mv_rec-wrap  {width: 100%;}
}
@media screen and (max-width:480px){
	.mv_sea-wrap {
		background: url("../images/index/mv_sea_bg2_sp.jpg")  no-repeat center #333;
		background-size: cover;
	}	
	.mv_sea-wrap.arena {
		background: url("../images/index/mv_arena_bg_sp.jpg")  no-repeat center #333;
		background-size: cover;
	}/* 24-10-09 */     
	.mv_rec-wrap {
		background: url("../images/index/mv_rec_bg2_sp.jpg")  no-repeat center #333;
		background-size: cover;
	}
	.btns__bk--whi.w120 {width:80% !important;}
    .arena .btns__bk--whi.w120 {width:60% !important; font-size: 12px;}    
	.mv_sea-wrap .inner,.mv_rec-wrap .inner {min-height: 160px;}
	.mv__rec {
	width:30%;
	box-sizing: border-box;
	margin: 0 4%;
	/*margin-left: 8%;*/
}/**/
}

.tab_wrap {
	width:960px;
	margin-left: auto;
	margin-right: auto;
}

/* ----------------------------------------------- 2022 
*/

.whi {color:#fff;}

.minc {font-family: 'Noto Serif JP', serif;}
.btns__bk{
	position: relative;
	display: inline-block;
	text-decoration: none;
	color:#fff;
	padding: 5px;
	box-sizing: border-box;
	font-size: 14px;
	text-align: center;
	background: #000;
}
.btns__bk:hover{
	background: #333;
}/**/

.btns__bk--whi{
	position: relative;
	display: inline-block;
	text-decoration: none;
	color:#fff;
	padding:5px;
	box-sizing: border-box;
	font-size: 14px;
	text-align: center;
	border: 1px solid #fff;
}
.btns__bk--whi:hover{
	opacity: 0.6;
}/**/

@media screen and (max-width:1000px){
	.mv__news--tit .btns__bk.w240 {width:80%;}
}
@media screen and (max-width:480px){
		.mv__news--tit .btns__bk.w240 {width:240px;}
}

/* ----------------------- TOP
*/
.mv__gg--wrap {
	width:100%;
	min-height: 570px;
	padding: 60px 0;
	background-blend-mode: lighten;
	background-color: rgba(255,255,255,0.55);
	background-image: url("../images/index/mv_gg_img.jpg");
	background-position: center;
	background-repeat: no-repeat;
	background-size: cover;
	box-sizing: border-box;
}
.mv__gg--wrap .inner {
	width:960px;
	height: 100%;
	margin-left: auto; 
	margin-right: auto; 
/*
	display: flex;
	flex-flow:row-reverse;
	align-items: flex-end;
*/
}
.mv__txt {
	width:/*640*/60%;
	box-sizing: border-box;
	font-size: 16px;
	line-height: 1.5;
/*	margin-right: 5%;*/
/*	border:1px solid #f00;*/
	margin-left: auto;
}
.mv__txt h3 {
	font-size: 42px;
	font-weight: 700;
	line-height: 1.2;
	margin-bottom: 0.8em;
	text-align: right;
}
@media screen and (max-width:1024px){
	.mv__gg--wrap .inner {
	width:100%;}	
}
@media screen and (max-width:834px){
	.mv__txt {
	width:70%;
	}
}
@media screen and (max-width:600px){
	.mv__gg--wrap {width:100%; mni-height: 400px; padding: 30px 0;}
	.mv__gg--wrap .inner {
	height: 100%;
		width: 96%;
	margin-left: auto; 
	margin-right: auto; 
/*
	display: flex;
	flex-flow:row;
		justify-content: center;
	align-items: flex-end;
*/
	}	
	.mv__txt {
	width:/*640*/90%;
	box-sizing: border-box;
	font-size: 16px;
	line-height: 1.5;
	margin-right: 0%;
	/*border:1px solid #f00;*/
}
	.mv__txt h3 {
	font-size: 8vw;
	font-weight: 700;
	line-height: 1.2;
	margin-bottom: 0.8em;
	text-align: center;
}
}	
/* ---------------- top service */

.mv__ser--tit {
	
}

.mv__ser--wrap {
	padding: 100px 0;
	background: linear-gradient(180deg, #000 0%, #000 20%, #fff 20%, #fff 100%);	
}

.mv__ser--wrap .inner {
	width:960px;
	margin-left: auto; 
	margin-right: auto;
	box-sizing: border-box;
	position: relative;

}

.mv__ser--tit {
	position: absolute;
	top:-1em;
	right: 0;
	width: 44.7916%;
	margin:0 25px;
}


.mv__ser--list li {
	width: 44.7916%;
	float: left;
	margin:15px 25px;
}

.mv__ser--list li div {
	background: #111;
	position: relative;
}
.mv__ser--list li div h3 {
	position: absolute;
	display: block;
	z-index: 2;
	top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
	color: #fff;
	white-space: nowrap;
}

.mv__ser--list li div img {transition: 0.3s all; width: 100%; height: auto;}
.mv__ser--list li div img:hover {opacity: 0.5;}

div {box-sizing: border-box;}

.dan2 {margin-top: 140px;}
.dan3,.dan5,.dan7 {margin-top: -140px;}

@media screen and (max-width:1024px){
	.mv__ser--wrap .inner {width:100%;}
	.mv__ser--list li {
		float: left;
		margin:5px 2.6%;
	}
	.dan2 {margin-top: 70px;}
	.dan3,.dan5,.dan7 {margin-top: -70px;}	
}

@media screen and (max-width:600px){
	.mv__ser--wrap {padding: 50px 0;}	
	.mv__ser--list li div h3 {font-size: 3vw;}
}

/* ----------------- top newsrelease */

.mv__news--wrap {width:100%; padding: 80px 0;}
/*
.mv__news--wrap .inner {
	width:960px; 
	margin-left: auto; 
	margin-right: auto;
	display: flex;
	flex-flow: row;
	justify-content: space-between;
}
*/
.mv__news--wrap .inner {
	width:960px; 
	margin-left: auto; 
	margin-right: auto;
/*
	display: flex;
	flex-flow: row;
	justify-content: space-between;
*/
}

.mv__news--kei{
	width: 50px;
    border-top: 3px solid #333;
    border-right: none;
    border-bottom: none;
    border-left: none;
	margin-left: 1px;
}

.mv__news--tit {width:25%;}/*240*/
/*.mv__gg--wrap {width:69.7916%;}*//*670*/
.mv__news--box {display: flex; flex-flow: row; justify-content: space-between}
.mv__news--box a {text-decoration: none; color: #333; transition: 0.2s all; display: block; margin-bottom: 20px; width: 31%; background: #fff}
.mv__news--box a:hover {opacity: 0.8;}

/*.mv__news--list {background: #fff; display: flex; flex-flow: row nowrap;}*/
/*.mv__news--list dt {width:52.2388%;}*//*350*/
.mv__news--list dt img {max-width: 100%; height: auto;}
/*.mv__news--list dd {width:47.7611%;padding:1em; box-sizing: border-box;}*//*320*/
.mv__news--list dd {width:100%; padding:1em; box-sizing: border-box;}
.mv__news--list dd h3 {font-weight: normal; font-size: 15px; line-height: 1.5;}
.mv__news--list time {font-size: 11px; display: block; margin-bottom: 5px;}

.mv__kei--wrap{display: flex; flex-flow: row; justify-content: flex-end}

@media screen and (max-width:1024px){
	.mv__news--wrap .inner {
	width:96%;}	
}
@media screen and (max-width:600px){
	.mv__news--wrap {width:100%; padding: 40px 0;}
	.mv__news--wrap .inner {
		width:90%;
		display: block;
	}
	.mv__news--box a {width: 100%;}
	.mv__news--box {display: block}
	.mv__news--tit,.mv__news--box {width:100%;}
	.mv__news--list {display: flex; flex-flow: row nowrap;}
	.mv__news--list dt {width:30%; }
	.mv__news--list dd {width:70%; padding:0.3em 0.5em;}
	.mv__news--list dd h3 {font-size: 13px;}
	.mv__news--list dt img {width: 100%; /* 好きなサイズを指定 */
  aspect-ratio: 1 / 1; /* アスペクト比を1:1に */
  object-fit: cover;}
	.mv__kei--wrap{display: flex; flex-flow: row; justify-content: center}
}

/* ----------------- top search */
.mv__sea--wrap {
	width:100%;
	height: 270px;
	background-image: url("../images/index/mv_bus_img.jpg");
	background-position: bottom;
	background-repeat: no-repeat;
	background-size: cover;		
}/**/

.mv__sea--wrap .inner {width:960px; height: 100%; margin: 0 auto; display: flex; align-items: center;}
.mv__sea--tit {width:50%;}

/* ----------------- top recruit */
.mv__rec--wrap {
	width:100%;
	height: 270px;
	background-image: url("../images/index/mv_bus_left.jpg");
	background-position: bottom;
	background-repeat: no-repeat;
	background-size: cover;		
}/**/

.mv__rec--wrap .inner {width:960px; height: 100%; margin: 0 auto; display: flex; flex-flow: row-reverse; align-items: center;}
.mv__sea--tit {width:50%;}

@media screen and (max-width:1024px){
	.mv__sea--wrap .inner,.mv__rec--wrap .inner {
	width:100%;}
	.mv__sea--tit,.mv__sea--tit {width:100%;}
}

/*------------------------------- 2022 top end */

@media screen and (max-width:1024px){
	.tab_wrap {
	width:100%;
	}
}

.tab-area {
width:100%; 
	margin-left: auto; 
	margin-right: auto;
  display: flex;
  justify-content:space-between;
  background-color: #768290;
	cursor: pointer;}
.tab {
    width: 33%;
    height: 30px;
    line-height: 30px;
    text-align: center;
    color: white;
  }
.tab.active {
    background-color: #333/*e7311b*/;
    color: #fff;
}

.content-area {
}
.content {
    display: none;
}
.content.show {
    margin-top: 50px;
    display: block;
}


/* btns */
.btns {
	position: relative;
	display: inline-block;
	text-decoration: none;
	color:#333;
	padding: 5px;
	border:1px solid #333;
	box-sizing: border-box;
	font-size: 14px;
	text-align: center;
}
.btns:hover {
	color:#e7311b;
	border:1px solid #e7311b;
}

.btns::after,.btns-bk::after{
  content: "";
  width: 10px;
  height: 10px;
  position: absolute;
  right: 10px;
  top: 50%;
  margin-top: -5px;
  -webkit-transform: rotateZ(45deg);
  -ms-transform: rotate(45deg);
  transform: rotateZ(45deg);
  border-style: solid;
  border-width: 2px 2px 0 0;
  border-left-color: #fff
}/**/

.btns-bk{
	position: relative;
	display: inline-block;
	text-decoration: none;
	color:#fff;
	padding: 5px;
	box-sizing: border-box;
	font-size: 14px;
	text-align: center;
	background: #000;
}/**/
.btns-bk:hover{
	background: #e7311b;
}/**/

.btn_kadmaru {
	position: relative;
	display: inline-block;
	text-decoration: none;
	color:#fff;
	background: #000;
	border-radius: 16px;
	padding: 10px 20px;
	box-sizing: border-box;
	font-size: 16px;
	text-align: center;
}
.btn_kadmaru::after{
  content: "";
  width: 10px;
  height: 10px;
  position: absolute;
  right: 20px;
  top: 50%;
  margin-top: -5px;
  -webkit-transform: rotateZ(45deg);
  -ms-transform: rotate(45deg);
  transform: rotateZ(45deg);
  border-style: solid;
  border-width: 2px 2px 0 0;
  border-left-color: #fff
}

.btn_kadmaru:hover {
	background: #e7311b;
}/**/


/* common */
.w120 {width:120px;}
.w180 {width:180px;}
.w240 {width:240px;}
.w300 {width:300px;}
.aC {text-align: center !important;}
.aL {text-align: left !important;}
.aR {text-align: right !important;}
.mb10 {margin-bottom: 10px;}
.mb20 {margin-bottom: 20px;}
.mb30 {margin-bottom: 10px;}
.mb40 {margin-bottom: 40px;}
.mb50 {margin-bottom: 50px;}
.mb60 {margin-bottom: 60px;}
.mb80 {margin-bottom: 80px;}
.mb100 {margin-bottom: 100px;}
.mb120 {margin-bottom: 120px;}
.mb140 {margin-bottom: 140px;}
.mb150 {margin-bottom: 150px;}
.mb200 {margin-bottom: 200px;}
.mt60 {margin-top: 60px;}

.mb05em {margin-bottom: 0.5em;}
.mb08em {margin-bottom: 0.8em;}
.mb1em {margin-bottom: 1em;}
.mb2em {margin-bottom: 2em;}
.mb3em {margin-bottom: 3em;}
.mb4em {margin-bottom: 4em;}
.mb5em {margin-bottom: 5em;}

@media screen and (max-width:1024px) {
	.mv_wrap .inner,.mv_gg_wrap .inner,.mv_bus_wrap .inner,.mv_sea_wrap .inner,.mv_rec-wrap .inner,.mv_sea-wrap .inner {
		width: 100%;
	}
}

@media screen and (max-width:768px){
.mv_gg_wrap,.mv_bus_wrap {
	height: auto;
}
	.mv_gg_wrap .inner,.mv_bus_wrap .inner {
	flex-direction: column;
	align-items: center;
}
	.mv_tit {
	width:/*34em*/100%;
	min-height: 150px;
	box-sizing: border-box;
	display: flex;
	flex-direction: column;
	justify-content: center;
	}
	.mv_txt {
	width:/*580*/90%;
	padding: 20px 20px;
	background: rgba(255,255,255,0.8);
	min-height: 150px;
	box-sizing: border-box;
	display: flex;
	flex-flow: wrap;
	justify-content: center;
	 align-items: center;
	font-size: 16px;
	line-height: 1.5;
}
	.mv_txt .aR {
		text-align: center !important;/*btnをcenter*/
	}
	
/*.mv_rec_wrap {
	width: 100% !important;
	height: 300px;
	background-position: center right;
}	
	
.mv_rec {
	width:90%;
	height: auto;
}	*/

.mv_bs_wrap {
	overflow: hidden;
	display: block;
}/**/
.bus_wrap {
	width:100%;
	height: 270px;
}/**/
.sea_wrap {
	width:100%;
	height: 270px;	
}/**/

.bs_mat {
	/*min-height: 350px;*/
	padding: 40px 10px 40px;
	width:90%;
}
	
	.mv_rec_wrap {
	background: url("../images/index/mv_rec_bg.jpg")  no-repeat 62% center;
	background-size: cover;
	margin-left: auto;
	margin-right: auto;
}/**/
	
}

@media screen and (max-width:480px){
	.mv_wrap {background: url("../images/index/mv_img_sp.jpg")  no-repeat center #fff; background-size: cover;}
	.mv_wrap .inner {
		width: 100%;
	height:540px;
	margin-left: auto; 
	margin-right: auto; 
	display: flex; 
	justify-content: center; 
	align-items:flex-start;
		padding-top: 10vh;
		box-sizing: border-box;

}	
	.mv_wrap .inner img {width:200px;/*240*/}
	
	.mv_rec_wrap {
	background: url("../images/index/mv_rec_bg_sp.jpg")  no-repeat center bottom;
	background-size: cover;
	margin-left: auto;
	margin-right: auto;
}/**/
.mv_rec_wrap .inner {
	min-height: 458px;	
	margin-left: auto; 
	margin-right: auto; 
	display: flex; 
	/*justify-content: center;*/
	align-items:flex-start;
}

.mv_rec {
	width:90%;
	margin-top: 20px;
	margin-left: auto;
	margin-right: auto;
	box-sizing: border-box;
	text-align: center;
}/**/	
	
}
@media screen and (max-width:320px){
	.mv_wrap .inner {
	height:400px;
}
	
	.w300 {width: 100%;}
}

/* sns 2022 */
.sns__list {
	margin-top: 0;
	display: flex;
	justify-content: center;
	align-items: center;
	text-align: center;
	background: #efefef;/**/
	padding: 20px 0;
}
.sns__list li {margin: 0 0.5em;}
.sns__list li a:hover {opacity: 0.6}


/* kuten */
.kuten {position: relative;}
.kuten::after{
	position: absolute;
	bottom:0.1em;
	right: -1em;
	content: "。"
}

/* 39fair */
.bnr__39 {
	position: fixed;
	right:0;
	bottom:40px;
}
@media screen and (max-width:600px){
	.bnr__39 {
	position: fixed;
	right:0;
	bottom:70px;
}
}

/* sp menu sns */
.snsArea .sns__sp {
    display: flex;
    flex-flow: row;
    justify-content: center;
    color: #fff;
    margin-top: 40px
}
.snsArea .sns__sp li a {
    color: #fff;
    width: 40px;
    height: 40px;
    display: flex;
    align-items: center;
    justify-content: center;
    text-decoration: none
}

/* 20240826 tuika */
.nav__link,
.nav__link__bs{
    display: flex;
    flex-flow: row wrap;
    justify-content: space-between
}
.nav__link li{
    width:24%;
    margin-bottom: 10px;
        border:1px solid #ccc;
}
.nav__link__bs li {
    width:32%;
    margin-bottom: 10px;
    border:1px solid #ccc;
/*
    display: flex;
    align-items: center;
    justify-content: center
*/
}
.nav__link li a,
.nav__link__bs li a {
    box-sizing: border-box;
    text-decoration: none;
    color: #333;
    height: 60px;
    width: 100%;
    padding: 10px;
    display: flex;
    align-items: center;
    justify-content: center;
    text-align: center;
    transition: .3s all ease
}
.nav__link li a:hover,
.nav__link__bs li a:hover {
    background: #333;
    color: #fff
}
.nav__link li a.current,
.nav__link__bs li a.current {
    background: #333;
    color: #fff
}

@media screen and (max-width:600px){

   .nav__link li,
    .nav__link__bs li{
        margin-bottom: 5px;
       width: 49%;
       font-size: 3.4vw
    }
}

/* ------ 2024-10-08 */
.tokuten__wrap {
    max-width:960px; 
    margin: 40px auto; 
    display: flex; 
    flex-flow: column; 
    align-items: center; 
/*    background: #fff; */
    padding:25px; 
    line-height: 1.3
}
.dan-1 {
    text-indent: -1em; padding-left: 1em
}
.mb_vw {
    margin-bottom: 7px
}
.tokuten__wrap h2 {
    font-size: 14px;
}
    p,ul {font-size: 12px;}
@media screen and (max-width:600px){
    .mb_vw {
    margin-bottom: 1.86vw
}
}