@charset "UTF-8";

/* ------------------------------
    mv
------------------------------ */
#mv {
	background-color: #f3981c;
	overflow: hidden;
	height: 614px;
}

#mv .img {
	width: auto;
	height: 100%;
	max-width: 1800px;
	position: absolute;
	top: 0;
	left: 50%;
	transform: translateX(-50%);
}

#mv .img img{
	max-width: inherit;
	width: auto;
	height: 100%;
}

@media screen and (max-width: 768px) {
	#mv {
		background-color: #f3981c;
/*		height: 131.6vw;*/
		height: auto;
	}
	#mv .img,
	#mv .img img{
		position: static;
		transform: none;
		width: 100%;
		height: auto;
	}
	
	.android #mv .txtwrap .ttl,
	.android #mv .txtwrap .txt1,
	.android #mv .txtwrap .txt2{
		letter-spacing: 0.1em;
	}
}

/* ------------------------------
    strengths
------------------------------ */
#sec_strengths {
	padding: 100px 0 270px;
}

#sec_strengths .list {
	display: flex;
	flex-wrap: wrap;
	justify-content: center;
	padding: 0 184px;
	background: url(../img/index/strengths_bgimg.png) no-repeat center top;
}

#sec_strengths .list .item {
	position: relative;
	padding: 24px 20px;
}

#sec_strengths .list .item::before{
	content: "";
	width: 100%;
	height: 100%;
	border-radius: 16px;
	background-color: #f3981c;
	mix-blend-mode: multiply;
	position: absolute;
	left: 0;
	top: 0;
}

#sec_strengths .list .item::after {
	content: "";
	width: 0;
	height: 0;
	border-style: solid;
	border-width: 0 18px 18px 0;
	mix-blend-mode: multiply;
	border-color: transparent #f3981c transparent transparent;
	position: absolute;
	top: 100%;
}

#sec_strengths .list .item:nth-child(even)::after {
	border-width: 18px 18px 0 0;
	border-color: #f3981c transparent transparent transparent;
}

#sec_strengths .list .item:nth-child(1) {
	width: 307px;
	margin-right: 115px;
}

#sec_strengths .list .item:nth-child(1)::after {
	left: 130px;
}

#sec_strengths .list .item:nth-child(1)::after {
	left: 130px;
}

#sec_strengths .list .item:nth-child(2) {
	width: 259px;
	margin-right: 51px;
}

#sec_strengths .list .item:nth-child(2)::after {
	left: 120px;
}

#sec_strengths .list .item:nth-child(3) {
	width: 265px;
	padding: 20px 20px;
	margin-top: 40px;
}

#sec_strengths .list .item:nth-child(3)::after {
	left: 74px;
}

#sec_strengths .list .item .txt {
	color: #fff;
	font-weight: bold;
	line-height: 1.66;
	text-align: center;
	letter-spacing: 0.2em;
	font-feature-settings: "palt";
	position: relative;
	z-index: 1;
}

#sec_strengths .list .item:last-child {
	width: 700px;
	margin: 35px 0 0;
	padding: 30px 32px;
}

#sec_strengths .list .item:last-child::before {
	background-color: rgba(25, 47, 114, .95);
}

#sec_strengths .list .item:last-child::after {
	border-color: rgba(25, 47, 114, .95) transparent transparent transparent;
	left: 50%;
	margin-left: -9px;
}

#sec_strengths .list .item:last-child .large {
	font-size: 3.4rem;
	line-height: 1;
	margin: .5em 0;
}

#sec_strengths .list .item:last-child .large span {
	font-size: 200%;
	color: #fdd000;
}

#sec_strengths .list .item .txt:last-child {
	line-height: 2;
}

/*block*/
#sec_strengths .block {
	margin-top: 100px;
	height: 372px;
	position: relative;
}

#sec_strengths .block::before {
	content: "";
	width: calc(50% + 550px);
	height: 100%;
	background-color: #fdd000;
	mix-blend-mode: multiply;
	position: absolute;
	left: 0;
	top: 0;
	border-radius: 0 40px 40px 0;
}

#sec_strengths .block:nth-child(odd)::before {
	left: auto;
	right: 0;
	border-radius: 40px 0 0 40px;
}

#sec_strengths .block .wrap {
	height: 100%;
	display: flex;
	justify-content: space-between;
	z-index: 3;
}

