 background:var(--grad); background:var(--grad); background:var(--grad); background:var(--grad);@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@500;700&display=swap');
/* CSS Document */
*{zoom:1;}
:root{
	--bgP:#dbcbf2;
	--bgG:#efeae0;
	--darkP:#392b3c;
	--red:#f33574;
	--lineG:#d9ceb6;
	--lineP:#eee8f1;
	--grad:linear-gradient(90deg,#fadeed,#e5e8fb);
}
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;
	color:var(--darkP);
    width:100%;
   	font-size: max(3.3vw, 13px);
	line-height: 1.5em;
    overflow-y:scroll;
	overflow-x:hidden;
	margin:0;
	padding:0;
	box-sizing:border-box;
	text-size-adjust: 100%;
	-webkit-text-size-adjust: 100%;
}
nav,header,div,p,a,ul,li,section,article,dl,dt,dd,h1,h2,h3,h4,h5,h6,img,table{
	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;
	outline: none;
}
a:hover{
}

a.txtLink{
	border-bottom: var(--darkP) 1px dashed;
	border-spacing: 2px;
	color:  var(--darkP);
	padding: 0 0.2em;
}
a.txtLink:hover{
	background: var(--grad);
}
.br2{display:inline-block;}


ul.notes{margin-left:1em; font-size: max(0.7em,11px); line-height: 1.5em;}
ul.notes li{text-indent:-1em;}
/*ボックス関係*/
.corner_r{
	border-radius: 6px;
}
/*テキスト関係*/
.smallTxt{font-size: max(0.8em,11px); line-height: 1.5em;}
.center{text-align: center;}

.centerGrid{
	position: relative;
	display: grid;
	justify-content: center;
	width: 100%;
}
/*グリッド関係*/
.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{

	 bottom:0.5em;
	right:0.5em;
	cursor:pointer;
	position: fixed;
	z-index:800;
	display: block;
	width: 4em;
	height: 4em;
	margin-left: auto;
	--backTopBg:#fff;
	z-index: 100;
}
#backTop span{
	display: block;
	position: relative;
	width: 4em;
	height: 4em;
	text-indent: -99999px;
	margin-left: auto;
}
#backTop span:before{
	content: "";
	width: 100%;
	top:0;
	bottom: 0;
	background: var(--backTopBg);
	border: var(--lineP) 2px solid;
	box-sizing: border-box;
	/*box-shadow:  inset 0 0 0 0.3em  var(--backTopBg), 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:var(--darkP);
	border-top:var(--darkP) 2px solid;
	position: absolute;
	display: block;
	text-indent: 0;
	line-height: 1em;

}
/*----------------------------------------------------------------
ローディング
-----------------------------------------------------------------*/
.loading{
    width:100%;
    position:fixed;
    top:50%;
    z-index:800;
	font-size: 1em;
}
.loading .load{
	width: 12em;
	margin: 0 auto;
	background: var(--grad);
	color: var(--darkP);
	border-radius:50px; 
	padding: 0.5em;
}

/*----------------------------------------------------------------
コンテンツ
-----------------------------------------------------------------*/
	#wrap{
		width: 100%;
		display: block;
		position: relative;

	}
	#contents{
		width: 100%;
		opacity: 0;
		position: relative;
	}
#contents:before{
	content: "";
	width: 100%;
	max-width: none;
	display: block;
	position: fixed;
	top:0;
	left:0;
	height: 100vh;
	background-image: url("../img/smp/bg.jpg");
	background-position:center;
	background-repeat: no-repeat;
	background-size:contain;
	z-index: -1;
}

	.mainWrap{
		padding-top: 4em;
		padding-bottom: 18vh;
		background-image: url("../img/bottom_bg.png");
		background-position: center bottom;
		background-repeat: no-repeat;
		background-size: contain;
		position: relative;
	}
.mainWrap:before{
	content: "";
	position: fixed;
	display: block;
	width: 100%;
	height: 4em;
	background-color: #fff;
	top:0;
	left: 0;
	z-index: 800;
}

	.contentsBox{
		width: calc(100% - 2em);
		max-width: 1100px;
		margin: 0 auto;
	}
/*--footer--*/
footer.white{
	color: #434343;

}
/*----------------------------------------------------------------
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
------------------------------------------------------------*/
/*PC*/
@media (max-width: 380px) {/*極小*/


	body{

		font-size:  max(3.6vw, 12px);
	}
/*----------------------------------------------------------------
コンテンツ
-----------------------------------------------------------------*/

	.contentsBox{
		width: calc(100% - 2em);

	}


}

@media (min-width: 481px) {/*429~768px*/

	body{
		font-size:clamp(12px, 2.6vw, 14px);
		line-height: 1.5em;
	}
}
/*@media (min-width: 769px) {*//*タブレット・PC(1450pxまで)*/
@media (min-width: 769px) {
	body{
		font-size:clamp(14px, 2vw, 16px);
		line-height: 1.5em;
	}
	.contentsBox{
		width: calc(100% - 4em);
	}

}
@media (min-width: 1025px) {/*タブレット・PC(1450pxまで)*/
	body{
		font-size:14px;
		line-height:1.5em;
		/*min-width:1450px;*/
		overflow-x: auto;
		
	}

	.mainWrap{
		padding-top: 0;
		padding-bottom: 40vh;
	}
	#contents:before{
		content: "";
		width: 100%;
		left:0;
		background-size: cover;
		background-image: url("../img/bg.jpg");
	}

}
@media (min-width: 1451px) {
	body{
		font-size:clamp(14px, 1.5vw, 18px);
		line-height: 1.5em;
	}
}
@media (min-width: 1921px) {
		#contents:before{
		content: "";
		width: 100%;
		max-width: 1920px;
		left:calc(calc(100% - 1920px) / 2);
		background-size: cover;
	}

}