:root {
	--contents_blue_bg2: rgba(0, 47, 109, 0.1);
	--contents_blue_bg1: rgba(0, 139, 208, 0.15);
}

.visual_top > h1 {
	display: table-cell;
	margin: 0;
	padding: 0 0 30px 30px;
	vertical-align: bottom;
	text-align: left;
	font-style: normal;
	font-weight: bold;
	font-size: 19px;
	line-height: 1;
	color: #fff;
	text-shadow: 1px 1px 3px rgba(0, 0, 0, 0.7);
}

.visual_top > h1 > b {
	display: block;
	margin: 0;
	padding: 0 0 10px;
	font-style: normal;
	font-weight: bold;
	font-size: 14px;
	line-height: 1;
}

.visual_top > h1 > i {
	display: block;
	font-style: normal;
	font-weight: normal;
	font-size: 19px;
	line-height: 1;
}

.visual_top.recruit > h1,
.visual_top.news > h1 {
	padding: 0 0 30px 30px;
	color: #000;
	text-shadow: 1px 1px 3px rgba(255, 255, 255, 0.7);
}

@media (min-width: 1000px) {
	.visual_top > h1 {
		padding: 0 0 30px 50px;
		vertical-align: bottom;
		font-weight: normal;
		font-size: 26px;
		line-height: 1;
	}

	.visual_top > h1 > b {
		padding: 0 0 12px;
		font-weight: normal;
		font-size: 18px;
		line-height: 1;
	}

	.visual_top > h1 > i {
		font-size: 26px;
		line-height: 1;
	}
}

/**/

.container {
	width: 100%;
	margin: 0 auto;
	padding: 30px 15px;
}

@media (min-width: 1000px) {
	.container {
		width: 1000px;
		padding: 50px 0;
	}
}

.contents_wrapper {
	width: 100%;
	margin: 0;
	padding: 0;
	background-color: #fff;
}

.contents_wrapper.blue_bg {
	background-color: var(--contents_blue_bg1);
}

.contents_h2 {
	margin: 0;
	padding: 0;
	font-style: normal;
	font-weight: normal;
	font-size: 20px;
	line-height: 1;
	color: #333;
}

.contents_h2 > figure {
	display: block;
	height: 40px;
	margin: 0 0 20px;
	padding: 0;
}

.contents_h2 > figure > img {
	width: initial;
	height: 100%;
	vertical-align: bottom;
}

.contents_h2 > b {
	display: inline-block;
	margin: 0;
	padding: 0;
	font-style: normal;
	font-weight: normal;
	font-size: 1em;
	line-height: 1;
	color: #333;
}

.contents_h2 > i {
	display: inline-block;
	margin: 0;
	padding: 0 0 0 0.5em;
	font-family: -apple-system, BlinkMacSystemFont, 'Helvetica Neue', arial, sans-serif;
	font-style: normal;
	font-weight: normal;
	font-size: 1em;
	line-height: 1;
	color: #aaa;
}

.contents_h2 > span {
	display: inline-block;
	height: 0.7em;
	margin: 0;
	padding: 0 0 0 0.5em;
	border-right: 1px solid #aaa;
	font-size: 1em;
	line-height: 1;
}

.contents_p {
	margin: 0;
	padding: 1.5em 0 0;
	font-style: normal;
	font-weight: normal;
	font-size: 14px;
	line-height: 1.8;
}

.contents_ul {
	margin: 0;
	padding: 1em 0 0 1.4em;
	list-style-type: decimal;
}

.contents_ul > li {
	margin: 0;
	padding: 0.5em 0;
	font-style: normal;
	font-weight: normal;
	font-size: 14px;
	line-height: 1.3;
}

@media (min-width: 1000px) {
	.contents_h2 {
		font-size: 24px;
		line-height: 1;
	}

	.contents_h2 > figure {
		height: 52px;
	}

	.contents_p {
		font-size: 16px;
		line-height: 1.8;
	}

	.contents_ul > li {
		font-size: 16px;
		line-height: 1.3;
	}
}

/****************************
  company
****************************/

#corporate_philosophy > div {
	width: 100%;
	margin: 0 auto;
	padding: 30px 15px;
}

#corporate_philosophy > div > div {
	margin: 0;
	padding: 0;
	text-align: left;
}

#corporate_philosophy > div > figure {
	max-width: 350px;
	margin: 0 auto;
	padding: 20px 0 0;
}

