@charset "utf-8";
/* ===================================================================
//CSS information

// file name  :  corporate.css
// style info :  スタイル指定　　　ベースカラー　#0446a1
=================================================================== */

@media only screen and (max-width: 767px) {
.container.contentsListWrap .no-gutter {
	padding-left: 15px;
    padding-right: 15px;
}
}

/* ===================================================================
//corporatePage
=================================================================== */
.corporatePage .contentsListWrap .contentsListBtn .contentsListText p + i {
	font-size: 12px;
	margin-top: 20px;
}

/* ===================================================================
//message
=================================================================== */
.messagePage .messageTopWrap h3 {
	font-size: 21px;
	line-height: 2;
	padding: 40px 15.5%;
}
.messagePage .messageTopWrap h3::after {
	content: '';
	background: #0446a1;
	display: block;
	height: 2px;
	margin-top: 30px;
	width: 10%;
}
.messagePage .messageWrap p {
	margin-top: 20px;
}
.messagePage .messageWrap p:nth-of-type(1) {
	margin-top: 0;
}

.messagePage .sign {
	text-align: right;
	margin-top: 40px;
}
.messagePage .sign > div {
	display: inline-block;
	line-height: 1.6;
	vertical-align: middle;
	text-align: left;
}
.messagePage .sign > div:nth-of-type(2) {
	max-width: 200px;
	margin-left: 10px;
}

@media only screen and (max-width: 1050px) {
}
@media only screen and (max-width: 991px) {
.messagePage .messageTopWrap h3 {
	padding: 40px 6% 0;
}
}
@media only screen and (max-width: 768px) {
.messagePage .messageTopWrap h3 {
	padding: 40px 6% 0;
}
}
@media only screen and (max-width: 767px) {
.messagePage .messageTopWrap h3 {
	font-size: 16px;
}
.messagePage .sign > div:nth-of-type(1) {
	display: block;
	margin-bottom: 10px;
	font-size: 12px;
	text-align: right;
}
.messagePage .sign > div:nth-of-type(2) {
	max-width: 140px;
	margin-left: 0;
}
}
@media only screen and (max-width: 679px) {
}
@media only screen and (max-width: 479px) {
}
@media only screen and (max-width: 320px) {
}

/* ===================================================================
//philosophy
=================================================================== */
.philosophyPage .groupMessage {
	border: #f2f2f2 solid 10px;
	background: #fff;
	margin-top: 40px;
}
.philosophyPage .groupMessage > div {
	position: relative;
	display: inline-block;
	vertical-align: middle;
	padding: 120px 40px;
	width: 50%;
}
.philosophyPage .groupMessage > div:nth-of-type(1) {
	text-align: center;
}
.philosophyPage .groupMessage > div:nth-of-type(2) {
	padding: 120px 6%;
}
.philosophyPage .groupMessage > div:nth-of-type(2)::after {
	content: '';
	position: absolute;
	top: 1em;
	bottom: 1em;
	left: 0;
	width: 1px;
	background: #f2f2f2;
}
.philosophyPage .groupMessage > div p {
	font-size: 16px;
	font-weight: 500;
	line-height: 2.4;
}
.philosophyPage .groupMessage.groupSimbol > div {
	width: 100%;
	text-align: center;
	padding: 40px;
}
.philosophyPage .groupMessage.groupSimbol > div:nth-of-type(1) {
	padding: 80px 40px;
}
.philosophyPage .groupMessage.groupSimbol > div:nth-of-type(2)::after {
	content: '';
	position: absolute;
	top: 0;
	bottom: auto;
	left: 1em;
	right: 1em;
	width: auto;
	height: 1px;
}

