@charset "UTF-8";

/*===============*/
/* Google Fonts */
/*
font-family: 'Bodoni Moda', serif;
font-family: 'Gupter', serif;
font-family: 'Noto Sans JP', sans-serif;
font-family: 'Noto Serif JP', serif;
*/
/*===============*/
@import url('https://fonts.googleapis.com/css2?family=Noto+Sans+JP&family=Noto+Serif+JP:wght@500&display=swap');


/*===============*/
/* reset */
/*===============*/
html,
body,
div,
span,
applet,
object,
iframe,
h1,
h2,
h3,
h4,
h5,
h6,
p,
blockquote,
pre,
a,
abbr,
acronym,
address,
big,
cite,
code,
del,
dfn,
em,
img,
ins,
kbd,
q,
s,
samp,
small,
strike,
strong,
sub,
sup,
tt,
var,
b,
u,
i,
center,
dl,
dt,
dd,
ol,
ul,
li,
fieldset,
form,
label,
legend,
table,
caption,
tbody,
tfoot,
thead,
tr,
th,
td,
article,
aside,
canvas,
details,
embed,
figure,
figcaption,
footer,
header,
hgroup,
menu,
nav,
output,
ruby,
section,
summary,
time,
mark,
audio,
video {
	margin: 0;
	padding: 0;
	border: 0;
	vertical-align: baseline;
	font: inherit;
	font-size: 100%;
}

main,
article,
aside,
details,
figcaption,
figure,
footer,
header,
hgroup,
menu,
nav,
section {
	display: block;
}

body {
	line-height: 1;
}

ol,
ul {
	list-style: none;
}

blockquote,
q {
	quotes: none;
}

blockquote:before,
blockquote:after,
q:before,
q:after {
	content: '';
	content: none;
}

table {
	border-spacing: 0;
	border-collapse: collapse;
}

* {
	-webkit-box-sizing: border-box;
	-moz-box-sizing: border-box;
	box-sizing: border-box;

	-webkit-tap-highlight-color: transparent;
}

body {
	background-color: #FFF;
	letter-spacing: 0;
	font-weight: 400;
	font-style: normal;
	font-family: "Noto Sans JP", "游ゴシック体", YuGothic, "游ゴシック", "Yu Gothic", Verdana, Meiryo, "M+ 1p", sans-serif;
	line-height: 1.8;
}

.sans_serif {
	font-family: "Noto Sans JP", "游ゴシック体", YuGothic, "游ゴシック", "Yu Gothic", Verdana, Meiryo, "M+ 1p", sans-serif;
}

.serif {
	font-family: "Noto Serif JP", "游明朝", "Yu Mincho", "游明朝体", "YuMincho", "ヒラギノ明朝 Pro W3", "Hiragino Mincho Pro", "HiraMinProN-W3", "HGS明朝E", "ＭＳ Ｐ明朝", "MS PMincho", "Sawarabi Mincho", serif;
}

a {
	outline: none;
	color: #000;
	text-decoration: none;
}

img {
	width: 100%;
	height: auto;
	vertical-align: top;
}

@media (min-width:769px) {
	.sp {
		display: none !important;
	}

	body {
		font-size: 16px;
	}
}

@media (max-width:768px) {
	.pc {
		display: none !important;
	}

	html {
		font-size: 14px;
	}
}

@media (max-width:414px) {
	html {
		font-size: 3.4vw;
	}
}

/*===============*/
/* body */
/*===============*/
body {
	opacity: 0;
	transition: opacity .3s ease-in;
}

body.loaded {
	opacity: 1;
}

/*===============*/
/* hover */
/*===============*/
/* h_border */
.h_b a {
	border-bottom: 1px solid rgba(6, 45, 71, .3);
	color: #062D47;
}

body.d_pc .h_b a {
	transition: border .5s 0s;
}

body.d_pc .h_b a:hover {
	border-bottom-color: rgba(6, 45, 71, 1);
	transition: border .5s .2s;
}

/* h_opacity */
body.d_pc .h_o {
	opacity: 1;
	transition: opacity .5s 0s;
}

body.d_pc .h_o:hover {
	opacity: .6;
	transition: opacity .5s .2s;
}

/*===============*/
/* footer */
/*===============*/
footer {
	margin-top: 50px;
}

@media (max-width:940px) and (min-width:769px) {
	footer {
		font-size: 14px;
	}
}

@media (max-width:768px) {
	footer {
		margin-top: 3em;
	}
}

/* page-top */
footer .page-top {
	position: relative;
	display: block;
	width: 100%;
	height: 0;
	border-top: 1px solid rgba(41, 38, 39, .5);
}

footer .page-top span {
	position: absolute;
	top: 50%;
	left: 50%;
	display: block;
	width: 50px;
	height: 50px;
	border: 3px solid #FFF;
	border-radius: 50%;
	background-color: #292627;
	cursor: pointer;
	transform: translate(-50%, -50%);
}

body.d_pc footer .page-top span {
	transition-delay: 0s;
	transition-duration: .1s;
	transition-property: width, height, background-color;
}

