@charset "utf-8";
* {
  box-sizing: border-box;
}
.red{color: #D41A20;}
.yellow{color: #FFFF00;}
.pc_only{display: block;}
.pc_none{display: none;}
.sp_only{display: none;}
body {
  margin: 0;
  padding: 0;
  height: 100%;
  font-family: "メイリオ", Meiryo, "ＭＳ Ｐゴシック", "MS PGothic", "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", Osaka, Arial, Helvetica;
  -webkit-text-size-adjust: 100%;
  background-color: #fff;
  letter-spacing: 0.2em;
}
header {
  z-index: 9999;
  padding: 10px 4% 10px;
  position: fixed;
  top: 0;
  width: 100%;
  /*
  background-color: #2293c9;
  */
  background-color: #222222;
  display: flex;
  align-items: center;
  transition: all .2s ease-out;
}
header.min-header {
  padding: 10px 4%;
  /*
  background-color: #2293c9;
  */
  background-color: #222222;
}
.page_top{
  width: 50px;
  height: 50px;
  position: fixed;
  right: 25px;
  bottom: 20px;
  background: #3f98ef;
  opacity: 0.6;
  border-radius: 50%;
	 z-index: 999;
}
.page_top a{
  position: relative;
  display: block;
  width: 50px;
  height: 50px;
  text-decoration: none;
  text-align: center;
}
.page_top a::before{
  font-family: "Font Awesome 5 Free";
  content: '\f106';
  font-weight: 900;
  font-size: 25px;
  color: #fff;
  position: absolute;
  width: 25px;
  height: 25px;
  top: 10px;
  bottom: 10px;
  right: 0;
  left: 0;
  margin: auto;
}

a:hover {
  color: #fff000;
}
h1 {
  margin: 0;
  padding: 0;
  font-size: 20px;
}
h2, h3, h5 {
  position: relative;
  color: #c50018;
  font-size: 20px;
  padding: 10px 0;
  text-align: center;
  margin: 2em 0;
}
/*h2:before, h3:before, h5:before {
  content: "";
  position: absolute;
  top: -8px;
  left: 50%;
  width: 150px;
  height: 58px;
  border-radius: 50%;
  border: 5px solid #dd9977;
  border-left-color: transparent;
  border-right-color: transparent;
  -webkit-transform: translateX(-50%);
  transform: translateX(-50%);
}*/
h4 {
  position: relative;
  font-size: 50px;
  padding: 0.9% 0;
  margin: 0;
  text-align: center;
	border-top: #000 1px solid;
	border-bottom: #000 1px solid;
}
h6 {
  color: #293f4d;
  padding: 0.5em 0;
  border-top: solid 3px #293f4d;
  border-bottom: solid 3px #293f4d;
  width: 80%;
  margin: 0 auto 2em auto;
  font-size: 18px;
}
.wrapper {
  max-width: 1000px;
  margin: 0 auto;
}
.content1 {
  max-width: 1000px;
  margin: 50px auto;
  padding: 0;
  text-align: center;
}
.number {
  font-size: 30px;
  color: #293f4d;
  font-weight: bold;
  margin: 0;
  padding: 0;
}
.howto {
  font-size: 16px;
  color: #c30d23;
  font-weight: bold;
  margin: 0;
  padding: 0 20px;
  text-align: left;
  line-height: 1.3em;
}
.box1 {
  width: 100%;
  margin: 10px auto;
  padding: 5px 0;
  text-align: center;
	background-color: #c50018; 
}
.text01 {
  text-align: left;
  padding: 0 0 20px 0;
  margin: 0;
}
.text02 {
  text-align: center;
  font-size: 24px;
  color: #fff;
  padding: 0;
	margin: 0;
	font-weight: bold;
}
.comment01 {
  font-size: 14px;
  color: #333;
  margin: 0;
  padding: 0 20px;
  text-align: left;
  line-height: 1.3em;
}
.comment02 {
  font-size: 16px;
  color: #000;
  margin: 0;
  padding: 0 20px;
  text-align: left;
  line-height: 1.3em;
}
.comment03 {
  font-size: 14px;
}
a {
  text-decoration: none;
  color: #fff;
}
nav {
  margin: 0 0 0 auto;
}
ul {
  list-style: none;
  margin: 0;
  display: flex;
}
li {
  margin: 0 0 0 15px;
}
img {
  margin: 0;
  padding: 0;
  max-width: 100%;
}
img.pre {
  margin: 0;
  padding: 0;
  width: 500px;
}
img.main {
  margin: 0;
  padding: 0;
  max-width: 100%;
}
img.member {
  margin: 0;
  padding: 0;
  width: 1000px;
}
img.card {
  margin: 0;
  padding: 0;
  width: 300px;
}
img.floor {
  margin: 0;
  padding: 0;
	max-width: 100%;
}
img.time {
  margin: 0;
  padding: 0;
  width: 500px;
}
iframe {
  width: 80%;
  margin-bottom: 3em;
}

.sub{
	margin-top: 50px;
	background: #FFFF00;
	font-size: 34px;
	font-weight: bold;
	text-align: center;
	padding: 1.8%;
}
.sub .red{font-size: 39px;}
.main-visual {
  display: flex;
  justify-content: center;
  align-items: center;
	background: #D41A20;
}
.main-visual_m {
  display: none;
}
.sp-nav {
  display: none;
}
/*リンクボタン*/
a.button {
  display: block;
  width: 250px;
  margin: 0 auto;
  padding: 15px 30px;
  text-align: center;
  border: 1px solid #fff;
  transition: all .3s ease-out;
}
a.button:hover {
  color: #505050;
  background-color: #fff;
}
/* section */
.flex {
  display: flex;
}
section {
  overflow: hidden;
  text-align: center;
  padding: 30px 0;
}
.list {
  display: block;
  margin: 0 auto;
}

#ttl h2{
	color: inherit;
	font-size: 48px;
	margin: 0;
	padding: 0;
	line-height: 1.2;
}
#ttl h2 b{font-size: 68px;}
#ttl p{
	font-size: 23px;
	font-weight: bold;
	margin: 10px 0 0;
}
#ttl p.red{
	font-size: 74px;
	margin-top: 20px;
	line-height: 1.2;
}
.term{
	background: #000;
	text-align: center;
	font-size: 38px;
	font-weight: bold;
	color: #FFF;
	padding: 1.7%;
}

