@charset "UTF-8";

#company::before {
	background: url(../../images/company/bg_company.jpg) no-repeat center 0 #f9f7f0;
	background-size: 100% auto;
}

#company h1 img {
	width: auto;
	height: 74px;
}

article h1 .sub {
	position: relative;
	top: -20px;
}

.page_contents h2.page_title {
	padding: 6px 0 9px 110px;
	background: url(../../images/company/icon_company.svg) no-repeat 0 0;
}
.profile .page_contents h2.page_title {
	background-image:url(../../images/company/icon_company_profile.svg) !important;
}
.office .page_contents h2.page_title {
	background-image:url(../../images/company/icon_company_office.svg) !important;
}
.sdgs .page_contents h2.page_title {
	background-image:url(../../images/company/icon_company_sdgs.svg) !important;
}

.page_contents h2.page_title .eng img {
	width: auto;
	height: 16px;
}

.sec_block {
	padding: 0 30px;
	margin: 95px 0 0;
}

.page_contents h2.page_title+.sec_block {
	margin-top: 0;
}

.sec_block h3 {
	font-size: 30px;
	font-weight: normal;
	line-height: 1.4;
	letter-spacing: 0.05em;
	margin: 0 0 30px -30px;
	padding: 0 0 0 13px;
	border-left: solid 2px #595959;
}

.sec_block h4 {
	font-size: 26px;
	font-weight: normal;
	line-height: 1.4;
	letter-spacing: 0.05em;
	margin: 55px 0 25px;
	padding: 0 0 0 30px;
	position: relative;
}

.sec_block h4::before {
	content: "";
	width: 21px;
	height: 21px;
	border: solid 4px #595959;
	position: absolute;
	top: 7px;
	left: 0;
	border-radius: 11px;
	box-sizing: border-box;
}

.sec_block h3+h4 {
	margin-top: 25px;
}

.sec_block h5 {
	font-size: 20px;
	font-weight: bold;
	line-height: 1.4;
	letter-spacing: 0.05em;
	margin: 50px 0 5px;
	padding: 0 0 0 1.3em;
	position: relative;
}

.sec_block h5 .num {
	position: absolute;
	left: 0;
}

.sec_block h4+h5 {
	margin-top: 20px;
}

.sec_block p {
	font-size: 18px;
	line-height: 1.85;
	letter-spacing: 0.05em;
}

.sec_block p+p {
	margin-top: 30px;
}

.sec_block .twocol .image {
	width: 460px;
	min-width: 460px;
	margin: 0 0 0 30px;
}

.sec_block .waku {
	padding: 30px;
	margin: 25px 0;
	background: #fff;
	border: solid 1px #f1f1f1;
}

table.list_table {
	color: #010101;
	width: 100%;
}

table.list_table tr:nth-child(odd) th,
table.list_table tr:nth-child(odd) td {
	background: #f3f3f3;
}

table.list_table tr:nth-child(even) th,
table.list_table tr:nth-child(even) td {
	background: #fff;
}

table.list_table th,
table.list_table td {
	font-size: 18px;
	line-height: 1.6;
	letter-spacing: .1em;
	text-align: left;
	vertical-align: middle;
	padding: 19px 3.5%;
}

table.list_table th {
	width: 180px;
	box-sizing: border-box;
	white-space: nowrap;
}

table.list_table td {
	width: calc(100% - 180px);
	box-sizing: border-box;
}

table.list_table td dl {
	display: flex;
}
table.list_table td dl + dl {
	margin-top:5px;
}
table.list_table td dl dt {
	width:8em;
	min-width:8em;
}

table.list_table td h4 {
	font-size: 16px;
	margin: 20px 0 6px;
	padding: 0 0 0 20px;
}

table.list_table h4::before {
  width: 13px;
  height: 13px;
  border: solid 3px #595959;
  top: 4px;
}

table.list_table td .ibk {
	margin-top:5px;
}

table.list_table td > *:nth-child(1) {
	margin-top:0 !important;
}

table.list_table ul.indent {
	padding:0 0 0 20px;
}

table.list_table ul.indent li {
	line-height:1.6;
	text-indent:-1em;
	padding-left:1em;
}

table.list_table ul.indent li+li {
	margin-top:8px;
}

table.list_table ul.indent li sup {
	font-size:100%;
	vertical-align: text-bottom;
}

table.list_table td a {
	color:#000;
	text-decoration:underline;
	transition:ease .3s;
}

