@charset "UTF-8";

.dir_title h1:after{
	content: "CORPORATE PHILOSOPHY";
}
body.policy .dir_title h1:after{
	content: "COMPANY POLICY";
}
body.group .dir_title h1:after{
	content: "GROUP PHILOSOPHY";
}


body.index #page_content main h2{
	font-size: 24px;
    text-align: center;
    font-weight: bold;
    padding-bottom: 18px;
    margin:0 auto 94px;
    line-height: 1.4;
	width:96%;
	max-width: 980px;
    border-bottom: solid 2px #15336c;
	color:#626262;
}
#page_content main .lead{
	font-size:27px;
	text-align: center;
	color:#626262;
	font-weight: bold;
	margin-bottom: 80px;
	line-height: 1.5;
}
#page_content main .phi_wrapper{
	max-width:980px;
	margin:0 auto 140px;
}
#page_content main .phi_wrapper > section{
	display:flex;
	justify-content: space-between;
	width:100%;
	margin-bottom: 120px;
	align-items: center;
}
#page_content main .phi_wrapper > section.sect2{
	flex-direction: row-reverse;
}
#page_content main .phi_wrapper > section.sect3{
	margin-bottom: 0;
}
#page_content main .phi_wrapper > section .pic{
	width:580px;
	flex:1;
}
#page_content main .phi_wrapper > section .pic img{
	width:100%;
}
#page_content main .phi_wrapper > section .txt{
	width:400px;
	text-align: center;
	font-size:20px;
	display:flex;
	flex-direction: column;
	line-height: 2.2;
	color:#626262;
}
#page_content main .phi_wrapper > section .txt i{
	margin-bottom: 2.2em;
}

#page_content main .btn_wrapper{
	width:90%;
	max-width:720px;
	margin:0 auto 100px;
	display:flex;
	justify-content: space-between;
}
#page_content main .btn_wrapper > p{
	width:220px;
}
#page_content main .btn_wrapper > p a{
	height:48px;
	line-height: 48px;
	display:block;
	position:relative;
	border: solid 1px #626262;
    box-sizing: border-box;
    text-align: left;
	padding-left:12px;
    font-size: 16px;
}
#page_content main .btn_wrapper > p a i{
	display: block;
    width: 1.1em;
    height: 1.1em;
    content: "";
    background: url(/common2021/img/i_arrow1.svg) no-repeat center center;
    background-size: contain;
    position: absolute;
    top: 50%;
    right: 0.9em;
    transform: translateY(-50%);
}


@media screen and (max-width: 834px) {
	#page_content main h2{
		margin:0 auto 72px;
	}
	#page_content main .lead{
		margin-bottom: 56px;
	}
	#page_content main .phi_wrapper{
		margin:0 auto 100px;
	}
	#page_content main .phi_wrapper > section{
		display:block;
		width:100%;
		margin-bottom: 0;
		padding-bottom: 40px;
	}
	#page_content main .phi_wrapper > section.sect1,
	#page_content main .phi_wrapper > section.sect3{
		margin-left:0px;
	}
	#page_content main .phi_wrapper > section .pic{
		max-width:680px;
		width:100%;
		margin:0 auto 30px;
	}
	#page_content main .phi_wrapper > section .txt{
		width:90%;
		margin:0 auto;
		font-size:20px;
	}
	#page_content main .phi_wrapper > section .txt i{
		margin-bottom: 1.6em;
	}
	#page_content main .phi_wrapper > section .txt i img{
		width:auto;
	}
	#page_content main .btn_wrapper{
		flex-wrap:wrap;
		justify-content: center;
	}
	#page_content main .btn_wrapper > p{
		margin:0 20px 20px;
	}
}


@media screen and (max-width: 599px) {
	#page_content main .btn_wrapper{
		margin:0 auto 70px;
		display:flex;
		flex-direction: column;
	}
	#page_content main .btn_wrapper > p{
		margin:10px auto;
	}
}