body.d_pc footer .page-top span:hover {
	width: 60px;
	height: 60px;
	background-color: #C94D97;
	transition-delay: .2s;
}

footer .page-top span i {
	position: absolute;
	top: 52%;
	left: 50%;
	transform: translate(-50%, -50%);
}

footer .page-top span i::before,
footer .page-top span i::after {
	position: absolute;
	left: 50%;
	width: 6px;
	height: 6px;
	border: solid #FFF;
	border-width: 2px 2px 0 0;
	content: "";
	transform: translateX(-50%) rotate(-45deg);
}

footer .page-top span i::before {
	top: 0;
}

footer .page-top span i::after {
	bottom: 0;
}

@media (max-width:768px) {

	/* page-top */
	footer .page-top span {
		width: 3.2em;
		height: 3.2em;
		border-width: 2px;
	}

	footer .page-top span i {
		position: absolute;
		top: 52%;
		left: 50%;
		transform: translate(-50%, -50%);
	}

	footer .page-top span i::before,
	footer .page-top span i::after {
		width: .5em;
		height: .5em;
		border-width: 2px 2px 0 0;
	}

	footer .page-top span i::after {
		bottom: -1px;
	}
}

/* bottom */
footer .bottom>div {
	display: flex;
	display: -webkit-flex;
	display: -ms-flexbox;
	-webkit-box-pack: center;
	-ms-flex-pack: center;
	justify-content: center;
	margin: 0 auto;
	padding: 60px 0 20px;
	max-width: 980px;
	width: 90%;
}

footer .bottom .copyright {
	display: flex;
	display: -webkit-flex;
	display: -ms-flexbox;
	-webkit-box-align: center;
	align-items: center;
	-ms-flex-align: center;
	vertical-align: middle;
	white-space: nowrap;
}

/* copyright */
footer .bottom .copyright {
	line-height: 1.2;
}

footer .bottom .copyright small {
	margin-top: .75em;
	margin-right: 2em;
	font-size: 70%;
	opacity: .8;
}

footer .bottom .copyright a {
	display: block;
}

body.d_pc footer .bottom .copyright a {
	transition: opacity .2s 0s;
}

body.d_pc footer .bottom .copyright a:hover {
	opacity: .6;
	transition: opacity .2s .2s;
}

footer .bottom .copyright img {
	max-width: 217px;
}

@media (max-width:768px) {

	/* bottom */
	footer .bottom>div {
		-webkit-box-orient: vertical;
		-webkit-box-direction: normal;
		-ms-flex-direction: column;
		flex-direction: column;
		padding: 3em 0 2em;
	}

	footer .bottom .copyright {
		-webkit-box-orient: vertical;
		-webkit-box-direction: reverse;
		-ms-flex-direction: column-reverse;
		flex-direction: column-reverse;
	}

	/* sns */
	footer .bottom ul.sns {
		margin-bottom: 1.5em;
	}

	footer .bottom ul.sns li:first-child {
		margin-right: 1em;
	}

	footer .bottom ul.sns li a {
		width: 2.6em;
	}

	/* copyright */
	footer .bottom .copyright small {
		margin-top: 1em;
		margin-right: 0;
	}

	footer .bottom .copyright img {
		max-width: none;
		width: auto;
		height: 3em;
	}
}

/*===============*/
/* expobanner */
/*===============*/
.expobanner {
	position: fixed;
	bottom: 1.2em;
	left: 1.2em;
	z-index: 100;
	max-width: 500px;
	background-color: #FFF;
	box-shadow: 0 0 1.5em rgba(0, 0, 0, .3);
}

body.expobanner_hide .expobanner {
	display: none;
}

.expobanner i {
	position: absolute;
	top: 8px;
	left: 8px;
	width: 20px;
	height: 20px;
	background-color: #FFF;
	cursor: pointer;
}

.expobanner i::before,
.expobanner i::after {
	position: absolute;
	top: 50%;
	left: 50%;
	width: 80%;
	height: 2px;
	background-color: #000;
	content: "";
	opacity: .5;
}

.expobanner i::before {
	transform: translate(-50%, -50%) rotate(45deg);
}

.expobanner i::after {
	transform: translate(-50%, -50%) rotate(-45deg);
}

.expobanner a,
.expobanner img {
	display: block;
}

@media (max-width:600px) {
	.expobanner {
		width: 55%;
	}

	.expobanner i {
		top: .6em;
		left: .6em;
		width: 1.4em;
		height: 1.4em;
	}

	.expobanner i::before,
	.expobanner i::after {
		width: 1em;
	}
}

/*===============*/
/* note */
/*===============*/
i.note {
	position: absolute;
	right: 1em;
	bottom: .8em;
	z-index: 20;
	color: #FFF;
	text-shadow: 0 0 .5em #000, 0 0 .25em #000;
	font-size: 60%;
	line-height: 1.4;
	opacity: .9;
}

/*===============*/
/* print */
/*===============*/
@media print {
	body {
		font-size: 12px;
	}

	[data-aos^=fade][data-aos^=fade] {
		opacity: 1 !important;
		transform: translateZ(0) !important;
	}

	aside {
		display: none !important;
	}
}