#sec_strengths .block:nth-child(odd) .wrap {
	padding-left: 60px;
	flex-direction: row-reverse;
}

#sec_strengths .block:nth-child(even) .wrap {
	padding-right: 60px;
}


#sec_strengths .block .img {
	height: 100%;
	display: flex;
	align-items: center;
}

#sec_strengths .block02 .img {
	padding-bottom: 34px;
}

#sec_strengths .block03 .img {
	padding-top: 22px;
}

#sec_strengths .block .txtwrap {
	width: 716px;
	position: relative;
}

#sec_strengths .block02 .txtwrap {
	width: 760px;
}

#sec_strengths .block03 .txtwrap {
	width: 770px;
}



#sec_strengths .block .txtwrap .ttlwrap {
	display: flex;
	align-items: flex-end;
	font-feature-settings: "palt";
	margin-bottom: 15px;
}

#sec_strengths .block .txtwrap .ttlwrap .ttl {
	font-weight: bold;
	font-size: 2.4rem;
	line-height: 2;
	letter-spacing: 0.15em;
}

#sec_strengths .block .txtwrap .ttlwrap .ttl sup{
	font-size: 60%;
}

#sec_strengths .block .txtwrap .ttlwrap .num {
	color: #192f72;
	font-size: 23.3rem;
	line-height: .72;
	letter-spacing: 0;
	margin: -.1em .08em 0 0;
}

#sec_strengths .block01 .txtwrap .ttlwrap .num {
	margin-left: -.05em;
}

#sec_strengths .block .txtwrap .txt {
	font-size: 1.6rem;
	line-height: 2.125;
	letter-spacing: 0.15em;
	font-feature-settings: "palt";
	position: relative;
	text-align: justify;
	z-index: 1;
}

#sec_strengths .block .txtwrap .txt .small {
	font-size: 1.4rem;
	position: absolute;
	right: 0;
	bottom: 0;
	letter-spacing: 0;
}

#sec_strengths .block .btn {
	position: absolute;
	bottom: -23px;
	left: 0;
}

#sec_strengths .block03 .btn {
	left: auto;
	right: 0;
}


/*芽のアニメーション*/
#sec_strengths .block .bud {
	position: absolute;
	top: -56px;
	overflow: hidden;
	left: calc(50% + 446px);
	height: 0;
}

#sec_strengths .block.is-show .bud {
	height: auto;
}

#sec_strengths .block02 .bud {
	top: -47px;
	left: 50%;
}


#sec_strengths .block.is-show .bud img {
	animation: bud 0.4s linear 0s 1;
}


@keyframes bud {
	0% {
		transform: scale(1.0, 1.0) translate(0%, 100%);
	}

	15% {
		transform: scale(1.0, 1.0) translate(0%, 90%);
	}

	30% {
		transform: scale(1.0, 0.8) translate(0%, 70%);
	}

	50% {
		transform: scale(0.8, 1.0) translate(0%, 50%);
	}

	70% {
		transform: scale(1.0, 0.9) translate(0%, 10%);
	}

	100% {
		transform: scale(1.0, 1.0) translate(0%, 0%);
	}
}


/*IE*/
.ie #sec_strengths .list .item::before{
	background-color: rgba(243,152,28,.9);
}
.ie #sec_strengths .list .item::after{
	border-color: transparent rgba(243,152,28,.9) transparent transparent;
}
.ie #sec_strengths .list .item:nth-child(even)::after {
	border-color: rgba(243,152,28,.9) transparent transparent transparent;
}


.ie #sec_strengths .list .item:last-child::before{
	background-color: rgba(25,47,114,.9);
}
.ie #sec_strengths .list .item:last-child::after{
	border-color: rgba(25,47,114,.9) transparent transparent;
}


@media screen and (max-width: 768px) {
	#sec_strengths {
		padding: 9.33vw 0 118.4vw;
	}

	#sec_strengths .wrap {
		width: 100%;
	}

	#sec_strengths .list {
		display: block;
		padding: 0 4vw;
		background: url(../img/index/strengths_bgimg_sp.png) no-repeat center top 4.2vw / 100% auto;
	}

	#sec_strengths .list .item {
		padding: 3vw;
	}
	
	#sec_strengths .list .item::before{
		border-radius: 3.2vw;
	}

	#sec_strengths .list .item::after {
		border-width: 0 3.7vw 3.7vw 0;
