@charset "utf-8";

html,
body {
	height: auto;
}

body {
	font-family: 'Noto Sans JP', sans-serif;
	font-family: 'Noto Serif JP', serif;
	font-size: 16px;
	line-height: 1.8em;
	color: #333333;
	/* text-shadow: 1px 2px 2px rgba(0, 0, 0, 0.3);*/
	-webkit-text-size-adjust: 100%;
}
img {
	max-width: 100%;
	vertical-align: middle;
}
/*space*/
.mt {
	margin-top: 20px;
}
.mtm {
	margin-top: 10px;
}

.mtx2 {
	margin-top: 40px;
}

.pt {
	padding-top: 20px;
}

.ptx2 {
	padding-top: 40px;
}

.pb {
	padding-bottom: 20px;
}

.pbx2 {
	padding-bottom: 40px;
}

.mbm {
	margin-bottom: 10px;
}

.mb {
	margin-bottom: 20px;
}

.mbx2 {
	margin-bottom: 40px;
}
/* position*/
.cen {
	text-align: center;
}
.left {
	text-align: left;
}
.right {
	text-align: right;
}

.flexb {
	display: flex;
	justify-content: space-between;
}

.flexc {
	display: flex;
	justify-content: center;
}

.flexa {
	display: flex;
	justify-content: space-around;
}

.alignc {
	align-items: center;
}



/*side*/
.pw {
	padding-left: 2%;
	padding-right: 2%;
	box-sizing: border-box;
}

/*fonts*/

.color_white {
	color: #ffffff;
}

.fontsx2 {
	font-size: 80%;
}
.fonts {
	font-size: 90%;
}
.fontb {
	font-weight: bold;
}

.fontbx2 {
	font-size: 22px;
	line-height: normal;
}
.strong {
	font-weight: bold;
}
.em {
	color: #ff0000;
}

.em02 {
	color: #ff0000;
	font-size: 14px;
	font-weight: bold;
	padding-top: 10px;
}

.em03 {
	color: #8c8c8c;
	font-size: 14px;
	font-weight: bold;
	padding-top: 10px;
}

.border01{
	border-bottom:2px solid #524641;
}


/*sizing*/

.w30 {
	width: 30%;
}

.w50 {
	width: 49%;
}
.w90 {
	width: 90%;
	margin: 0 auto;
}
.w70 {
	width: 70%;
	margin: 0 auto;
}

pre {
	font-family: 'ヒラギノ角ゴ Pro W3', 'Hiragino Kaku Gothic Pro', 'メイリオ', Meiryo, Osaka, 'ＭＳ Ｐゴシック', 'MS PGothic', sans-serif;
}

.inner {
	width: 1200px;
	margin-left: auto;
	margin-right: auto;
	position: relative;
}

.inner_big {
	width: 1400px;
	margin-left: auto;
	margin-right: auto;
	position: relative;
}

.inner02 {
	width: 1000px;
	margin-left: auto;
	margin-right: auto;
	position: relative;
}

.inner03 {
	width: 800px;
	margin-left: auto;
	margin-right: auto;
	position: relative;
}

/*inline*/

.youtube {
	position: relative;
	width: 100%;
	padding-top: 56.25%;
}

.youtube iframe {
	position: absolute;
	top: 0;
	right: 0;
	width: 100% !important;
	height: 100% !important;
}

/**Hover*/

a:hover,
a:hover img,
.nav li:hover,
.nav2 li:hover,
.navwrap li:hover {
	opacity: 1;
	-webkit-animation: flash 1.5s;
	animation: flash 1.5s;
}

@-webkit-keyframes flash {
	0% {
		opacity: 0.4;
	}

	100% {
		opacity: 1;
	}
}

@keyframes flash {
	0% {
		opacity: 0.4;
	}

	100% {
		opacity: 1;
	}
}
