@charset 'utf-8';


#filterblock {
	padding: 20px 0;
	text-align: center;
}

#filterblock h2 {
	margin-bottom: .5em;
	font-size: 1.4em;
	font-weight: normal;
	line-height: 1.4;
}

#filterblock ul,
#filterblock li {
	list-style: none;
}

#filterblock ul {
	font-size: 0;
}

#filterblock li ul {
	display: inline;
}

#filterblock li {
	display: inline;
	font-size: .75rem;
}

#filterblock a {
	display: inline-block;
	margin: 2px;
	padding: .7em 1.2em;
	border-radius: 0;
	border: 2px solid;
	color: #bca8c9;
	font-feature-settings: 'palt';
	text-decoration: none;
	line-height: 1;
}

#filterblock a.current {
	border-color: #2d2830;
	color: #2d2830;
}

#filterblock a:hover,
#filterblock a.hover {
	border-color: #2d2830;
	color: #2d2830;
}

#case_categories > ul > li > a {
	display: none;
}

#case_categories > ul > li#ncp_all > a {
	display: inline-block;
	border-color: #bca8c9;
	background: #bca8c9;
	color: #fff;
}

#case_categories > ul > li#ncp_all > a:hover,
#case_categories > ul > li#ncp_all > a.hover {
	border-color: #2d2830;
	background: #bca8c9;
}


#caselist {
	display: flex;
	flex-wrap: wrap;
}

#caselist a {
	display: block;
	width: 100%;
	height: 100%;
	padding: 6%;
	border-radius: 0;
	border: 2px solid transparent;
	color: #2d2830;
	text-decoration: none;
	position: relative;
}

#caselist a:hover,
#caselist a.hover {
	border-color: #bca8c9;
	background: #f4f4f4;
	transform: scale(1.1);
}

#caselist .item {
	display: block;
	width: 100%;
	padding: 1.8%;
	font-size: 1rem;
	text-align: center;
	vertical-align: middle;
	position: relative;
}

#caselist .item .cover {
	display: flex;
	flex-wrap: wrap;
	width: 100%;
	height: 100%;
	position: relative;
}

#caselist .item img {
	width: 100%;
	height: auto;
}

#caselist .item .title {
	margin-bottom: 1em;
	font-size: 1.6em;
	font-weight: 900;
}

#caselist .sitethumb {
	width: 100%;
	font-size: 0;
}

#caselist .sitethumb .thumb {
	display: inline-block;
	vertical-align: top;
}

#caselist .sitethumb .thumb.sp {
	width: 48%;
	margin-right: 4%;
}

#caselist .sitethumb .thumb.pc {
	width:  48%;
}

#caselist .sitethumb figure {
	position: relative;
}

#caselist .sitethumb .sp figure {
	padding-top: 100%;
}

#caselist .sitethumb .pc figure {
	padding-top: 100%;
}

#caselist .sitethumb span {
	border-radius: 0;
	overflow: hidden;
	position: absolute;
	top: 0;
	left: 0;
	right: 0;
	bottom: 0;
}

#caselist .siteinfo {
	align-self: flex-end;
	width: 100%;
	margin-top: 1em;
	padding: 0 1em;
	font-size: .75em;
	line-height: 1.4;
}

#caselist .item .name {
	margin-bottom: .7em;
}

#caselist .item .name strong {
	font-size: 1.4em;
	font-weight: 700;
}

#caselist .item .name span {
	display: inline-block;
	padding-left: .2em;
}

#caselist .item .category {
	margin-bottom: .5em;
}

#caselist .item .category span {
	display: inline-block;
	padding: .5em 1em;
	border-radius: 0;
	border: 2px solid;
	background: #fff;
	color: #bca8c9;
	line-height: 1;
}

#caselist .item .plan {
	color: #bca8c9;
}

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

/* 
	#caselist .item {
		width: 50%;
	}
 */
}

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

	#caselist .item {
		width: 50%;
	}
}



#document {
	margin-bottom: 50px;
}

#documentbody {
	display: flex;
	flex-wrap: wrap;
	max-width: 900px;
	margin: 0 auto;
	padding: 30px 0;
}

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

#documentbody figure {
	border-radius: 0;
	overflow: hidden;
}

#documentbody figure figcaption {
	padding-top: .5em;
	color: #666;
	font-size: .85rem;
	text-align: right;
	line-height: 1.5;
}

#documentbody .btnarea a {
	margin: 5px 10px;
}

#siteinfo {
	width: 80%;
	padding-left: 8%;
	padding-right: 10px;
	font-size: .85rem;
	order: 2;
}

.sitedata {
	width: 80%;
	max-width: 600px;
	margin: 0 auto;
	padding: 0 10px;
	font-size: .9rem;
	order: 4;
}

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

#sitethumb_sp {
	width: 20%;
	order: 1;
}

#sitethumb_pc {
	width: 100%;
	padding: 6% 0;
	order: 3;
}

#articletitle {
	margin-bottom: 2em;
}

#articletitle h1 {
	margin-bottom: 1.2em;
	font-size: 2em;
	font-weight: 900;
}

#articletitle h2 {
	margin-bottom: 1.2em;
	font-size: 1em;
	font-weight: normal;
}

#articletitle h2 strong {
	font-size: 1.4em;
	font-weight: 700;
}

#articletitle h2 span {
	display: inline-block;
	padding-left: .2em;
}

#articletitle .shoulder {
	margin-bottom: .3em;
	font-size: .85em;
}

#articletitle .desc p {
	line-height: 1.6;
}

#articletitle .category {
	margin-bottom: .5em;
	font-size: .75em;
}