/*		bottom: -3.6vw;*/
	}

	#sec_strengths .list .item:nth-child(even)::after {
		border-width: 3.7vw 3.7vw 0 0;
	}

	#sec_strengths .list .item:nth-child(1) {
		width: 61.33vw;
		margin-right: auto;
	}

	#sec_strengths .list .item:nth-child(1)::after {
		left: 25.8vw;
	}

	#sec_strengths .list .item:nth-child(2) {
		width: 52vw;
		margin-right: 0;
		margin-left: auto;
		margin-top: 4.5vw;
	}

	#sec_strengths .list .item:nth-child(2)::after {
		left: 33vw;
	}

	#sec_strengths .list .item:nth-child(3) {
		width: 53vw;
		padding: 3vw;
		margin: 4.5vw auto 0;
	}

	#sec_strengths .list .item:nth-child(3)::after {
		left: 14.4vw;
	}

	#sec_strengths .list .item:last-child {
		width: 92%;
		margin: 28.5vw auto 0;
		padding: 5vw 0;
	}

	#sec_strengths .list .item:last-child::after {
		margin-left: -1.85vw;
	}


	#sec_strengths .list .item:last-child .txt:first-child {
		font-size: 4vw;
	}

	#sec_strengths .list .item:last-child .large {
		font-size: 6.1vw;
		margin: .4em 0;
	}


	#sec_strengths .list .item .txt:last-child {
		font-size: 3.2vw;
	}
	
	.android #sec_strengths .list .item .txt:last-child{
		letter-spacing: 0.1em;
	}

	/*block*/
	#sec_strengths .block {
		margin-top: 13.33vw;
		height: auto;
	}

	#sec_strengths .block03 {
		margin-top: 17.6vw;
	}

	#sec_strengths .block::before {
		width: 92vw;
		border-radius: 0 7.4vw 7.4vw 0;
	}

	#sec_strengths .block:nth-child(odd)::before {
		border-radius: 7.4vw 0 0 7.4vw;
	}

	#sec_strengths .block .wrap {
		display: block;
		width: 84vw;
	}

	#sec_strengths .block:nth-child(odd) .wrap {
		padding-left: 8vw;
	}

	#sec_strengths .block:nth-child(even) .wrap {
		padding-right: 8vw;
	}


	#sec_strengths .block .img {
		height: auto;
		display: block;
	}

	#sec_strengths .block01 .img {
		width: 56vw;
		margin: 0 auto 3vw;
	}

	#sec_strengths .block02 .img {
		width: 60vw;
		padding-bottom: 0;
		margin: 7vw auto 8vw;
	}

	#sec_strengths .block03 .img {
		width: 52.8vw;
		padding-top: 0;
		margin: 6vw auto 4vw;
	}

	#sec_strengths .block .txtwrap {
		width: 100%;
		padding: 8vw 0;
	}

	#sec_strengths .block02 .txtwrap {
		width: 100%;
		padding-bottom: 14vw;
	}
	
	#sec_strengths .block03 .txtwrap{
		width: 100%;
		padding-bottom: 14vw;
	}

	#sec_strengths .block .txtwrap .ttlwrap{
		margin-bottom: 4vw;
	}
	#sec_strengths .block .txtwrap .ttlwrap .ttl {
		font-size: 4.2vw;
		white-space: nowrap;
	}

	#sec_strengths .block03 .txtwrap .ttlwrap .ttl {
		letter-spacing: 0.1em;
	}
	
	.android #sec_strengths .block03 .txtwrap .ttlwrap .ttl{
		letter-spacing: 0;
	}

	#sec_strengths .block .txtwrap .ttlwrap .num {
		font-size: 33vw;
		margin: -.1em .08em 0 0;
	}

	#sec_strengths .block01 .txtwrap .ttlwrap .num {
		margin-left: -.05em;
	}

	#sec_strengths .block .txtwrap .txt {
		font-size: 3.2vw;
	}

	#sec_strengths .block .txtwrap .txt .small {
		font-size: 2.8vw;
		position: static;
		display: block;
		text-align: right;
		line-height: 1;
	}

	#sec_strengths .block .btn {
		position: absolute;
		bottom: -7.3vw;
		left: 0;
	}

	#sec_strengths .block03 .btn {
		left: auto;
		right: 0;
	}


	/*芽のアニメーション*/
	#sec_strengths .block .bud {
		width: 12vw;
		top: -8.4vw;
		left: 72vw;
	}

	#sec_strengths .block02 .bud {
		width: 20.2vw;
		top: -8.4vw;
		left: 72vw;
	}

}


