@charset 'utf-8';


#contentblock {
	width: 100%;
	position: relative;
}

#contentblock > .inner {
	width: 100%;
/* 
	max-width: 1000px;
 */
	margin: 0 auto;
	position: relative;
}


section .sentence {
	width: 100%;
	font-size: 1.4em;
	line-height: 1.8;
}

section .sentence:not(:last-child) {
	margin-bottom: 2em;
}

section .sentence a[target="_blank"]:after {
	display: inline-block;
	content: '\f109';
	margin-left: .3em;
	font-family: 'uiicon';
	font-weight: normal !important;
	text-align: center;
}

section .sentence h2 {
	margin-bottom: 1em;
	font-size: 1.6em;
	line-height: 1.5;
}

section .sentence h3 {
	margin-bottom: 1em;
	font-size: 1.4em;
	line-height: 1.5;
}

section .sentence h4 {
	margin-bottom: 1em;
	border-bottom: 1px solid;
	font-size: 1.2em;
	line-height: 1.5;
}

section .sentence p:not(:last-child) {
	margin-bottom: 1.5em;
}

section .sentence ul,
section .sentence ol {
	margin-left: 2em;
}

section .sentence ul:not(:last-child),
section .sentence ol:not(:last-child) {
	margin-bottom: 1.5em;
}

section .sentence .addr span {
	display: inline-block;
}

section .sentence .insidetbl {
	display: table;
}

section .sentence .insidetbl > div {
	display: table-row;
}

section .sentence .insidetbl > div > span {
	display: table-cell;
	width: auto;
	vertical-align: top;
}

section .sentence .insidetbl .head {
	padding-right: 1em;
	font-weight: 700;
	white-space: nowrap;
}

section .sentence .insidetbl .example {
	display: inline-block;
	font-size: .85em;
	line-height: 1.5;
}

section .sentence.contact {
	text-align: center;
}

section .sentence.contact .call {
	max-width: 300px;
	margin: 0 auto;
}

section .sentence.contact .call p {
	margin: 0;
}

section .sentence.contact .call .fonnumber {
	font-size: 2em;
	font-weight: 700;
	line-height: 1.2;
}

section .sentence.contact .call .fonnumber a {
	text-decoration: none;
	color: #000;
}

section .sentence.contact .call .time {
	font-size: .85em;
}

section .sentence.contact .addr span {
	display: inline-block;
}

section .sentence .announce {
	font-size: .8em;
	text-align: center;
}

section .sentence .announce p {
	margin: 1em;
}

section .sentence .announce .filepassword {
	display: inline-block;
	padding: 1em;
	background: #e1edf5;
}

section .sentence .announce .filepassword strong {
	display: inline-block;
	padding: .5em 1em;
	background: #fff;
	font-size: 1.6em;
}

.btnarea.download {
	display: flex;
	flex-direction: row;
	justify-content: center;
	align-items: center;
}

.btnarea.download > div {
	width: 100%;
	max-width: 400px;
	padding: 5px 0;
	font-size: 1.4em;
	font-weight: 700;
}

.btnarea.download > div a {
	width: 100%;
	padding: 1em .5em;
	border-radius: 5px;
	border: none;
	box-shadow: 0 5px 0 0 #168bb1;
	background: #24a7d2;
	color: #fff;
}

.btnarea.download > div a:hover,
.btnarea.download > div a.hover {
	transform: scale(1);
	background: #46bee5;
}

.btnarea.download > div a:after {
	content: '\f101';
	display: inline-block;
	margin-left: .3em;
	font-family: 'uiicon';
	font-weight: normal !important;
	transform: rotate(90deg);
	transition: .2s;
}

.btnarea.download > div a:hover:after,
.btnarea.download > div a.hover:after {
	transform: rotate(90deg) translateX(5px);
}

@media only screen and (min-width: 769px) {

	section .sentence {
		font-size: 1.6em;
	}
}


.stockinfo {
	width: 100%;
}

.stockinfo:not(:last-child) {
	margin-bottom: 30px;
}

.stockinfo > .inner {
	width: 100%;
	padding-bottom: 30px;
}

