@charset "utf-8";

.preload * {
	transition: unset;
}

.br:before {
	content: "\A";
	white-space: pre;
}

.br.onPC, 
.br.onTB, 
.br.onSP {
	display: inline-block;
	height: 0.1em;
}

#wid {
	position: fixed;
	top: 0;
	left: 0;
	width: 80px;
	height: 32px;
	line-height: 32px;
	text-align: center;
	color: #fff;
	background: rgba(0,0,0,0.32);
	z-index: 20000;
}

html {
	font-size: 62.5%;
	@media only screen and(-webkit-min-device-pixel-ratio: 2),(min-resolution: 2dppx) {
		-webkit-font-smoothing: antialiased;
		-moz-osx-font-smoothing: grayscale;
	}
}

body {
	position: relative;
	display: flex;
	flex-direction: column;

	min-height: calc(100vh - 0px);
	margin: 0;

	text-align: left;
	line-height: 1.75;
	font-size: 1.8rem;

	background: #fff;

	color: #1a1a1a;
}

body.bgon {
	background: #fff url("../imgs/pict.png") center 20px no-repeat;
}

body, form, input, textarea, button, select {
	font-family: 'M PLUS Rounded 1c', sans-serif;
	font-weight: 400;
}


.aC, .alignC	{ text-align: center !important; }
.aL, .alignL	{ text-align: left !important; }
.aR, .alignR	{ text-align: right !important; }
.aJ, .alignJ, p, li, td {
	text-align: justify !important;
	text-justify: inter-ideograph;
	text-justify: inter-character;
}

.regular #body p {
	text-indent: 1.0em;
}

.regular #body p + p {
	margin-top: 1.75em;
}

.indent0 {
	text-indent: 0 !important;
}

a,
map, 
area,
.breakall {
	text-decoration: none;
	word-break: break-all;
	outline: none;
}

sup,
sub {
	height: 0;
	line-height: 1;
	vertical-align: baseline;
	_vertical-align: bottom;
	position: relative;
	margin: 0;
}
 
sup {
	bottom: 0.5em;
}
 
sub {
	top: 0.3em;
}

span[class^="space"] {
	clear: both;
	display: block;
}

.space0		{ height: 0; }
.space1		{ height: 1px; }
.space5		{ height: 5px; }
.space10	{ height: 10px; }
.space15	{ height: 15px; }
.space20	{ height: 20px; }
.space30	{ height: 30px; }
.space40	{ height: 40px; }
.space50	{ height: 50px; }
.space60	{ height: 60px; }
.space80	{ height: 80px; }
.space100	{ height: 100px; }
.space120	{ height: 120px; }
.space150	{ height: 150px; }
.space200	{ height: 200px; }

.mT0	{ margin-top: 0 !important; }
.mT5	{ margin-top: 5px !important; }
.mT10	{ margin-top: 10px !important; }
.mT20	{ margin-top: 20px !important; }
.mT30	{ margin-top: 30px !important; }
.mT40	{ margin-top: 40px !important; }
.mT50	{ margin-top: 50px !important; }
.mT60	{ margin-top: 60px !important; }
.mT80	{ margin-top: 80px !important; }
.mT100	{ margin-top: 100px !important; }

.mB0	{ margin-bottom: 0 !important; }
.mB5	{ margin-bottom: 5px !important; }
.mB10	{ margin-bottom: 10px !important; }
.mB20	{ margin-bottom: 20px !important; }
.mB30	{ margin-bottom: 30px !important; }
.mB40	{ margin-bottom: 40px !important; }
.mB50	{ margin-bottom: 50px !important; }
.mB60	{ margin-bottom: 60px !important; }
.mB80	{ margin-bottom: 80px !important; }
.mB100	{ margin-bottom: 100px !important; }

.mL0	{ margin-left: 0 !important; }
.mL5	{ margin-left: 5px !important; }
.mL10	{ margin-left: 10px !important; }
.mL20	{ margin-left: 20px !important; }
.mL30	{ margin-left: 30px !important; }
.mL40	{ margin-left: 40px !important; }
.mL50	{ margin-left: 50px !important; }

.mR0	{ margin-right: 0 !important; }
.mR5	{ margin-right: 5px !important; }
.mR10	{ margin-right: 10px !important; }
.mR20	{ margin-right: 20px !important; }
.mR30	{ margin-right: 30px !important; }
.mR40	{ margin-right: 40px !important; }
.mR50	{ margin-right: 50px !important; }

.block,
.is-show,
.show		{ display: block !important; }
.iblock		{ display: inline-block !important; }
.inline		{ display: inline !important; }
.is-hidden,
.hide		{ display: none !important; }