#articletitle .category a {
	display: inline-block;
	padding: .5em 1em;
	border-radius: 0;
	border: 2px solid;
	background: #fff;
	color: #bca8c9;
	text-decoration: none;
	line-height: 1;
}

#articletitle .category a:hover,
#articletitle .category a.hover {
	border-color: #2d2830;
	color: #2d2830;
}

#articletitle .plan {
	margin-bottom: .5em;
	color: #bca8c9;
	font-size: .85em;
}

#articletitle .website {
	margin-bottom: 1em;
	line-height: 1.4;
	font-size: .9em;
	word-break: break-all;
}

#articletitle .website a {
	color: #2d2830;
}

.sitedata h2 {
	margin-bottom: 1em;
	font-size: 1.4em;
/* 	text-align: center; */
	line-height: 1.4;
}

.sitedata h3 {
	margin-bottom: .5em;
	font-size: 1.2em;
}

.sitedata p:not(:last-child) {
	margin-bottom: 1em;
}

.sitedata .planlist {
	list-style: none;
	margin-bottom: 1.5em;
	padding-left: .5em;
}

.sitedata .contents {
	font-size: 1.1em;
}

.sitedata .planlist li {
	list-style: none;
	padding-left: 1.2em;
	line-height: 1.4;
	position: relative;
}

.sitedata .planlist li:not(:last-child) {
	margin-bottom: .2em;
}

.sitedata .planlist li:before {
	display: inline-block;
	font-family: 'uiicon';
	font-weight: normal !important;
	text-align: center;
	position: absolute;
	top: 0;
	left: 0;
}

.sitedata .planlist.contents li:before {
	content: '\f113';
	font-size: 1em;
	line-height: 1.5em;
}

.sitedata .planlist.function li:before {
	content: '\f118';
	font-size: .8em;
	line-height: 1.8em;
}

#document .articleblock {
	max-width: 900px;
	margin: 0 auto;
	margin-bottom: 2em;
	padding: 30px 0;
}

#document .articleblock img {
	width: 100%;
	height: auto;
}

#document .articleblock .chapter:not(:last-child) {
	margin-bottom: 3em;
}

#document .articleblock .chapter {
	font-size: 1rem;
	line-height: 1.8;
}

#document .articleblock .chapter figure {
	margin-bottom: 2em;
}

#document .articleblock figure figcaption {
	padding-top: .5em;
	color: #666;
	font-size: .85rem;
	text-align: right;
	line-height: 1.5;
}

#document .articleblock .chapter .enclosed {
	width: 80%;
	max-width: 600px;
	margin: 0 auto;
}

#document .articleblock .chapter .enclosed h2 {
	margin-bottom: 1em;
	font-size: 1.6em;
}

#document .articleblock .chapter .enclosed h3 {
	margin-bottom: .5em;
	font-size: 1.2em;
}

#document .articleblock .chapter .enclosed p:not(:last-child),
#document .articleblock .chapter .enclosed ul:not(:last-child) {
	margin-bottom: 1em;
}

#document .articleblock .chapter .enclosed ul {
	margin-left: 1.5em;
}

#document .articleblock .chapter.comment {
	padding: 2em;
	background: rgba(20,65,153,.05);
}

#recommenditems .sectheader {
	margin-bottom: 1em;
	padding: .8em 2.2em;
	text-align: center;
	color: #000;
	font-size: 1.4em;
	font-weight: 700;
	font-feature-settings: 'palt';
	line-height: 1.4;
}

#recommenditems .sectheader > span {
	display: inline-block;
	padding: .5em 1.5em;
	border-radius: 0;
	border: 2px solid #000;
	position: relative;
}

#recommenditems .sectheader > span:before{
	content: '';
	margin-left: -15px;
	border: 12px solid transparent;
	border-top: 12px solid #fff;
	position: absolute;
	bottom: -24px;
	left: 50%;
	z-index: 2;
}

#recommenditems .sectheader > span:after{
	content: '';
	margin-left: -17px;
	border: 14px solid transparent;
	border-top: 14px solid #000;
	position: absolute;
	bottom: -29px;
	left: 50%;
	z-index: 1;
}

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

	#siteinfo {
		width: 60%;
		padding-left: 10%;
		font-size: 1rem;
	}

	.sitedata {
		font-size: 1rem;
	}

	#sitethumb_sp {
		width: 30%;
	}

	#recommenditems .sectheader {
		font-size: 1.8em;
	}
}


#companylist {
	display: flex;
	flex-wrap: wrap;
	padding: 20px;
}

#companylist .item {
	width: 100px;
	padding: 5px;
}

#companylist .item img {
	width: 100%;
	height: auto;
}

#companylist .item a {
	display: block;
}

#companylist .item a:hover,
#companylist .item a.hover {
	transform: scale(1.1);
}



.chartblock {
	display: flex;
	flex-wrap: wrap;
	width: 100%;
	max-width: 900px;
	margin-left: auto;
	margin-right: auto;
	margin-bottom: 50px;
	padding: 20px;
}

.chartblock .chart {
	width: 33.333%;
}

.chartblock .chart .charttitle {
	padding: 0 20px;
	font-size: 1rem;
	font-weight: 700;
}

.chartblock .chart .chartcover {
	position: relative;
}

.chartblock .chart .chartcover span {
	font-size: 1rem;
	font-weight: 700;
	transform: translate(-50%,-30%);
	position: absolute;
	top: 50%;
	left: 50%;
}

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

	.chartblock .chart {
		padding: 40px;
	}

	.chartblock .chart .chartcover span {
		font-size: 1.6rem;
	}
}
