/* CSS Document */
@import url("https://fonts.googleapis.com/css?family=Noto+Sans+JP:100,300,400,500,700,900&display=swap&subset=japanese");
body {
  font-family: 'Noto Sans JP', sans-serif;
  scroll-behavior: smooth; }

.overflow_eliminator {
  max-width: 100%;
  overflow: hidden;
  position: relative; }

.spacer {
  width: 100%;
  overflow: auto;
  height: 5px; }

.mid-spacer {
  width: 100%;
  overflow: auto;
  height: 25px; }

.dropdownspace {
  display: none;
  transition: all 0.2s; }

.dropdownspace.hovered {
  padding-top: 30px;
  position: fixed;
  display: block;
  min-height: 200px;
  max-height: 400px;
  background-color: rgba(123, 123, 123, 0.8);
  z-index: 40;
  left: 0px;
  top: 105px;
  width: 100%;
  color: white;
  opacity: 1;
  -webkit-box-shadow: -1px 1px 2px 0px rgba(0, 0, 0, 0.5);
  -moz-box-shadow: -1px 1px 2px 0px rgba(0, 0, 0, 0.5);
  box-shadow: -1px 1px 2px 0px rgba(0, 0, 0, 0.5); }

.headroom--unpinned .dropdownspace {
  display: none; }

.navcontrols .hasDropdown {
  position: relative;
  padding-bottom: 100px; }

.navcontrols .hasDropdown:after {
  content: "";
  position: absolute;
  height: 100px;
  width: 50px; }

.navcontrols .hasDropdown:before {
  content: "";
  position: absolute;
  left: -50px;
  height: 100px;
  width: 50px; }

.iemidfix .mainholders {
  flex-grow: 1;
  flex-shrink: 0;
  flex-basis: 0;
  overflow: hidden; }

.centertext {
  height: 100%;
  width: 100%;
  display: flex;
  /*justify-content: center;*/
  flex-direction: column;
  text-align: left;
  font-size: 18px;
  font-weight: 700;
  padding-top: 65px;
  box-sizing: border-box;
   }

.mainholders {
  flex-basis: auto;
  position: relative;
  overflow: auto;
  height: 0;
  padding-bottom: 35.5555555556%; }

.mainholders .backmain {
  position: relative;
  width: 100%;
  z-index: 1; }

.mainholders .frontmain {
  position: relative;
  max-width: 100%;
  z-index: 2; }

.topnavbar {
  position: fixed;
  height: 105px;
  width: 100%;
  z-index: 5;
  padding: 20px 40px 10px;
  transition: all 0.4s;
  top: 0px;
  background-color: rgba(0, 0, 0, 0); }

.topnavbar .toplogo {
  width: 240px;
  padding-top: 15px; }

.topnavbar .navcontrols {
  float: right;
  width: calc(100vw - 350px); }

.topnavbar .navcontrols ul {
  float: right;
  padding-top: 18px; }

.topnavbar .navcontrols ul li {
  display: inline-block;
  text-align: center;
  width: calc((100vw - (220px + 15vw)  ) / 6.5);
  float: left;
  max-width: 200px; }

.topnavbar .navcontrols ul li a {
  font-size: 16px;
  font-weight: 300;
  color: white;
  -moz-text-shadow: 0px 0px 4px rgba(0, 0, 0, 0.8);
  -webkit-text-shadow: 0px 0px 4px rgba(0, 0, 0, 0.8);
  -ms-text-shadow: 0px 0px 4px rgba(0, 0, 0, 0.8);
  text-shadow: 0px 0px 3px rgba(0, 0, 0, 0.9); }

.headroom--unpinned {
  top: -120px; }

.headroom--not-top {
  background-color: rgba(0, 0, 0, 0.8); }