table.list_table td a.maplink {
	color:#c53e38;
	font-size:12px;
	font-weight:bold;
	line-height:1;
	text-align: center;
	padding:4px 8px;
	text-decoration:none;
	border:solid 1px #c53e38;
	display:inline-block;
	position:relative;
	top:-2px;
	transition:ease .3s;
}

.office_map {
	width:100%;
	margin:50px 0 0;
	display:flex;
	flex-direction:row-reverse;
	align-items: center;
}
.office_map .text {
	width:50%;
	padding-left:30px;
}
.office_map .text h2 {
	font-size:36px;
	font-weight:bold;
	line-height:1.4;
	letter-spacing:0.1em;
	margin:0;
}
.office_map .text p {
	font-size:21px;
	line-height:1.72;
	letter-spacing:0.05em;
	margin:30px 0 0;
}
.office_map .image {
	width:50%;
}
.office_map .image img {
	width:85.4%;
	margin:0 auto;
	display: block;
}
.office_block {
	margin:60px 0 0;
	position:relative;
}
.office_block .leadtxt {
	margin:0 0 30px;
}
.office_block .leadtxt p {
	font-size:20px;
}
.office_block .twocol {
	width:100%;
	justify-content: space-between;
	align-items: flex-start;
}
.office_block .twocol > .office_img,
.office_block .twocol > .text {
	width:calc(50% - 30px);
}
.office_block .twocol > .office_img img {
	width:100%;
	max-width:460px;
	margin:0 auto;
	display:block;
}
.office_block .twocol > .text p {
	font-size:20px;
	line-height:1.9;
}
.office_block .twocol .text .more {
	text-align: right;
}
.office_block .twocol .text .more .btn {
	width:240px;
}
.office_block .twocol .map {
	width:calc(50% - 30px);
}
.office_block .twocol .map iframe {
	width:100%;
	height:346px;
	display: block;
}
#ibaraki.office_block .twocol .map iframe {
	height:460px;
}
.office_block .twocol .map .more .btn {
	margin:30px 0 0 auto;
}

.sdgs_title {
	width:80%;
	margin:0 auto 40px;
}
.sdgs .sec_block p.lead {
	font-size:24px;
	font-weight:bold;
	line-height:1.6;
	text-align:center;
	margin:0 0 25px;
}
ul.sdgs_icons {
	margin:0 -7px 80px;
	display:flex;
	flex-wrap:wrap;
}
ul.sdgs_icons li {
	width:calc(12.5% - 14px);
	margin:14px 7px 0;
}
ul.sdgs_icons li img {
	display: block;
}
.sdgs .sec_block h5 {
	padding-left:0;
}
.sec_block table.torikumi {
	width: calc(100% + 60px);
	border-collapse: separate;
	border-spacing: 30px 0;
	margin:30px -30px 0;
}
.sec_block table.torikumi th {
	font-size: 20px;
	font-weight: normal;
	line-height: 1.4;
	letter-spacing: 0.05em;
	margin: 0 0 20px 0;
	padding: 0 0 9px 40px;
	border-bottom: solid 1px #b3b3b3;
	position: relative;
	text-align: left;
	white-space: nowrap;
}
.sec_block table.torikumi th::before {
	content: "";
	width: 21px;
	height: 21px;
	border: solid 4px #b3b3b3;
	position: absolute;
	top: 4px;
	left: 10px;
	border-radius: 11px;
	box-sizing: border-box;
}
.sec_block table.torikumi th:nth-child(1) {
	width:6.5em;
}
.sec_block table.torikumi th:nth-child(2) {
	width:280px;
}
.sec_block table.torikumi td {
	font-size: 18px;
	letter-spacing: .1em;
	line-height: 1.4;
	padding: 10px;
	vertical-align: middle;
	border-bottom:solid 1px #b3b3b3;
}
.sec_block table.torikumi tr td:nth-child(1) {
	text-align: center;
}
.sec_block table.torikumi td p {
	font-size:16px;
	text-indent:-1em;
	line-height:1.6;
	padding-left:1em;
}
.sec_block table.torikumi td p + p {
	margin-top:5px;
}
.sec_block table.torikumi td img {
	width:80px;
	height:auto;
	display:inline-block;
}
.sec_block table.torikumi td img + img {
	margin-left:10px;
}
.sec_block table.torikumi tr:nth-child(1) td {
	padding-top: 19px;
}


@media only screen and (min-width:768px) {
table.list_table td a:hover {
	color:#c53e38;
	text-decoration:none;
}
table.list_table td a.maplink:hover {
	color:#fff;
	background:#c53e38;
}

}