/* ------------------------------
    link_block
------------------------------ */
#link_block {
	position: relative;
	margin-top: -150px;
}

#link_block .wrap {
	display: flex;
	justify-content: space-between;
}

#link_block .item {
	width: 538px;
	min-height: 300px;
	padding: 33px 48px 35px;
	background-size: cover;
	background-position: center;
}

#link_block .item.business {
	background-image: url(../img/index/contact_business_bg.png);
}

#link_block .item.personal {
	background-image: url(../img/index/contact_personal_bg.png);
}


#link_block .item .fukidashi {
	width: 210px;
	height: 114px;
	border-radius: 18px;
	display: flex;
	align-items: center;
	justify-content: center;
	position: relative;
	margin-bottom: 20px;
	padding-top: 6px;
}

#link_block .item .fukidashi p {
	color: #fff;
	text-align: center;
	font-weight: bold;
	font-size: 1.6rem;
	line-height: 1.625;
	letter-spacing: 0.1em;
	font-feature-settings: "palt";
	position: relative;
	z-index: 1;
}

#link_block .item.business .fukidashi {
	background-color: rgba(25, 47, 114, .5);
}

#link_block .item.personal .fukidashi::after {
	content: "";
	width: 100%;
	height: 100%;
	position: absolute;
	left: 0;
	top: 0;
	border-radius: 18px;
	background-color: rgba(143, 195, 31, .7);
	mix-blend-mode: multiply;
}

#link_block .item .fukidashi::before {
	content: "";
	width: 0;
	height: 0;
	border-style: solid;
	border-width: 0 20px 20px 0;
	position: absolute;
	left: 50px;
	top: 100%;
}

#link_block .item .fukidashi:last-child::before {
	left: auto;
	right: 50px;
	border-width: 20px 20px 0 0;
}

#link_block .item.business .fukidashi::before {
	border-color: transparent rgba(25, 47, 114, .5) transparent transparent;
}

#link_block .item.business .fukidashi:last-child::before {
	border-color: rgba(25, 47, 114, .5) transparent transparent transparent;
}

#link_block .item.personal .fukidashi::before {
	mix-blend-mode: multiply;
	border-color: transparent rgba(143, 195, 31, .7) transparent transparent;
}

#link_block .item.personal .fukidashi:last-child::before {
	border-color: rgba(143, 195, 31, .7) transparent transparent transparent;
}

#link_block .item .txt {
	color: #fff;
	text-align: center;
	font-weight: bold;
	font-size: 2.4rem;
	letter-spacing: 0.1em;
	line-height: 1;
	margin: 0 0 1.15em;
}

#link_block .item .btn a {
	width: 237px;
	height: 46px;
	font-size: 1.6rem;
	margin: 0 auto;
	background-color: #fff;
}

#link_block .item.business .btn a {
	color: #192f72;
}

#link_block .item .btn a:hover{
	background-color: rgba(255,255,255,.8);
}

#link_block .item.business .btn a::before {
	border-color: #192f72;
}

#link_block .item.business .btn a:hover {
	color: #635e91;
}

#link_block .item.business .btn a:hover::before {
	border-color: #635e91;
}

#link_block .item.personal .btn a {
	color: #8fc31f;
}

#link_block .item.personal .btn a::before {
	border-color: #8fc31f;
}

#link_block .item.personal .btn a:hover {
	color: #b6d56a;
}

#link_block .item.personal .btn a:hover::before {
	border-color: #b6d56a;
}

@media screen and (max-width: 768px) {
	#link_block {
		margin-top: -99.2vw;
	}

	#link_block .wrap {
		display: block;
		width: 92%;
	}

	#link_block .item {
		width: 100%;
		min-height: 59.86vw;
		padding: 6.5vw 4vw 6.9vw;
		border-radius: 3.73vw;
	}

	#link_block .item.personal {
		margin-top: 9.33vw;
	}


	#link_block .item .fukidashi {
		width: 40vw;
		height: 21.6vw;
		border-radius: 3.46vw;
		margin-bottom: 5.33vw;
		padding-top: 1vw;
	}

	#link_block .item .fukidashi p {
		font-size: 3.2vw;
	}

	#link_block .item.personal .fukidashi::after {
		border-radius: 3.46vw;
	}

	#link_block .item .fukidashi::before {
		border-width: 0 4.26vw 4.26vw 0;
		left: 8.8vw;
