@charset "utf-8";

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

responsive.css

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

.megaMenuPC {
    display: block;
    background-color: #E60012;
    width: 75%;
    right: -75%;
    position: absolute;
    max-height: calc(100vh - 67px);
    padding: 30px;
	overflow: auto;
	transition: 0.5s ease-in-out;
}
.megaMenuPC::-webkit-scrollbar{
	display: none;
}
.megaMenuPC.open{
	right: 0;
}
.megaMenuPC .inner{
	width: auto;
	min-width: none;
}
.megaMenuPC a:hover{
	text-decoration: none;
}
.megaMenuPC a {
	color: #FFFFFF;
	display: block;
	padding: 15px;
}
.megaMenuPC .gNavLinkList {
    display: grid;
    width: 100%;
    margin-top: 20px;
    font-size: 1.4rem;
    grid-template-columns: 1fr 1fr 1fr;
    column-gap: 4%;
}
.megaMenuPC .gNavLinkList > li > a{
	background-image: url(../images/ico_arrow_white_mini.svg);
	background-repeat: no-repeat;
	background-position: right 4% center;
}
.megaMenuPC li {
	width: 100%;
	text-align: left;
	border-left: none;
	border-bottom: solid 1px #FFF;
	padding-left: 0;
	padding-right: 0;
	border-top: solid 1px #FFF;
	margin-top: -1px;
}

.megaMenuPC li:last-child {
	border-right: none;
}
.megaMenuPC .gNavLinkList > li .child {
	padding-left: 4%;
	padding-right: 4%;
	display: block;
	position: relative;
	padding-top: 0;
	padding-bottom: 0;
	left: auto;
	margin-top: auto;
	width: auto;
	z-index: auto;
	background-color: transparent;
}
.megaMenuPC a.parent.active > span {
	background-color: transparent;
}

.megaMenuPC .gNavLinkList > li .child li{
	border-bottom: none;
	margin-bottom: 10px;
	padding-bottom: 0;
	border-top: none;
}

.megaMenuPC .gNavLinkList > li .child a {
	padding-top: 5px;
	padding-bottom: 5px;
	background-color: #E60012;
	border-radius: 5px;
	background-image: url(../images/ico_arrow_white.svg);
	background-repeat: no-repeat;
	background-position: left 10px center;
	padding-left: 26px;
	font-size: 1.3rem;
	background-size: 10px;
}



.forPC { display: block; }
.forSP { display: none; }

br.forPC { display: inline; }
br.forSP { display: none; }

img.forPC { display: inline; }
img.forSP { display: none; }


.tokyoLogoSp{
	display: none;
}
@media screen and (max-width: 1220px) {
	.inner{
		padding-left: 2%;
		padding-right: 2%;
	}
	.businessIntroImgR{
		margin-right: -2%;
	}
}

/*-------------------------------------------------------------------
 Media Queries
-------------------------------------------------------------------*/
@media screen and (max-width: 1240px) {

}
@media screen and (max-width: 1200px) {

	
}

@media screen and (max-width: 1025px) {
	
}

/* SP layout
-------------------------------------------------------------------*/