@media only screen and (max-width: 991px) {
}
@media only screen and (max-width: 768px) {
.philosophyPage .groupMessage > div {
	padding: 60px 40px;
	width: 100%;
}
.philosophyPage .groupMessage > div:nth-of-type(2) {
	padding: 40px;
}
.philosophyPage .groupMessage > div:nth-of-type(2)::after {
	content: '';
	position: absolute;
	top: 0;
	bottom: auto;
	left: 1em;
	right: 1em;
	width: auto;
	height: 1px;
}
.philosophyPage .groupMessage.groupSimbol > div:nth-of-type(1) {
	padding: 60px 40px;
}
.philosophyPage .groupMessage.groupSimbol > div:nth-of-type(2) {
	text-align: left;
}
}
@media only screen and (max-width: 767px) {
.philosophyPage .groupMessage > div p {
    font-size: 14px;
    font-weight: 500;
    line-height: 2;
}
}
@media only screen and (max-width: 679px) {
}
@media only screen and (max-width: 479px) {
}
@media only screen and (max-width: 320px) {
}

/* ===================================================================
//outline
=================================================================== */
.outlinePage .companyData {
    width: 100%;
    border-collapse: collapse;
}
.outlinePage .companyData th,
.outlinePage .companyData td {
	border: 1px solid #D9D9D9;
	border-width: 1px;
	font-size: 14px;
	line-height: 1.4;
	vertical-align: top;
	text-align: left;
	padding: 15px 0;
}
.outlinePage .companyData th {
	border-width: 0 0 1px;
	font-weight: 500;
	width: 25%;
}
.outlinePage .companyData td {
    border-width: 0 0 1px;
    border-left-color: #FFF;
}

@media only screen and (max-width: 991px) {
}
@media only screen and (max-width: 768px) {
}
@media only screen and (max-width: 767px) {
.outlinePage .companyData th,
.outlinePage .companyData td {
	display: block;
	width: 100%;
}
.outlinePage .companyData th {
	border: none;
	padding: 15px 0 0;
}
.outlinePage .companyData td {
	padding: 15px 0 15px 15px;
}
}
@media only screen and (max-width: 679px) {
}
@media only screen and (max-width: 479px) {
}
@media only screen and (max-width: 320px) {
}

.outlinePage .contentsListWrap .contentsListBtn .contentsListText {
	padding: 3em;
}
.outlinePage .contentsListWrap .contentsListBtn .contentsListText p + i {
	font-size: 12px;
	margin-top: 20px;
}
@media only screen and (max-width: 991px) {
.outlinePage .contentsListWrap .contentsListBtn .contentsListText {
	height: auto;
}
}
@media only screen and (max-width: 768px) {
}
@media only screen and (max-width: 767px) {
}
@media only screen and (max-width: 679px) {
}
@media only screen and (max-width: 479px) {
}
@media only screen and (max-width: 320px) {
}

/* ===================================================================
//historyPage
=================================================================== */
.historyPage .companyData {
    width: 100%;
    border-collapse: collapse;
}
.historyPage .companyData th,
.historyPage .companyData td {
	border: 1px solid #D9D9D9;
	border-width: 1px;
	font-size: 14px;
	line-height: 1.4;
	vertical-align: top;
	text-align: left;
	padding: 15px 0;
}
.historyPage .companyData th {
	border-width: 0 0 1px;
	font-weight: 500;
	width: 25%;
}
.historyPage .companyData td {
    border-width: 0 0 1px;
    border-left-color: #FFF;
}

@media only screen and (max-width: 991px) {
}
@media only screen and (max-width: 768px) {
}
@media only screen and (max-width: 767px) {
.historyPage .companyData th,
.historyPage .companyData td {
	display: block;
	width: 100%;
}
.historyPage .companyData th {
	border: none;
	padding: 15px 0 0;
}
.historyPage .companyData td {
	padding: 15px 0 15px 15px;
}
}
@media only screen and (max-width: 679px) {
}
@media only screen and (max-width: 479px) {
}
@media only screen and (max-width: 320px) {
}