@media only screen and (max-width:1499px) {
	.sec_block {
		padding: 0 10px;
	}

	.sec_block .twocol > .text {
		width: calc(50% - 25px);
	}

	.sec_block .twocol .image {
		width: 50%;
		min-width: inherit;
		margin: 0 0 0 25px;
	}

	.sec_block h3 {
		margin-left: -10px;
	}

	.office_map .image img {
		width:100%;
	}

}


@media only screen and (max-width:1299px) {
	.sdgs_title {
    width: 90%;
    margin: 0 auto 35px;
	}
	.sdgs .sec_block p.lead {
    font-size: 20px;
		margin:0 0 20px;
	}
	ul.sdgs_icons {
    margin: 0 -7px 60px;
	}
	ul.sdgs_icons li {
    width: calc(16.66% - 14px);
	}
	.sdgs .sec_block h5 {
		font-size:18px;
	}
	.sec_block table.torikumi th {
    font-size: 18px;
		padding:0 0 9px 36px;
	}
	.sec_block table.torikumi th::before {
    width: 19px;
    height: 19px;
    top: 3px;
	}
	.sec_block table.torikumi th:nth-child(1) {
  	width: 6em;
	}
	.sec_block table.torikumi th:nth-child(2) {
    width: 235px;
	}
	.sec_block table.torikumi td {
		font-size:16px;
	}
	.sec_block table.torikumi tr td:nth-child(2) {
		padding:5px;
	}
	.sec_block table.torikumi td img {
    width: 65px;
		margin:3px 5px 0 !important;
	}
	.sec_block table.torikumi td p + p {
    margin-top: 0;
	}

}

@media only screen and (max-width:1199px) {
	.sec_block .twocol {
		display: block;
	}

	.office_block .twocol > .office_img,
	.sec_block .twocol > .text,
	.sec_block .twocol .image {
		width: auto;
	}

	.sec_block .twocol .image {
		max-width: 460px;
		margin: 25px auto 0;
	}

	table.list_table th {
		width:150px;
		padding-right:0;
	}

	table.list_table td {
    width:calc(100% - 150px);
	}

	table.list_table td dl {
		display:block;
	}
	table.list_table td dl + dl {
		margin-top:10px;
	}
	table.list_table td dl dt {
		width:auto;
		min-width:inherit;
	}
	table.list_table td dl dd br {
		display:none;
	}

	.office_map {
		margin:50px 0 0;
		display:block;
	}
	.office_map .text {
		width:auto;
		padding-left:0;
	}
	.office_map .image {
		width:auto;
		margin-top:30px;
	}
	.office_map .image img {
		width:80%;
		max-width:444px;
	}
	.office_block .twocol .text .more .btn {
		margin-top:25px;
	}
	.office_block .twocol .map {
		width:100%;
		margin-top:40px;
	}
	.office_block .twocol .map iframe {
		height:346px !important;
	}
	.sec_block table.torikumi th:nth-child(2) {
    width: 160px;
	}
	.sec_block table.torikumi tr td:nth-child(2) {
    text-align: center;
	}

}


@media only screen and (max-width:999px) {
	#company h1 img {
		height: 64px;
	}

	article h1 .sub {
		font-size: 18px;
		padding: 6px 14px;
	}

	.sec_block {
		padding: 0;
	}

	.page_contents h2.page_title {
		font-size: 26px;
		margin: 0 0 25px;
		padding: 6px 0 10px 86px;
		background-size: auto 70px !important;
	}

	.page_contents h2.page_title .page_title_text {
		margin-bottom: 5px;
	}

	.page_contents h2.page_title .eng img {
		height: 14px;
	}

	.sec_block h3 {
		font-size: 26px;
		margin-left: 0;
	}

	.sec_block h4 {
		font-size: 24px;
		padding: 0 0 0 27px;
	}

	.sec_block h4::before {
		width: 19px;
		height: 19px;
	}

	.sec_block .waku {
		padding: 25px;
	}

	table.list_table th {
		width:180px;
		padding-right:3.5%;
	}

	table.list_table td {
    width:calc(100% - 180px);
	}
}


@media only screen and (max-width:767px) {
	#company::before {
		background-size: auto 110%;
	}

	.office_block {
		margin:70px 0 0;
	}
	.sdgs_title {
		width:70%;
	}

}