/*
article.group
*/
article.group{
	width:96%;
	max-width: 980px;
	margin:0 auto 110px;
}
article.group h2{
	font-size:24px;
	text-align: center;
	font-weight: bold;
	padding-bottom: 18px;
	margin-bottom: 34px;
	line-height: 1.4;
	border-bottom:solid 2px #15336c;
	color:#626262;
}
article.group .msg{
	font-size:16px;
	text-align: center;
	line-height: 2.24;
	margin-bottom:40px;
}
article.group .box{
	border:solid 8px #f3f5f8;
	background:#f3f5f8;
	padding:44px 2em;
	font-size:16px;
	text-align: center;
}
article.group .box .catch{
	font-size:28px;
	margin-bottom: 30px;
	color:#222;
}
article.group .box .catch + p{
	line-height: 2.2;
}



@media screen and (max-width: 767px) {
	article.group .box{
		border:solid 8px #f3f5f8;
		padding:30px 1.4em;
	}
}



@media screen and (max-width: 678px) {
	article.group .msg{
		text-align: left;
		margin-bottom: 30px;
	}
}


@media screen and (max-width: 678px) {
	article.group .box .catch + p{
		text-align: left;
	}
	article.group .box .catch + p br{
		display:none;
	}
}






/*
article.spirit
*/
article.spirit{
	width:96%;
	max-width: 980px;
	margin:0 auto 130px;
}
article.spirit h2{
	font-size:24px;
	text-align: center;
	font-weight: bold;
	padding-bottom: 18px;
	margin-bottom: 34px;
	line-height: 1.4;
	border-bottom:solid 2px #15336c;
	color:#626262;
}
article.spirit .msg{
	font-size:16px;
	text-align: center;
	line-height: 2.24;
	margin-bottom:40px;
}
article.spirit .spi_wrapper{
	display:flex;
	justify-content: space-between;
	flex-wrap: wrap;
	margin:0 auto 80px;
}
article.spirit .spi_wrapper > div{
	width:31%;
	border:solid 8px #f3f5f8;
	padding:2.8em 2em 2em;
	box-sizing: border-box;
}
article.spirit .spi_wrapper > div img{
	margin-bottom: 30px;
	width:100%;
}
article.spirit .spi_wrapper > div p.strong{
	margin-bottom: 23px;
	text-align: center;
	font-size: 20px;
	font-weight: bold;
}
article.spirit .spi_wrapper > div p.strong strong{
	font-weight: bold;
}
article.spirit .spi_wrapper > div p.strong + p{
	line-height: 2.2;
	font-size: 14px;
	text-align: justify;
}
article.spirit .bottom_msg{
	text-align: center;
	font-size:20px;
	color:#15336c;
	font-weight: bold;
	line-height: 1.9;
	letter-spacing: 0.1em;
	padding-right: 0.1em;
}



@media screen and (max-width: 767px) {
	article.group {
		margin: 0 auto 77px;
	}
	article.spirit .spi_wrapper > div{
		border:solid 8px #f3f5f8;
	}
}



@media screen and (max-width: 678px) {
	article.spirit{
		margin:0 auto 92px;
	}
	article.spirit h2{
		padding-bottom: 13px;
		margin-bottom: 23px;
	}
	article.spirit .msg{
		margin-bottom:28px;
		text-align: left;
	}
	article.spirit .msg br{
		display:none;
	}
	article.spirit .spi_wrapper{
		display:block;
		margin:0 auto 56px;
	}
	article.spirit .spi_wrapper > div{
		width:100%;
		display:block;
		margin-bottom: 16px;
	}
	article.spirit .spi_wrapper > div > div{
		width:100%;
	}
	article.spirit .spi_wrapper > div p.strong{
		margin-bottom: 14px;
		text-align: left;
	}
	article.spirit .spi_wrapper > div p.strong + p{
		line-height: 1.8;
	}
	article.spirit .bottom_msg{
		text-align: left;
	}
	article.spirit .bottom_msg br{
		display: none;
	}
}