.footer {
  padding-top: 30px;
  padding-bottom: 30px;
  min-height: 100px;
  background-color: #333333; }

.footer .footerbot li {
  list-style: none;
  line-height: 14px;
  margin-bottom: 16px; }

.footer .footerbot a {
  color: white;
  font-size: 14px;
  font-weight: 100; }

.footer .footerbot span {
  color: white; }

.footer .footerbot .highlight {
  font-weight: 500;
  font-size: 14px;
  line-height: 18px; }

.footer .footerglobe {
  color: white;
  padding-top: 25px;
  text-align: center; }

.footer .footerglobe a {
  color: white; }

.footer .footerglobe img {
  width: 20px;
  height: 20px;
  display: block;
  margin: 0 auto; }

.topglobe {
  color: white;
  position: relative;
  top: -8px;
  text-align: center; }

.topglobe a {
  color: white; }

.topglobe img {
  width: 30px;
  height: 30px;
  display: block;
  margin: 0 auto; }

.copyrightarea {
  background-color: black;
  padding: 15px 0;
  overflow: auto; }

.copyrightloc {
  float: right;
  padding-right: 5%;
  color: white;
  font-size: 13px;
  font-weight: 100; }

.footerlogo {
  float: left;
  margin-left: 5%; }

.footerlogo img {
  width: 150px; }

#mobileheader {
  height: 65px;
  position: fixed;
  z-index: 50;
  width: 100%;
  top: 0;
  transition: all 0.4s; }

#mobileheader .mobiletoplogo {
  float: left;
  margin-left: 25px;
  margin-top: 25px;
  width: 150px; }

#mobileheader .mobilenavigation {
  display: block;
  float: right;
  margin-right: 20px;
  margin-top: 20px;
  width: 25px;
  height: 20px;
  overflow: hidden; }

#mobileheader .mobilenavigation .hamburger {
  position: relative;
  width: 25px;
  height: 20px; }

#mobileheader .mobilenavigation .hamburger span {
  opacity: 1;
  left: 0;
  display: block;
  width: 100%;
  height: 2px;
  border-radius: 10px;
  color: black;
  background-color: white;
  position: absolute;
  transform: rotate(0deg);
  transition: .4s ease-in-out; }

#mobileheader .mobilenavigation .hamburger span:nth-child(1) {
  top: 0; }

#mobileheader .mobilenavigation .hamburger span:nth-child(2) {
  top: 9px; }

#mobileheader .mobilenavigation .hamburger span:nth-child(3) {
  top: 18px; }

#mobileheader .mobilenavigation .hamburger.open span:nth-child(1) {
  transform: translateY(9px) rotate(135deg); }

#mobileheader .mobilenavigation .hamburger.open span:nth-child(2) {
  opacity: 0;
  transform: translateX(60px); }

#mobileheader .mobilenavigation .hamburger.open span:nth-child(3) {
  transform: translateY(-9px) rotate(-135deg); }

.mobilemenu {
  position: fixed;
  top: 65px;
  left: 60vw;
  background-color: rgba(0, 0, 0, 0);
  height: calc(100vh - 65px);
  width: 100vw;
  z-index: -5;
  opacity: 0;
  transition: all 0.4s;
  overflow: auto;
  -webkit-overflow-scrolling : touch;
}
.mobilemenu::-webkit-scrollbar {
  display: none;
}

.mobilemenu div {
  position: relative; }

.mobilemenu.open {
  background-color: rgba(0, 0, 0, 0.9);
  left: 0vw;
  z-index: 50;
  opacity: 1; }