/*		bottom: -4vw;*/
	}

	#link_block .item .fukidashi:last-child::before {
		right: 8.8vw;
		border-width: 4.26vw 4.26vw 0 0;
	}

	#link_block .item .txt {
		font-size: 4.8vw;
	}

	#link_block .item .btn a {
		width: 47.46vw;
		height: 9.33vw;
		font-size: 3.2vw;
	}

}


/* ------------------------------
    company
------------------------------ */
#sec_company {
	margin-top: 70px;
	background-color: #f3981c;
	padding: 130px 0 100px;
}

#sec_company::before {
	content: "";
	width: 0;
	height: 0;
	border-style: solid;
	border-width: 70px 247px 0 247px;
	border-color: #fff transparent transparent transparent;
	position: absolute;
	left: 0;
	right: 0;
	top: 0;
	margin: 0 auto;
}

#sec_company .secttl {
	text-align: center;
	color: #fff;
	margin-bottom: 40px;
}

#sec_company .secttl > span {
	display: inline-block;
	position: relative;
	line-height: 1;
}

#sec_company .secttl span .ja {
	font-weight: bold;
	font-size: 3rem;
	letter-spacing: 0.15em;
	position: absolute;
	left: 0;
	right: 0;
	top: 1.3em;
	margin: auto;
}

#sec_company .secttl span .en {
	font-size: 11.146rem;
	letter-spacing: 0.04em;
	color: rgba(255, 255, 255, .2);
}

/*message*/
#sec_company .message {
	position: relative;
	height: 585px;
	z-index: 1;
}

#sec_company .message::before {
	content: "";
	width: calc(50% + 550px);
	height: 100%;
	background: url(../img/common/bg.png);
	position: absolute;
	left: -100%;
	top: 0;
	border-radius: 0 36px 36px 0;
	box-shadow: 0 0 5px rgba(0, 0, 0, .2);
	transition: 1s ease;
}

#sec_company .message.is-show::before {
	left: 0;
}

#sec_company .message::after {
	content: "";
	width: 74px;
	height: 73px;
	background: url(../img/index/company_message_fukidashi.png) no-repeat center top / 100% auto;
	position: absolute;
/*	bottom: -72px;*/
	top: 100%;
	left: calc(50% - 566px);
	opacity: 0;
	transition: 1s ease;
	transition-delay: 1s;
	margin-top: -1px;
}

#sec_company .message.is-show::after {
	opacity: 1;
}


#sec_company .message .wrap {
	height: 100%;
	display: flex;
	align-items: center;
	justify-content: space-between;
	padding-right: 45px;
}

#sec_company .message .wrap .img {
	width: 505px;
}

#sec_company .message .wrap .txtwrap {
	width: 520px;
	height: 100%;
	position: relative;
	padding-top: 100px;
	padding: 100px 35px 0 20px;
}

#sec_company .message .wrap .txtwrap::before,
#sec_company .message .wrap .txtwrap::after {
	content: "";
	width: 63px;
	height: 48px;
	background: url(../img/index/company_message_frame.png) no-repeat center / 100% auto;
	position: absolute;
	opacity: 0;
	transition: opacity 1s;
	transition-delay: 1.5s;
}

#sec_company .message.is-show .wrap .txtwrap::before,
#sec_company .message.is-show .wrap .txtwrap::after {
	opacity: 1;
}

#sec_company .message .wrap .txtwrap::before {
	left: 0;
	top: -10px;
}

#sec_company .message .wrap .txtwrap::after {
	right: 0;
	bottom: -10px;
	transform: scale(-1, -1);
}

#sec_company .message .wrap .txtwrap .ttl {
	font-weight: bold;
	font-size: 2.4rem;
	letter-spacing: 0.1em;
	margin-bottom: 1.5em;
}

#sec_company .message .wrap .txtwrap .txt {
	font-size: 1.6rem;
	line-height: 2.125;
	letter-spacing: 0.15em;
	font-feature-settings: "palt";
	text-align: justify;
	text-indent: 1em;
}

#sec_company .message .wrap .txtwrap .txt + .txt {
	margin-top: 2em;
}