@media (min-width: 1000px) {
	#corporate_philosophy > div {
		display: table;
		width: 1000px;
		margin: 0 auto;
		padding: 50px 0;
	}

	#corporate_philosophy > div > div {
		display: table-cell;
		width: 600px;
		padding: 30px 120px 270px 0;
		vertical-align: top;
		text-align: left;
	}

	#corporate_philosophy > div > figure {
		display: table-cell;
		max-width: initial;
		margin: 0;
		padding: 0;
		background-repeat: no-repeat;
		background-position: right top;
		background-size: cover;
		background-image: url(../../files/company/1.jpg);
		vertical-align: top;
		text-align: left;
	}
}
@media (min-width: 1200px) {
	#corporate_philosophy > div {
		width: 1200px;
	}

	#corporate_philosophy > div > div {
		width: 750px;
	}
}

/* company greeting */

#greeting > div {
	width: 100%;
	margin: 0 auto;
	padding: 30px 15px;
}

@media (min-width: 1000px) {
	#greeting > div {
		width: 1000px;
		padding: 50px 250px 50px 0;
	}
}
@media (min-width: 1200px) {
	#greeting > div {
		width: 1200px;
		padding: 50px 250px 50px 0;
	}
}

.signature {
	margin: 0;
	padding: 1.5em 0 0;
	text-align: right;
	font-family: var(--font-mincho);
	font-style: normal;
	font-weight: normal;
	font-size: 18px;
	line-height: 1.5;
}

/* company management_philosophy */

#management_philosophy > div {
	width: 100%;
	margin: 0 auto;
	padding: 30px 15px;
}

#management_philosophy > div > div {
	margin: 0;
	padding: 0;
	text-align: left;
}

#management_philosophy > div > figure {
	max-width: 100%;
	height: 250px;
	margin: 0 auto;
	padding: 20px 0 0;
	background-repeat: no-repeat;
	background-position: center bottom;
	background-size: cover;
	background-image: url(../../files/company/2sp.jpg);
}

#management_philosophy h3 {
	margin: 0;
	padding: 3em 0 0;
	font-style: normal;
	font-weight: bold;
	font-size: 16px;
	line-height: 1;
	color: #999;
}

#management_philosophy h3 + .contents_p {
	padding: 1em 0 0;
}

@media (min-width: 1000px) {
	#management_philosophy > div {
		display: table;
		width: 1000px;
		margin: 0 auto;
		padding: 50px 0;
	}

	#management_philosophy > div > div {
		display: table-cell;
		width: 600px;
		margin: 0;
		padding: 30px 80px 100px 0;
		vertical-align: top;
		text-align: left;
	}

	#management_philosophy > div > figure {
		display: table-cell;
		max-width: initial;
		margin: 0;
		padding: 0;
		background-position: right top;
		background-image: url(../../files/company/2pc.jpg);
		vertical-align: top;
		text-align: left;
	}
}
@media (min-width: 1200px) {
	#management_philosophy > div {
		width: 1200px;
	}

	#management_philosophy > div > div {
		width: 750px;
	}
}

/**/

#overview > div {
	width: 100%;
	margin: 0 auto;
	padding: 30px 15px;
}

@media (min-width: 1000px) {
	#overview > div {
		width: 800px;
		padding: 80px 0;
	}
}

#overview dl {
	display: table;
	width: 100%;
	margin: 10px 0 0;
	padding: 0;
	border: 1px solid rgba(0, 47, 109, 0.2);
	background-color: #fff;
}

#overview h2 + dl {
	margin-top: 30px;
}

#overview dl > dt,
#overview dl > dd {
	display: table-cell;
	margin: 0;
	padding: 0.7em 1em;
	font-style: normal;
	font-weight: normal;
	font-size: 13px;
	line-height: 1.5;
	color: #333;
}

#overview dl > dt {
	width: 6em;
	padding: 0.7em 0.5em;
	white-space: nowrap;
}

#overview dl > dd {
	display: table-cell;
}

#overview dl > dd > span {
	display: block;
	margin: 0.2em 0 0;
}

@media (min-width: 1000px) {
	#overview dl > dt,
	#overview dl > dd {
		font-size: 16px;
		line-height: 1.5;
	}

	#overview dl > dt {
		width: 8em;
	}

	#overview dl > dd > span {
		display: inline-block;
		margin: 0;
	}

	#overview dl > dd > span::before {
		content: '/';
		padding-right: 0.4em;
		padding-left: 0.2em;
	}
}

/**/

#history > div {
	width: 100%;
	margin: 0 auto;
	padding: 30px 15px;
}

@media (min-width: 1000px) {
	#history > div {
		width: 800px;
		padding: 80px 0;
	}
}

#history dl {
	display: table;
	width: 100%;
	margin: 10px 0 0;
	padding: 0;
	border: 1px solid rgba(0, 47, 109, 0.2);
	background-color: #fff;
}

#history h2 + dl {
	margin-top: 30px;
}