/* ===================================================================
//organizationPage
=================================================================== */
.organizationPage .companyData {
    width: 100%;
    border-collapse: collapse;
	margin-top: 20px;
}
.organizationPage .companyData th,
.organizationPage .companyData td {
	border: 1px solid #D9D9D9;
	border-width: 1px;
	font-size: 14px;
	line-height: 1.4;
	vertical-align: top;
	text-align: left;
	padding: 15px 0;
}
.organizationPage .companyData th {
	border-width: 0 0 1px;
	font-weight: 500;
	width: 25%;
}
.organizationPage .companyData td {
    border-width: 0 0 1px;
    border-left-color: #FFF;
}

@media only screen and (max-width: 991px) {
}
@media only screen and (max-width: 768px) {
}
@media only screen and (max-width: 767px) {
.organizationPage .companyData th,
.organizationPage .companyData td {
	display: block;
	width: 100%;
}
.organizationPage .companyData th {
	border: none;
	padding: 15px 0 0;
}
.organizationPage .companyData td {
	padding: 15px 0 15px 15px;
}
}
@media only screen and (max-width: 679px) {
}
@media only screen and (max-width: 479px) {
}
@media only screen and (max-width: 320px) {
}

/* ===================================================================
//groupPage
=================================================================== */
.groupPage .contentsListWrap .contentsListBtn .contentsListText {
	height: auto;
	padding: 3em;
}
.groupPage .contentsListWrap .contentsListBtn .contentsListText p + i {
	font-size: 12px;
	margin-top: 20px;
}
@media only screen and (max-width: 991px) {
}
@media only screen and (max-width: 768px) {
}
@media only screen and (max-width: 767px) {
}
@media only screen and (max-width: 679px) {
}
@media only screen and (max-width: 479px) {
}
@media only screen and (max-width: 320px) {
}

/* ===================================================================
//accessmapPage
=================================================================== */
.accessmapPage .gmapsWrap {
	border: #fff solid 1px;
	margin-top: 2em;
	margin-bottom: 2em;
	height: 500px;
	width: 100%;
}
.accessmapPage .gmapsWrap iframe {
	height: 100%;
	width: 100%;
}
.accessmapPage .accessData {
	background: #f2f2f2;
	padding: 1em 2em;
}

.accessmapPage .contentsListWrap .contentsListBtn .contentsListText {
	height: auto;
}
.accessmapPage .contentsListWrap .contentsListBtn:hover {
	color: #333;
}
.accessmapPage .contentsListWrap .contentsListBtn:hover .contentsListText h3::after {
	-webkit-transform-origin: left top;
	-webkit-transform: scale(.05, 1);
	transform-origin: left top;
	transform: scale(.05, 1);
}
.accessmapPage .contentsListWrap .gmapsWrap {
	border: #fff solid 1px;
	margin-top: 2em;
	margin-bottom: 2em;
	height: 300px;
	width: 100%;
}
.accessmapPage .contentsListWrap .gmapsWrap iframe {
	height: 100%;
	width: 100%;
}

.mapsDetails {
	height: 0;
	overflow: hidden;
	-webkit-transition: all .5s ease;
	transition: all .5s ease;
}
.mapsDetails.is_active {
	height: auto;
}
.mapsDetailsToggleBtn {
	font-size: 14px;
	text-align: left;
	padding: 20px 0 0;
	-webkit-transition: all .5s ease;
	transition: all .5s ease;
}
.mapsDetailsToggleBtn > * {
	display: inline-block;
	vertical-align: middle;
	-webkit-transition: all .5s ease;
	transition: all .5s ease;
}
.mapsDetailsToggleBtn > div {
	margin: auto;
	cursor: pointer;
}
.mapsDetailsToggleBtn > div:nth-of-type(2) {
	display: none;
}
.mapsDetailsToggleBtn > div > i {
	color: #0446a1;
	margin-right: 10px;
}
.mapsDetailsToggleBtn > div > span {
	position: relative;
}
.mapsDetailsToggleBtn > div > span::after {
	position: absolute;
	bottom: -8px;
	left: 0;
	content: '';
	width: 100%;
	height: 1px;
	background: #0446a1;
	-webkit-transform: scale(0, 1);
	-webkit-transform-origin: center top;
	-webkit-transition: transform .3s;
	transform: scale(0, 1);
	transform-origin: center top;
	transition: transform .3s;
}
.mapsDetailsToggleBtn > div:hover {
	color: #0446a1;
}
.mapsDetailsToggleBtn > div:hover > span::after {
	-webkit-transform-origin: center top;
	-webkit-transform: scale(1, 1);
	transform-origin: center top;
	transform: scale(1, 1);
}
.mapsDetailsToggleBtn.is_active > div:nth-of-type(1) {
	display: none;
}
.mapsDetailsToggleBtn.is_active > div:nth-of-type(2) {
	display: inline-block;
}