.stockinfo.memberloginbtn > .inner {
	max-width: 600px;
	margin: 0 auto;
}

.stockinfo .column p:not(:last-child) {
	margin-bottom: 1.5em;
}

.stockinfo .empty {
	display: flex;
	align-items: center;
	justify-content: center;
	padding: 1em;
	border: 1px solid #ccc;
	color: #808080;
	font-size: .85em;
}

@media only screen and (min-width: 481px) {

	.stockinfo:first-child > .inner {
		padding-top: 30px;
	}
}



.reference {
	width: 100%;
}

.reference:not(:last-child) {
	margin-bottom: 30px;
}

.reference > .inner {
	width: 100%;
	padding-bottom: 30px;
}

.reference h2 {
	margin-bottom: 1em;
	font-size: 1.8em;
	text-align: center;
	line-height: 1.5;
}


.sentence.actionblock h2 {
	margin-bottom: .5em;
	font-size: 1.4em;
	text-align: center;
	line-height: 1.5;
}

.sentence.actionblock h2 span {
	display: inline-block;
}

.sentence.actionblock p {
	text-align: center;
}

.actionblock .btn_action {
	font-size: 24px;
	line-height: 1;
}

.actionblock .btn_action .btn {
	display: block;
	width: 100%;
	padding: 15px;
	background: #0073bc;
	color: #fff;
	text-align: center;
	transition: .2s;
	cursor: pointer;
}

.actionblock .btn_action .btn.unlock {
	max-width: 300px;
	margin: 0 auto;
	background: #fff;
	color: #0073bc;
}

.actionblock .btn_action .btn.download {
	background: #fff;
	color: #0073bc;
}

.actionblock .btn_action .btn.hover {
	background: #3b99d5;
	color: #fff;
}

.actionblock .btn:before {
	display: inline-block;
	content: '';
	height: 100%;
	vertical-align: middle;
}

.actionblock .btn_action i {
	display: inline-block;
	width: 30px;
	height: 30px;
	font-style: normal;
	vertical-align: middle;
	position: relative;
}

.actionblock .btn_action span.icon {
	width: 100%;
	height: 100%;
}

.actionblock .btn_action span.icon span {
	width: 100%;
	height: 100%;
}

.actionblock .btn_action span.label {
	display: inline-block !important;
	padding-left: .4em;
	font-weight: 700;
	vertical-align: middle;
}

.actionblock .btn_action svg {
	fill: currentColor;
}


.stockinfo.announce {
	border: 1px solid #ccc;
	background: #ebebeb;
	font-size: .85em;
}

.stockinfo.announce > .inner {
	padding: 2em;
}


#attach.stockinfo.announce {
	border: none;
	border-top: 1px solid #ccc;
	background: transparent;
}

#attach.stockinfo.announce > .inner {
	padding: 0;
	padding-top: 1em;
}

#attach.stockinfo.announce h3 {
	font-size: 1em;
	font-weight: 400;
	text-align: center;
}

#attach.stockinfo.announce .fineinfo {
	font-weight: 400;
}


.announce .actionblock .btn_action {
	font-size: 18px;
}

.announce .actionblock .btn_action i {
	width: 22px;
	height: 22px;
}

.announce .actionblock .btn_action .register .label:after {
	display: inline-block;
	content: '\f109';
	margin-left: .3em;
	font-family: 'uiicon';
	font-weight: normal !important;
	text-align: center;
}

.announce .actionblock .btn_action .download .label:after {
	display: inline-block;
	content: '\f101';
	margin-left: .3em;
	font-family: 'uiicon';
	font-weight: normal !important;
	transform: rotate(90deg);
	text-align: center;
}

.datalists a[target="_blank"]:not(.download):after {
	display: inline-block;
	content: '\f109';
	margin-left: .3em;
	font-family: 'uiicon';
	font-weight: normal !important;
	text-align: center;
}


.datalists {
	width: 100%;
/* 	max-width: 1000px; */
	margin: 0 auto;
	font-size: .85rem;
	line-height: 1.6;
}