@media only screen and (max-width:639px) {
	#company h1 img {
		height: 36px;
	}

	article h1 .sub {
		font-size: 11px;
		padding: 5px 8px;
		top: -15px;
	}

	table.list_table th,
	table.list_table td {
		font-size: 13px;
		padding: 15px 3.5%;
	}

	table.list_table th {
		width: 140px;
		padding-right: 0;
	}

	table.list_table td {
		width: calc(100% - 140px);
	}

	table.list_table td h4 {
    font-size: 13px;
		padding:0 0 0 16px;
		margin-top:15px;
	}

	table.list_table h4::before {
    width: 10px;
    height: 10px;
    border: solid 2px #595959;
		left:1px;
	}

	table.list_table ul.indent {
    padding: 0;
	}

	table.list_table td a.maplink {
    font-size: 10px;
    padding: 2px 4px;
    top: -1px;
	}

	.office_map {
    margin:35px 0 0;
	}
	.office_map .text h2 {
		font-size:28px;
		text-align: center;
	}
	.office_map .text p {
		font-size:18px;
	}
	ul.sdgs_icons {
    margin: 0 0 50px;
	}
	ul.sdgs_icons li {
    width: calc(16.66% - 10px);
		margin: 10px 5px 0;
	}
	.sdgs .sec_block h5 {
    font-size: 16px;
		line-height: 1.6;
	}
	.sec_block table.torikumi th {
		font-size: 16px;
		white-space: normal;
	}
	.sec_block table.torikumi {
    width:calc(100% + 30px);
    border-collapse: separate;
    border-spacing: 15px 0;
    margin: 25px -15px 0;
	}
	.sec_block table.torikumi td p,
	.sec_block table.torikumi td {
    font-size: 14px;
	}
	.sec_block table.torikumi th:nth-child(2) {
    width: 130px;
	}

}



@media only screen and (max-width:479px) {
	.page_contents h2.page_title {
		font-size: 18px;
		margin: 0 0 20px;
		padding: 6px 0 10px 60px;
		background-size: auto 49px !important;
	}

	.page_contents h2.page_title .eng img {
		height: 9px;
	}

	.sec_block {
		margin: 60px 0 0;
	}

	.sec_block h3 {
		font-size: 16px;
		margin: 0 0 20px;
	}

	.sec_block h4 {
		font-size: 14px;
		padding: 0 0 0 17px;
		margin: 35px 0 15px;
	}

	.sec_block h4::before {
		width: 11px;
		height: 11px;
		border: solid 2px #595959;
		top: 4px;
	}

	.sec_block h3+h4 {
		margin-top: 20px;
	}

	.sec_block h5 {
		font-size: 13px;
		margin: 40px 0 5px;
	}

	.sec_block h4+h5 {
		margin-top: 15px;
	}

	.sec_block p {
		font-size: 13px;
	}

	.sec_block p+p {
		margin-top: 15px;
	}

	.sec_block .waku {
		padding: 15px;
		margin: 20px 0;
	}

	table.list_table th {
    width: 120px;
	}
	table.list_table td {
		width: calc(100% - 120px);
	}
	.office_map {
    margin:25px 0 0;
	}
	.office_map .text h2 {
		font-size:22px;
	}
	.office_map .text p {
		font-size:14px;
		margin-top:20px;
	}
	.office_map .image {
		margin-top:15px;
	}
	.office_block .twocol > .text p {
    font-size:14px;
	}
	.office_block .twocol .text .more .btn {
    margin-top: 20px;
	}
	.office_block .twocol .text .more .btn {
    width: 180px;
	}
	.office_block .twocol .map {
		margin-top:30px;
	}
	.office_block .twocol .map iframe {
		height:240px !important;
	}
	.sdgs_title {
		margin:0 auto 25px;
	}
	.sdgs .sec_block p.lead {
		font-size:16px;
	}
	ul.sdgs_icons li {
    width: calc(25% - 10px);
	}
	ul.sdgs_icons {
    margin: 0 0 40px;
	}
	.sdgs .sec_block h5 {
    font-size: 15px;
	}
	.sec_block table.torikumi th {
		font-size: 15px;
		padding:0 10px 8px;
	}
	.sec_block table.torikumi th::before {
		display:none;
	}
	.sec_block table.torikumi th:nth-child(1) {
    width: 4em;
	}
	.sec_block table.torikumi th:nth-child(2) {
    width: 65px;
	}
	.sec_block table.torikumi td img {
    width: 50px;
    margin: 1px 0px 0 !important;
	}
	.sec_block table.torikumi td p, .sec_block table.torikumi td {
    font-size: 13px;
	}

}