.mobilemenuitem {
  color: white;
  width: 90vw;
  margin: 12px auto 12px;
  border-bottom: 1px solid #808080; }

.mobilemenuitem .spacer {
  width: 100%;
  height: 20px; }

.mobilemenuitem a {
  font-weight: 500;
  color: white;
  display: block;
  font-size: 16px;
  margin-left: 30px;
  padding-bottom: 12px;
  position: relative; }

.mobilemenuitem a:after {
  content: "";
  width: 0;
  height: 0;
  border-style: solid;
  border-width: 5px 0 5px 8.7px;
  border-color: transparent transparent transparent #ffffff;
  position: relative;
  display: inline-block;
  left: 13px; }

.mobilemenuitem a.mobilesub {
  margin-left: 90px;
  font-size: 14px;
  font-weight: 300;
  padding: 15px 0px 0px; }

.mobilemenuitem span {
  font-weight: 500;
  color: white;
  display: block;
  font-size: 16px;
  margin-left: 30px;
  display: block;
  padding-bottom: 0px; }

.mobilemenuglobe {
  padding-top: 20px;
  display: block;
  text-align: center;
  padding-bottom: 100px; }

.mobilemenuglobe .mobtopglobe {
  width: 20px;
  height: 20px; }

.mobilemenuglobe a {
  color: white;
  font-size: 14px; }

.mobilemenuglobe span {
  display: block;
  padding-top: 3px; }

.slide :nth-child(1) {
  animation: slidein;
  animation-duration: .25s; }

.slide :nth-child(2) {
  animation: slidein;
  animation-duration: .35s; }

.slide :nth-child(3) {
  animation: slidein;
  animation-duration: .4s; }

.slide :nth-child(4) {
  animation: slidein;
  animation-duration: .45s; }

.slide :nth-child(5) {
  animation: slidein;
  animation-duration: .5s; }

.slide :nth-child(6) {
  animation: slidein;
  animation-duration: .53s; }

.slide :nth-child(7) {
  animation: slidein;
  animation-duration: .57s; }

.slide :nth-child(8) {
  animation: slidein;
  animation-duration: .6; }

@keyframes slidein {
  0% {
    transform: translate(150px); }
  100% {
    transform: translate(0px); } }
.mobile-headroom--top {
  background: rgba(0, 0, 0, 0); }

.mobile-headroom--not-top {
  background: rgba(0, 0, 0, 0.9); }

.mobile-headroom--unpinned {
  top: -65px !important; }

.hoverfade {
  opacity: 1;
  transition: all 0.2s; }

.hoverfade:hover {
  opacity: 0.8; }

.mobilewhitebuttonholder {
  width: 100%;
  text-align: center; }

.mobilewhitebutton {
  background-color: white;
  padding: 12px 55px 12px 20px;
  min-width: 10px;
  text-align: left;
  position: relative;
  margin: 0 auto;
  display: inline-block; }

.mobilewhitebutton:hover {
  text-decoration: none; }

.mobilewhitebutton > .darktext {
  color: black;
  display: block; }

.mobilewhitebutton .midsize {
  font-size: 0.7rem;
  line-height: 0.85rem;
  font-weight: 900; }

.mobilewhitebutton .smallsize {
  font-size: 0.7rem;
  line-height: 0.85rem;
  font-weight: 500; }

.mobilewhitebutton:after {
  content: "";
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  right: 25px;
  width: 0;
  height: 0;
  border-style: solid;
  border-width: 6px 0 6px 9px;
  border-color: transparent transparent transparent #000000; }

.mobilereduction {
  max-width: 100vw;
  overflow: hidden; }

.footerheader {
  font-size: 13px;
  font-weight: 700;
  margin-bottom: 2px; }

.mobilefooter {
  background-color: #262626;
  padding-top: 37px; }

.mobilefooter .mobfootlist {
  padding-left: 0;
  text-align: center; }

.mobilefooter .mobfootlist a {
  color: white;
  font-size: 11px;
  font-weight: 300;
  line-height: 28px; }

.mobilefooter .mobfootlist li {
  list-style: none; }

.mobilefooter .mobfootlist li.mobfoothigh {
  font-size: 13px;
  font-weight: 700;
  color: white; }

.mobilefooter .mobfootlist li.mobfoothigh a {
  font-size: 12px;
  font-weight: 700; }

.mobilefooter .mobfootglobe {
  padding-top: 20px;
  display: block;
  text-align: center;
  padding-bottom: 20px; }

.mobilefooter .mobfootglobe .mobfootglsvg {
  width: 20px;
  height: 20px; }

.mobilefooter .mobfootglobe a {
  color: white;
  font-size: 14px; }

.mobilefooter .mobfootglobe span {
  display: block;
  padding-top: 3px; }

.mobcopyright {
  padding: 10px 15px;
  background-color: black;
  overflow: auto; }

.mobcopyright .mobcopylogo {
  float: left; }

.mobcopyright .mobcopylogo img {
  height: 25px; }

.mobcopyright .mobcopyrighttext {
  float: right;
  color: white;
  font-size: 7px;
  font-weight: 300;
  line-height: 25px; }

.desktop_background_top {
  position: relative;
  background-position: center !important;
  background-size: cover !important;
  min-height: 450px; }

.desktop_background_top > .desktoptitle {
  position: absolute;
  top: 50%;
  text-align: center;
  width: 100%;
  padding-left: 10px;
  padding-right: 10px;
  transform: translate(0, -50%);
  color: white;
 text-shadow:0px 0px 3px #232323;}

.desktoptitle {
  font-size: 2.5rem; }

body:before {
  content: "";
  display: block;
  position: fixed;
  left: 0;
  top: 0;
  width: 100%;
  height: 100%;
  z-index: -10;
  background: url("/template/common/image/draw.png") no-repeat center center;
  -webkit-background-size: cover;
  -moz-background-size: cover;
  -o-background-size: cover;
  background-size: cover; }

.pankuzutop {
  padding-top: 25px;
  padding-left: 25px;
  padding-bottom: 25px;
  color: #6F6F6F;
 font-size: 0.9em;
 font-weight: 300;}

.pankuzutop a {
  color: #6F6F6F; }

div.reg {
  width: 90vw;
  max-width: 1000px;
  margin: 0 auto; }

div.wide {
  max-width: 1200px;
  margin: 0 auto; }

div.full {
  max-width: 100vw;
  margin: 0 auto; }

div.spacer-sm {
  width: 100%;
  height: 10px;
  overflow: auto;
  clear: both; }

div.spacer-md {
  width: 100%;
  height: 25px;
  overflow: auto;
  clear: both; }

div.spacer-lg {
  width: 100%;
  height: 50px;
  overflow: auto;
  clear: both; }

p.p-lg {
  font-size: 16px;
  font-weight: 400;
  line-height: 27px; }

p.p-reg {
  font-size: 16px;
  font-weight: 300;
  line-height: 24px; }

p.p-caption {
  font-size: 13px;
  font-weight: 300;
  line-height: 16px; }

.h-mega {
  padding: 60px 0 45px;
  text-align: center;
  font-size: 28px;
  font-weight: 500;
  width: 100%; }

.h-big {
  text-align: center;
  font-size: 22px;
  font-weight: 500;
  line-height: 35px; }

img.img-center {
  margin: 0 auto;
  display: block; }

.p-pad {
  padding-left: 15px;
  padding-right: 15px; }

.black-bg {
  background-color: black;
  color: white; }

.with-bg {
  background-size: cover !important;
  max-width: 100% !important; }

div.img-full {
  width: 100%;
  overflow: hidden; }

div.img-full img {
  width: 100%; }

.sp-show-block {
  display: none; }

.whitebuttonholder {
  width: 100%;
  text-align: center;
  font-weight: 700; }
  .whitebuttonholder .regularweight {
    font-weight: 300; }

.whitebutton {
  background-color: white;
  font-size: 13px;
  line-height: 20px;
  text-align: left;
  position: relative;
  margin: 0 auto;
  display: inline-block; }
  .whitebutton:hover {
    text-decoration: none; }
  .whitebutton > .darktext {
    color: black; }
  .whitebutton.black-outline {
    border: 1px solid #666; }
  .whitebutton.big {
    font-size: 15px;
    line-height: 20px;
    min-width: 180px;
    min-height: 40px;
    padding: 18px 75px 18px 35px; }
    .whitebutton.big:after {
      content: "";
      position: absolute;
      top: 50%;
      transform: translateY(-50%);
      right: 25px;
      width: 0;
      height: 0;
      border-style: solid;
      border-width: 9px 0 9px 15px;
      border-color: transparent transparent transparent #000000; }
  .whitebutton.small {
    padding: 15px 55px 15px 35px;
    text-align: center;
    min-width: 140px;
    font-size: 15px;
    font-weight: 400;
    min-height: 50px; }
    .whitebutton.small:after {
      content: "";
      position: absolute;
      top: 50%;
      transform: translateY(-50%);
      right: 25px;
      width: 0;
      height: 0;
      border-style: solid;
      border-width: 7.6px 0 7.6px 11px;
      border-color: transparent transparent transparent #000000; }


/*10月追加*/

div.picture-with-button {
	position:relative;
	width: 100%;
}
div.picture-with-button img{
width:100%;	
	
}
div.picture-with-button .whitebuttonholder {
	  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
}


@media only screen and (max-width: 992px) {
  .desktop_background_top {
    min-height: 300px; } }
@media only screen and (max-width: 768px) {
  .desktop_background_top {
    min-height: 250px;
    background-size: 50%; }

  div.wide {
    margin: 0px 20px; }

  p.p-lg {
    font-size: 15px;
    font-weight: 400;
    line-height: 20px; }

  .p-pad {
    padding: 0; }

  p.p-reg {
    font-size: 14px;
    font-weight: 300;
    line-height: 18px; }

  .spacer-lg {
    height: 0px !important; }

  .spacer-md {
    height: 0px !important; }

  .spacer-sm {
    height: 0px !important; }

  .h-mega {
    padding: 60px 0 10px;
    text-align: center;
    font-size: 20px;
    font-weight: 500; }

  .h-big {
    text-align: center;
    font-size: 16px;
    font-weight: 500;
    line-height: 20px; }

  .pankuzutop {
    font-size: 13px;
    padding-top: 7px;
    padding-left: 10px;
    padding-bottom: 13px;
    color: #6F6F6F; 
    font-size: 0.8em;
    font-weight: 300;}

  .pankuzutop a {
    color: #6F6F6F; }

  .SP_pad-lg {
    width: 100%;
    height: 35px; }

  .SP_pad-md {
    width: 100%;
    height: 10px; }

  .SP_pad-sm {
    width: 100%;
    height: 5px; }

  div.reg {
    width: 100%; }

  div.sp_padding_10 {
    padding-left: 10px;
    padding-right: 10px; }

  div.sp_padding_20 {
    padding-left: 20px;
    padding-right: 20px; }

  .sp-hidden {
    display: none !important; }

  .sp-show-block {
    display: block; }

  .sp-arrow {
    padding-left: 12px;
    color: black;
    position: relative;
    font-size: 0.85em; }

  .sp-arrow:before {
    content: "";
    position: absolute;
    left: 0px;
    top: 8px;
    width: 0;
    height: 0;
    border-style: solid;
    border-width: 5px 0 5px 8.7px;
    border-color: transparent transparent transparent #000000; }

  .desktoptitle {
    font-size: 1.8rem; } }

/* 20210224 */
.contentsmid .col-5 {
  padding-bottom: 20px;
  box-sizing: border-box
}

.contentsmid .mainholders {
  margin-bottom: 5px
}

.contentsmid a.dropdownChild {
  line-height: 1.5;
  display: block;
  position: relative;
  padding-left: 2.5em;
  box-sizing: border-box;
  font-size: 16px;
  text-align: left;
  color: #fff;
}

.contentsmid a.dropdownChild:before {
  content: '－';
  position: absolute;
  top: 0;
  left: 1em
}

.mobilemenuitem a.mobilesub.is-child {
	position: relative;
	padding-left: 2.5em;
	box-sizing: border-box
}

.mobilemenuitem a.mobilesub.is-child:before {
	content: '－';
	position: absolute;
	top: 15px;
	left: 14px
}

.mobilefooter {
	border-top: 2px solid #d3d3d4;
	box-sizing: border-box;
	background: #fff
}

.mobilefooter .row {
	padding: 0 20px 17px;
	box-sizing: border-box;
	-webkit-box-pack: justify;
	-ms-flex-pack: justify;
	justify-content: space-between
}

.mobilefooter .col {
	-webkit-box-flex: 0;
	-ms-flex: 0 0 45%;
	flex: 0 0 45%;
	max-width: 45%;
	margin-bottom: 20px
}

.mobilefooter .mobfootlist {
	text-align: left
}

.mobilefooter .mobfootlist .parent {
	margin-bottom: 5px;
	font-weight: 700;
	font-size: 12px
}

.mobilefooter .mobfootlist .parent a,
.mobilefooter .mobfootlist .parent span {
	line-height: 2;
	display: block;
	font-weight: 700;
	font-size: 12px
}

.mobilefooter .mobfootlist .child a,
.mobilefooter .mobfootlist .grand a {
	line-height: 2;
	position: relative;
	padding-left: 1.5em;
	box-sizing: border-box
}

.mobilefooter .mobfootlist .child a:before,
.mobilefooter .mobfootlist .grand a:before {
	content: '－';
	position: absolute;
	top: 0;
	left: 0
}

.mobilefooter .mobfootlist .grand a {
	padding-left: 2.5em
}

.mobilefooter .mobfootlist .grand a:before {
	content: '├';
	left: 1.3em
}

.mobilefooter .mobfootlist a {
	display: block;
	color: #000
}

.mobilefooter .ftNav {
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	-ms-flex-wrap: wrap;
	flex-wrap: wrap;
	-webkit-box-pack: justify;
	-ms-flex-pack: justify;
	justify-content: space-between;
	padding: 20px 20px 10px;
	box-sizing: border-box;
	background: #333;
	color: #fff
}

.mobilefooter .ftNav li {
	width: calc(50% - 10px);
	margin-bottom: 10px
}

.mobilefooter .ftNav li a {
	line-height: 1.5;
	display: block;
	font-size: 13px
}

.footer {
	padding: 0;
	border-top: 2px solid #d3d3d4;
	box-sizing: border-box;
	background: #fff
}

.footer .row {
	padding: 40px 0 20px;
	box-sizing: border-box;
	-webkit-box-pack: justify;
	-ms-flex-pack: justify;
	justify-content: space-between
}

.footer .col {
	-webkit-box-flex: 0;
	-ms-flex: 0 0 25%;
	flex: 0 0 25%;
	max-width: 25%;
	margin-bottom: 20px
}

.footer .footerbot {
	text-align: left
}

.footer .footerbot li {
	margin-bottom: 8px
}

.footer .footerbot .parent {
	margin-bottom: 10px;
	font-weight: 700;
	font-size: 16px
}

.footer .footerbot .parent a,
.footer .footerbot .parent span {
	line-height: 2;
	display: block;
	color: #000;
	font-weight: 700;
	font-size: 16px
}

.footer .footerbot .child a,
.footer .footerbot .grand a {
	line-height: 1.5;
	position: relative;
	padding-left: 1.5em;
	box-sizing: border-box
}

.footer .footerbot .child a:before,
.footer .footerbot .grand a:before {
	content: '－';
	position: absolute;
	top: 0;
	left: 0
}

.footer .footerbot .grand a {
	padding-left: 2.5em
}

.footer .footerbot .grand a:before {
	content: '├';
	left: 1.3em
}

.footer .footerbot a {
  display: block;
	color: #000;
	font-size: 14px
}
.footer .footerglobe  a {
  color: #000;
}

.ftNav {
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	-ms-flex-wrap: wrap;
	flex-wrap: wrap;
	-webkit-box-pack: center;
	-ms-flex-pack: center;
	justify-content: center;
  margin: 0;
	padding: 30px;
	box-sizing: border-box;
	background: #333;
	color: #fff;
  list-style:none;
}

.ftNav li {
	margin: 0 15px
}

.ftNav li a {
	line-height: 1.5;
	display: block;
	font-size: 14px;
  color: #fff;
}

html.is-fixed{
  height: 100%;
  overflow: hidden;
}