#global {
  background-color: #D41A20;
	padding-top: 0;
}
#global h2{
	margin: 0;
	padding: 0;
}
#global .content1 {
	margin: 0 auto;
}
#global p {
  padding: 0 30px;
}
#global ul {
  margin: 0;
  padding: 0;
  flex-direction: row;
  justify-content: space-between;
  flex-wrap: wrap;
  list-style: none;
  display: flex;
}
#global ul li {
  width: 50%;
  margin: 0 auto;
  text-align: center;
}
#global ul li:nth-of-type(2) {
  transition-delay: .2s;
}
#global ul li:nth-of-type(3) {
  transition-delay: .4s;
}
#global ul li:nth-of-type(4) {
  transition-delay: .6s;
}
#global .content1 .target{
	margin: 30px auto 0;
	max-width: 700px;
	position: relative;
}
#global .content1 .target .ico{
	position: absolute;
	right: -28%;
	top: 50%;
	transform: translateY(-40%);
}

#feature{
	background: #000;
	color: #FFF;
	font-weight: bold;
}
#feature .wrapper{
	display: flex;
	align-items: center;
	justify-content: space-between;
}
#feature .module{
	width: 51.614%;
	text-align: left;
}
#feature .module .ttl{margin: 0;}
#feature .module .txt{font-size: 19px;}