.flex		{ display: flex !important; }
.flex.sa	{ justify-content: space-around; }
.flex.sb	{ justify-content: space-between; }
.flex.fs	{ justify-content: flex-start; }
.flex.fe	{ justify-content: flex-end; }
.flex.ce	{ justify-content: center; }

.center, .fC {
	margin-left: auto !important;
	margin-right: auto !important;
}
.fL	{ float: left !important; }
.fR	{ float: right !important; }
.fClr { clear: both; }

.s0  { display: none; }
.s10 { font-size: 1.0rem !important; }
.s11 { font-size: 1.1rem !important; }
.s12 { font-size: 1.2rem !important; }
.s13 { font-size: 1.3rem !important; }
.s14 { font-size: 1.4rem !important; }
.s15 { font-size: 1.5rem !important; }
.s16 { font-size: 1.6rem !important; }
.s17 { font-size: 1.7rem !important; }
.s18 { font-size: 1.8rem !important; }
.s20 { font-size: 2.0rem !important; }
.s22 { font-size: 2.2rem !important; }
.s24 { font-size: 2.4rem !important; }
.s26 { font-size: 2.6rem !important; }
.s28 { font-size: 2.8rem !important; }
.s32 { font-size: 3.2rem !important; }

.l100	{ line-height: 1.0 !important; }
.l110	{ line-height: 1.1 !important; }
.l120	{ line-height: 1.2 !important; }
.l140	{ line-height: 1.4 !important; }
.l150	{ line-height: 1.5 !important; }
.l160	{ line-height: 1.6 !important; }
.l180	{ line-height: 1.8 !important; }

.k-10	{ letter-spacing: -0.05em; }
.k-20	{ letter-spacing: -0.10em; }
.k-30	{ letter-spacing: -0.15em; }
.k-40	{ letter-spacing: -0.20em; }
.k-50	{ letter-spacing: -0.25em; }
.k-60	{ letter-spacing: -0.30em; }
.k-80	{ letter-spacing: -0.40em; }
.k-100	{ letter-spacing: -0.50em; }
.k-150	{ letter-spacing: -0.75em; }
.k-200	{ letter-spacing: -1.00em; }
.k-400	{ letter-spacing: -2.00em; }

.indent-5	{ display: inline-block; text-indent: -5px; }
.indent-6	{ display: inline-block; text-indent: -6px; }
.indent-7	{ display: inline-block; text-indent: -7px; }
.indent-8	{ display: inline-block; text-indent: -8px; }
.indent-10	{ display: inline-block; text-indent: -10px; }

.normal		{ font-weight: normal !important;}
.bold		{ font-weight: bold !important; }
.slanted	{ font-style: italic !important; }
.strike		{ text-decoration: line-through; }
.underline	{ text-decoration: underline; }
.italic {
	font-style: italic !important;
	font-family: serif !important;
	font-size: 115%;
	line-height: 0.9;
}

.en {
	font-size: 110%;
}

.br:after {
	content: "\A";
	white-space: pre;
	height: 0.1px;
}

.red		{ color: #f00; }
.gray		{ color: #8a8a8a; }
.blue		{ color: #00f; }
.bluegray	{ color: #4e6cb4; }
.mint		{ color: #00c8d0; }
.bg-mint	{ background-color: #00c8d0; }
.grayLite	{ color: #dadada; }

a,
a:before,
a:after {
	transition: all .16s linear 0s;
	text-decoration: none;
}

a, 
.link a {
	color: #0076dd;
}

a:visited, 
.link a:visited {
	color: #0056cc;
}

a:hover,
.link:hover a, 
.kyozai-DL:hover a {
	color: #08e/* !important*/;
}

h1,
h2,
h3,
h4,
h5,
h6 {
	line-height: 1.5;
}


#body {
	margin-top: 105px;
	margin-top: 97px;
	margin-top: 88px;
}

.regular #body {
	padding: 80px 0 80px;
	padding: 76px 0 80px;
}

.wrapper {
	width: 100%;
	max-width: 1024px;
	margin: 0 auto;
}

.inner {
	width: 100%;
	max-width: 640px;
	margin: 0 auto;
}

.inner720 {
	width: 100%;
	max-width: 720px;
	margin: 0 auto;
}

.obj:before {
	content: "";
	display: block;
	/* それぞれの画像にあわせてpadding-topで高さを指定する */
}




.error {
	margin: 150px 0 50pc;
	font-weight: bold;
	text-align: center;
	line-height: 1.05;
	color: #dadada;
}

.error .code {
	font-size: 10.0rem;
	text-align: center;
}

.error .cont {
	margin-bottom: 50px;
}



header {
	position: fixed;
	top: 0;
	left: 0;
	z-index: 20000;

	width: 100%;
	height: 88px;
	text-align: center;
	background: #fff url("../imgs/nav-bg2.jpg") top center;
	background-size: 3000px;
	background-position-y: 5px;

	transition: all .16s linear 0s;
}

.logged-in header {
	top: 32px;
}

.logged-in .contentlist.sticky-menu {
	top: 118px;
}

#sitetitle {
	margin: 0;
	font-size: 2.0rem;
	line-height: 1.1;
}

#sitetitle img {
/*
	width: 100%;
	width: 280px;
	width: 320px;
	height: auto;
*/

	width: auto;
	height: 32px;

	margin: 16px 0 12px;
	transition: all .16s linear 0s;
}

#navMain {
	text-align: center;
}

.list-nav {
	display: flex;
	justify-content: center;
	align-items: center;
	margin: -5px 0 0;
	padding: 0;
	list-style: none;
	line-height: 1.3;
	font-size: 1.8rem;

	font-size: 1.6rem;

}

#navMain li {
	margin: 0 8px 5px;
}

#navMain a {
	display: inline-block;
	padding: 4px 10px;
	line-height: 1.0;
	text-align: center;
	color: #5a5a5a;
	white-space: nowrap;
	border-radius: 12px;

	font-variant-east-asian: proportional-width;
	-moz-font-feature-settings: "palt";
	-webkit-font-feature-settings: "palt";
	font-feature-settings: "palt";
/*
	letter-spacing: .038em;
*/
}