#history dl.even {
	background-color: rgba(0, 47, 109, 0.04);
}

#history dl > dt,
#history dl > dd {
	display: table-cell;
	margin: 0;
	padding: 0.7em 0.5em;
	font-style: normal;
	font-weight: normal;
	font-size: 13px;
	line-height: 1.5;
	color: #333;
}

#history dl > dt {
	width: 9em;
	white-space: nowrap;
}

#history dl > dd {
	display: table-cell;
}

@media (min-width: 1000px) {
	#history dl > dt,
	#history dl > dd {
		padding: 0.7em 1em;
		font-size: 16px;
		line-height: 1.5;
	}

	#history dl > dt {
		width: 10em;
	}
}

/**/

#access > div {
	width: 100%;
	margin: 0;
	padding: 0;
}

#access > div > div {
	width: 100%;
	margin: 0;
	padding: 0;
	text-align: left;
}

#access > div > div + div {
	padding: 30px 15px;
}

#access > div > div > iframe {
	display: block;
	width: 100%;
	height: 400px;
}

#access dl > dt,
#access dl > dd {
	margin: 0;
	padding: 0.75em 0 0;
	font-family: 'Hiragino Kaku Gothic ProN', 'ヒラギノ角ゴ ProN W3', Meiryo, 'メイリオ', arial, sans-serif;
	font-style: normal;
	font-weight: normal;
	font-size: 14px;
	line-height: 1.5;
	color: #333;
}

#access dl > dt {
	padding: 2em 0 0;
	font-weight: bold;
}

@media (min-width: 1000px) {
	#access > div {
		display: table;
		padding: 0;
	}

	#access > div > div {
		display: table-cell;
		width: 50%;
		margin: 0;
		padding: 0;
		vertical-align: top;
		text-align: left;
	}

	#access > div > div + div {
		padding: 50px 50px 50px 50px;
	}

	#access > div > div > iframe {
		display: block;
		width: 100%;
		height: 600px;
	}

	#access dl > dt,
	#access dl > dd {
		font-size: 16px;
		line-height: 1.5;
	}
}

/****************************
  contents_contact
****************************/

#contents_contact {
	width: 100%;
	margin: 0;
	padding: 0;
	background-color: var(--contents_blue_bg1);
}

#contents_contact > div {
	width: 100%;
	margin: 0;
	padding: 0;
}

#contents_contact > div > div {
	margin: 0;
	padding: 15px 0;
	text-align: center;
}

#contents_contact > div > div + div {
	border-top: 3px solid #fff;
}

#contents_contact > div > div#service_contact_title {
	display: none;
}

#service_contact_title > h2 {
	position: absolute;
	top: 50%;
	left: 50%;
	transform: translate(-100%, -100%);
	margin: 0;
	padding: 0;
	font-style: normal;
	font-weight: normal;
	font-size: 25px;
	line-height: 1;
}

#service_contact_title > h2 > div {
	margin: 0;
	padding: 0 0 10px;
	font-style: normal;
	font-weight: normal;
	font-size: 18px;
	line-height: 1;
}

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

#contents_contact dt {
	margin: 0;
	padding: 55px 0 0;
	font-style: normal;
	font-weight: bold;
	font-size: 15px;
	line-height: 1;
	color: #000;
	position: relative;
}

#contents_contact dt::before {
	position: absolute;
	z-index: 1;
	top: 0;
	left: 50%;
	transform: translateX(-50%);
	width: 40px;
	height: 40px;
	margin: 0;
	padding: 0;
	vertical-align: 0;
	border-radius: 100%;
	background-color: var(--blue_icon_bg_out);
	content: '';
}

#contents_contact dt::after {
	position: absolute;
	z-index: 2;
	top: 0;
	left: 50%;
	margin: 0;
	padding: 0;
	font-family: 'FontAwesome';
	color: #fff;
}

#contents_contact #contents_contact_mail dt::after {
	transform: translate(-50%, 8px);
	content: '\f003';
	font-size: 22px;
	line-height: 1;
}

#contents_contact #contents_contact_phone dt::after {
	transform: translate(-10px, 9px);
	content: '\f095';
	font-size: 25px;
	line-height: 1;
}

#contents_contact #contents_contact_entry dt::after {
	transform: translate(-10px, 10px);
	content: '\f08e';
	font-size: 21px;
	line-height: 1;
}

#contents_contact dd {
	margin: 0;
	padding: 10px 0 0;
	font-style: normal;
	font-weight: normal;
	font-size: 14px;
	line-height: 1.4;
	color: #000;
}

#contents_contact dd a {
	display: inline-block;
	font-style: normal;
	font-weight: normal;
	font-size: 18px;
	line-height: 1.4;
}