#guide {
  background:url("../img/top/bg_guide.png") repeat center center;
	background-size: 4px 4px;
	padding: 40px 0;
}
.mito {
  background:url(../img/top/back01.png) no-repeat top center;
	background-size:100% auto;
	margin: 0;
	padding: 0;
}
#guide p {
  text-align: center;
  margin: 0 auto;
  padding: 0 20px;
	font-weight: bold;
}
#guide h4 + p {margin: 30px auto 10px;}
#guide ul {
  margin: 0 0 40px;
  padding: 0;
  flex-direction: row;
  justify-content: space-between;
  flex-wrap: wrap;
}
#guide ul li {
  width: 25%;
  margin: 0 0 20px 0;
  text-align: center;
}
#guide ul li:nth-of-type(2) {
  transition-delay: .2s;
}
#guide ul li:nth-of-type(3) {
  transition-delay: .4s;
}
#guide ul li:nth-of-type(4) {
  transition-delay: .6s;
}
#guide ul li img {
  max-width: 200px;
}
#guide .place p{text-align:left;}
#guide .place p.ttl{
	font-size: 38px;
	font-weight: bold;
	margin:0 0 10px;
}
#guide .place .ttl img{
	vertical-align: middle;
	margin-left: 15px;
}
#guide .place .module{
	display: flex;
	line-height: 0;
}
#guide .place .module p{
	margin: 0;
	padding: 0;
}
#guide .place .module p:first-child{margin-right: 22px;}

#access {
	background: #000;
	color: #FFF;
  text-align: center;
}
#access h4{
	border-top: #FFF 1px solid;
	border-bottom: #FFF 1px solid;
}
#access .module{
	display: flex;
	align-items: center;
	max-width: 912px;
	margin: 40px auto 20px;
}
#access .module h5{
	margin: 0;
	padding: 20px 0;
	background: #FFFFCE;
	color: #000;
	font-size: 28px;
	font-weight: bold;
	text-align: center;
	border-radius: 50%;
	width: 23.6%;
	line-height: 1.2;
}
#access .module p {
	width: 70%;
  margin: 0 0 0 2%;
  padding: 0;
	text-align: left;
	font-size: 22px;
}
#access ul {
  margin: 0;
  padding: 0;
  flex-direction: row;
  justify-content: space-between;
  flex-wrap: wrap;
  list-style: none;
  display: flex;
}
#access ul li {
  width: 50%;
  margin: 0 auto;
  text-align: center;
}
#access ul li:nth-of-type(2) {
  transition-delay: .2s;
}
#access ul li:nth-of-type(3) {
  transition-delay: .4s;
}
#access ul li:nth-of-type(4) {
  transition-delay: .6s;
}
/* footer */
footer {
  padding: 20px 0;
  background-color: #D41A20;
  text-align: center;
  color: #fff;
  font-size: 24px;
	font-weight: bold;
	line-height: 1.2;
	letter-spacing: 0;
}
footer p{margin: 0 0 20px;}
/* -------------------------------------------------------------------
*  Ipad
* ------------------------------------------------------------------*/
@media screen and (max-width: 1000px) {
.pc_only{display: none;}
.pc_none{display: block;}
.wrapper{padding: 0 2%;}
#global .content1 .target .ico {
	right: -4%;
	transform: translateY(-50%);
	width: 30%;
}
#feature .wrapper{padding: 0 2%;}

}
/* -------------------------------------------------------------------
*  iphone
* ------------------------------------------------------------------*/
@media screen and (max-width: 700px) {
  img.floor {
    margin: 0;
    padding: 0;
    width: 90%;
  }
	img.member {
    width: 100%;
  }
#global ul li {
  width: 90%;
	margin: 20px auto;
}
	#access ul li {
  width: 90%;
	margin: 20px auto;
}
}
@media screen and (max-width: 640px) {
.sp_only{display: block;}

h4{
	font-size: 6.4vmin;
	padding: 0.5em 0;
}

.sub{font-size: 4vmin;}
.sub .red{font-size: 4.8vmin;}
#ttl h2{font-size: 5.6vmin;}
#ttl h2 b{font-size: 8vmin;}
#ttl p{font-size: 4.8vmin;}
#ttl p.red{font-size: 5.6vmin;}
.term{font-size: 4.8vmin;}

#global ul {
	flex-direction: column;
}
#global ul li{
	margin: 0 auto;
	width: 96%;
}
#global .content1 .target {width: 96%;}
#feature .wrapper{flex-direction: column;}
#feature .wrapper .ico{
	width: 64%;
	margin: 0 auto 4%;
}
#feature .module {width: 100%;}