/*
plan
*/
body.policy #page_content{
	font-size:16px;
}
body.policy .localnavi{
	max-width:980px;
	width:96%;
	margin:0 auto 90px;
	display:flex;
	flex-wrap: wrap;
	justify-content: space-between;
}
body.policy .localnavi li{
	margin-bottom:2%;
	background:#f4f5f9;
	min-height: 5em;
	width:32.4%;
}
body.policy .localnavi li:nth-of-type(n+3){
	line-height:1.6
}
body.policy .localnavi li a{
	padding:0 0.7em;
	height:100%;
	display:flex;
	align-items: center;
	justify-content: center;
	background:#f4f5f9;
	text-align: center;
	line-height: 1.5;
}
body.policy section.sect{
	max-width:980px;
	width:96%;
	margin:0 auto 148px;
}
body.policy section.sect h2{
	font-size:24px;
	text-align: center;
	font-weight: bold;
	padding-bottom: 18px;
	margin-bottom: 34px;
	line-height: 1.4;
	border-bottom:solid 2px #15336c;
	color:#626262;
}
body.policy section.sect ._container{
	margin:0 auto;
	width:90%;
	line-height: 2.1;
}
body.policy section.sect .sq_ttl{
	border-bottom:#444 solid 1px;
	padding-bottom:0.5em;
	font-size:18px;
	color:#15336c;
	font-weight: bold;
	line-height: 1.1;
	margin-bottom:0.7em;
}
body.policy section.sect .sq_ttl:before{
	content:"";
	display:inline-block;
	width:1em;
	height:1em;
	background:#15336c;
	margin-right:0.5em;
	vertical-align: -3px;
}
body.policy .mb30{
	margin-bottom: 30px;
}
body.policy .sq_block{
	padding-left:1.7em;
	margin-bottom: 40px;
}
body.policy .sq_block .h3_lead{
	margin-bottom: 40px;
	font-size: bold;
}

body.policy dl.plan_dtl{
	overflow: hidden;
	margin-bottom: 10px;
}
body.policy dl.plan_dtl dt,
body.policy dl.plan_dtl dd{
	float:left;
	height:2.2em;
}
body.policy dl.plan_dtl dt:last-child,
body.policy dl.plan_dtl dd:last-child{
	height:4.4em;
}
body.policy dl.plan_dtl dt{
	width:10%;
    max-width: 5.4em;
}
body.policy dl.plan_dtl dd{
	width:90%;
}
body.policy dl.plan_dtl .numbering_list{
	margin-left:18px;
	margin-bottom: 0;
}
body.policy dl.plan_dtl .numbering_list li{
	margin-bottom: 2px;
}

body.policy .numbering_list.box{
	margin:0;
	border:solid #f4f5f9 8px;
	box-sizing: border-box;
	padding:2em 3.4em;
}
body.policy .numbering_list.box + *{
	margin-top:40px;
}
body.policy .numbering_list.box li{
	margin-bottom: 2px;
	color:#15336c;
}
body.policy .numbering_list.box li ol{
	margin-bottom: 2em;
	margin-left: 0;
}
body.policy .numbering_list.box li ol li{
	color:#626262;
	margin-bottom:0.4em;
}
body.policy .numbering_list.box li strong{
	color:#15336c;
}
body.policy .numbering_list.box:first-of-type li{
	margin-bottom: 0.7em;
}
body.policy .numbering_list.box:first-of-type li:last-child{
	margin-bottom: 0;
}
body.policy .numbering_list.box:first-of-type li:last-child ol{
	margin-bottom: 0;
}
body.policy .numbering_list.box li span{
	color:#666;
}
body.policy .jisedai_box{
	border:solid #f4f5f9 8px;
	background:#f4f5f9;
	padding:1.8em 2.4em;
	box-sizing: border-box;
	line-height: 2.2;
}
body.policy .jisedai_box .term{
	font-weight: bold;
}



body.policy h4{
	margin-bottom: 1.5em;
}
body.policy h5{
	padding-left:1em;
}
body.policy .table_wrapper_scr{
	margin:0 48px 40px 1em;
}
body.policy .info_tbl{
	width:100%;
	margin:0 0 0 0;
	box-sizing: border-box;
	text-align: center;
}
body.policy .info_tbl thead{
	background:#e0e0e0;
}
body.policy .info_tbl th,
body.policy .info_tbl td{
	padding:0.7em 0;
	box-sizing: border-box;
}
body.policy .info_tbl thead th,
body.policy .info_tbl thead td{
	width:25%;
	background:#e0e0e0;
	border-bottom: solid 4px #fff;
	border-right: solid 1px #fff;
}
body.policy .info_tbl thead th{
	border-right: solid 4px #fff;
}
body.policy .info_tbl.beginner th[rowspan='2']{
	vertical-align: middle;
}
body.policy .info_tbl tbody th{
	background:#e0e0e0;
	letter-spacing: 1.1em;
	padding-left:1.1em;
	text-align: center;
	border-right: solid 4px #fff;
	border-bottom: solid 1px #fff;
}
body.policy .info_tbl tbody td{
	background:#f3f3f3;
	border-bottom: solid 1px #fff;
	border-right: dotted 1px #fff;
}
body.policy .info_tbl tr td:last-child{
	border-right: none;
}