#navMain a,
#navMain a:visited {
	color: #5a5a5a;
	color: #009a9f;
}

#navMain .on a {
	font-weight: bold;
	color: #6b6b6b;
	color: #fff !important;
	background-color: #00c8d0;
}

#navMain:hover li.on a {
	background-color: rgba(0, 201, 208, 0.5);
}

#navMain a:hover {
	color: #fff;
	background-color: rgba(0, 201, 208, 1.0) !important;
}

body.float > header {
	height: 69px;
	box-shadow: 0 10px 10px rgba(0,0,0,0.16);
}

.float #sitetitle img {
	height: 24px;
	margin: 12px 0 8px;
}

.float #navMain a {
	padding: 3px 10px;
	font-size: 1.5rem;
}

/*
.regular.float h1#pagetitle {
	font-size: 1.4rem;
}
*/

.contentlist.float .box {
	box-shadow: 0 10px 10px rgba(0,0,0,0.14);
}

#topimage {
	position: relative;
	text-align: center;
	background: #e2dddd;
}

#topimage .obj {
/*	min-height: 360px;*/
}

#topimage .obj:before {
	padding-top: 35.205078125%;
}

#topimage img {
	position: absolute;
	top: 0;
	left: 50%;
	transform: translateX(-50%);
	width: 100%;
/*	min-width: 1024px; */
	height: auto;

}

#topimage2 {
	text-align: center;
	background: #e2dddd;
}

#topimage2 #slider {
	margin: 0;
	padding: 0;
	list-style: none;
}

#topimage2 img {
	width: 100%;
	height: auto;
}

#intro {
	margin: 24px auto 6px;
	padding: 0 54px;
	font-size: 2.0rem;
	line-height: 1.6;
	text-align: justify;
	text-justify: inter-ideograph;
	text-justify: inter-character;
	max-width: 720px;
}

#HOME #intro {
	max-width: 522px;
	max-width: 774px;
}

#news {
	display: flex;
	justify-content: center;
	align-items: flex-start;
	align-items: center;
	margin: 0 auto;
	padding: 32px 0;
}

#news > h2 {
	display: inline-block;
	width: 84px;
	height: 84px;
	overflow: hidden;
	margin: 6px 32px 0 0;
	padding: 0;
	text-align: center;
	font-size: 1.6rem;
	letter-spacing: 0.01em;
	line-height: 84px;
	color: #fff;
	border-radius: 50%;
	background: #00c8d0;
}

.list-news {
	display: block;
	margin: 0;
	padding: 0;
	list-style: none;
}

.list-news > li {
	display: block;
}

.list-news a {
	display: flex;
	justify-content: flex-start;
	align-items: center;
	padding: 8px 0;
	font-size: 1.6rem;
	color: #1a1a1a;
}

.list-news .d {
	display: inline-block;
	margin-top: 2px;
	font-size: 1.2rem;
	flex: 0 0 110px;
	letter-spacing: 0.1em;
}

.list-news .t {
	display: block;
	line-height: 1.2;
	flex: 0 0 100%;
}


#reports-HOME {
	display: flex;
	justify-content: center;
	flex-wrap: wrap;
	margin: 26px 0 0;
}