#sec_company .message .wrap .txtwrap .name {
	text-align: right;
	font-size: 1.6rem;
	letter-spacing: 0.1em;
	margin-top: .5em;
}

#sec_company .message .wrap .txtwrap .name span {
	font-weight: bold;
	font-size: 2rem;
	margin-left: .5em;
}

/*about*/
#sec_company .about {
	position: relative;
	padding: 316px 0 65px;
	margin-top: -246px;
}

#sec_company .about::before {
	content: "";
	width: calc(50% + 550px);
	height: 100%;
	background-color: #fff;
	position: absolute;
	right: 0;
	top: 0;
	border-radius: 36px 0 0 36px;
}

#sec_company .about::after {
	content: "";
	width: 0;
	height: 0;
	border-style: solid;
	border-width: 70px 70px 0 0;
	border-color: #fff transparent transparent transparent;
	position: absolute;
/*	bottom: -70px;*/
	top: 100%;
	right: calc(50% - 550px);
}

#sec_company .about .wrap {
	padding: 0 77px;
}

#sec_company .about .box {
	padding: 3px;
	border: 7px solid #192f72;
}

#sec_company .about .box .boxin {
	padding: 7px 43px;
	border: 2px solid #192f72;
}

#sec_company .about .box dl {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	width: 100%;
	padding: 28px 0;
	position: relative;
}

#sec_company .about .box dl + dl {
	border-top: 1px solid #192f72;
}

#sec_company .about .box dl + dl::before,
#sec_company .about .box dl + dl::after {
	content: "";
	width: 5px;
	height: 5px;
	background-color: #192f72;
	border-radius: 50%;
	position: absolute;
	top: -3px;
}

#sec_company .about .box dl + dl::before {
	left: 0;
}

#sec_company .about .box dl + dl::after {
	right: 0;
}

#sec_company .about .box dl dt {
	width: 250px;
	font-weight: bold;
	font-size: 1.8rem;
	letter-spacing: 0.2em;
	padding-left: 2em;
	position: relative;
}

#sec_company .about .box dl dt::before {
	content: "";
	width: 25px;
	height: 26px;
	background: url(../img/common/ico_sun.png) no-repeat center / 100% auto;
	position: absolute;
	left: 0;
	top: .3em;
}

#sec_company .about .box dl dd {
	width: calc(100% - 250px);
	font-size: 1.6rem;
	line-height: 1.625;
	letter-spacing: 0.15em;
	font-feature-settings: "palt";
}

#sec_company .about .box dl dd ul li {
	font-size: 1.6rem;
	line-height: 1.625;
	letter-spacing: 0.15em;
	font-feature-settings: "palt";
	padding-left: 2em;
	position: relative;
}

#sec_company .about .box dl dd ul li::before {
	content: "";
	width: 1em;
	height: 1em;
	background-color: #f3981c;
	border-radius: 50%;
	position: absolute;
	left: 0;
	top: .3em;
}

#sec_company .about .box dl dd ul li + li {
	margin-top: .5em;
}



#sec_company .about .block {
	margin-top: 64px;
}

#sec_company .about .block .blockttl {
	font-weight: bold;
	color: #192f72;
	font-size: 2.4rem;
	letter-spacing: 0.15em;
	line-height: 1.5;
	padding-bottom: .4em;
	border-bottom: 4px solid #192f72;
}

#sec_company .about .block .blockttl span {
	font-weight: 400;
	font-size: 1.6rem;
	margin-left: 2em;
/*	display: inline-block;*/
	vertical-align: middle;
}

#sec_company .about .block .blockttl span::before {
	content: "";
	width: .5em;
	height: 2px;
	display: inline-block;
	background-color: #192f72;
	position: relative;
	vertical-align: middle;
	margin-right: .5em;
}

#sec_company .about .block.company_name .inner {
	display: flex;
	justify-content: space-between;
}

#sec_company .about .block.company_name .inner .txtwrap {
	width: 694px;
}

#sec_company .about .block.company_name .txt {
	font-size: 1.6rem;
	line-height: 2.125;
	letter-spacing: 0.15em;
	font-feature-settings: "palt";
	text-align: justify;
	margin-top: .8em;
}

#sec_company .about .block.company_name .inner .img {
	margin-top: -10px;
}

#sec_company .about .block.insurance .link {
	display: flex;
	justify-content: space-between;
	margin-top: 40px;
}