body.policy .info_tbl.beginner th,
body.policy .info_tbl.beginner td{
	width:auto;
	text-align: center;
}
body.policy .info_tbl.beginner thead tr:first-of-type th{
	border-bottom:solid 1px #fff;
}
body.policy .info_tbl.beginner thead th,
body.policy .info_tbl.beginner thead td{
	width:33.33%;
}
body.policy .info_tbl.beginner.ikukyu th{
	vertical-align: middle;
	width:30%;
	letter-spacing: 0;
	text-align: left;
}
body.policy .info_tbl.beginner.ikukyu td{
	vertical-align: middle;
	width:70%;
	text-align: left;
	padding-left:1em;
	line-height: 1;
}
body.policy .info_tbl.beginner.ikukyu td strong{
}
body.policy .info_tbl.beginner.ikukyu td p{
	padding-top:0.4em;
	font-size:0.8em;
}
body.policy p.alert{
	text-align: right;
	font-size:0.9em;
	margin:-20px 48px 40px 1em;
	line-height: 1.3;
	@media screen and (max-width:  767px) {
		margin:-20px 0px 40px 1em;
		text-align: left;
	}
}
body.policy p.alert span{
	display:inline-block;
	@media screen and (max-width:  767px) {
		text-align: left;
	}
}



@media screen and (max-width: 767px) {
	body.policy .localnavi{
		margin:0 auto 64px;
	}
	body.policy .localnavi li br{
		display:none;
	}
	body.policy section.sect{
		margin:0 auto 100px;
	}
	body.policy section.sect h2{
		padding-bottom: 13px;
		margin-bottom: 24px;
	}
	body.policy section.sect .sq_ttl{
		margin-bottom:0.6em;
	}
	body.policy .sq_block{
		margin-bottom: 30px;
		padding-left:1em;
	}
	body.policy .sq_block .h3_lead{
		margin-bottom: 30px;
	}
	
	body.policy dl.plan_dtl{
		margin-bottom: 7px;
	}
	
	body.policy .numbering_list.box{
		border:solid #f4f5f9 6px;
	}
	body.policy .numbering_list.box + *{
		margin-top:30px;
	}
	body.policy .numbering_list.box li{
		margin-bottom: 2px;
	}
	body.policy .numbering_list.box li ol{
		margin-bottom: 1.5em;
	}
	body.policy .numbering_list.box:first-of-type li{
		margin-bottom: 0.5em;
	}
	body.policy .jisedai_box{
		border:solid #f4f5f9 6px;
	}	
	body.policy h4{
		margin-bottom: 1.2em;
	}
	body.policy .table_wrapper_scr{
		margin:0 36px 30px 1em;
		overflow-x: scroll;
	}
	body.policy .info_tbl{
		width:860px;
	}
	body.policy .mb30{
		margin-bottom: 22px;
	}
}






@media screen and (max-width:  599px) {
	body.policy .localnavi li,
	body.policy .localnavi li:nth-of-type(n + 3){
		width:90%;
		margin:0 auto 2%;
	}
	body.policy .localnavi li br{
		display:inline;
	}
	body.policy section.sect ._container {
		width: 96%;
	}
	body.policy .numbering_list.box{
		border:solid #f4f5f9 5px;
		padding:1.6em 2.4em;
	}
	body.policy .jisedai_box{
		border:none;
		padding:1.2em 1.8em;
	}
	body.policy dl.plan_dtl{
		margin-bottom: 7px;
	}
	body.policy dl.plan_dtl dt,
	body.policy dl.plan_dtl dd{
		float:none;
		height:auto;
	}
	body.policy dl.plan_dtl dt:last-child,
	body.policy dl.plan_dtl dd:last-child{
		height:auto;
	}
	body.policy dl.plan_dtl dt{
		width:100%;
		max-width: 100%;
		font-weight: bold;
	}
	body.policy dl.plan_dtl dd{
		width:100%;
		padding-bottom:0.2em;
	}
	body.policy .table_wrapper_scr{
		margin:0 0 30px 0.5em;
	}
	body.policy .info_tbl{
		width:660px;
	}
}