#reports-HOME h2 {
	margin: 0;
	padding: 0;
	font-size: 2.0rem;
	display: none;
}

#reports-HOME .report {
	position: relative;
	width: 223px;

	margin: 0 15px 40px;
	border: 1px solid #999;
	border-radius: 8px;
	overflow: hidden;
	cursor: pointer;
}

#reports-HOME .report-dami {
	width: 223px;
	margin: 0 15px 40px;
}

#reports-HOME .report .img {
	position: relative;
	width: 300px;
	height: 185px;

	background: #eaeaea;
	overflow: hidden;
}

#reports-HOME .report .obj:before {
	padding-top: 61.6666666666%;
}

#reports-HOME .report .img img {
	position: absolute;
	top: 50%;
	left: 50%;
	transform: translate(-50%, -50%);
	transition: all .32s ease-out 0s;
}

#reports-HOME .report .cont {
	padding: 20px 14px 30px;
	line-height: 1.3;
	border-top: 1px solid #dadada;
}

#reports-HOME .report .type {
	font-size: 1.2rem;
	color: #333;
}

#reports-HOME .report h3 {
	margin: 7px 0 0;
	padding: 0;
	font-weight: 800;
	font-size: 1.8rem;
	line-height: 1.3;
}

#reports-HOME .report h3 a {
	color: #1a1a1a !important;
}

#reports-HOME .report .writer {
	margin: 12px 0 0;
	font-size: 1.4rem;
	color: #5a5a5a;
}

#reports-HOME .report .d {
	margin: 12px 0 0;
	font-size: 1.2rem;
	color: #8a8a8a;
}

#reports-HOME .report:hover .img img {
	transform: translate(-50%, -50%) scale(1.1);
}

#reports-HOME .report .img.top0 img {
	top: 0;
	transform: translate(-50%, 0);
}

#reports-HOME .report:hover .img.top0 img {
	transform: translate(-50%, 0) scale(1.1);
}

#reports-HOME .report .img.top10 img {
	top: 10%;
	transform: translate(-50%, -10%);
}

#reports-HOME .report:hover .img.top10 img {
	transform: translate(-50%, -10%) scale(1.1);
}

#reports-HOME .report .img.top20 img {
	top: 20%;
	transform: translate(-50%, -20%);
}

#reports-HOME .report:hover .img.top20 img {
	transform: translate(-50%, -20%) scale(1.1);
}

#reports-HOME .report a.to {
	position: absolute;
	top: 0;
	left: 0;

	display: inline-block;
	width: 100%;
	height: 100%;
}





#acts-HOME {
	display: flex;
	justify-content: space-between;
	flex-wrap: wrap;
	margin: 38px 0 0;
}

#acts-HOME .act {
	width: 460px;
	min-height: 160px;
	margin: 0 20px 16px;
	text-align: center;
	background: #c7eaea;
	border-radius: 10px;
}

#acts-HOME .act:nth-child(2n+1)		{ margin-left: 0; }
#acts-HOME .act:nth-child(2n)		{ margin-right: 0; }

#acts-HOME .act h2 {
	margin: 0;
	padding: 0;
	font-size: 1.8rem;
	line-height: 1.2;
}

#acts-HOME .act.nl a {
	display: flex;
	padding: 20px 20px;
	text-align: left;
}

#acts-HOME .act h3 {
	
}

#acts-HOME .act.nl .img {
	margin-right: 20px;
}

#acts-HOME .act.nl img {
	width: 140px;
}


#linkS {
}

footer {
	border-top: 1px solid #b2b2b2;
	margin-top: auto;
}

footer p {
	margin: 0;
	padding: 32px 0 29px;
	text-align: center !important;
	font-size: 1.2rem;
	line-height: 1.5;
	color: #3a3a3a;
}

footer .totop {
	position: fixed;
	right: 30px;
	bottom: 10px;
	margin: 0 auto;
	display: none;
	width: 60px;
	height: 60px;
	overflow: hidden;
	text-align: center;
	line-height: 1.0;
	background: rgba(0, 201, 208, 0.6);
	border-radius: 4px;
	opacity: 0.48;
	transition: all .16s linear 0s;
	cursor: pointer;
}

footer .totop:before {
	content: url("../imgs/totop.svg");
	display: inline-block;
	width: 24px;
	height: 14px;
	overflow: hidden;
	line-height: 14px;
	overflow: hidden;
	transition: all .10s linear 0s;
	margin-top: 8px;
}

footer .totop:hover {
	background: #00c8d0;
	opacity: 1;
}

footer .totop:hover:before {
	margin-top: 4px;
}



/* Regular */

header {
/*
	border-bottom: 1px solid #c8c8c8;
*/
}