#contents_contact dd div {
	margin: 0;
	padding: 5px 0 0;
}

@media (min-width: 768px) {
	#contents_contact {
		padding: 0;
	}

	#contents_contact > div {
		display: table;
		width: 100%;
		height: 100%;
		margin: 0 auto;
		padding: 0;
	}
	
	#contents_contact > div > div {
		display: table-cell;
		width: calc(100% / 2);
		margin: 0;
		padding: 15px 0;
		vertical-align: middle;
		text-align: center;
	}

	#contents_contact > div > div + div {
		border-top: none;
		border-left: 3px solid #fff;
	}
}
@media (min-width: 1000px) {
	#contents_contact {
		height: 180px;
		padding: 0;
	}

	#contents_contact > div > div {
		width: calc(100% / 3);
		padding: 0;
	}

	#contents_contact > div > div + div {
		border-left: none;
	}

	#contents_contact > div > div#service_contact_title {
		display: table-cell;
		margin: 0;
		padding: 0;
		vertical-align: top;
		text-align: left;
		background: url(../../files/service/service_contact_title.png), linear-gradient(to right, rgba(211, 211, 213, 1), rgba(211, 211, 213, 0.5));
		background-repeat: no-repeat;
		background-position: center top 15px, center top;
		background-size: contain, cover;
		position: relative;
	}

	#contents_contact dt {
		font-size: 17px;
		line-height: 1;
	}

	#contents_contact dd {
		font-size: 15px;
		line-height: 1.4;
	}
}
@media (min-width: 1400px) {
	#contents_contact > div {
		width: 1400px;
	}
	
	#contents_contact > div > div {
		width: calc(100% / 3);
	}
}

/****************************
  service
****************************/

#service_summary {
	width: 100%;
	margin: 0;
	padding: 30px 15px;
}

#service_summary > div {
	width: 100%;
	margin: 0 auto;
	padding: 0;
}

.service_h2 {
	margin: 0;
	padding: 0;
	font-style: normal;
	font-weight: normal;
	font-size: 24px;
	line-height: 1;
}

#service_summary dl {
	margin: 0;
	padding: 0;
	font-size: 17px;
	line-height: 1;
}

#service_summary dt {
	margin: 0;
	padding: 2.5em 0 0;
	font-style: normal;
	font-weight: bold;
	font-size: 1em;
}

#service_summary dd + dt {
	padding: 1.5em 0 0;
}

#service_summary dd {
	margin: 0;
	padding: 0.7em 0 0;
	font-style: normal;
	font-weight: normal;
	font-size: 0.95em;
	line-height: 1.7;
}

@media (min-width: 1000px) {
	#service_summary {
		padding: 50px 0;
	}

	#service_summary > div {
		width: 1000px;
	}
}

#service_nav {
	width: 100%;
	margin: 0;
	padding: 0;
	background-color: var(--contents_blue_bg1);
}

#service_nav > div {
	width: 100%;
	margin: 0 auto;
	padding: 0;
}

#service_nav > div > ul {
	display: flex;
	justify-content: center;
	flex-wrap: wrap;
	margin: 0;
	padding: 0.75em 0;
}

#service_nav > div > ul > li {
	margin: 0.5em 0.3em;
	padding: 0;
}

#service_nav > div > ul > li > a {
	display: block;
	margin: 0;
	padding: 0 1em;
	border: 1px solid rgba(0, 47, 109, 0.3);
	border-radius: 40px;
	background-color: #fff;
	box-shadow: 0 0 5px rgba(0, 47, 109, 0.2);
	font-style: normal;
	font-weight: normal;
	font-size: 12px;
	line-height: 2.5;
	color: #000;
	transition: all 0.3s;
}

#service_nav > div > ul > li > a:hover {
	border: 1px solid rgba(51, 153, 255, 0.7);
	box-shadow: 0 0 7px rgba(51, 153, 255, 0.5);
	color: rgba(51, 153, 255, 1);
	text-decoration: none;
}

@media (min-width: 1000px) {
	#service_nav {
		padding: 30px 0;
	}

	#service_nav > div {
		width: 1000px;
	}

	#service_nav > div > ul {
		display: flex;
		justify-content: center;
		padding: 0;
	}

	#service_nav > div > ul > li {
		margin: 0 0.75em;
		padding: 0;
	}

	#service_nav > div > ul > li > a {
		padding: 0 1.5em;
		font-size: 16px;
		line-height: 2.5;
	}
}

.service_wrapper {
	width: 100%;
	margin: 0;
	padding: 30px 15px;
}

.service_wrapper > div {
	width: 100%;
	margin: 0 auto;
	padding: 0;
}

