@charset "utf-8";
@import url('https://fonts.googleapis.com/css?family=Noto+Sans+JP&display=swap');
/*
↓明朝
@import url('https://fonts.googleapis.com/css2?family=Noto+Serif+JP:wght@400;700&display=swap');*/
/* CSS Document */
*{zoom:1;}
:root{
	--red:#9f1222;
	--black:#000000;
	--gold:#d0b154;

}
body {
	font-family:'Noto Sans JP', "游ゴシック", YuGothic, "メイリオ", Meiryo, "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", Osaka, "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
	/*font-family: 'Noto Serif JP',"游明朝", YuMincho, "ヒラギノ明朝 Pro W6", "Hiragino Mincho Pro", "HGS明朝E", "ＭＳ Ｐ明朝", serif; */
    background-color:var(--red);
	font-size:16px;
	color:#000;
    line-height:1.5em;
    width:100%;
    /*min-width:960px;*/
    overflow-y:scroll;
/*	-webkit-text-size-adjust:100%;*/
}
body,nav,header,div,p,a,ul,li,section,article,dl,dt,dd,h1,h2,h3,h4,h5,h6,img{
	margin:0;
	padding:0;
	font-weight:normal;
	list-style-type:none;	
	box-sizing:border-box;
	font-size: 1em;
}

body.fixed {
    position: fixed;
    width: 100%;
    height: 100%;
    left: 0;
}

.clearfix::after{
  content: "";
  display: block;
  clear: both;
}

::selection {
    background: #6c7f96;
    color: #fff;
}

/*Firefox*/
::-moz-selection {
    background: #6c7f96;
    color: #fff;
}

.clear{clear:both;}


img{
	width:100%;
    vertical-align: bottom;
    border:0;
}

a{
	text-decoration:none;
	word-break: break-all;
}
a:hover{
}
a.txtLink{
	color: var(--gold);
	font-weight: bold;
	padding:0 0.5em;
}
a.txtLink:hover{
	color: var(--black);
	background-color: var(--gold);
}
.br2{display:inline-block;}


ul.notes{margin-left:1em;}
ul.notes li{text-indent:-1em;}
/*ボックス関係*/
.corner_r{
	border-radius: 6px;
}
/*テキスト関係*/
.smallTxt{font-size: max(0.8em,11px);}
.center{text-align: center;}
/*グリッド関係*/
.grid_box{
	display: grid;
	column-gap: 1em;
	row-gap: 1em;
}
.grid_4{grid-template-columns:repeat(4, 1fr);}
.grid_3{grid-template-columns:repeat(3, 1fr);}
.grid_2{grid-template-columns:repeat(2, 1fr);}
/*ルビ関係*/
ruby {
        display: inline-table;
        border-collapse: collapse;
        margin: 0;
        padding: 0;
        border: none;
        white-space: nowrap;
        text-indent: 0;
        vertical-align: 0.9em;
        text-decoration: inherit;
        text-align: center;
        line-height: 1em;
        }
ruby>rt {
    display: table-header-group;
    height: 25%;
    margin: 0;
    padding: 0 0.125em;
    border: none;
    font: inherit;
    font-size: 50%;
    line-height: 1em;
	text-align: center;
    }

/*トップヘ戻る*/
#backTop{
	width: 10%;
	max-width:70px;
	/*bottom:100px;*/
    bottom:5px;
	right:5px;
	cursor:pointer;
	position: fixed;
	z-index:999;
}
#backTop span{
	display: block;
	position: relative;
	width: 4em;
	height: 4em;
	text-indent: -99999px;
}
#backTop span:before{
	content: "";
	width: 100%;
	top:0;
	bottom: 0;
	background-color: var(--black);
	/*box-shadow:  inset 0 0 0 0.3em var(--red), inset 0 0 0 0.4em var(--gold);*/
	box-shadow:  inset 0 0 0 0.3em var(--black), inset 0 0 0 0.4em var(--gold);
	position: absolute;
	display: block;
	border-radius: 50%;
}
#backTop span:after{
	content: "▲";
	width: 1em;
	height: 1em;
	margin-top: -0.5em;
	margin-left: -0.5em;
	top:50%;
	left: 50%;
	color: #fff;
	border-top: #fff 2px solid;
	position: absolute;
	display: block;
	text-indent: 0;
	line-height: 1em;

}
/*----------------------------------------------------------------
動画
-----------------------------------------------------------------*/
 .movieArea {
	position: relative;
	padding-bottom: 56.25%;
	height: 0;
	overflow: hidden;
	margin:auto;
	border: solid 1px #2c2c2c;
}