#guide p{padding: 0;}
#guide .place p.ttl{font-size: 5.6vmin;}
#guide .place .ttl img{width: 16%;}
#access .module{flex-direction: column;}
#access .module h5 {
	padding: 0.6em;
	font-size: 4.8vmin;
	border-radius: 4em;
	width: 100%;
}
#access .module p {
	width: 100%;
	margin: 10px auto 0;
	font-size: 4vmin;
}
iframe{
	width: 100%;
	height: 60vw;
	margin: 0;
}
footer{font-size: 4vmin;}

  /*ハンバーガーメニュー*/
  .pc-nav {
    display: none;
  }
  .sp-nav {
    z-index: 1;
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 100vh;
    display: block;
    width: 100%;
    background: rgba(0, 0, 0, .8);
    opacity: 0;
    transform: translateY(-100%);
    transition: all .2s ease-in-out;
  }
  #hamburger {
    position: relative;
    display: block;
    width: 30px;
    height: 25px;
    margin: 0 0 0 auto;
  }
  #hamburger span {
    position: absolute;
    top: 50%;
    left: 0;
    display: block;
    width: 100%;
    height: 2px;
    background-color: #fff;
    transform: translateY(-50%);
  }
  #hamburger::before {
    content: '';
    display: block;
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 2px;
    background-color: #fff;
  }
  #hamburger::after {
    content: '';
    display: block;
    position: absolute;
    bottom: 0;
    left: 0;
    width: 70%;
    height: 2px;
    background-color: #fff;
  }
  /*スマホメニュー*/
  .sp-nav ul {
    padding: 0;
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
    height: 100%;
  }
  .sp-nav li {
    margin: 0;
    padding: 0;
  }
  .sp-nav li span {
    font-size: 15px;
    color: #fff;
  }
  .sp-nav li a, .sp-nav li span {
    display: block;
    padding: 20px 0;
  }
  /*-閉じるアイコンー*/
  .sp-nav .close {
    position: relative;
    padding-left: 20px;
  }
  .sp-nav .close::before {
    content: '';
    position: absolute;
    top: 50%;
    left: 0;
    display: block;
    width: 16px;
    height: 1px;
    background: #fff;
    transform: rotate(45deg);
  }
  .sp-nav .close::after {
    content: '';
    position: absolute;
    top: 50%;
    left: 0;
    display: block;
    width: 16px;
    height: 1px;
    background: #fff;
    transform: rotate(-45deg);
  }
  .toggle {
    transform: translateY(0);
    opacity: 1;
  }
  /* section */
  #service ul li {
    width: 100%;
  }
  #guide ul li {
    width: 100%;
  }
}
table {
  max-width: 700px;
  margin: 0 auto;
  color: #aaa;
}
/* フェードイン用のCSS */
/* 上からフェードイン */
.slide-top {
  opacity: 0;
  transform: translate(0, -20px);
  transition: all 1s ease-out;
}
/* 下からフェードイン */
.slide-bottom {
  opacity: 0;
  transform: translate(0, 20px);
  transition: all 1s ease-out;
}
/* 左からフェードイン */
.slide-left {
  opacity: 0;
  transform: translate(-20px, 0);
  transition: all 1s ease-out;
}
/* 右からフェードイン */
.slide-right {
  opacity: 0;
  transform: translate(20px, 0);
  transition: all 1s ease-out;
}