.service_wrapper > div > div {
	margin: 0;
	padding: 0;
}

.service_wrapper > div > div + div {
	padding-top: 30px;
}

.service_wrapper > div > div figure {
	max-width: 400px;
	margin: 0;
	padding: 20px 0 0;
}

@media (min-width: 1000px) {
	.service_wrapper {
		padding: 50px 0;
	}

	.service_wrapper > div {
		display: flex;
		justify-content: space-between;
		width: 1000px;
	}

	.service_wrapper > div > div {
		margin: 0;
		padding: 0;
	}

	.service_wrapper > div > div + div {
		padding-top: 0;
	}

	.service_wrapper > div > div:nth-child(1) {
		width: 250px;
	}

	.service_wrapper > div > div:nth-child(2) {
		width: 300px;
	}

	.service_wrapper > div > div:nth-child(3) {
		width: 300px;
	}

	.service_wrapper > div > div figure {
		max-width: initial;
		width: 100%;
		padding: 40px 0 0;
	}
}

.service_dl {
	margin: 0;
	padding: 0;
	font-size: 17px;
	line-height: 1;
}

.service_dl dt {
	margin: 0;
	padding: 0;
	font-style: normal;
	font-weight: bold;
	font-size: 1em;
}

.service_dl dd {
	margin: 0;
	padding: 1em 0 0;
	font-style: normal;
	font-weight: normal;
	font-size: 0.9em;
	line-height: 1.7;
}

#service_figure {
	width: 100%;
	height: 400px;
	margin: 0;
	padding: 0;
	background-repeat: no-repeat;
	background-position: center top;
	background-size: cover;
	background-image: url(../../files/service/service_figure.jpg);
}

@media (min-width: 1000px) {
	#service_figure {
		width: 1000px;
		margin: 0 auto;
		padding: 0;
	}
}

.service_dispatch {
	width: 100%;
	margin: 0;
	padding: 30px 15px;
}

.service_dispatch > div {
	width: 100%;
	margin: 0 auto;
	padding: 0;
}

.service_dispatch .contents_p {
	padding: 0;
}

@media (min-width: 1000px) {
	.service_dispatch {
		padding: 50px 0;
	}

	.service_dispatch > div {
		display: flex;
		justify-content: space-between;
		width: 1000px;
	}

	.service_dispatch > div > div:nth-child(1) {
		width: 250px;
	}

	.service_dispatch > div > div:nth-child(2) {
		width: 700px;
	}
}

/****************************
  license
****************************/

#license_1 {
	width: 100%;
	margin: 0;
	padding: 0;
}

#license_1 > div {
	width: 100%;
	margin: 0;
	padding: 30px 15px;
}

#license_1 > div > div {
	width: 100%;
	margin: 0;
	padding: 0;
}

#license_1 h2 {
	margin: 0;
	padding: 0;
	font-style: normal;
	font-weight: normal;
	font-size: 20px;
	line-height: 1;
}

#license_1 dl {
	width: 100%;
	margin: 15px 0 0;
	padding: 15px 10px;
	border-radius: 2px;
	border: 1px solid #000;
}

#license_1 dl > dt {
	margin: 0;
	padding: 0;
	font-style: normal;
	font-weight: normal;
	font-size: 14px;
	line-height: 1;
}

#license_1 dl > dd {
	margin: 0;
	padding: 10px 0 0;
	font-style: normal;
	font-weight: normal;
	font-size: 14px;
	line-height: 1;
}

@media (min-width: 768px) {
	#license_1 > div > div {
		display: flex;
		flex-wrap: wrap;
		justify-content: space-between;
	}

	#license_1 dl {
		width: calc(50% - 10px);
	}
}
@media (min-width: 1000px) {
	#license_1 > div {
		width: 1000px;
		margin: 0 auto;
		padding: 70px 0 0;
	}

	#license_1 > div > div {
		padding: 15px 0 0;
	}

	#license_1 h2 {
		font-size: 24px;
		line-height: 1;
	}

	#license_1 dl {
		width: 490px;
		margin: 20px 0 0;
		padding: 15px 15px 15px 30px;
	}

	#license_1 dl > dt {
		font-size: 17px;
		line-height: 1;
	}

	#license_1 dl > dd {
		font-size: 16px;
		line-height: 1;
	}
}

#license_2 {
	width: 100%;
	margin: 0;
	padding: 0 15px;
}

#license_2 > div {
	width: 100%;
	margin: 0;
	padding: 0 0 30px;
}

#license_2 > div > div {
	width: 100%;
	margin: 0;
	padding: 30px 0 0;
}