.datalists .columns {
	display: flex;
	flex-direction: column;
	justify-content: flex-start;
	align-items: flex-start;
}

.datalists .column {
	width: 100%;
}

.datalists .columns:not(:last-child),
.datalists .column:not(:last-child) {
	margin-bottom: 3em;
}

.datalists h2 {
	margin-bottom: 1em;
	font-size: 1.2em;
	line-height: 1.4;
	border-bottom: 1px solid;
}

.datalists h3:not(.title):not(.header) {
	margin-bottom: 1em;
	font-size: 1.2em;
	line-height: 1.4;
	border-bottom: 1px solid #ccc;
}

.datalists h4:not(.title) {
	margin-bottom: 1em;
	font-size: 1.1em;
	line-height: 1.4;
	border-bottom: 1px solid #ccc;
}

.datalists .url {
	word-break: break-all;
}

@media only screen and (min-width: 481px) {

	.datalists {
		font-size: 1rem;
	}
}

@media only screen and (min-width: 769px) {

	.datalists .columns {
		flex-direction: row;
		flex-wrap: wrap;
	}

	.datalists .column {
		width: 50%;
		margin-bottom: 0 !important;
		padding: 0 20px
	}
}



.datalists .item {
	border-bottom: 1px solid #ccc;
	font-size: 1rem;
}

.datalists .item .enclosed {
	padding: .8em .5em;
}

.datalists .meta {
	margin: .3em 0;
	color: #808080;
	font-size: .9em;
	line-height: 1.4;
}

.datalists .file {
	font-size: 1.2em;
	line-height: 1.5;
}

.datalists .file p {
	width: 100%;
	margin-bottom: .5em;
	padding-bottom: .5em;
	border-bottom: 1px solid #ccc;
	font-size: .85em;
	line-height: 1.5;
}

.datalists .file .label {
	margin-right: .3em;
	font-weight: 700;
}

.datalists .file .label:before {
	display: inline-block;
	content: '\f118';
	margin-right: .3em;
	font-family: 'uiicon';
	font-weight: normal !important;
	text-align: center;
}

.datalists .file .label:after {
	display: inline-block;
	content: '\f109';
	margin-left: .3em;
	font-family: 'uiicon';
	font-weight: normal !important;
	text-align: center;
}

.datalists .file .fineinfo {
	display: inline-block;
	color: #808080;
	font-size: .7em;
	font-weight: 400;
}

.datalists .sentence {
	font-size: 1em;
	line-height: 1.5;
}

@media only screen and (min-width: 481px) {

	.datalists .item .enclosed {
		display: flex;
		flex-direction: row;
		align-items: baseline;
		justify-content: flex-start;
	}

	.datalists .movie .item .enclosed {
		flex-direction: column;
	}

	.datalists .meta {
		width: 9em;
		margin: 0;
		white-space: nowrap;
	}

	.datalists .file {
		flex-grow: 1;
		width: calc(100% - (7em));
		margin: 0;
	}

	.datalists .sentence {
		flex-grow: 1;
		width: calc(100% - (7em));
		margin: 0;
	}
}



.memberdata {
	width: 100%;
	max-width: 800px;
	margin: 0 auto;
	font-size: .65rem;
	line-height: 1.6;
}

.memberdata > h2 {
	margin-bottom: 2em;
	font-size: 2em;
	text-align: center;
}

.memberdatalist {
	width: 100%;
	counter-increment: listnum;
}

.memberdatalist:not(:last-child) {
	margin-bottom: 2em;
}

.memberdatalist .header {
	margin-bottom: .5em;
	padding-left: 1.2em;
	border-bottom: 1px solid;
	font-size: 1.8em;
	position: relative;
}

.memberdatalist .header:before {
	content: counter(listnum) '.';
	width: 2em;
	text-align: right;
	position: absolute;
	top: 0;
	left: -1em;
}

.memberdatalist .datalist {
	font-size: 1.4em;
}

.memberdatalist .datalist ul {
	list-style: none;
	margin-left: 1em;
}

.memberdatalist .datalist li {
	border-bottom: 1px solid;
	counter-increment: itemnum;
}