.regular h1,
.regular h2,
.regular h3,
.regular h4,
.regular h5 {
	font-weight: bold;
	color: #00c8d0;
}

.regular h1#pagetitle {
	margin: 0;
	text-align: center;
	font-size: 3.6rem;
}

.regular h2 {
	margin: 150px 0 0;
	text-align: center;
	font-size: 3.2rem;
}

.regular #intro {
	padding: 0 96px;
	text-align: center;
}


:not("list-conts-yoko") > li + li {
	margin-top: 8px;
}

.list-h2 {
	margin: 0;
	padding: 0;
	list-style: none;
}

.list-h2 > li {
	padding-left: 2.0em;
}

.list-h2 > li > .h {
	display: block;
	float: left;
	margin-left: -2.0em;
}

.kakomi {
	margin: 0.32em 0 1em;
	padding: 0.58em 1em;
	border: 1px solid #999;
}

.go {
	text-align: center;
}

.go > a {
	display: inline-block;
	padding: 13px 16px;
	line-height: 1.2;
	font-size: 1.8rem;
	font-weight: bold;
	color: #06c;
	border: 3px solid #06c;
	border-radius: 35px;
}

.go > a.h50 { border-radius: 50px; }

.mac .go > a {
	padding: 10px 16px 15px;
}

.go > a:after {
	content: "\f0a9";
	font-family: "Font Awesome 5 Free";
	font-weight: 900;
	font-size: 2.4rem;

	display: inline-block;
	margin-left: 5px;

	transform: translateY(2px);
}

.go > a:hover {
	color: #09f !important;
	border-color: #09f;
}



a.download {
	display: inline-block;
	padding: 13px 16px;
	line-height: 1.2;
	font-size: 1.8rem;
	font-weight: bold;
	color: #06c;
	border: 3px solid #06c;
	border-radius: 35px;
}

.mac a.download {
	padding: 10px 16px 15px;
}

a.download:after {
	content: "\f019";
	font-family: "Font Awesome 5 Free";
	font-weight: 900;
	font-size: 2.4rem;

	display: inline-block;
	margin-left: 5px;

	transform: translateY(2px);
}

a.download:hover {
	color: #09f !important;
	border-color: #09f;
}




.list-conts,
.list-conts-yoko,
.list-newsletter {
	margin: 0;
	padding: 0;
	list-style: none;
	border-top: 2px solid #d2d2d2;
	border-top: 2px solid #cacaca;
}

.list-conts-yoko {
	border-top: none;
}

.list-conts-yoko.border {
	padding-bottom: 20px;
	border-bottom: 2px dotted #d2d2d2;
	border-bottom: 2px dotted #cacaca;
}

.list-conts > li,
.list-newsletter > li {
	display: flex;
	padding: 24px 0;
	border-bottom: 2px dotted #d2d2d2;
}

.list-conts > li:last-child, 
.list-newsletter > li:last-child {
	border-bottom: 2px solid #cacaca;
}


.list-conts .ttl,
.list-newsletter .ttl {
	margin: 0;
	padding: 0;
	font-size: 2.2rem;
}

.list-conts .a {
	font-size: 1.6rem;
}


.list-conts .d,
.list-newsletter .d {
	font-size: 1.3rem;
	color: #6b6b6b;
}

.list-newsletter .cont p {
	text-indent: 0 !important;
	font-size: 1.6rem;
	line-height: 1.6;
}


.list-conts .img,
.list-newsletter .img {
	display: block;
	margin: 0 0 0 42px;
	text-align: center;
}

.list-conts .img img,
.list-newsletter .img img {
	display: block;
	width: 180px;
	height: auto;
	/* margin-bottom: 7px; */
	border: 1px solid #cacaca;
	transition: all .2s linear 0s;
}

.list-conts .mat .img {
	margin: 0 0 0 30px;
}

.img.w210 img { width: 210px; }
.img.w220 img { width: 220px; }
.img.w230 img { width: 230px; }
.img.w240 img { width: 240px; }
.img.w250 img { width: 250px; }
.img.w260 img { width: 260px; }

.list-conts .mat .img img {
	width: 168px;
}

.list-conts .img a,
.list-newsletter .img a {
	display: block;
	padding: 0;
	font-size: 1.4rem;
	line-height: 1.0;
	color: #b6b6b6;
}

.list-conts .img a,
.list-newsletter .img a {
	position: relative;
}

.list-conts .img a:after,
.list-newsletter .img a:after {
	position: absolute;
	bottom: -18px;
	left: 0;

/*
	content: "\f019";
	font-family: "Font Awesome 5 Free";
	font-weight: 900;
	font-size: 1.8rem;
*/
	content: "ダウンロード";
	font-size: 1.2rem;
	color: #cacaca;
	text-align: center;

	display: block;
	width: 100%;
	margin: 8px 0 0;

	opacity: 1;

	display: none;
}

