@charset "utf-8";
@import url('https://fonts.googleapis.com/css?family=Noto+Sans+JP&display=swap');
@import url(https://fonts.googleapis.com/css?family=Denk+One);
/*
↓明朝
@import url('https://fonts.googleapis.com/css2?family=Noto+Serif+JP:wght@400;700&display=swap');*/
/* CSS Document */
*{zoom:1;}
:root{
--lightBrown:#ece4d7;
--mediumBrown:#d0bfa5;
--brown:#a59482;
--orange: #e77c38;
--blue:#5762ef;
--brownTxt:#8f8272;
--black:#333; 
}
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:#fff;
	font-size:16px;
	color:var(--black);
    line-height:1.5em;
    width:100%;

    overflow-y:scroll;
}
body,nav,header,footer,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-wrap: break-word;     /* 旧プロパティ名 */
	overflow-wrap: break-word; /* 新プロパティ名 */
}
a:hover{
}

.br2{display:inline-block;}


ul.notes{margin-left:1em;}
ul.notes li{text-indent:-1em;}
.midashiFont{font-family: 'Denk One', sans-serif;}
/*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;
    }
*/
ruby {
        display: inline-table;
        border-collapse: collapse;
        margin: 0;
        padding: 0;
        border: none;
        white-space: nowrap;
        text-indent: 0;
        vertical-align: 0.7em;
        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: 40%;
    line-height: 0.3em;
	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: rgba(0,0,0,0.7);
	box-shadow:  inset 0 0 0 0.3em  rgba(0,0,0,0.7), inset 0 0 0 0.4em #fff;
	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: 2em;
}
.loading .load{
	width: 10em;
	margin: 0 auto;
	text-align: center;
	
	color: var(--blue);
}

.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;
	}
	.mainWrap{
		background-color: #fff;
		background-image: url(../img/bg_top.jpg);
		background-position: center top;
		background-size:auto 80%;
		background-repeat: no-repeat;
		padding-top: 0.5em;
		position: relative;

	}
.mainWrap.second{
	background-image: url(../img/bg_second_m.jpg);
	background-position: center;
	background-repeat: no-repeat;
	background-size: 100% 100%;
}

.mainWrap.second:after{
	content: "";
	position: absolute;
	display: block;
	width: 100%;
	top:0;
	bottom:0;
	left: 0;
	background-image: url(../img/bg_second_b.png);
	background-position: center bottom;
	background-repeat: no-repeat;
	background-size: 100% auto;

}
	.contentsBox{
		width: calc(100% - 1em);
		max-width: 1300px;
		margin: 0 auto;
	}
/*----------------------------------------------------------------
フッター
-----------------------------------------------------------------*/
footer{
	background-color: #fff;
	padding-bottom: 50px;
	text-align: center;
}

footer #copy{
	padding: 10px 0;
	font-size: 12px;
	border-top: #ccc 1px solid;
	border-bottom: #ccc 1px solid;
}
footer #snsArea {
	padding: 10px 0;
	
}
footer #snsArea img{
	width: 40px;
}
footer #linkArea{
	padding-top: 10px;
}
footer #linkArea a{
	width: 32.8%;
	max-width: 200px;
	margin: 2px 0.25%;
	display: inline-block;
	vertical-align: top;
	border: #ccc 1px solid;
}
footer img.txt{
	width: 96%;
	max-width: 700px;
}
/*----------------------------------------------------------------
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) {
	body{
	font-size: 14px;
	}
	.mainWrap{
		padding-top: 0;

	}

}

@media (max-width: 786px) {
    body{
	min-width:0; 
	overflow-x:hidden;
	font-size: 2vw;
	}
}
@media (max-width: 480px) {
    /*トップヘ戻る*/
	.loading{
		font-size: 14px;
	}
    #backTop{display:none;}

    body{

		font-size: max(3vw, 11px);
		line-height: 1.5em;

	}
	footer #linkArea a{
		width: 49%;
		margin: 2px 0.5%;
	}
}