.memberdatalist .datalist li a {
	display: flex;
	width: 100%;
	z-index: 1;
	padding: .5em 1em;
	padding-left: 3.7em;
	text-decoration: none;
	overflow: hidden;
	position: relative;
}

.memberdatalist .datalist li.active a {
	pointer-events: none;
	background: #f2f2f2;
	color: #000;
	cursor: default;
}

.memberdatalist .datalist li a:before {
	content: counter(itemnum) '.';
	width: 3em;
	text-align: right;
	position: absolute;
	top: .5em;
	left: 0;
}

.memberdatalist .datalist li .enclosed {
	padding-left: 30px;
	padding-right: 5px;
	position: relative;
}

.memberdatalist .datalist li .enclosed .icon {
	width: 24px;
	height: 24px;
	position: absolute;
	top: 0;
	left: 0;
}

.memberdatalist .datalist li .enclosed .icon span {
	display: inline-block;
	width: 100%;
	height: 100%;
}

.memberdatalist .datalist li .arrow {
	display: block;
	height: 100%;
	font-size: 0;
	position: absolute;
	top: 0;
	right: 10px;
}

.memberdatalist .datalist li.active .arrow {
	display: none;
}

.memberdatalist .datalist li .arrow:before {
	display: inline-block;
	content: '';
	height: 100%;
	vertical-align: middle;
}

.memberdatalist .datalist li .arrow .icon {
	display: inline-block;
	width: 18px;
	height: 18px;
	color: #808080;
	vertical-align: middle;
	transform: rotate(-90deg);
}

.memberdatalist .datalist li .arrow .icon span {
	display: inline-block;
	width: 100%;
	height: 100%;
	opacity: 0;
	transition: .2s;
}

.memberdatalist .datalist li:not(.active) a:hover .arrow .icon span,
.memberdatalist .datalist li:not(.active) a.hover .arrow .icon span {
	opacity: 1;
	transform: translateY(10px);
}

.memberdatalist .datalist .icon svg {
	fill: currentColor;
}

.memberdatalist .datalist .time {
	color: #808080;
	font-size: .8em;
}




.selecttab {
	width: 100%;
	margin-bottom: 30px;
	padding: 1em;
	border: 1px solid #ccc;
	background: #ebebeb;
	text-align: center;
}

.selecttab ul {
	list-style: none;
	display: flex;
	flex-wrap: wrap;
	width: 100%;
	position: relative;
}

.selecttab li {
	padding: .3em .7em;
	color: #808080;
	font-size: 1.2em;
	font-weight: 700;
	line-height: 1;
	transition: .2s;
	cursor: pointer;
}

.selecttab li.hover,
.selecttab li.active {
	color: #000;
}



.tabdatalistsblock {
	font-size: .85rem;
}

.tabdatalistsblock h2 {
	margin-bottom: 1em;
	font-size: 1.2em;
	line-height: 1.4;
	border-bottom: 1px solid;
}

.tabdatalists {
	width: 100%;
	height: auto;
	overflow: hidden;
	position: relative;
}

.tabdatalists .tabdatalist {
	width: 100%;
	opacity: 0;
	position: absolute;
	top: 0;
	left: 0;
}

.tabdatalists .tabdatalist.active {
	opacity: 1;
	position: relative;
	z-index: 10;
}

.tabdatalists .tabdatalist .header {
	margin-bottom: 1em;
	font-size: 1.2em;
	line-height: 1.4;
	text-align: center;;
}

@media only screen and (min-width: 481px) {

	.tabdatalistsblock {
		font-size: 1rem;
	}
}



.servicelist.movie .item {
	border: none;
}

.servicelist.movie h2 {
	margin: 0;
	border: none;
	font-size: 1em;
	text-align: left;
}

.servicelist.movie .time {
	font-size: .85em;
	text-align: left;
}



.imagebox > div {
	display: flex;
	flex-wrap: wrap;
	width: 100%;
}

.imagebox .media {
	width: calc(100% / 2);
	padding: 1%;
}

@media only screen and (min-width: 769px) {

	.imagebox .media {
		width: calc(100% / 3);
	}
}