@media screen and (max-width: 769px) {
	br.forPC { display: none; }
	br.forSP { display: inline; }

	.forPC { display: none; }
	.forSP { display: block; }

	img.forPC { display: none; }
	img.forSP { display: inline; }
	.gNav .child a {
		background-image: url(../images/ico_arrow_white.svg);
	}



	.b3dviewer-wrapper {
		max-width: 92vw !important;
	}

	/* layout */
	.scrollBox {
		bottom: 85px;
	}

	.openingCopy p {
		font-size: 3.6rem;
	}

	body {
		min-width: inherit;
		font-size: 1.3rem;
	}
	#wrapper{
		overflow: hidden;
		min-width: auto;
	}
	header{
		min-width: auto;
	}

	header .headerLogo img {
		max-width: 140px;
	}
	.headerSpBtn{
		padding: 15px 15px 14px 13px;
		height: 26px;
	}



	header .headerLogo {
		padding-left: 15px;
		padding-top: 15px;
		padding-bottom: 13px;
		height: 55px;
		width: auto;
	}
	.inner {
		box-sizing: border-box;
		padding-left: 4%;
		padding-right: 4%;
		width: 100%;
	}

	
	.gNav {
		background-color: #E60012;
		padding-top: 20px;
		padding-bottom: 20px;
		clear: both;
		display: none;
		position: absolute;
		width: 100vw;
		z-index: 2;
		right: 0;
		top: 55px;
		overflow: auto;
		height: calc(100vh - 67px);
		height: calc(100dvh - 67px);
	}
	.gNav a {
		color: #FFFFFF;
		display: block;
		padding: 15px;
	}
	.gNav .gNavLinkList {
		display: block;
		width: 100%;
		margin-top: 20px;
		border-top: solid 1px #FFF;
		font-size: 1.4rem;
	}
	.gNav .gNavLinkList > li > a{
		background-image: url(../images/ico_arrow_white_mini.svg);
		background-repeat: no-repeat;
		background-position: right 4% center;
	}
	.gNav li {
		width: 100%;
		text-align: left;
		border-left: none;
		border-bottom: solid 1px #FFF;
		padding-left: 0;
    	padding-right: 0;
	}
	.gNav li:last-child {
		border-right: none;
		border-bottom: none;
	}
	.gNav .gNavLinkList > li .child {
		padding-left: 4%;
		padding-right: 4%;
		display: block;
		position: relative;
		padding-top: 0;
		padding-bottom: 0;
		left: auto;
		margin-top: auto;
		width: auto;
		z-index: auto;
		background-color: transparent;
	}
	.gNav a.parent.active > span {
		background-color: transparent;
	}
	
	.gNav .gNavLinkList > li .child li{
		border-bottom: none;
		margin-bottom: 5px;
		padding-bottom: 0;
	}
	.gNav .gNavLinkList > li .child li:last-child{
		margin-bottom: 20px;
	}

	.gNav .gNavLinkList > li .child a {
		padding-top: 5px;
		padding-bottom: 5px;
		background-color: #E60012;
		border-radius: 5px;
		background-image: url(../images/ico_arrow_white.svg);
		background-repeat: no-repeat;
		background-position: left 10px center;
		padding-left: 26px;
		font-size: 1.2rem;
		background-size: 10px;
	}
	.languageSelect > div a{
		padding: 10px;
	}
	

	/* top contents */

	.miniCateTitle h2 {
		padding-bottom: 8px;
		font-size: 1.2rem;
	}

	.mainText {
		position: relative;
		top: 17%;
		left: 0;
		transform: none;
		-webkit-transform: none;
		-ms-transform: translateX(-50%);
		font-size: 1.9em;
		font-weight: 900;
		text-align: left;
		color: #E60012;
		line-height: 2;
		text-align: center;
	}
	.topMaskMovie{
		width: 104%;
		right: 0;
		position: absolute;
		top: 39vh;
		left: 0;
		margin-left: -2%;
		margin-right: -2%;
	}
	.topMaskMovie02{
		width: 104%;
		right: 0;
		position: absolute;
		top: 39vh;
		left: 0;
		margin-left: -2%;
		margin-right: -2%;
	}


	.visualArea {
		padding-top: 3px;
		padding-bottom: 11px;
	}
	.visualArea .slide{
		width: auto;
	}

	.topSection {
		position: relative;
		padding-top: 60px;
		padding-bottom: 60px;
	}


	.obiTitle h2 {
		font-size: 4.3rem;
		margin-top: -40px;
		margin-left: 2%;
	}
	.topBussinessContents2c {
		position: relative;
		z-index: 1;
		padding-left: 4%;
		padding-right: 4%;
		margin-left: auto;
		margin-right: auto;
		padding-top: 40px;
		display: grid;
		grid-template-columns: 1fr;
		column-gap: 6%;
	}
	.obiTitle {
		position: absolute;
		z-index: 0;
		width: 60%;
		height: 230px;
	}
	.wipe_left_to_right.active {
		width: 100%;
	}
	.wipe_right_to_left.active {
		width: 100%;
	}
	.topBussinessContents2c .textBox {
		padding-top: 30px;
		margin-bottom: 20px;
	}
	.topBussinessContents2c h3 {
		font-size: 1.8rem;
		margin-bottom: 40px;
		line-height: 2;
	}
	.topBussinessContents2c .hikkiTitle {
		position: absolute;
		bottom: -60px;
		left: 0;
		z-index: 1;
		width: 60%;
		top: auto;
		right: auto;
	}
	.topBussinessContents2c .imgBox {
		position: relative;
		margin-bottom: 50px;
	}
	.topBussinessContents2c h3{
		margin-bottom: 20px;
	}
	.viewDetailsBtn a {
		font-size: 2rem;
	}
	.topBussinessUnit {
		padding-left: 4%;
		padding-right: 4%;
	}
	.topBussinessUnit h3 {
		font-size: 1.8rem;
		margin-bottom: 30px;
	}
	.topBussinessUnit4c ul {
		display: grid;
		grid-template-columns: 1fr 1fr;
		column-gap: 4%;
		z-index: 2;
		position: relative;
		row-gap: 70px;
	}
	.marqueeWrapper p{
		font-size: 4rem;
		color: #A9A9A9;
	}
	.marqueeWrapper {
		overflow: hidden;
		position: absolute;
		height: 130px;
		left: 0;
		top: calc(50% - 35px);
		width: fit-content;
		display: flex;
		width: 780px;
	}
	.topBussinessUnit4c h4 {
		text-align: center;
		margin-top: 8px;
		font-size: 1.3rem;
	}
	.topBussinessContents2c {
		margin-bottom: 20px;
	}
	.topCompany2c {
		display: grid;
		grid-template-columns: 1fr;
		z-index: 2;
		position: relative;
		padding-left: 0;
		padding-right: 0;
	}
	.topCompany .inner{
		padding-left: 0;
		padding-right: 0;
	}
	.topCompany .obiTitle {
		margin-top: 0;
	}
	.topCompany2c .imgBox {
		margin-top: 40px;
		padding-right: 4%;
	}
	.topCompanyContents {
		background-color: #000;
		padding-right: 6%;
		margin-bottom: 0;
		padding-left: 6%;
		padding-top: 120px;
		padding-bottom: 30px;
		margin-left: 4%;
		margin-top: -60px;
	}
	.topCompany2c .imgBox {
		margin-top: 40px;
		padding-right: 4%;
		z-index: 1;
	}
	.topCompany .hikkiTitle {
		position: absolute;
		left: auto;
		right: 0;
		margin-left: auto;
		margin-right: auto;
		text-align: center;
		margin-top: 0;
		mix-blend-mode: difference;
		z-index: 3;
		top: auto;
		width: 43%;
		top: 287px;
	}
	.topCompanyContents h3 {
		font-size: 1.8rem;
		margin-bottom: 30px;
		color: #FFF;
		line-height: 2;
	}
	.topCompany .miniCateTitle{
		margin-right: 4%;
		position: absolute;
		right: 0;
		top: -20px;
	}
	.topRecruitContents {
		background-color: #000;
		margin-left: 4%;
		margin-bottom: 0;
		padding-left: 6%;
		padding-top: 140px;
		padding-bottom: 6%;
		padding-right: 6%;
		z-index: 2;
		position: relative;
		width: 100%;
		margin-top: -50px;
	}
	.topRecruit2c {
		margin-top: 0px;
		margin-bottom: 60px;
	}
	.topRecruit2c .imgBox {
		width: 100%;
		padding-right: 4%;
		z-index: 3;
		position: relative;
		margin-top: 40px;
		padding-top: 40px;
	}
	.topRecruit .miniCateTitle{
		position: absolute;
		right: 4%;
		top: -20px;
	}
	.topRecruitContents h3 {
		font-size: 1.8rem;
		margin-bottom: 20px;
		color: #FFF;
	}
	.topTopics .obiTitle {
		position: absolute;
		z-index: 0;
		width: 50%;
		height: 80%;
		right: 0;
		margin-top: -90px;
	}
	.topRecruit .hikkiTitle {
		position: absolute;
		left: auto;
		right: 4%;
		margin-left: auto;
		margin-right: auto;
		text-align: center;
		margin-top: -30px;
		mix-blend-mode: difference;
		z-index: 3;
		width: 43%;
	}
	.topTopics .obiTitle {
		position: absolute;
		z-index: 0;
		width: 50%;
		height: 80%;
		right: 0;
		margin-top: -100px;
	}
	.topTopics .obiTitle h2 {
		margin-left: auto;
		font-size: 4.3rem;
		line-height: 1.2;
		margin-top: -25px;
		margin-left: 2%;
	}






	.topNewsPickWrapper {
		padding: 4% 0;
		background-color: #000;
		width: 100%;
		position: relative;
		left: 0;
		bottom: 0;
		text-align: left;
		box-sizing: border-box;
	}
	.topNewsPickWrapper .inner{
		margin-left: 0;
	}
	.topNewsPickWrapper h2 {
		font-size: 1.2rem;
		margin-bottom: 0px;
	}
	.visualArea .slide div.slideContents {
		border-radius: 4px;
		overflow: hidden;
		margin-left: 2%;
		margin-right: 2%;
	}
	.visualArea .slide .slick-slide div.slideContents{
		margin-left: auto;
		margin-right: auto;
	}
	.visualArea .slick-slide{
		margin-left: 5px;
		margin-right: 5px;
	
	}
	.visualArea .slick-dots li button{
		background-color: #dcdcdc;
		width: 32px;
		height: 4px;
		display: inline-block;
		border-radius: 100px;
		overflow: hidden;
	}
	.visualArea .slick-dots li {
		margin-left: 3px;
		margin-right: 8px;
		cursor: pointer;
		
	}
	.visualArea .slick-pause-icon{
		width: 15px;
	}
	.visualArea .slick-play-icon{
		width: 15px;
	}
	.topLinksWrapper {
		padding-bottom: 30px;
	}
	.topLinkBox {
		position: relative;
		display: block;
	}
	.topLinkBox .imgBox img{
		aspect-ratio: 4 / 3;
		overflow: hidden;
	}
	

	.topInformationEventContentsBox {
		display: grid;
		grid-template-columns: 1fr;
		column-gap: unset;
		row-gap: 2px;
	}
	.informationBox, .eventBox {
		padding: 4%;
		float: none;
	}
	.topPickupWrapper {
		padding-top: 30px;
		background-color: #EFF7FC;
		padding-bottom: 30px;
	}
	.topNewsPickWrapper h2:last-child {
		margin-bottom: 5px;
	}
	.topInformationEventContentsBox h2 {
		font-size: 1.8rem;
	}
	.topInformationEventContentsBox h2 span {
		display: inline-block;
		padding: 3px 20px;
		background-color: #FFFFFF;
		position: absolute;
		right: 0;
		font-size: 1.2rem;
		font-weight: normal;
		top: 2px;
	}
	.informationBox h2 {
		background-size: 20px;
		padding-left: 0px;
	}
	.eventBox h2 {
		background-size: 20px;
		padding-left: 0px;
	}
	.informationBox .textLinkList, .eventBox .textLinkList {
		height: auto;
	}
	.informationBox .textLinkList, .eventBox .textLinkList {
		padding: 4%;
		box-sizing: border-box;
	}
	
	.textLinkList dl{
		margin-left: -4%;
		margin-right: -4%;
	}
	.textLinkList dt {
		padding-left: 4%;
		margin-bottom: 10px;
		padding-right: 4%;
	}
	.textLinkList dd{
		padding-left: 4%;
		padding-right: 4%;
	}
	.topInformationEventWrapper {
		padding-top: 30px;
		padding-bottom: 30px;
	}
	.footerBannerWrapper {
		padding-top: 30px;
		padding-bottom: 30px;
		background-color: #EFF7FC;
	}
	.footerBanner ul {
		display: grid;
		grid-template-columns: 49% 49%;
		column-gap: 2%;
		row-gap: 20px;
	}

	.footerContentsBox {
		padding-top: 30px;
		padding-bottom: 30px;
		background-color: #E60012;
	}
	.footerContentsBox .inner {
		display: block;
	}
	.footerLinkBox {
		padding-left: 4%;
		padding-right: 4%;
		border-left: none;
		border-right: none;
		box-sizing: border-box;
		margin-bottom: 30px;
		border-bottom: solid 1px #FFFFFF;
		padding-bottom: 20px;
	}
	.footerInformationBox {
		padding-left: 0;
		padding-right: 0;
		border-right: none;
		box-sizing: border-box;
	}
	.footerOtherLinkBox a{
		font-size: 1.1rem;
	}

	.footerUniversityBox ul {
		display: block;
	}
	.footerUniversityBox ul li:first-child {
		border-left: none;
		margin-bottom: 20px;
		padding-bottom: 20px;
		border-bottom: #E60012 solid 1px;
	}
	.footerUniversityBox ul li {
		border-right: none;
	}
	.footerLinkHome a {
		background-size: 16px;
		padding-left: 24px;
	}
	.footerSnsBox img{
		max-width: 25px;
	}
	.footerUniversityBox ul li img {
		max-width: 95%;
	}
	#pagetop{
		width: 45px;
	}
	.footerBtnBox {
		display: grid;
		grid-template-columns: 1fr;
		margin-bottom: 30px;
		text-align: center;
		column-gap: 4%;
		row-gap: 20px;
	}
	.pickupList div.slide div.slideContents .imgBox img {
		max-height: 360px;
	}

	.pickupList div.slide div.slideContents {
		height: auto;
	}

	.footerContect h2 {
		text-align: center;
		font-size: 1.6rem;
	}
	.footerContect .fotterContactBtn a {
		font-size: 1.6rem;
		padding-left: 0;
		padding-right: 0;
		position: relative;
		padding-top: 10px;
		padding-bottom: 10px;
		box-sizing: border-box;
		border: #E60012 solid 2px;
		background-color: #FFFFFF;
		color: #E60012;
		border-radius: 100px;
		display: block;
		width: 80%;
		margin-left: auto;
		margin-right: auto;
	}

	.topInfomationContents {
		background-color: #000;
		padding-right: 4%;
		padding-left: 4%;
		padding-top: 4%;
		padding-bottom: 4%;
		z-index: 1;
		position: relative;
		margin-left: 4%;
	}
	.topInfomationContents h2 {
		font-size: 4rem;
		margin-bottom: 20px;
	}
	.topInfomationContents .miniCateTitle h2{
		font-size: 1.3rem;
		padding-bottom: 8px;
	}
	.textLinkList {
		margin-bottom: 30px;
	}
	.textLinkList dl {
		margin-left: 0;
		margin-right: 0;
	}
	.textLinkList dl:first-child {
		border-top: solid 1px #F9F9F9;
		padding-top: 10px;
	}
	.textLinkList dd {
		padding-bottom: 10px;
    	margin-bottom: 10px;
	}
	.footerGroupInfo h3 {
		font-size: 2.6rem;
		text-align: center;
		margin-bottom: 30px;
		font-family: 'Filson Pro';
	}
	.footerGroupInfo {
		border-top: #f9f9f9 solid 5px;
		padding-top: 40px;
		padding-bottom: 40px;
	}
	.footerBanner ul {
		display: grid;
		grid-template-columns: 100%;
		column-gap: 2%;
		row-gap: 15px;
	}



	/* detail */
	
	article {
		margin-bottom: 60px;
		padding: 0;
	}

	.textContents {
		margin-left: 2%;
		margin-right: 2%;
	}

	.articleTitle h1 {
		background-position: left center;
		padding-left: 2%;
		padding-top: 20px;
		padding-bottom: 20px;
		font-size: 2rem;
		padding-right: 2%;
	}
	.articleTitle {
		margin-bottom: 30px;
	}
	.articleBody p{
		font-size: 1.2rem;
	}
	.articleBody .imgBoxL {
		float: none;
		max-width: none;
		margin-bottom: 10px;
		margin-right: 0;
	}
	.articleBody .imgBoxR {
		float: none;
		max-width: none;
		margin-bottom: 10px;
		margin-right: 0;
		margin-left: 0;
	}
	.articleBody .imgBoxC {
		max-width: 100%;
		margin-bottom: 10px;
	}
	.articleBody section {
		margin-bottom: 30px;
		position: relative;
	}
	.articleBody h2 {
		padding-left: 60px;
		font-size: 1.8rem;
		margin-bottom: 15px;
	}
	.articleBody h2::before {
		width: 40px;
		height: 2px;
		content: '';
		display: block;
		position: absolute;
		top: 15px;
		left: 0;
		background-color: #E60012;
	}
	.articleBody h3 {
		padding: 4px 20px;
		font-size: 1.6rem;
		margin-bottom: 25px;
		font-weight: bold;
		background-color: #F9F9F9;
	}
	.articleBody h4 {
		padding-bottom: 8px;
		font-size: 1.4rem;
		margin-bottom: 25px;
		margin-left: 2%;
    	margin-right: 2%;
		padding-left: 5px;
	}
	.articleBody ul {
		margin-bottom: 10px;
		position: relative;
		padding-left: 10px;
		font-size: 1.2rem;
	}
	.articleBody ul li {
		margin-bottom: 8px;
		position: relative;
		padding-left: 20px;
	}
	.articleBody ul li::before {
		content: '';
		width: 6px;
		height: 6px;
		left: 0;
		top: 7px;
	}
	.articleBody ol {
		margin-bottom: 20px;
		position: relative;
		padding-left: 25px;
	}
	.articleBody ol li {
		margin-bottom: 8px;
		position: relative;
		padding-left: 7px;
		font-size: 1.2rem;
	}
	.tableBox{
		margin-left: auto;
		margin-right: auto;
	}
	.tableScrollBox {
		padding-right: 4vw;
		overflow: auto;
		width: calc( 100vw - 4% );
		background-color: #FFFFFF;
		margin-bottom: 20px;
		margin-left: auto;
		margin-right: auto;
	}
	
	
	
	.tableScrollBox table{
		min-width: 160%;
		max-width: 1140px;
		margin: 0 0 10px 0;
	}
	.articleBody .accordionBox h2 {
		margin-left: 0;
		font-size: 1.8rem;
		padding-left: 14px;
	}
	.articleBody .accordionBox h2.btn{
		background-size: 20px;
		padding-right: 30px;
	}
	.accordionBox{
		margin-bottom: 30px;
	}
	.articleBody .accordionBox h2::before {
		width: 25px;
		height: 2px;
		top: 13px;
	}
	.articleBody .accordionBox h2 {
		margin-left: 0;
		font-size: 1.6rem;
		padding-left: 40px;
		
	}
	.accordionBox {
		background-color: #F9F9F9;
		padding: 4% 4% 1px 4%;
	}
	.articleBody .accordionBoxInner {
		background-color: #FFFFFF;
		padding: 4%;
		margin-bottom: 20px;
		overflow: hidden;
	}
	.accordionBoxInner .tableBox {
		padding-right: 10vw;
		width: calc( 100vw - 8% );
	}
	.articleBtn a {
		padding: 10px 40px;
		min-width: 80%;
		margin-left: 10px;
		margin-right: 10px;
		margin-bottom: 20px;
	}
	.articleBody .accordionBox h3 {
		font-size: 1.4rem;
		margin-bottom: 15px;
	}
	.articleBody .accordionBox h3.btn {
		background-size: 20px;
		padding-right: 30px;
		padding-left: 0px;
    	margin-bottom: 15px;
	}
	.articleBody .accordionBox h4 {
		font-size: 1.2rem;
		margin-bottom: 15px;
	}
	.articleBody ul li a.blank,
	.articleBody ul li a.pdf,
	.articleBody ul li a.word,
	.articleBody ul li a.excel{
		background-size: 13px;
		padding-right: 20px;
	}
	.articleBody ul li img.icon{
		height: 15px;
	}

	.articleInfoBox2c{
		grid-template-columns: 1fr;
		row-gap: 2px;
	}
	.articleBody .informationBox h2,
	.articleBody .eventBox h2{
		font-size: 1.8rem;
	}
	.articleBody .informationBox h2 span,
	.articleBody .eventBox h2 span{
		display: inline-block;
		padding: 3px 20px;
		background-color: #FFFFFF;
		position: absolute;
		right: 0;
		font-size: 1.2rem;
		font-weight: normal;
		top: 2px;
	}
	.articleBody .informationBox h2 {
		background-size: 20px;
		padding-left: 30px;
	}
	.articleBody .eventBox h2 {
		background-size: 20px;
		padding-left: 30px;
	}
	.articleBody .topLinkBox h2 {
		font-size: 1.3rem;
		font-weight: bold;
		padding-left: 22px;
		position: relative;
		margin-bottom: 9px;
	}
	.articleBody .topLinkBox h2::before {
		width: 15px;
		height: 2px;
		top: 10px;
		left: 0;
	}

	/* pc 2-3 column imgs */
	.articleBody .gallery2c{
		margin-left: 2%;
		margin-right: 2%;
	}
	.articleBody .gallery2c{
		display: grid;
		grid-template-columns: 100%;
		row-gap: 20px;
	}
	.articleBody .gallery2c .imgBox{
		font-size: 1.2rem;
	}
	.articleBody .gallery3c{
		margin-left: 2%;
		margin-right: 2%;
	}
	.articleBody .gallery3c{
		display: grid;
		grid-template-columns: 100%;
		row-gap: 20px;
	}
	.articleBody .gallery3c .imgBox{
		font-size: 1.2rem;
	}
	.contactBox {
		width: 96%;
	}
	.requiredImg {
		position: relative;
		width: 95%;
		top: -20px;
		bottom: auto;
		margin-bottom: 0;
		right: 0;
		margin-left: auto;
		margin-right: auto;
	}
	.missionBox section p {
		font-size: 13px;
	}

	.siteMapLinkListWrapper {
		grid-template-columns: 1fr;
	}
	.recruitInfomation2c {
		display: grid;
		grid-template-columns: 1fr;
		text-align: center;
		margin-top: 40px;
		row-gap: 30px;
	}

	.recruitInfomation2c .recruitInfomationBtn:last-child{
		border-left: none;
	}
	.recruitInfomation2c a {
		font-size: 14px;
	}
	.recruitEntryBox .recruitEntryBtn a {
		font-size: 14px;
	}
	.categoryFooterLinks ul {

		grid-template-columns: 1fr ;
	}
	.categoryFooterLinks ul li a {
		color: #333;
		padding: 15px 15px 15px 44px;
		background-color: #FFF;
		display: block;
		background-image: url(../images/ico_arrow_circle_blue.svg);
		background-repeat: no-repeat;
		background-position: left 15px center;
		background-size: 15px;
		font-size: 1.4rem;
	}

	.articleBody.message article{
		padding: 0;
		width: auto;
	}
	.recrutDetailNanameBody .articleBody h2{
		font-size: 1.8rem;
	}
	.recruitEntryWrapper .centerH2{
		text-align: center;
		font-size: 18px;
		margin-bottom: 30px;
	}
	.recruitEntryBox p.lead {
		font-size: 13px;
	}
	.fixedListR {
		top: 74px;
	}
	.brandBox ul{
		grid-template-columns: 1fr;
		row-gap: 30px;
	}


	.breadcrumb {
		padding-bottom: 45px;
	}
	.breadcrumb ul li{
		background-position: left 11px center;
		margin-right: 0;
		background-repeat: no-repeat;
		font-size: 1.3rem;
		background-color: #fff;
		padding: 10px 10px 10px 40px;
		background-size: 8px;
		font-size: 1rem;
	}

	/* company */
	.bottomVisualArea h1 span {
		padding-bottom: 3px;
	}
	.bottomVisualArea{
		min-height: auto;
		margin-top: 55px;
	}
	.bottomVisualArea h1 {
		font-size: 1.36rem;
		margin-top: 0;
	}
	.bottomVisualArea h1 em {
		font-size: 1.1rem;
		margin-top: 5px;
	}
	.bottomTopContents .hikkiTitle {
		position: absolute;
		top: -72px;
		right: 0;
		width: 38%;
	}
	.bottomTopContents .obiTitle h2 {
		font-size: 3rem;
		margin-top: -21px;
		margin-left: 5%;
		line-height: 1.3;
	}
	.topImg {
		float: none;
		width: 100%;
		margin-right: 0;
		margin-top: 0;
	}
	.topMessageDetailBox {
		background-color: #FFF;
		padding: 6%;
		position: relative;
		z-index: 2;
		margin-top: 60px;
		margin-bottom: 5px;
		width: 100%;
	}
	.topMessageText {
		margin-right: 0;
		padding-top: 30px;
	}
	.topMessageText h2 {
		font-size: 1.8rem;
		margin-bottom: 20px;
	}
	.topMessageText p {
		margin-bottom: 20px;
	}
	.signature .companyName {
		text-align: right;
		margin-bottom: 15px;
		font-size: 1.3rem;
	}
	.signature .position {
		display: inline-block;
		font-size: 1.4rem;
		margin-right: 10px;
	}
	.signature .signatureImg {
		display: inline-block;
		width: 140px;
		margin-bottom: 0px;
		vertical-align: sub;
	}
	.companyFooterLinks h2 {
		font-size: 2rem;
		margin-bottom: 30px;
	}
	.Links3c ul {
		display: grid;
		grid-template-columns: 1fr;
	}
	.Links3c .rightLink2c h2 {
		font-size: 1.3rem;
	}
	.Links3c .rightLink2c .viewDetailsBtn a {
		font-size: 1.3rem;
		padding-right: 14px;
	}
	.articleBody h1 {
		font-size: 2rem;
	}

	.articleBody dl dd {
		margin-left: 65px;
		border-left: 3px #dcdcdc solid;
		padding-left: 15px;
	}
	.articleBody dl dt {
		float: left;
		min-width: 50px;
		margin-right: 20px;
	}
	.articleBody dl {
		font-size: 1.2rem;
	}

	.topMassage2c {
		display: grid;
		grid-template-columns: 1fr;
		column-gap: 0;
		margin-bottom: 5px;
		row-gap: 30px;
	}
	.companyTopBox h2 {
		font-size: 2rem;
		margin-bottom: 20px;
	}
	.companyTopBox h3 {
		font-size: 1.6rem;
		margin-bottom: 10px;
	}
	.Links2c ul {
		display: grid;
		grid-template-columns: 1fr;
		column-gap: 5px;
		row-gap: 5px;
	}
	.rightLink2c .viewDetailsBtn a {
		font-size: 1.3rem;
		letter-spacing: 1px;
	}
	.viewDetailsBtn a::after {
		width: 100%;
		height: 2px;
		background-color: #000;
		position: absolute;
		bottom: -3px;
		content: '';
		left: 0;
	}
	.rightLink2c h2 {
		font-size: 1.6rem;
		margin-bottom: 10px;
		position: relative;
	}
	.rightLink2c h2::after {
		width: 8px;
		height: 8px;
		background-color: #E60012;
		border-radius: 100px;
		position: absolute;
		margin-left: 20px;
		margin-top: 9px;
		content: '';
	}
	.rightLink2c p{
		font-size: 1.2rem;
	}
	.bottomGray {
		background-color: #f9f9f9;
		padding-bottom: 60px;
	}
	table td table th{
		width: auto;
	}
	table{
		margin-left: 0;
		margin-right: 0;
	}
	table td {
		border: solid 1px #dcdcdc;
		padding: 10px;
		word-break: break-all;
	}



	/* interview */
	
	.interviewStaffList ul {
		z-index: 1;
		position: relative;
		display: grid;
		grid-template-columns: 1fr;
		column-gap: 4%;
		row-gap: 50px;
	}


	.inteviewImg {
		box-sizing: border-box;
		padding-left: 4%;
		padding-right: 4%;
		width: 100%;
	}

	.interviewDetailStaffInfo {
		position: relative;
		left: auto;
		bottom: auto;
		z-index: 2;
		text-align: left;
		max-width: 100%;
		background-color: rgba(230,0,18,0.9);
	}
	.visualArea.interviewDetail .slide {
		position: relative;
		transition: none;
		left: auto;
		top: auto;
		width: 100%;
		height: auto;
		min-width: 100vw;
		min-height: auto;
		transform: none;
		bottom: auto;
	}
	.visualArea.interviewDetail {
		height: auto;
		margin-top: 52px;
	}
	.interviewIntroBox {
		padding-top: 40px;
	}
	.interviewDetailStaffInfo h1 {
		padding: 4%;
		border-bottom: 1px solid #fff;
		font-size: 16px;
		color: #fff;
	}
	.interviewDetailStaffInfo .staffInfo {
		padding: 5%;
		display: grid;
		grid-template-columns: 1fr;
	}
	.interviewDetailStaffInfo .name {
		display: inline-block;
		font-size: 26px;
		font-weight: bold;
		color: #fff;
		margin-bottom: 10px;
	}
	.interviewDetailStaffInfo .division {
		display: flex;
		font-size: 11px;
		font-weight: normal;
		background-color: #fff;
		padding: 5px;
		color: #E60012;
		align-items: center;
		justify-content: center;
	}
	.interviewTopBox {
		background-color: #FFF;
		display: grid;
		grid-template-columns: 1fr;
	}
	.interviewIntroText .division {
		float: none;
		font-size: 1.4rem;
		padding-top: 0;
	}
	.interviewIntroText {
		padding: 6%;
	}
	.interviewQAbox {
		padding: 6%
	}
	.interviewTopBox h2 {
		font-size: 2.6rem;
		margin-bottom: 10px;
	}
	.interviewIntroText p {
		line-height: 2;
		font-size: 1.4rem;
	}
	.interviewQAbox h3 {
		font-size: 1.8rem;
		font-weight: bold;
		margin-bottom: 10px;
	}
	.interviewQAbox h3 span.num {
		font-size: 2.5rem;
		margin-right: 10px;
		float: left;
		margin-bottom: 10px;
	}
	.interviewObi .wipe_left_to_right {
		height: 190px;
		position: absolute;
	}
	.wipe_left_to_right.active {
		width: 90%;
	}
	.interviewQAbox p {
		line-height: 2;
		font-size: 1.4rem;
		clear: both;
	}
	.inteviewImg {
		padding-top: 40px;
	}
	.inteviewImg .imgBox {
		max-width: 100%;
	}
	section.interviewSection {
		position: relative;
		padding-bottom: 50px;
	}

	.linkToThePeaople h2 {
		text-align: center;
		margin-bottom: 20px;
		font-size: 2rem;
	}
	.linkToThePeaople em {
		display: block;
		margin-top: 10px;
		font-weight: normal;
		font-size: 1.1rem;
		font-weight: 400;
		text-align: center;
		margin-bottom: 30px;
	}
	.linkToThePeaople h2::before, .linkToThePeaople h2::after {
		content: '';
		width: 8px;
		height: 8px;
		border-radius: 100px;
		background-color: #E60012;
		position: absolute;
		top: 14px;
	}
	.linkToThePeaople {
		padding-top: 40px;
	}
	.linkToThePeaople p.lead {
		margin-bottom: 30px;
	}
	.otherInterview{
		position: absolute;
		right: 4%;
		top: -90px;
		width: 160px;
	}


	/* business */
	.businessHikkiTitle {
		top: -55px;
		width: 45%;
	}
	.businessBottomContentsBox.imgRexsist {
		margin-right: 0;
	}

	.businessBottomSection .businessBottomContentsBox h3 {
		font-size: 1.5rem;
		margin-bottom: 15px;
	}
	.businessIntroImgR {
		position: relative;
		top: auto;
		right: auto;
		margin-right: 0;
		max-width: 100%;
	}
	.businessBottomContentsBox.imgRexsist {
		margin-bottom: 30px;
	}
	.businessBottomContentsBox h5 {
		font-weight: bold;
		font-size: 1.5rem;
		position: relative;
		padding-left: 15px;
		margin-bottom: 3px;
	}
	.businessBottomContentsBox h5::before{
		top: 9px;
	}
	
	.businessBottomSection.spShortMrg{
		margin-bottom: 50px;
	}
	.businessBottomSection h3 {
		font-size: 1.5rem;
		margin-bottom: 30px;
	}
	.businessPoint3c ul {
		display: grid;
		grid-template-columns: 1fr;
		column-gap: 4%;
	}
	.businessBottomSection h4 {
		font-size: 1.5rem;
	}
	.businessBottomSection {
		margin-bottom: 130px;
		position: relative;
	}
	.bottomTopContents .businessBottomSection .obiTitle {
		top: -65px;
	}
	.businessBottomSection .obiTitle h3{
		font-size: 2rem;
	}
	.businessPoint2c {
		padding-top: 30px;
		z-index: 2;
		position: relative;
	}
	.businessObiBottom .wipe_left_to_right {
		bottom: -20px;
	}
	.otherBusiness {
		position: absolute;
		right: 4%;
		top: -100px;
		width: 44%;
	}
	.otherBusinssUnit h2 {
		text-align: center;
		margin-bottom: 40px;
		font-size: 1.6rem;
	}
	.otherBusinssUnit h2::before, .otherBusinssUnit h2::after {
		margin-left: -25px;
		top: 9px;
	}
	.otherBusinssUnit h2::after {
		margin-left: 15px;
	}
	.otherBusinssUnit .topBussinessUnit ul {
		display: grid;
		grid-template-columns: 1fr;
		row-gap: 30px;
	}
	.backToTop a {
		font-size: 1.6rem;
	}
	.businessPoint2c ul {
		grid-template-columns: 1fr;
		row-gap: 20px;
	}
	.otherBusinssUnit {
		padding-top: 50px;
		padding-bottom: 30px;
		background-color: #FFF;
	}





	/* bussiness top*/
	.bottomVisualArea.businessTop h2 {
		margin-bottom: 30px;
		font-size: 2.2rem;
	}
	.businessTopHead h2 {
		text-align: center;
		margin-bottom: 0;
		font-size: 1.8rem;
	}

	.businessTopHead h2::before, .businessTopHead h2::after{
		top: 10px;
	}

	.businessTopContents {
		padding-bottom: 20px;
		padding-top: 60px;
	}
	.businessSectionL .imgBox {
		margin-left: 4%;
		z-index: 2;
		position: relative;
	}
	section.businessTopSection {
		margin-bottom: 120px;
		display: grid;
		grid-template-columns: 1fr;
		column-gap: 4%;
	}
	.businessSectionR .textBox {
		margin-right: 0;
		padding-left: 4%;
		padding-right: 4%;
	}
	.businessSectionL .textBox {
		margin-left: 0;
		padding-left: 4%;
		padding-right: 4%;
	}
	.businessTopTextBox{
		padding-left: 0;
		padding-right: 0;
	}
	.businessTopTextBox h3 {
		font-size: 2.2rem;
		margin-bottom: 15px;
	}
	.businessTopTextBox h4 {
		font-size: 1.6rem;
		margin-bottom: 20px;
	}
	.businessTopTextBox p {
		margin-bottom: 20px;
		line-height: 2;
	}
	.departmentsList ul li h3 {
		margin-bottom: 10px;
		font-size: 1.46rem;
	}
	.departmentsList ul {
		display: grid;
		grid-template-columns: 1fr;
		column-gap: 10px;
		row-gap: 10px;
	}
	.otherDepartmentsBox .imgBox {
		margin-bottom: 20px;
	}
	.bottomVisualArea .bottomMainVisualImgBox {
		max-width: 47%;
	}


	/* groupIdentity */
	.groupIdentityBox h3 {
		text-align: center;
		font-size: 1.8rem;
		margin-bottom: 20px;
		padding-left: 6%;
		padding-right: 6%;
	}
	.groupIdentityBox p.lead {
		font-size: 1.4rem;
		margin-bottom: 20px;
		padding-left: 6%;
		padding-right: 6%;
	}
	section.groupIdentitySection p {
		font-size: 1.3rem;
		margin-bottom: 20px;
	}
	.groupIdentityBox h4 {
		font-size: 1.6rem;
		text-align: center;
		padding-bottom: 15px;
		position: relative;
		margin-bottom: 15px;
	}
	section.groupIdentitySection p.redCopy {
		font-size: 2rem;
	}
	section.groupIdentitySection p {
		font-size: 1.3rem;
	}
	section.groupIdentitySection p strong{
		font-size: 1.5rem;
	}
	.groupLinkBox ul {
		display: grid;
		grid-template-columns: 1fr;
	}
	.groupIdentityBox {
		background-color: #f9f9f9;
		padding: 6% 0;
	}
	.groupLinkBox ul li .name span {
		font-size: 1.1rem;
	}
	.groupLinkBox ul li a.blank {
		background-size: 10px;
	}
	.groupLinkBox ul li .name {
		font-size: 1.6rem;
	}
	.recruitBtn2c ul {
		display: grid;
		grid-template-columns: 1fr;
		column-gap: 6%;
		row-gap: 10px;
	}
	.articleBody .recruitBtn2c ul li {
		margin-bottom: 8px;
		position: relative;
		padding-left: 0;
	}
	.articleBody .leadTxt p {
		font-weight: bold;
		font-size: 1.6rem;
		text-align: center;
		background-color: #f9f9f9;
		padding: 4%;
		margin-left: 0;
		margin-right: 0;
	}
	.articleBody h1::before{
		top: 10px;
	}
	.articleBody h1 {
		padding-left: 25px;
	}

	.groupCompaniesList ul {
		display: grid;
		grid-template-columns: 1fr;
		column-gap: 8%;
		background-color: #f9f9f9;
		padding: 8%;
		row-gap: 25px;
	}
	.businessIntroImgR.h3exist {
		top: 0;
	}
	.articleBody .contactBox .leadTxt p {
		font-size: 1.6rem;
	}

	.companyDetailBox .pickupList{
		margin-bottom: 40px;
		display: grid;
		grid-template-columns: 1fr;
		column-gap: 4%;
		row-gap: 30px;
	}



	h2.yearSelect {
		background-position: left center;
		font-size: 2rem;
		padding-left: 25px;
	}


	h2.yearSelect::before{
		content: '';
		width: 15px;
		height: 15px;
		background-color: #E60012;
		border-radius: 100px;
		top: 10px;
		left: 0;
		position: absolute;
	}
	.newsYearListBox ul {
		display: grid;
		grid-template-columns: 1fr 1fr;
		column-gap: 3px;
		row-gap: 3px;
	}
	.newsYearListBox ul li a {
		display: block;
		background-color: #f9f9f9;
		font-size: 1.3rem;
		font-weight: normal;
		text-align: center;
		padding: 8px;
	}

	.topBusinessIntegration2c .inner {
		display: grid;
		grid-template-columns: 1fr;
		column-gap: 4%;
		row-gap: 40px;
	}

	.topBusinessIntegrationUnit h3 {
		margin-top: 10px;
		margin-bottom: 10px;
		font-size: 2.2rem;
		color: #000;
	}
	.topBusinessIntegration2c h2 {
		text-align: center;
		font-size: 4rem;
	}


}


@media screen and (max-width: 430px) {
	
}