#license_2 h2 {
	width: 100%;
	height: 100px;
	margin: 0;
	padding: 0;
	background-repeat: no-repeat;
	background-position: center center;
	background-size: cover;
	background-image: url(../../files/license/20.jpg);
	text-align: center;
	font-style: normal;
	font-weight: normal;
	font-size: 20px;
	line-height: 100px;
	color: #fff;
	text-shadow: 1px 1px 3px rgba(0, 0, 0, 0.7);
}

#license_2 h3 {
	margin: 0;
	padding: 0 0 10px;
	font-style: normal;
	font-weight: normal;
	font-size: 16px;
	line-height: 1;
}

#license_2 dl {
	display: flex;
	justify-content: space-between;
	width: 100%;
	margin: 8px 0 0;
	padding: 15px 10px;
	border-radius: 2px;
	border: 1px solid #999;
}

#license_2 dl > dt {
	margin: 0;
	padding: 0;
	font-style: normal;
	font-weight: normal;
	font-size: 14px;
	line-height: 1;
}

#license_2 dl > dd {
	margin: 0;
	padding: 0;
	font-style: normal;
	font-weight: normal;
	font-size: 14px;
	line-height: 1;
}

@media (min-width: 768px) {
	#license_2 > div {
		display: flex;
		justify-content: space-between;
		padding: 0 0 30px;
	}

	#license_2 > div > div {
		width: calc(50% - 10px);
	}
}
@media (min-width: 1000px) {
	#license_2 {
		width: 1000px;
		margin: 0 auto;
		padding: 70px 0;
	}

	#license_2 > div {
		display: flex;
		justify-content: space-between;
		padding: 0;
	}

	#license_2 > div > div {
		width: calc(50% - 10px);
	}

	#license_2 h2 {
		height: 200px;
		font-size: 28px;
		line-height: 200px;
	}

	#license_2 h3 {
		font-size: 16px;
		line-height: 1;
	}

	#license_2 dl {
		height: 48px;
		padding: 15px 30px 0;
	}

	#license_2 dl > dt {
		font-size: 16px;
		line-height: 1;
	}

	#license_2 dl > dd {
		font-size: 16px;
		line-height: 1;
	}

	#license_2 figure {
		width: 100%;
		height: 272px;
		margin: 8px 0 0;
		padding: 0;
		background-repeat: no-repeat;
		background-position: center center;
		background-size: cover;
		background-image: url(../../files/license/21.jpg);
	}
}

/****************************
  works
****************************/

#works_summary {
	width: 100%;
	margin: 0;
	padding: 0;
}

#works_summary > div {
	width: 100%;
	margin: 0;
	padding: 30px 15px;
}

#works_summary h2 {
	width: 100%;
	height: 100px;
	margin: 30px 0 0;
	padding: 0;
	background-repeat: no-repeat;
	background-position: center center;
	background-size: cover;
	background-image: url(../../files/works/summary.jpg);
	text-align: center;
	font-style: normal;
	font-weight: normal;
	font-size: 20px;
	line-height: 100px;
	color: #fff;
	text-shadow: 1px 1px 3px rgba(0, 0, 0, 0.7);
}

#works_summary p {
	margin: 0;
	padding: 0;
	font-style: normal;
	font-weight: normal;
	font-size: 14px;
	line-height: 1.8;
}

@media (min-width: 768px) {

}
@media (min-width: 1000px) {
	#works_summary > div {
		width: 1000px;
		margin: 0 auto;
		padding: 50px 0 0;
	}

	#works_summary h2 {
		height: 200px;
		font-size: 28px;
		line-height: 200px;
	}

	#works_summary p {
		font-size: 16px;
		line-height: 1.8;
	}
}

#works_archive {
	width: 100%;
	margin: 0;
	padding: 0;
}

#works_archive > div {
	width: 100%;
	margin: 0;
	padding: 30px 15px;
}

#works_archive dl {
	display: flex;
	justify-content: space-between;
	width: 100%;
	margin: 8px 0 0;
	padding: 10px 10px;
	border-radius: 2px;
	border: 1px solid #999;
}

#works_archive dl > dt {
	margin: 0;
	padding: 0;
	font-style: normal;
	font-weight: normal;
	font-size: 13px;
	line-height: 1;
}

#works_archive dl > dd {
	margin: 0;
	padding: 0;
	font-style: normal;
	font-weight: normal;
	font-size: 13px;
	line-height: 1;
}

#works_archive dl.works_title {
	background-color: #efefef;
}

#works_archive dl.works_title > dt {
	font-size: 12px;
}

#works_archive dl.works_title > dd {
	font-size: 12px;
}