@media only screen and (min-width: 1001px) {

	.imagebox .media {
		width: calc(100% / 4);
	}
}

.imagebox .media figure {
	width: 100%;
	padding-top: 100%;
	background: #e6e6e6;
	position: relative;
}

.imagebox .media figure .cover {
	display: block;
	padding: 5%;
	position: absolute;
	top: 0;
	left: 0;
	right: 0;
	bottom: 0;
}

.imagebox .media figure .cover > span,
.imagebox .media figure .cover > a {
	display: flex;
	justify-content: center;
	align-items: center;
	width: 100%;
	height: 100%;
	background-image: url(data:image/svg+xml;base64,PHN2ZyB2ZXJzaW9uPSIxLjEiIHhtbG5zPSJodHRwOi8vd3d3LnczLm9yZy8yMDAwL3N2ZyIgeD0iMHB4IiB5PSIwcHgiIHZpZXdCb3g9IjAgMCA1MTIgNTEyIiBzdHlsZT0iZW5hYmxlLWJhY2tncm91bmQ6bmV3IDAgMCA1MTIgNTEyOyIgeG1sOnNwYWNlPSJwcmVzZXJ2ZSI+PHN0eWxlIHR5cGU9InRleHQvY3NzIj4uc3Qwe2ZpbGw6IzMzMzMzMzt9PC9zdHlsZT48cG9seWdvbiBjbGFzcz0ic3QwIiBwb2ludHM9IjQzMy4yLDExOC45IDQzMy4yLDIyMCA0NTAuNSwxMjIgIi8+PHBvbHlnb24gY2xhc3M9InN0MCIgcG9pbnRzPSIyMTAsMjguMSAyMDEsNzguOCAyMjYuOCw3OC44IDIzMC41LDU3LjUgMzUxLjMsNzguOCA0MzMuMiw3OC44IDQzMy4yLDkzLjIgNDc5LjgsMTAxLjQgNDMzLjIsMzY1LjggNDMzLjIsNDAxLjcgNDUyLDQwNSA1MDkuMiw4MC45ICIvPjxwYXRoIGNsYXNzPSJzdDAiIGQ9Ik0xMDQuMSwxMDQuMXYzMjkuMWgzMDMuOFYxMDQuMUgxMDQuMXogTTM4Mi42LDQwNy45SDEyOS40VjEyOS40aDI1My4yVjQwNy45eiIvPjxyZWN0IHg9IjE1NC43IiB5PSIxNTQuNyIgY2xhc3M9InN0MCIgd2lkdGg9IjIwMi41IiBoZWlnaHQ9IjIwMi41Ii8+PC9zdmc+);
	background-repeat: no-repeat;
	background-position: center center;
	background-size: 22%;
	text-align: center;
	position: relative;
}

.imagebox .media figure .cover > span:before,
.imagebox .media figure .cover > a:before {
	content: '';
	width: 100%;
	height: 100%;
	background-color: #fff;
	opacity: .7;
	position: absolute;
	top: 0;
	left: 0;
	right: 0;
	bottom: 0;
}

.imagebox img {
	width: auto;
	max-width: 100%;
	height: auto;
	max-height: 100%;
	position: relative;
}


.reference .link {
	width: 100%;
	max-width: 600px;
	margin: 0 auto;
	margin-bottom: 3em;
	font-size: 1rem;
	line-height: 1.5;
}

.reference .link > .item {
	display: flex;
	justify-content: center;
	border-bottom: 1px solid;
	padding: .3em;
}

.reference .link > .item a {
	flex-grow: 1;
	text-decoration: none;
}

.reference .link > .item:has(a[target="_blank"]):after {
	display: inline-block;
	content: '\f109';
	margin-left: .5em;
	font-size: .8em;
	font-family: 'uiicon';
	font-weight: normal !important;
	text-align: center;
	/* line-height: 2; */
	vertical-align: top;
	-webkit-font-smoothing: antialiased;
	-moz-osx-font-smoothing: grayscale;
	transition: .2s;
}

.reference .link > .item:hover:after {
	transform: translate(5px,-5px);
}