.list-conts a:hover img,
.list-newsletter a:hover img {
	border-color: #eaeaea;
	box-shadow: 0 2px 18px rgba(0,0,0,0.24);
}

.list-conts a:hover,
.list-conts a:hover:after,
.list-newsletter a:hover,
.list-newsletter a:hover:after {
	opacity: 1;
	color: #09f !important;
}

.list-conts > li + li {
	margin-top: 0;
}

.list-conts .cont {
	width: 100%;
}

.list-conts .cont .mats {
	margin-top: 22px;
	margin-top: 12px;
}

.list-conts .mats .mat {
	position: relative;
	display: flex;
	align-items: center;
	padding: 22px 0 22px 64px;
	padding: 12px 0 12px 96px;
}

/*
.list-conts .mats {
	border-top: 2px dotted #eaeaea;
}
*/

.list-conts .mats > .mat {
	border-top: 2px dotted #eaeaea;
}

.list-conts .mats > .mat:last-child {
	padding-bottom: 0;
}

.list-conts .cont .mats .label {
	display: block;
	width: 40px;
	height: 40px;
	text-align: center;
	line-height: 40px;
	font-size: 1.3rem;
	font-weight: bold;

	border-radius: 50%;
	border: 2px solid rgba(0, 201, 208, 0.5);
	color: #00c9d0;
/*
	color: #fff;
	background: rgba(0, 201, 208, 0.65);
*/

	position: absolute;
	left: 32px;
	top: 50%;
	transform: translateY(-50%);
}

.list-conts .mats > .mat:last-child .label {
	top: calc((100% + 22px) * 0.5);
}

.list-conts .cont .mat .img {
	margin: 0 0 0 22px;
}

.list-conts .cont .mat .img a {
	display: block;
	padding: 0;
}

.list-conts .cont .mat .img img {
	margin-bottom: 0;
}

/*.list-conts .cont h3 {*/
.list-conts .cont h4 {
	font-size: 2.0rem;
	margin-bottom: 5px;
	line-height: 1.35;
}

.list-conts .mat h4.ttl {
	font-size: 1.6rem;
	line-height: 1.35;
	color: #333;
}

/*
.list-conts .mat .d {
	margin-bottom: -22px;
}
*/

.kakko-st {
	text-indent: -0.45em;
}

#kenkyu .list-conts-yoko {
	margin: 0 -160px;
}

#tanken-note .list-conts-yoko {
	margin: 0 -120px;
}

.list-conts-yoko {
	display: flex;
	justify-content: space-between;
	flex-wrap: wrap;
}

.list-conts-yoko.col3 li { width: 320px; }
.list-conts-yoko.col4 li { width: 240px; }
.list-conts-yoko.col5 li { width: 192px; }

.list-conts-yoko.col3 .img img { width: 260px; }
.list-conts-yoko.col4 .img img { width: 200px; }
.list-conts-yoko.col5 .img img { width: 160px; }

.mono-width > li {
	flex: 1;
}

.list-conts-yoko.mono-width.col5 > li {
	margin: 0 10px 20px;
}

.list-conts-yoko > li {
/*
	display: flex;
	flex-direction: column;
	align-items: center;
*/
	margin-bottom: 30px;
}

#susumekata,
#kyozai {
	max-width: 960px;
	margin-right: auto;
	margin-left: auto;
}

.play-btn, 
.dl-btn, 
.kyozai-DL a, 
.kyozai-DL .ttl, 
.kyozai-DL .img {
	transition: all .2s linear 0s;
}
/*
.list-conts-yoko .img a, 
.list-conts-yoko .img a img, */
.kyozai-DL .img {
	display: inline-block;
	position: relative;
}

.kyozai-DL .img img {
	display: block;
}

/*
#kenkyu .list-conts-yoko .img a:after, */
.kyozai-DL .img:after {
	content: "";
	position: absolute;
	top: 0;
	left: 0;
	display: block;
	width: calc(100% - 2px);
	height: calc(100% - 2px);
	border: 1px solid rgba(0,0,0,0.2);
}

/*
#kenkyu .list-conts-yoko .img a:hover,*/
.kyozai-DL a:hover .img {
	box-shadow: 0 2px 18px rgba(0,0,0,0.24);
}

/*
#kenkyu .list-conts-yoko .img a:hover:after,*/
.kyozai-DL a:hover .img:after {
	border-color: rgba(0,0,0,0.1);
}

