@charset "UTF-8";
:root {
	--ui-bottom-tall: 0; 
	--ui-lastscroll-top: 0;
	--header-height-wide: 0px;
	--header-height-smp: 0px;
}

/*cat: body*/
html,body {
	width: 100%;
	height: 100%;
	font-size: 16px;
	line-height: 1em;
}
body {
	background-color: var(--cl-background);
	color: var(--cl-pageink);
	font-family: var(--font-g);
	z-index: 0;
}

/*cat: anker*/
a:link,a:visited {
	color: var(--cl-pageink-link);
}
a:hover {
	color: var(--cl-pageink-hover);
}
a:active {
	color: var(--cl-pageink-active);
}

/*cat: share style*/
.align-L {
	text-align: left;
}
.align-C {
	text-align: center;
}
.align-R {
	text-align: right;
}
.im-wide {
	width: 100%;
	height: auto;
}
.abs-centering {
	position: absolute;
	top: 50%;
	left: 50%;
	transform: translateY(-50%) translateX(-50%);
	-webkit-transform: translateY(-50%) translateX(-50%);
}

/*cat: h*/
h1 {
	font-size: 28px;
	line-height: 1.75em;
	font-weight: 500;
	letter-spacing: 0.04em;
}
h2 {
	font-size: 26px;
	line-height: 2.2em;
	font-weight: 500;
	margin-bottom: 1em;
}
h3 {
	font-size: 24px;
	line-height: 1.85em;
	letter-spacing: 0.04em;
	font-weight: 500;
	margin-bottom: 1em;
}
h4 {
	font-size: 20px;
	line-height: 1.85em;
	letter-spacing: 0.04em;
	font-weight: 500;
	margin-bottom: 1em;
}
h5 {
	font-size: 18px;
	line-height: 1.85em;
	font-weight: 500;
	margin-bottom: 1em;
}
h6 {
	font-size: 15px;
	font-weight: 500;
	margin-bottom: 1em;
}
p {
	line-height: 2.2em;
}
sup {
	font-size: 0.65em;
}
@media only screen and (max-width:640px) {
	h1 {
		font-size: 19px;
	}
	h2 {
		font-size: 26px;
	}
	h3 {
		font-size: 24px;
	}
	h4 {
		font-size: 20px;
	}
	h5 {
		font-size: 18px;
	}
}

/*cat: bind wrap*/
.wide-bind {
	max-width: var(--bindwrap-width);
	padding: 85px;
	margin-left: auto;
	margin-right: auto;
}
.contents-bind {
	padding: 1.4em;
	margin-left: auto;
	margin-right: auto;
}
@media only screen and (min-width:1281px) {
	.wide-bind {
		max-width: var(--bindwrap-width);
		margin-left: auto;
		margin-right: auto;
	}
}
@media only screen and (min-width: 961px) {
	.contents-bind {
		padding: 0;
		max-width: var(--contents-width);
		margin-left: auto;
		margin-right: auto;
	}
}

/*cat: margin*/
.margin-bot {
	marg