@media only screen and (max-width: 991px) {
}
@media only screen and (max-width: 768px) {
}
@media only screen and (max-width: 767px) {
.accessmapPage .accessData {
	font-size: 12px;
	padding: 1em 1.5em;
}
}
@media only screen and (max-width: 679px) {
}
@media only screen and (max-width: 479px) {
.accessmapPage .gmapsWrap {
	height: 300px;
}
.accessmapPage .contentsListWrap .gmapsWrap {
	height: 200px;
}
}
@media only screen and (max-width: 320px) {
}

/* ===================================================================
//health
=================================================================== */
.healthPage .groupMessage {
	border: #f2f2f2 solid 10px;
	background: #fff;
	margin-top: 40px;
	margin-bottom: 40px;
}
.healthPage .groupMessage > div {
	position: relative;
	display: inline-block;
	vertical-align: middle;
	padding: 120px 40px;
	width: 50%;
}
.healthPage .groupMessage > div:nth-of-type(1) {
	text-align: center;
}
.healthPage .groupMessage > div:nth-of-type(2) {
	padding: 120px 6%;
}
.healthPage .groupMessage > div:nth-of-type(2)::after {
	content: '';
	position: absolute;
	top: 1em;
	bottom: 1em;
	left: 0;
	width: 1px;
	background: #f2f2f2;
}
.healthPage .groupMessage > div p {
	font-size: 16px;
	font-weight: 500;
	line-height: 2.4;
}
.healthPage .groupMessage.groupSimbol > div {
	width: 100%;
	text-align: center;
	padding: 40px;
}
.healthPage .groupMessage.groupSimbol > div:nth-of-type(1) {
	font-size: 24px;
	font-weight: 700;
	padding: 40px;
}
.healthPage .groupMessage.groupSimbol > div:nth-of-type(2)::after {
	content: '';
	position: absolute;
	top: 0;
	bottom: auto;
	left: 1em;
	right: 1em;
	width: auto;
	height: 1px;
}

@media only screen and (max-width: 991px) {
}
@media only screen and (max-width: 768px) {
.healthPage .groupMessage > div {
	padding: 60px 40px;
	width: 100%;
}
.healthPage .groupMessage > div:nth-of-type(2) {
	padding: 40px;
}
.healthPage .groupMessage > div:nth-of-type(2)::after {
	content: '';
	position: absolute;
	top: 0;
	bottom: auto;
	left: 1em;
	right: 1em;
	width: auto;
	height: 1px;
}
.healthPage .groupMessage.groupSimbol > div:nth-of-type(2) {
	text-align: left;
}
}
@media only screen and (max-width: 767px) {
.healthPage .groupMessage > div p {
    font-size: 14px;
    font-weight: 500;
    line-height: 2;
}
.healthPage .groupMessage.groupSimbol > div:nth-of-type(1) {
	padding: 40px 20px;
	font-size: 18px;
}
}
@media only screen and (max-width: 679px) {
}
@media only screen and (max-width: 479px) {
}
@media only screen and (max-width: 320px) {
}

/* ===================================================================
//
=================================================================== */

@media only screen and (max-width: 991px) {
}
@media only screen and (max-width: 768px) {
}
@media only screen and (max-width: 767px) {
}
@media only screen and (max-width: 679px) {
}
@media only screen and (max-width: 479px) {
}
@media only screen and (max-width: 320px) {
}