/*
#kenkyu .list-conts-yoko .cont,*/
.kyozai-DL {
	text-align: center;
}

/*
.list-conts-yoko .cont .ttl,*/
.kyozai-DL .ttl {
	display: block;
	margin: 0px 0 0;
	padding: 0 0.5em;
	line-height: 1.2;
	text-align: center;
	font-weight: bold;
	color: #333;
	font-size: 1.6rem;
/*
	transition: all .2s linear 0s;
*/
}

/*.list-conts-yoko .cont .ttl.kakko-st,*/
.kyozai-DL .ttl.kakko-st {
	text-indent: 0 !important;
}

.kyozai-DL a:hover .ttl {
	color: inherit;
}

/*.list-conts-yoko .cont .d,*/ 
.kyozai-DL .d {
	margin-top: 5px;
	font-size: 1.3rem;
	display: none;
}

.play-btn, 
.dl-btn {
	display: inline-block;
	margin-top: 5px;
	padding: 3px 8px;
	border: 1px solid #0076dd;
	border-radius: 10px;
	font-size: 1.2rem;
	line-height: 1.01;
	color: #0076dd;
}

.play-btn:after, 
.dl-btn:after {
	content: "\f56d";
	font-family: "Font Awesome 5 Free";
	font-weight: 900;
	display: inline-block;
	margin-left: 3px;
}

.play-btn:after	{ content: "\f04b"; }
.dl-btn:after	{ content: "\f56d"; }


a:hover .play-btn, 
a:hover .dl-btn {
	color: #fff;
	background: #08e;
}













.list-link-collection {
	margin: 24px 0 0;
	padding: 0;
	list-style: none;
}

.list-link-collection > li {
	font-size: 1.5rem;
	line-height: 1.6;
	text-align: center !important;
}

.list-link-collection > li + li {
	display: block;
	margin-top: 2.0em;
}

.list-link-collection > li > a {
	display: block;
	font-size: 1.8rem;
	text-align: center;
}


.memo {
	padding-left: 1.5em;
	padding-right: 0.5em;
}

.memo.fC {
	display: inline-block;
}

.memo > .h {
	display: inline-block;
	text-indent: -1.5em;
}

form {
	margin: 0;
	padding: 0;
}

input,
select,
textarea,
button {
	font-size: 1.6rem;
	line-height: 1.5;
}

.list-form {
	margin: 0;
	padding: 0;
	list-style: none;
	font-size: 1.6rem;
}


.list-form > li {
	display: block;
	padding-left: 160px;
}

.list-form > li > .h {
	display: block;
	float: left;
	margin: 0.4em 0 0 -160px;
	width: 152px;
}


#toi-confirm .list-form > li		{ padding-top: 10px; }
#toi-confirm .list-form > li > .h	{ margin-top: 0px; }


.list-form > li > .h.hissu:after {
	content: "必須";

	float: right;
	display: block;
	margin-left: 0;
	padding: 4px 6px 3px;
	font-size: 1.1rem;
	line-height: 1.01;
	color: #fff;
	background: #e81c71;
	border-radius: 3px;
	transform: translateY(6px);
}

.list-form input[type="text"],
.list-form textarea {
	width: calc(100% - 22px);
	margin: 0;
	padding: 6px 10px;
	border: 1px solid #d2d2d2;
	border-radius: 4px;
	background: #fff;
}

#toiawase .list-form textarea {
	min-height: 120px;
}

#acception {
	text-align: center;
}

#acception label {
	cursor: pointer;
}

#acception input[type="checkbox"] {
	display: none;
}

#acception label:before {
	content: "\A0";
	font-family: "Font Awesome 5 Free";
	font-weight: bold;
	line-height: 20px;
	text-align: center;
	text-indent: 1px;
	display: inline-block;
	width: 20px;
	height: 20px;
	margin-right: 8px;
	border: 2px solid #00c8d0;
	border-radius: 6px;
	transform: translateY(1px);
}

#acception label.on:before {
	content: "\f00c";
}



.form-btns {
	margin-top: 5px;
	text-align: center;
}

.form-btns button {
	padding: 10px 20px;
	color: #00c8d0;
	border: 3px solid #00c8d0;
	border-radius: 6px;
	background: #fff;
	cursor: pointer;
	transition: all .2s linear 0s;
}

.form-btns button:hover {
	color: #fff;
	background: #00c8d0;
}

.form-btns button:disabled {
	cursor: default;
	color: #a2a2a2;
	border-color: #a2a2a2;
	background: #fff;
}

#toi-confirm .form-btns, 
#toi-done .form-btns {
	margin-top: 50px;
}




#kojinjoho {
	max-width: 640px;
	margin: 30px 0 24px;
	font-size: 1.4rem;
	line-height: 1.6;
}