#sec_company .about .block.insurance .link li {
	width: 223px;
	height: 92px;
}

#sec_company .about .block.insurance .link li a {
	width: 100%;
	height: 100%;
	display: flex;
	align-items: center;
	justify-content: center;
	background-color: #fff;
	box-shadow: 0 0 5px rgba(0, 0, 0, .2);
	position: relative;
	transition: .3s ease;
}

#sec_company .about .block.insurance .link li a::before {
	content: "";
	width: 8px;
	height: 8px;
	background: url(../img/common/ico_blank.png) no-repeat center / 100% auto;
	position: absolute;
	right: 10px;
	bottom: 8px;
}

#sec_company .about .block.insurance .link li a:hover {
	opacity: .8;
}

#sec_company .about .blockwrap {
	display: flex;
	justify-content: space-between;
}

#sec_company .about .blockwrap .block {
	width: 450px;
}

#sec_company .about .block .tb {
	width: 100%;
	border-collapse: collapse;
	margin-top: 5px;
}

#sec_company .about .block .tb th,
#sec_company .about .block .tb td {
	font-size: 1.5rem;
	border-bottom: 1px solid #b2b2b2;
	letter-spacing: 0.05em;
	vertical-align: top;
	padding: .5em 0;
}

#sec_company .about .block .tb tr:last-of-type th,
#sec_company .about .block .tb tr:last-of-type td {
	border: none;
}

#sec_company .about .block .tb th {
	font-weight: bold;
	letter-spacing: 0.07em;
	width: 120px;
}

#sec_company .about .block.history .tb th {
	width: 100px;
}

#sec_company .about .block .tb + .note {
	font-size: 1.4rem;
	text-align: right;
	margin-top: 1.5em;
}

/*IE*/
.ie #sec_company .about .box dl{
	padding: 32px 0 24px;
}

.ie #sec_company .about .box dl dt::before{
	top: .1em;
}

.ie #sec_company .about .box dl dd ul li::before{
	top: .1em;
}

.ie #sec_company .about .block .tb th,
.ie #sec_company .about .block .tb td{
	padding: .6em 0 .4em;
}

@media screen and (max-width: 768px) {
	#sec_company {
		margin-top: 9.33vw;
		padding: 12vw 0 13.33vw;
	}

	#sec_company::before {
		border-width: 9vw 29.5vw 0 29.5vw;
	}

	#sec_company .secttl {
		margin-bottom: 8vw;
	}

	#sec_company .secttl span .ja {
		font-size: 6vw;
	}

	#sec_company .secttl span .en {
		font-size: 22.26vw;
	}

	/*message*/
	#sec_company .message {
		height: auto;
	}

	#sec_company .message::before {
		background-size: 50vw auto;
		width: 92vw;
		border-radius: 0 6.6vw 6.6vw 0;
		box-shadow: 0 0 1vw rgba(0, 0, 0, .2);
	}

	#sec_company .message::after {
		width: 9.86vw;
		height: 9.86vw;
/*		bottom: -9.86vw;*/
		left: 5vw;
	}

	#sec_company .message .wrap {
		padding: 13.33vw 8vw 13.33vw 0;
		display: block;
	}


	#sec_company .message .wrap::before,
	#sec_company .message .wrap::after {
		content: "";
		width: 12.4vw;
		height: 9.3vw;
		background: url(../img/index/company_message_frame.png) no-repeat center / 100% auto;
		position: absolute;
		opacity: 0;
		transition: opacity 1s;
		transition-delay: 1.5s;
	}

	#sec_company .message.is-show .wrap::before,
	#sec_company .message.is-show .wrap::after {
		opacity: 1;
	}

	#sec_company .message .wrap::before {
		left: 0;
		top: -2vw;
	}

	#sec_company .message .wrap::after {
		right: 8vw;
		bottom: -2vw;
		transform: scale(-1, -1);
	}

	#sec_company .message .wrap .img {
		width: 100%;
	}

	#sec_company .message .wrap .txtwrap {
		width: 100%;
		padding: 9vw 0 0 0;
	}

	#sec_company .message .wrap .txtwrap::before,
	#sec_company .message .wrap .txtwrap::after {
		content: none;
	}



	#sec_company .message .wrap .txtwrap .ttl {
		font-size: 4.8vw;
		white-space: nowrap;
	}
	
	.android #sec_company .message .wrap .txtwrap .ttl{
		letter-spacing: 0;
	}

	#sec_company .message .wrap .txtwrap .txt {
		font-size: 3.2vw;
	}


	#sec_company .message .wrap .txtwrap .name {
		font-size: 3.2vw;
	}

	#sec_company .message .wrap .txtwrap .name span {
		font-size: 4vw;
	}

	/*about*/
	#sec_company .about {
		padding: 36vw 0 8vw;
		margin-top: -26vw;
	}

	#sec_company .about::before {
		width: 92vw;
		border-radius: 6.6vw 0 0 6.6vw;
	}

	#sec_company .about::after {
		border-width: 9.33vw 9.33vw 0 0;