.movieArea iframe,  
.movieArea object,  
.movieArea embed {
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
}
/*----------------------------------------------------------------
ローディング
-----------------------------------------------------------------*/
.loading{
    width:100%;
    position:fixed;
    top:50%;
    z-index:999;
	font-size: 16px;
}
.loading .load{
	width: 10em;
	margin: 0 auto;
}
.loading .load span{
	display: block;
	position: relative;
	padding: 0.5em;
	background-image: url("../img/midasgi_black_bg.jpg");
	color: var(--gold);
	font-weight: bold;
	text-align: center;
	background-repeat: repeat-x;
	background-size: auto 100%;
	
}
.loading .load span{
	
	position: relative;
	padding: 0.5em;
	line-height: 1.5em;

}
.loading .load span:before{
	content: "";
	display: block;
	position: absolute;
	width: 4em;
	top:0;
	bottom: 0;
	left: -2em;
	background-image: url("../img/midasgi_black_side.png");
	background-position: left top;
	background-repeat: no-repeat;
	background-size: auto 100%;
}
.loading .load span:after{
	content: "";
	display: block;
	position: absolute;
	width: 4em;
	top:0;
	bottom: 0;
	right: -2em;
	background-image: url("../img/midasgi_black_side.png");
	background-position: left top;
	background-repeat: no-repeat;
	background-size: auto 100%;
	transform: scale(-1,-1);
}

.loadBg{
	background-color: #fff;
	position: absolute;
	top:0;
	right: 0;
	border-left: #000 1px solid;
	opacity: 0;
	z-index: 999;
}
/*----------------------------------------------------------------
コンテンツ
-----------------------------------------------------------------*/
	#wrap{
		width: 100%;
		display: block;
		position: relative;

	}
	#contents{
		width: 100%;
		opacity: 0;
		position: relative;
	}
#contents:before{
	content: "";
	position: absolute;
	display: block;
	width: 5vw;
	height: 16em;
	background-image: url("../img/top_img_l.png");
	background-position: left top;
	background-repeat: no-repeat;
	background-size: contain;
	top:0;
	left: 0;
}
#contents:after{
	content: "";
	position: absolute;
	display: block;
	width: 5vw;
	height: 16em;
	background-image: url("../img/top_img_r.png");
	background-position: left top;
	background-repeat: no-repeat;
	background-size: contain;
	top:0;
	right: 0;
}

	.mainWrap{
		position: relative;
			background-image: url("../img/bottom_img_r.png");
	background-position: right bottom;
	background-repeat: no-repeat;
	background-size: contain;
		background-size: 5vw auto;

	}
.mainWrap:before{
	content:"";
	position: absolute;
	display: block;
	top:1vw;
	bottom: 1vw;
	left: 1vw;
	right: 1vw;
	z-index: -1;
	border: var(--black) 0.4vw solid;
}

.mainWrap:after{
	content: "";
	position: absolute;
	display: block;
	width: 5vw;
	height: 16em;
	background-image: url("../img/bottom_img_l.png");
	background-position: left bottom;
	background-repeat: no-repeat;
	background-size: contain;
	bottom:0;
	left: 0;
}

	.mainWrap .main{
		position: relative;
		padding-bottom: 8em;
	}

	.mainWrap .main:before{
		content: "";
		width: 6.5vw;
		height: 15em;
		background-image: url("../img/bonbori_black.png");
		background-position: center top;
		background-repeat: no-repeat;
		background-size: contain;
		left: 6vw;
		top:1.4vw;
		position: absolute;
		display: block;
		z-index: 3;

	}
	.mainWrap .main:after{
		content: "";
		width: 6.5vw;
		height: 15em;
		background-image: url("../img/bonbori_black.png");
		background-position: center top;
		background-repeat: no-repeat;
		background-size: contain;
		right: 6vw;
		top:1.4vw;
		position: absolute;
		display: block;
		z-index: 3;
	}
	.contentsBox{
		width: calc(100% - 3em);
		max-width: 1300px;
		margin: 0 auto;
		position: relative;
		display: block;
		
	}


/*----------------------------------------------------------------
showAction
-----------------------------------------------------------------*/

.actionObject{
	opacity:0;
}
.showAction{
  animation: 0.5s ease-out 0s 1 normal forwards running;
  animation-name: showAction;
}

@keyframes showAction {
  0% {
    transform: translateY(20px);
	opacity:0;

  }
  100% {
    transform: translateY(0px);
	opacity:1;

  }
}

/*----------------------------------------------------------------
メディアクエリ
-----------------------------------------------------------------*/
@media (max-width: 1024px) {
#contents:before{

	width: 10vw;
}
#contents:after{

	width: 10vw;
}

	.mainWrap{

		background-size: 10vw auto;

	}
.mainWrap:before{
	content:"";
	position: absolute;
	display: block;
	top:2vw;
	bottom: 2vw;
	left: 2vw;
	right: 2vw;
	z-index: -1;
	border: var(--black) 0.8vw solid;
}

.mainWrap:after{

	width: 10vw;
}


	.mainWrap .main:before{
		content: "";
		width: 13vw;
		left: 4em;
		top:2vw;

	}
	.mainWrap .main:after{
		content: "";
		width: 13vw;
		right: 4em;
		top:2vw;
	}

}

@media (max-width: 912px) {
	body{
	font-size: 14px;
	}
}

@media (max-width: 786px) {
    body{
	min-width:0; 
	overflow-x:hidden;
	font-size:  max(2vw, 13px);
	}
}
@media (max-width: 480px) {
    /*トップヘ戻る*/
	.loading{
		font-size: 14px;
	}
    #backTop{display:none;}

    body{

		font-size: max(3vw, 12px);
		line-height: 1.5em;

	}
}