.kj_outer {
	border: 1px solid #a2a2a2;
	border-radius: 3px;
	background-color: #fff;
	margin: 8px 0 20px;
}

.kj_inner {
	height: 172px;
	padding: 16px 34px;
	overflow: auto;
	text-align: justify;
	text-justify: inter-ideograph !important;
	text-justify: inter-character !important;

}

#kojinjoho p.lead {
	text-align: center !important;
}


.list-decimal {
	list-style-type: decimal;
}

#kojinjoho .list-decimal {
	font-size: 1.4rem;
	margin-top: 25px;
}

#toi-confirm #kojinjoho,
#toi-done #kojinjoho {
	display: none;
}


.list-nomark {
	margin: 0;
	padding: 0;
	list-style: none;
}

.list-closingBracket {
	margin: 0;
	padding: 0;
	list-style: none;
	font-size: 1.4rem;
}

.list-closingBracket > li {
	padding-left: 1.5em;
	counter-increment: cnt;
}

.list-closingBracket > li:before {
	content: counter(cnt) ") ";
	display: block;
	float: left;
	margin-left: -1.5em;
}

.list-nomark,
.list-closingBracket {
	margin-top: 2px;
}

.list-nomark > li + li,
.list-closingBracket > li + li {
	margin-top: 2px;
}

label.chkbox {
	cursor: pointer;
}

#accept-chkbox {
	width: 18px;
	height: 18px;
	border: 2px solid #5a5a5a;
	background: none;
	transform: translateY(3px);
}

.max1200 {
	width: 100%;
	max-width: 1200px;
	min-width: 960px;

}

.rotate-4 { transform: rotate(-4deg); }
.rotate-8 { transform: rotate(-8deg); }
.rotate10 { transform: rotate(10deg); }


.dropshadow {
	display: inline-block;
	box-shadow: 0 12px 20px rgba(0,0,0,0.215);
}





#nm {
	position: absolute;
	top: 0;
	right: 0;
	width: 80px;
	height: 80px;
	height: 76px;
	overflow: hidden;
	text-align: center;
	line-height: 1.0;
	z-index: 18001;
	background: #fff;
	cursor: pointer;
	display: none;
}

#nm > span {
	position: relative;
	display: inline-block;
	margin: 32px 0 0;
}

#nm > span,
#nm > span:before,
#nm > span:after {
	display: inline-block;
	width: 30px;
	height: 4px;
	border-radius: 3px;
	background: #00c8d0;
	transition: 0.35s all ease-in-out;
}

#nm > span:before,
#nm > span:after {
	content: "";
	position: absolute;
	left: 0;
}

#nm > span:before	{ top: -10px; }
#nm > span:after	{ top: 10px; }

#nm.selected > span {
	background: rgba(102, 102, 102, 0);
}

#nm.selected > span:before,
#nm.selected > span:after {
	background: #fff;
}

#nm.selected > span:before {
	top: 0;
	transform: rotate(405deg);
}
#nm.selected > span:after {
	top: 0;
	transform: rotate(-405deg);
}

#nm.selected {
	background: #00c8d0;
}

.contentlist {
	max-width: 640px;
	margin: 50px auto 0;
	padding: 0;
/*	overflow: hidden;*/
	z-index: 18000;
	text-align: center;
}

.contentlist .box {
	display: inline-flex;
	justify-content: center;
	gap: 0;
	border-radius: 18px;
	transition: all .16s linear 0s;
}

.contentlist a {
	display: block;
	margin: 0;
	padding: 5px 16px;
	font-size: 1.6rem;
	color: #00cad1;
	color: #009a9f;
	background: rgba(0, 200, 208, 0.23);
	background: #c5f2f4;
}

.contentlist a + a {
	border-left: 1px solid #fff;
}

.contentlist a:first-of-type { border-radius: 18px 0 0 18px; padding-left: 20px; }
.contentlist a:last-of-type { border-radius: 0 18px 18px 0; padding-right: 20px; }

.contentlist a:hover {
	color: #fff !important;
	background: rgba(0, 200, 208, 1.0);
}

.contentlist.sticky-menu {
	position: sticky;
	top: 86px;
}


a[href*=void] {
	cursor: default !important;
	color: #999;
}

a[href*=void]:hover {
	color: #999 !important;
}

.badge_new {
	display: inline-block;
	padding: 3px 6px;
	line-height: 1.0;
	font-size: 1.2rem;
	text-align: center;
	font-weight: bold;
	color: #fff;
	background: #f06;
	border-radius: 4px;
	transform: translateY(-1px);
}

.safari .badge_new {
	padding: 4px 6px 3px;
}