@media (min-width: 768px) {
	#works_archive > div {
		display: flex;
		flex-wrap: wrap;
		justify-content: space-between;
	}

	#works_archive dl {
		width: calc(50% - 10px);
	}
}
@media (min-width: 1000px) {
	#works_archive > div {
		width: 1000px;
		margin: 0 auto;
		padding: 30px 0 0;
	}

	#works_archive dl {
		width: 490px;
		margin: 8px 0 0;
		padding: 10px 10px;
	}

	#works_archive dl > dt {
		font-size: 15px;
		line-height: 1;
	}

	#works_archive dl > dd {
		font-size: 15px;
		line-height: 1;
	}

	#works_archive dl.works_title > dt {
		font-size: 13px;
	}
	
	#works_archive dl.works_title > dd {
		font-size: 13px;
	}
}

#works_client {
	width: 100%;
	margin: 0;
	padding: 0;
}

#works_client > div {
	width: 100%;
	margin: 0;
	padding: 0 15px 30px;
}

#works_client > div > div {
	width: 100%;
	margin: 0;
	padding: 0;
}

#works_client > div > div + div {
	padding-top: 30px;
}

.works_h2 {
	margin: 0;
	padding: 0;
	font-style: normal;
	font-weight: bold;
	font-size: 15px;
	line-height: 1;
}

.works_ul {
	margin: 0;
	padding: 10px 0 0;
}

.works_ul > li {
	margin: 0;
	padding: 10px 0 0;
	font-style: normal;
	font-weight: normal;
	font-size: 13px;
	line-height: 1.2;
}

@media (min-width: 1000px) {
	#works_client > div {
		display: flex;
		justify-content: space-between;
		width: 1000px;
		margin: 0 auto;
		padding: 50px 0;
	}

	#works_client > div > div {
		width: 490px;
		margin: 0;
		padding: 0;
	}

	#works_client > div > div + div {
		padding-top: 0;
	}

	.works_h2 {
		font-size: 16px;
		line-height: 1;
	}

	.works_ul > li {
		font-size: 15px;
		line-height: 1.2;
	}
}

/****************************
  csr
****************************/

.csr_wrapper {
	width: 100%;
	margin: 0;
	padding: 0;
}

.csr_wrapper > div {
	width: 100%;
	margin: 0;
	padding: 30px 15px;
}

.csr_wrapper > div > figure {
	width: 150px;
	padding: 20px 0 0;
}

#volunteer > div > figure {
	display: none;
}

.csr_wrapper > figure {
	margin: 0 auto;
	padding: 0;
	background-repeat: no-repeat;
	background-position: center center;
	background-size: cover;
}

#activity_figure {
	width: 100%;
	height: 200px;
	background-image: url(../../files/csr/activity2.jpg);
}

#partnership_figure {
	width: calc(100% - 15px);
	height: 20vw;
	background-image: url(../../files/csr/partnership2.png);
}

.csr_wrapper h2 {
	margin: 0;
	padding: 0;
	font-style: normal;
	font-weight: bold;
	font-size: 16px;
	line-height: 1;
}

.csr_wrapper h3 {
	margin: 0;
	padding: 1.5em 0 0;
	font-style: normal;
	font-weight: bold;
	font-size: 15px;
	line-height: 1;
}

.csr_wrapper p {
	margin: 0;
	padding: 1.5em 0 0;
	font-style: normal;
	font-weight: normal;
	font-size: 14px;
	line-height: 1.8;
}

.csr_wrapper ul {
	list-style-type: decimal;
	margin: 0;
	padding: 0.5em 0 0 1.5em;
}

.csr_wrapper ul > li {
	margin: 0;
	padding: 1.5em 0 0;
	font-style: normal;
	font-weight: normal;
	font-size: 14px;
	line-height: 1.5;
}

@media (min-width: 1000px) {
	.csr_wrapper > div {
		display: flex;
		justify-content: space-between;
		width: 1000px;
		margin: 0 auto;
		padding: 50px 0;
	}

	.csr_wrapper > div > div {
		width: 800px;
		padding: 0 50px 0 0;
	}

	.csr_wrapper > div > figure {
		width: 200px;
		padding: 42px 0 0;
	}

	#volunteer > div > div {
		width: 500px;
		padding: 0 50px 0 0;
	}

	#volunteer > div > figure {
		display: block;
		width: 500px;
		height: 200px;
		padding: 0;
		background-repeat: no-repeat;
		background-position: center center;
		background-size: cover;
		background-image: url(../../files/csr/volunteer.jpg);
		overflow: hidden;
	}

	.csr_wrapper h2 {
		font-size: 20px;
		line-height: 1;
	}

	.csr_wrapper h3 {
		font-size: 17px;
		line-height: 1;
	}

	.csr_wrapper p {
		font-size: 16px;
		line-height: 1.8;
	}

	.csr_wrapper ul > li {
		font-size: 16px;
		line-height: 1.5;
	}

	.csr_wrapper > figure,
	#activity_figure,
	#partnership_figure {
		width: 1000px;
		height: 200px;
		margin: 0 auto;
		padding: 0;
	}
}