/*		bottom: -9vw;*/
		right: 7.46vw;
	}

	#sec_company .about .wrap {
		padding: 0 0 0 8vw;
	}

	#sec_company .about .box {
		padding: .6vw;
		border: 1.33vw solid #192f72;
	}

	#sec_company .about .box .boxin {
		padding: 3vw 8vw;
		border: .4vw solid #192f72;
	}

	#sec_company .about .box dl {
		display: block;
		padding: 4vw 0;
	}


	#sec_company .about .box dl + dl::before,
	#sec_company .about .box dl + dl::after {
		width: 1vw;
		height: 1vw;
		top: -.5vw;
	}

	#sec_company .about .box dl dt {
		width: 100%;
		font-size: 3.6vw;
		margin-bottom: .5em;
	}

	#sec_company .about .box dl dt::before {
		width: 4.9vw;
		height: 5.1vw;
		top: .25em;
	}

	#sec_company .about .box dl dd {
		width: 100%;
		font-size: 3.2vw;
	}

	#sec_company .about .box dl dd ul li {
		font-size: 3.2vw;
		padding-left: 1.5em;
	}
	
	#sec_company .about .box dl dd ul li::before{
		width: .8em;
		height: .8em;
		top: .4em;
	}


	#sec_company .about .block {
		margin-top: 9vw;
	}

	#sec_company .about .block .blockttl {
		font-size: 4.8vw;
		border-bottom: .8vw solid #192f72;
		letter-spacing: 0.1em;
	}

	#sec_company .about .block .blockttl span {
		font-size: 3.2vw;
	}

	#sec_company .about .block.insurance  .blockttl span {
		margin-left: 1.5em;
	}

	#sec_company .about .block .blockttl span::before {
		width: .65em;
		height: .4vw;
	}

	#sec_company .about .block.company_name .inner {
		display: block;
	}

	#sec_company .about .block.company_name .inner .txtwrap {
		width: 100%;
	}
	#sec_company .about .block.company_name .txt {
		font-size: 3.2vw;
	}

	#sec_company .about .block.company_name .inner .img {
		width: 41vw;
		margin: 4vw auto 0;
	}

	#sec_company .about .block.insurance .link {
		flex-wrap: wrap;
		margin-top: 2vw;
	}

	#sec_company .about .block.insurance .link li {
		width: 36.4vw;
		height: 16.5vw;
		margin-top: 3.2vw;
	}

	
	#sec_company .about .block.insurance .link li:nth-child(1) img{
		width: 19vw;
	}
	
	#sec_company .about .block.insurance .link li:nth-child(2) img{
		width: 25vw;
	}
	
	#sec_company .about .block.insurance .link li:nth-child(3) img{
		width: 28.66vw;
	}

	#sec_company .about .block.insurance .link li a {
		box-shadow: 0 0 1vw rgba(0, 0, 0, .2);
	}

	#sec_company .about .block.insurance .link li a::before {
		width: 1.8vw;
		height: 1.8vw;
		right: 1vw;
		bottom: 1vw;
	}

	#sec_company .about .blockwrap {
		display: block;
	}

	#sec_company .about .blockwrap .block {
		width: 100%;
	}

	#sec_company .about .block .tb {
		margin-top: 1vw;
	}

	#sec_company .about .block .tb th,
	#sec_company .about .block .tb td {
		font-size: 2.9vw;
	}

	#sec_company .about .block .tb th {
		width: 8em;
	}

	#sec_company .about .block.history .tb th {
		width: 8em;
	}
	
	#sec_company .about .block .tb td{
		padding-right: 1em;
	}

	#sec_company .about .block .tb + .note {
		font-size: 2.8vw;
		margin-top: .5em;
	}
}