/****************************
  privacypolicy
****************************/

#privacypolicy {
	width: 100%;
	margin: 0 auto;
	padding: 30px 15px 50px;
}

#privacypolicy > dl {
	margin: 0;
	padding: 0;
	font-size: 14px;
}

#privacypolicy > dl > dt,
#privacypolicy > dl > dd {
	margin: 0;
	text-align: left;
	font-style: normal;
	font-weight: normal;
	font-size: 1em;
	line-height: 1.5;
}

#privacypolicy > dl > dt {
	padding: 0;
}

#privacypolicy > dl > dd + dt {
	padding-top: 1.5em;
}

#privacypolicy > dl > dd {
	padding: 1em 0;
}

@media (min-width: 1000px) {
	#privacypolicy {
		width: 850px;
		padding: 50px 0;
	}

	#privacypolicy > dl {
		margin: 0;
		padding: 0;
		font-size: 16px;
	}
}

/****************************
  visual_top
****************************/

.visual_top {
	display: table;
	width: 100%;
	height: 260px;
	margin: 0;
	padding: 0;
	background-repeat: no-repeat;
	background-position: center top;
	background-size: cover;
	background-image: url(../../files/company/vtsp.jpg);
}

.visual_top.company {
	background-image: url(../../files/company/vtsp.jpg);
}

.visual_top.service {
	background-image: url(../../files/service/vtsp.jpg);
	background-position: center 90%;
}

.visual_top.license {
	background-image: url(../../files/license/vtsp.jpg);
	background-position: center 90%;
}

.visual_top.works {
	background-image: url(../../files/works/vtsp.jpg);
	background-position: center 85%;
}

.visual_top.csr {
	background-image: url(../../files/csr/vtsp.jpg);
	background-position: center 85%;
}

.visual_top.news {
	height: 180px;
	background-image: url(../../files/news/vt.jpg);
	background-position: center 40%;
}

.visual_top.contact {
	height: 180px;
	background-image: url(../../files/contact/vt.jpg);
	background-position: center 40%;
}

.visual_top.privacypolicy {
	height: 180px;
	background-image: url(../../files/privacypolicy/vt.jpg);
	background-position: center 40%;
}

.visual_top.recruit {
	background-position: center top;
	background-image: url(../../files/recruit/vtsp.jpg);
}

.visual_top.recruit.voice1 {
	background-position: center center;
	background-image: url(../../files/recruit/voice1_vtsp.jpg);
}

.visual_top.recruit.voice2 {
	background-position: center center;
	background-image: url(../../files/recruit/voice2_vtsp.jpg);
}

.visual_top.recruit.voice3 {
	background-position: center center;
	background-image: url(../../files/recruit/voice3_vtsp.jpg);
}

@media (min-width: 821px) {
	.visual_top.news {
		height: 240px;
		background-position: center 60%;
	}

	.visual_top.contact {
		height: 240px;
		background-position: center 60%;
	}

	.visual_top.privacypolicy {
		height: 240px;
		background-position: center 60%;
	}
}
@media (min-width: 1000px) {
	.visual_top {
		height: 25vw;
		padding: 0;
		background-position: center 50%;
		background-image: url(../../files/company/vtpc.jpg);
	}

	.visual_top.company {
		background-image: url(../../files/company/vtpc.jpg);
	}

	.visual_top.service {
		background-image: url(../../files/service/vtpc.jpg);
		background-position: center 90%;
	}

	.visual_top.license {
		background-image: url(../../files/license/vtpc.jpg);
		background-position: center 90%;
	}

	.visual_top.works {
		background-image: url(../../files/works/vtpc.jpg);
	}

	.visual_top.csr {
		background-image: url(../../files/csr/vtpc.jpg);
	}

	.visual_top.recruit {
		background-position: center top;
		background-image: url(../../files/recruit/vtpc.jpg);
	}

	.visual_top.recruit.voice1 {
		background-position: center 30%;
		background-image: url(../../files/recruit/voice1_vtpc.jpg);
	}

	.visual_top.recruit.voice2 {
		background-position: center 30%;
		background-image: url(../../files/recruit/voice2_vtpc.jpg);
	}
	
	.visual_top.recruit.voice3 {
		background-position: center 30%;
		background-image: url(../../files/recruit/voice3_vtpc.jpg);
	}
}
@media (min-width: 1400px) {
	.visual_top {
		height: 20vw;
		background-position: center 60%;
	}
}
