@charset "UTF-8";

body {
width:100%;
 min-height: 100%;
 position: relative;/*←相対位置*/
 box-sizing: border-box;/*←全て含めてmin-height:100vhに*/
 margin:0;
 font-size:16px;
 font-family: 'Noto Sans JP',Meiryo,"Hiragino Kaku Gothic ProN", sans-serif;
 line-height:2;
	
	background-color: #F6FAFC;
}

body.info_g {
	background-image: linear-gradient(90deg, #528AD5 0%, #528AD5 25%, #D4ECF3 100%),linear-gradient(90deg, #FBFBFB 0%, #FBFBFB 100%); 
    background-size: 100% 480px,cover;
    background-position: top,top;
    background-repeat: no-repeat,no-repeat;
}

body.info_c {
	background-image: linear-gradient(90deg, #528AD5 0%, #528AD5 15%, #5FD192 100%),linear-gradient(90deg, #FBFBFB 0%, #FBFBFB 100%); 
    background-size: 100% 480px,cover;
    background-position: top,top;
    background-repeat: no-repeat,no-repeat;
}

body.info_o {
	background-image: linear-gradient(90deg, #F6FAFC 0%, #F6FAFC 15%, #D4ECF3 100%),linear-gradient(90deg, #FBFBFB 0%, #FBFBFB 100%); 
    background-size: 100% 480px,cover;
    background-position: top,top;
    background-repeat: no-repeat,no-repeat;
}

body.interview_head_bg {
	background-image: linear-gradient(90deg, #528AD5 0%, #528AD5 25%, #D4ECF3 100%),linear-gradient(90deg, #FBFBFB 0%, #FBFBFB 100%);
    background-size: 100% 400px,cover;
    background-position: top,top;
    background-repeat: no-repeat,no-repeat;
}

a {
 color:#1b1a18;
 text-decoration:none;
}


a:hover {
 opacity: 0.8;/*要素の透明度を指定*/
 filter: alpha(opacity=80); /*ie6、7の透明度指定*/
}.contact_wrap

a:hover img {
 opacity: 0.9;/*要素の透明度を指定*/
 filter: alpha(opacity=90); /*ie6、7の透明度指定*/
}

.bold{font-weight:bold;}

.clearfix:after {
  content: ".";
  display: block;
  height: 0;
  clear: both;
  visibility: hidden;
}
.clearfix { display: inline-table; }
.title_pconly{display: inherit;}
.title_sponly{display: none;}

.pconly{display: inherit;}
.sponly{display: none;}

/* Hides from IE-mac \*/
* html .clearfix { height: 1%; }
.clearfix { display: block; }
/* End hide from IE-mac */

div#header_nav {
	width:100%;
	height:80px;
	position:fixed;
	background:#fcfcfc;
	z-index: 999;
	box-shadow: 4px 8px 32px rgba(0,0,0,0.08);
}

.nav_wrap {
	width: 1120px;
    height: 100%;
    margin: 0 auto;
    padding: 0;
    display: flex;
    justify-content: space-between;
    flex-wrap: wrap;
    align-items: center;
	box-sizing: border-box;
}

.flex {
	display: flex;
    justify-content: space-between;
    flex-wrap: wrap;
    align-items: center;
}

.flex_mirror {
	display: flex;
    justify-content: space-between;
    flex-wrap: wrap;
    align-items: center;
}

.daiji {
	width: 32%;
	margin:auto 0;
	padding:0;
	display: block;
}

.daiji a {
	margin: 0;
	padding: 0;
	display: block;
	line-height: 64px;
}

.daiji a img {
	width:100%;
	height: auto;
	margin: 0;
	padding: 0;
	display: block;
}

.daiji a img#line_top {
	width:35px;
	height: auto;
}

.slicknav_menu {
	display:none;
}

div#header_nav ul {
	width: 64%;
	height: 80px;
	margin: 0;
    padding: 0 0 0 20px;
    display: block;
    display: flex;
	justify-content: space-between;
}

div#header_nav ul li {
	width: auto;
	padding: 0 20px;
	/*width: 16.666%;*/
	list-style:none;
	display: flex;
}

div#header_nav ul li a {
	margin: auto;
    padding: 0;
    text-align: center;
    display: block;
	color:#212121;
	/*border-right:1px dotted #efefef;*/
	
	font-size: 14px;
}

div#header_nav ul li.entry{
  display: none;
}

div#header_nav ul li.entry_img {
	width: 10%;
	/*color: #fff;*/
    background: linear-gradient(120deg, #528AD5 0%, #528AD5 24%, #5FD192 100%);
    border-right: 0 !important;
}

div#header_nav ul li.entry_img a{
	color: #fff;
	/*color: #0E4098;*/
	text-align: center;
}

#header_nav .daiji .title_pconly{
	display: flex;
	align-items: center;
	width: 100%;
	box-sizing: border-box;
	margin: 1em 0 0;
	padding: 0;
}
#header_nav .daiji .title_pconly img{
	position: relative;
	top: inherit;
	left: inherit;
	display: block;
	width: 42%;
	transform: none;
}
#header_nav .daiji .title_pconly span{
	font-size: 1em;
	font-weight: bold;
	color: #0d4199;
	line-height: 1em;
	display: inline-block;
	margin: 0 0 0 0.25em;
}
@media screen and (min-width: 1000px){
	#header_nav .daiji .title_pconly{
		width: 368px;
		margin: 0;
	}
	#header_nav .daiji .title_pconly span{
		font-size: 1.3em;
		line-height: 1.5em;
	}
}


#startentry{
	
	padding: 14px 28px;
    border-radius: 28px;
    
    box-shadow: 4px 4px 24px rgb(0 0 0 / 8%);
    background-color: #fff;
    color: #0E4098;
    font-size: 12px;
    text-indent: 0;
    text-align: center;
    font-weight: bold;
    line-height: 1;
    
	position: fixed;
    bottom: 70px;
    right: 160px;
	
	z-index: 99;
}

.footer_pankuzu {
	padding: 24px 0 132px;
	background-color: #fff;
}

.footer_pankuzu .pankuzu2 ul{
	margin: 0;
	padding: 0;
}

.footer_pankuzu .pankuzu2 ul li{
	color: #212121;
}

.footer_pankuzu .pankuzu2 a{
	color: #212121;
}

.pankuzu {
  margin:0;
  padding:0;
}
.pankuzu  ul li {
  margin:0;
  display: inline;
  font-size: 12px;
}
.pankuzu  ul li:after {
  content: ">";
  margin-left: 8px;
	color: #0E4098;
}
.pankuzu  ul li:last-child:after {
  content: none;
  margin-right: 0;
}

.pankuzu2 {
  margin:0;
  padding:0;
  z-index:10;
}
.pankuzu2  ul li {
  color:#333;
  margin:0;
  display: inline;
  font-size: 12px;
}
.pankuzu2  ul li a {
  color:#333;
}
.pankuzu2  ul li:after {
  content: ">";
  margin-left: 8px;
	color: #0E4098;
}
.pankuzu2  ul li:last-child:after {
  content: none;
  margin-right: 0;
}

.bg {
	margin: 0;
	padding: 112px 0 64px;
	background-color: #f6fafc;
}

.bg_common {
	margin: 0;
	padding: 0 0 104px;
	background-color: #f6fafc;
}

.center {
	text-align: center!important;
}

.line_through {
	text-decoration: line-through;
}

.container {
	width: 1120px;
	height: auto;
	margin: 0 auto;
	padding: 0;
}

.bg_cover {
	background-color:#fff;
}

.inner.small{
	width: 640px;
	height: auto;
	margin: 0 auto;
	padding: 0;
}

.inner.middle{
	width: 800px;
	height: auto;
	margin: 0 auto;
	padding: 0;
}

.inner.large{
	width: 1120px;
	height: auto;
	margin: 0 auto;
	padding: 0;
}

.inner.intern{
	width: 800px;
	height: auto;
	margin: 0 auto;
	padding: 64px 0 0;
	
	background-color: #fff;
}

.inner .intern p{
	text-align: center;
}

.inner_movie {
	width: 1120px;
	height: auto;
	margin: 0 auto;
	padding: 40px 0 0;
	
	/*background-color: #fff;*/
}

.inner section {
	margin: 0 0 80px;
	padding: 0;
}

.inner section:last-child {
	margin: 0 0 0;
	padding: 0;
}

.inner section.report:last-child {
	margin: 24px 0 0;
}

.inner section.report:last-child ul.review{
	margin: 0 0 0;
}

.inner section.flow_container {
	margin: 0 0 80px;
}

.inner a{
	color: #0E4098;
	text-decoration: underline;
}

.inner h2{
	margin: 0;
	padding: 0;
	
	font-size: 1.24em;
	line-height: 1;
	letter-spacing: 0.15em;
	color: #0E4098;
}

.inner p {
	margin: 0;
	padding: 0;
	
	color: #333;
	font-size: 1em;
	line-height: 2.0;
	text-align: justify;
}

.inner p.attention {
	margin: 0 0 24px;
	color: #cc0000;
}

.inner ul {
	margin: 0 auto 24px;
	padding: 0;
}

.inner li {
	margin: 0 0 0 2em;
	padding: 0;
	color: #333;
	font-size: 1rem;
	line-height: 2;
	font-weight: bold;
}

.inner table {
	margin: 0;
	padding: 0;
	
	display: block;
	font-size: 0.88rem;
	color: #333;
}

.inner tr {
	margin: 0;
	padding: 12px 0;
	border-bottom: #000;
}

.inner th {
	margin: 0;
	padding: 12px 20px 12px 0;
	
	font-weight: bold;
	color: #0E4098;
}

.inner td {
	margin: 0;
	padding: 0 0 0 20px;
}

p.release {
	margin: 16px 0 32px;
	text-align: right;
}

/*bg*/

#slider {
    width: 100%;
    height: 100vh;/*スライダー全体の縦幅を画面の高さいっぱい（100vh）にする*/
}

.wrapper{
  position: relative;
}

.wrapper #slider img.top_logo {
	
	width: 960px;
	height:auto;
	margin: 29px 0 0;
	
	position: absolute;
	top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    -webkit-transform: translate(-50%, -50%);
    -ms-transform: translate(-50%, -50%);
}

/*scroll*/

.scrolldown1{
	height:50px;
	
	position:absolute;
	left:50%;
	bottom:3em;
}

.scrolldown1 span{
	color: #0E4098;
	font-size: 0.88rem;
	letter-spacing: 0.05em;
	
	position: absolute;
	left:-16px;
	top: -16px;
}

.scrolldown1::after{
	width: 1px;
	height: 32px;
	background: #0E4098;
	
	content: "";
	position: absolute;
	top: 0;
	
	animation: pathmove 1.4s ease-in-out infinite;
	opacity:0;
}

.top_logo {
	width: 598px;
	height: auto;
	margin: 0;
	padding: 0;
	
	display: block;
	
	position: absolute;
	top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    -webkit-transform: translate(-50%, -50%);
    -ms-transform: translate(-50%, -50%);
	
	filter: drop-shadow(1rem 1rem 1.6rem rgb(0,0,0,0.12));
}
.top_logo p{
	font-size: 4vw;
	font-weight: bold;
	text-align: center;
	line-height: 1em;
	display: block;
	width: fit-content;
	background: #ffffff;
	box-sizing: border-box;
	margin: 0.5em 0 0;
	padding: 0.75em 1.25em;
}
@media screen and (min-width: 1000px){
	.top_logo p{
		font-size: 1.5em;
	}
}

@keyframes pathmove{
	0%{
		height:0;
		top:0;
		opacity: 0;
	}
	30%{
		height:32px;
		opacity: 1;
	}
	100%{
		height:0;
		top:50px;
		opacity: 0;
	}
}

main > section {
	width: 100%;
	height: 80vh;
	max-height: 640px;
	position: relative;
	overflow: hidden;
}

.bgImg {
	position   : absolute;
  top        : 64px;
  left       : 0;
  bottom     : 0;
  right      : 0;
  opacity    : 0;
  animation  : bgAnime 20s infinite;
	overflow: hidden;
}
	
	#bg-01 {
		width: 100%;
		height: 80vh;
		max-height: 640px;
		background-image: url("../images/bg-01-pc.jpg");
		background-position: center top;
		background-repeat: no-repeat;
		background-size: cover;
	}
	
	#bg-02 {
		width: 100%;
		height: 80vh;
		max-height: 640px;
		background-image: url("../images/bg-02-pc.jpg");
		background-position: center top;
		background-repeat: no-repeat;
		background-size: cover;
		animation-delay  : 5s;
	}
	
	#bg-03 {
		width: 100%;
		height: 80vh;
		max-height: 640px;
		background-image: url("../images/bg-03-pc.jpg");
		background-position: center top;
		background-repeat: no-repeat;
		background-size: cover;
		animation-delay  : 10s;
	}
	
	#bg-04 {
		width: 100%;
		height: 80vh;
		max-height: 640px;
		background-image: url("../images/bg-04-pc.jpg");
		background-position: center top;
		background-repeat: no-repeat;
		background-size: cover;
		animation-delay  : 15s;
	}

@keyframes bgAnime {
   0% { opacity: 0; }
   7% { opacity: 1; }
  25% { opacity: 1; }
  32% { opacity: 0; }
 100% { opacity: 0; }
}


/*bg*/

div.top_main_contents {
	width:100%;
	padding: 0 0 107px;
}

div.main_bg{
	padding-top: 0;
	background-color: #ECF6F9;
}

.section-conts {
	margin: 0 auto 48px;
	padding: 0;
	display: block;
}

.bg-white {
	width: 100%;
    height: auto;
	margin: 0;
    padding: 0;
    display: block;
}

.bg-white h2{
    margin: 0 auto;
    padding: 0;
	
	text-align: center;
	font-size: 2.8em;
    line-height: 1.25;
    letter-spacing: 0.1em;
	text-indent: 0.75em;
	color: #0E4098;
}

.bg-white p{
	margin:24px auto 0;
	padding: 0;
	
	text-align: center;
	font-size: 1.6em;
	line-height: 1;
	letter-spacing: 2px;
	font-weight: bold;
}

.fadein {
    opacity : 0.1;
    transform : translate(0, 50px);
    transition : all 1s;
    }

.fadein2 {
    opacity : 0.1;
    transform : translate(0, 50px);
    transition : all 1.5s;
    }

.fadein3 {
    opacity : 0.1;
    transform : translate(0, 50px);
    transition : all 2s;
    }

.fadein4 {
    opacity : 0.1;
    transform : translate(0, 50px);
    transition : all 2.5s;
    }

.fadein5 {
    opacity : 0.1;
    transform : translate(0, 50px);
    transition : all 3s;
    }

.scrollin {
    opacity : 1;
    transform : translate(0, 0);
    }

div.read_1915{
	width: 100%;
	height: auto;
	margin: 0 auto;
	padding:160px 0 120px;
	
	background-image: url("../images/since_1915.png"), linear-gradient( to right, rgba(0,0,0,0.4), rgba(0,0,0,0.4) ),url("../images/bg_1915.jpg");
	background-size: 560px auto, cover, cover;
	background-repeat: no-repeat;
	background-position: top right, center, center;
}

div.read_1915 .container_1915 {
	width: 1120px;
	min-height: 640px;
	margin: 0 auto;
	padding: 0;
	
	display: flex;
    justify-content: space-between;
    flex-wrap: wrap;
}

div.read_1915 .text_1915{
	width: 37.5%;
	height: auto;
	margin: 10% 0 0;
	padding: 0;
	
	display: block;
}

div.read_1915 .image_1915 {
	width: 56%;
	height: auto;
	margin: 0;
	padding: 0;
	
	display: block;
	position: relative;
}

div.read_1915 .image_1915 img{
	width: 100%;
	height: auto;
	margin: 0;
	padding: 0;
	
	display: block;
	
	-webkit-filter: drop-shadow(2px 2px 8px rgba(0,0,0,.25));
    filter: drop-shadow(2px 2px 8px rgba(0,0,0,.25));
}

div.read_1915 .image_1915 img.layer{
	position: absolute;
}

div.read_1915 h1{
	margin: 0 0 24px;
	padding: 0;
	
	color: #fff;
	font-size: 2.8em;
	line-height: 1.4;
	letter-spacing: 0.035em;
}

div.read_1915 p{
	margin: 0;
	padding: 0;
	
	color: #fff;
	font-size: 1.2em;
	line-height: 2;
	letter-spacing: 0.035em;
	text-align: justify;
}

div.read_2021{
	width: 100%;
	height: auto;
	margin: 0 auto;
	padding:120px 0 160px;
	
	background-image: url("../images/2023.png"), linear-gradient( to right, rgba(0,63,152,0.72), rgba(0,63,152,0.72) ),url("../images/bg_2021.jpg");
	background-size: 560px auto, cover, cover;
	background-repeat: no-repeat;
	background-position: bottom left, center, center;
	position: relative;
}

div.read_2021 .container_2021 {
	width: 1120px;
	min-height: 640px;
	margin: 0 auto;
	padding: 0;
	
	display: flex;
    justify-content: space-between;
    flex-wrap: wrap;
}

div.read_2021 .text_2021{
	width: 37.5%;
	height: auto;
	margin: 10% 0 0;
	padding: 0;
}

div.read_2021 .image_2021{
	width: 56%;
	height: auto;	
	margin: 0;
	padding: 0;
	
	display: block;
	position: relative;
}

div.read_2021 .image_2021 img{
	width: 100%;
	height: auto;
	margin: 0;
	padding: 0;
	
	display: block;
	position: absolute;
	top: 0;
	left: 0;
	-webkit-filter: drop-shadow(2px 2px 8px rgba(0,0,0,.25));
    filter: drop-shadow(2px 2px 8px rgba(0,0,0,.25));
}

div.read_2021 h1{
	margin: 0 0 24px;
	padding: 0;
	
	color: #fff;
	font-size: 2.8em;
	line-height: 1.4;
	letter-spacing: 0.035em;
}

div.read_2021 p{
	margin: 0;
	padding: 0;
	
	color: #fff;
	font-size: 1.2em;
	line-height: 2;
	letter-spacing: 0.035em;
	text-align: justify;
}

.main_btn {
	width: 320px;
	height: 56px;
	margin: 0 auto;
	padding: 0;

	display: block;
	/*border:solid 1px #0E4098;*/
	background-color: #fff;
	
	color: #0E4098;
	font-size: 0.88em;
	font-weight: bold;
	text-align: center;
	line-height: 56px;
	letter-spacing: 0.5em;
	text-indent: 0.5em;
	
	box-shadow: 8px 8px 20px rgba(0,63,152,0.18);
}

.main_btn:hover,.main_btn:active {
	border:none;
	background-color: #fff;
	color: #0E4098;
	text-decoration: none;
	opacity: 1;
	transform: all 0.5s;
	box-shadow: 2px 2px 10px rgba(0,63,152,0.32);
}


/*----- top page -----*/

.top_mv {
	content: '　';
	
	width: 100%;
	height: 100vh;
	margin: 0;
	padding: 0;
	
	display: block;
	
	position: relative;
	
	background-image: url(../images/mv_pc.jpg);
	background-size: cover;
	background-position: center;
}

div.news {
	width: 100%;
    height: auto;
    margin: 0;
    padding: 0;
    background-color: #fafafa;
    box-shadow:none;
	
	position: absolute;
	bottom: 0;
}

div.news h3{
	margin:0;
	padding:0 0 16px;
	
	font-size: 1.5em;
	color: #0E4098;
	line-height: 1;
}

div.news .bg_grey {
	background-color:#eee;
}

.news dl {
	width:640px;
	height: 48px;
	margin:0 auto;
	padding: 0;
	
	font-size: 0.88em;
	letter-spacing: 0.05em;
	line-height: 1;
	
	display: flex;
	flex-wrap: wrap;
	justify-content: space-between;
}

.news dl dt {
	width: 120px;
	height: 48px;
	margin: 0;
	padding:0;
	
	display: flex;
	align-items: center;
}

.news dl dd {
	width: calc(100% - 120px);
	height: 48px;
	margin: 0;
	padding:0;
	
	display: flex;
	align-items: center;
}

.news dl dd a{
	color: #0E4098;
	font-weight: bold;
}


/*----- recruit message -----*/

.recruit_message {
	width: 100%;
    height: auto;
    margin: 0;
    padding: 80px 0;
	
    background: url(../images/top_bg_message.svg),url(../images/message_bg.png),linear-gradient(0deg, #fff 0%, #fff 100%);
    background-position: -4px 40px, right 0, center;
    background-repeat: no-repeat;
    background-size: auto 96px, auto 100%, cover;
}

.recruit_message_container {
	width: 1120px;
	height: auto;
	margin: 0 auto;
	padding: 0;
}

.recruit_message_text {
	width: 560px;
	height: auto;
	margin: 0 auto 32px;
	padding: 0;
	
	text-align: center;
}

.recruit_message_text h1 {
	margin: 0 0 16px;
	padding: 0;
	
	font-size: 1.6rem;
	line-height: 1.6;
	font-weight: bold;
	color: #0E4098;
}

.recruit_message_text p {
	margin: 0;
	padding: 0;
	
	font-size: 0.88rem;
	line-height: 2.4;
	font-weight: bold;
	color: #212121;
}

/*----- recruit message -----*/

/*----- business image -----*/

.business {
	width: 100%;
	height: auto;
	margin: 0;
	padding: 80px 0;
	
	background: url(../images/top_bg_business.svg),linear-gradient(0deg, #f6fafc 0%, #f6fafc 100%);
    background-position: right -4px top 40px, center;
    background-repeat: no-repeat;
    background-size: auto 96px, cover;
}

.business_container {
	width: 1120px;
	height: auto;
	margin: 0 auto;
	padding: 0;
}

.business_text {
	width: 100%;
	height: auto;
	margin: 0 auto 32px;
	padding: 0;
	
	text-align: center;
}

.business_text h1 {
	margin: 0 0 16px;
	padding: 0;
	
	font-size: 1.6rem;
	line-height: 1.6;
	font-weight: bold;
	color: #0E4098;
}

.business_text p {
	margin: 0;
	padding: 0;
	
	font-size: 0.88rem;
	line-height: 2.4;
	font-weight: bold;
	color: #212121;
}

.business_image {
	width: 100%;
	height: auto;
	margin: 0 auto 40px;
	padding: 0;
	
	display: flex;
	flex-wrap: wrap;
	justify-content: space-between;
}

.business_image a {
	margin: 0;
	padding: 0;
	
	display: block;
	
	filter: drop-shadow(6px 8px 16px rgb(14,64,152,0.12));
}

.business_image a figure{
	width: 198px;
	height: auto;
	margin: 0;
	padding: 0;
	
	display: flex;
	align-items: center;
	
	overflow: hidden;
	position: relative;
	
	text-align: center;
}

.business_image a img {
	width: 100%;
	height: auto;
	margin: 0;
	padding: 0;
	
	display: block;
	
	transition: .4s;
}

.business_image a figure::after {
	width: 100%;
	height: 100%;
	margin: 0 auto;
	padding: 0;

	display: flex;
	justify-content: center;
	
	background:rgba(0,0,0,.64);
	transition: .8s;
	
	position: absolute;
	top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    -webkit-transform: translate(-50%, -50%);
    -ms-transform: translate(-50%, -50%);
	
	opacity: 0;
	
	align-items: center;
	color: #fff;
	font-size: 1.2rem;
}

.business_image a figure.top_shimbun::after {
	content: '新聞';
}

.business_image a figure.top_digital::after {
	content: 'デジタルメディア';
}

.business_image a figure.top_event::after {
	content: 'イベント';
}

.business_image a figure.top_publish::after {
	content: '出版';
}

.business_image a figure.top_seminor::after {
	content: 'セミナー・教育';
}

.business_image a:hover figure::after {
  opacity: 1;
}

.business_image a:hover figure img {
    transform: scale(1.1);
}

.business_image a:hover {
  text-decoration: none;
}


/*----- business image -----*/

/*----- works -----*/

.works {
	width: 100%;
	height: auto;
	margin: 0;
	padding: 80px 0;
	
	background: url(../images/top_bg_works.svg),linear-gradient(0deg, #fff 0%, #fff 100%);
    background-position: -4px 40px, center;
    background-repeat: no-repeat;
    background-size: auto 96px, cover;
}

.works_container {
	width: 1120px;
	height: auto;
	margin: 0 auto;
	padding: 0;
}

.works_text {
	width: 100%;
	height: auto;
	margin: 0 auto 32px;
	padding: 0;
	
	text-align: center;
}

.works_text h1 {
	margin: 0 0 16px;
	padding: 0;
	
	font-size: 1.6rem;
	line-height: 1.6;
	font-weight: bold;
	color: #0E4098;
}

.works_text p {
	margin: 0;
	padding: 0;
	
	font-size: 0.88rem;
	line-height: 2.4;
	font-weight: bold;
	color: #212121;
}

.works_image_container {
	width: 100%;
	height: auto;
	margin: 0 auto 48px;
	padding: 0;
	
	display: flex;
	flex-wrap: wrap;
	justify-content: space-between;
}

.works_image_container a {
	width: 540px;
	height: auto;
	margin: 0;
	padding: 0;
	
	display: block;
}

.works_image_container a .works_thumbnail {
	width: 100%;
	height: auto;
	margin: 0 0 16px;
	padding: 0;
	
	display: block;
	
	position: relative;
}

.works_image_container a .works_thumbnail img {
	width: 100%;
	height: auto;
	margin: 0;
	padding: 0;
	
	display: block;
}

.works_image_container a .works_thumbnail .works_label {
	margin: 0;
	padding: 0;
	
	display: block;
	
	position: absolute;
	bottom: 0;
	left: 0;
}

.works_image_container a .works_thumbnail .works_label.editer {
	
}

.works_image_container a .works_thumbnail .works_label.marketer {
	
}

.works_image_container a .works_thumbnail .works_label .label_sub {
	width: 48px;
	height: auto;
	margin: 0 0 4px;
	padding: 8px 8px;
	
	display: block;
	
	line-height: 1;
	background-color: #0E4098;
	color: #fff;
	font-weight: bold;
	font-size: 0.72rem;
	text-align: center;
}

.works_image_container a .works_thumbnail .works_label .label_main {
	margin: 0;
	padding: 12px 12px;
	
	line-height: 1;
	background-color: #fff;
	color: #212121;
	font-weight: bold;
	font-size: 1.24rem;
}

.works_image_container a p{
	margin: 0;
	padding: 0;
	
	line-height: 1.6;
	font-size: 0.88rem;
	font-weight: bold;
	color: #212121;
	text-align: justify;
}

/*----- works -----*/

/*----- interview -----*/

.top_interview {
	width: 100%;
    height: auto;
    margin: 0;
    padding: 80px 0;
	
    background: url(../images/top_bg_interview.svg),linear-gradient(180deg, #ebf4f8 0%, #f6fafc 100%);
    background-position: right -4px top 40px, center;
    background-repeat: no-repeat;
    background-size: auto 96px, cover;
}

.top_interview_container {
	width: 1120px;
	height: auto;
	margin: 0 auto;
	padding: 0;
}

.top_interview_text {
	width: 100%;
	height: auto;
	margin: 0 auto 32px;
	padding: 0;
	
	text-align: center;
}

.top_interview_text h1 {
	margin: 0 0 16px;
	padding: 0;
	
	font-size: 1.6rem;
	line-height: 1.6;
	font-weight: bold;
	color: #0E4098;
}

.top_interview_text p {
	margin: 0;
	padding: 0;
	
	font-size: 0.88rem;
	line-height: 2.4;
	font-weight: bold;
	color: #212121;
}

.top_interview_image {
	width: 100%;
	height: auto;
	margin: 0 auto 40px;
	padding: 0;
	
	display: flex;
	flex-wrap: wrap;
	justify-content: space-between;
}

.top_interview_image a {
	width: 254px;
	height: auto;
	margin: 0;
	padding: 0;
	
	display: block;
}

.top_interview_image a .top_interview_thumbnail_photo{
	width: 100%;
	height: auto;
	margin: 0 0 12px;
	padding: 0;
	
	display: block;
	
	position: relative;
}

.top_interview_image a .top_interview_thumbnail_photo img {
	width: 100%;
	height: auto;
	margin: 0 0 12px;
	padding: 0;
	
	display: block;
}

.top_interview_image a .top_interview_thumbnail_photo .job{
	margin: 0;
	padding: 4px 8px;
	
	display: block;
    color: #fff;
    font-size: 0.72rem;
    line-height: 1;
    background: transparent linear-gradient(90deg, #4182CC 0%, #0E4098 100%);
	
	position: absolute;
	left: 0;
	bottom: 0;
}

.top_interview_image a h3 {
	margin: 0 0 8px;
	padding: 0;
	
	font-size: 1.04rem;
	line-height: 1.4;
	font-weight: bold;
	color: #212121;
}

.top_interview_image a p.shimei {
	margin: 0 0 8px;
	padding: 0;
	
	font-size: 0.88rem;
	line-height: 1;
	font-weight: bold;
	color: #0E4098;
}

.top_interview_image a p.affiliation {
	margin: 0 0 6px;
	padding: 0;
	
	font-size: 0.72rem;
	line-height: 1;
	color: #212121;
}

.top_interview_image a p.join {
	margin: 0 0 0;
	padding: 0;
	
	font-size: 0.72rem;
	line-height: 1;
	color: #212121;
}

/*----- interview -----*/

/*----- top page -----*/


.main_halfbox {
	width: 50%;
	height: 72vh;
	display: block;
}

.main_halfbox h1{
	margin: 0 0 32px;
    padding: 0;
	
	color: #0E4098;
	font-size: 3.2em;
	font-weight: bold;
    line-height: 1;
    letter-spacing: 0.08em;
}

.main_halfbox h2{
	margin: 0 0 24px;
    padding: 0;
	
	color: #0E4098;
    font-size: 1.5em;
    font-weight: bold;
    line-height: 1;
	letter-spacing: 0.08em;
}

.main_halfbox p{
	margin: 0 0 32px;
    padding: 0;
	
	color: #333;
	font-size: 1em;
	text-align: justify;
	line-height: 1.8;
}

.main_works {
	width: 100%;
	height: auto;
	margin: 0 auto;
	padding: 88px 0;
	
	background-color:#D4ECF3;
}

div.main_works .text {
	width: 420px;
	height: auto;
	margin: 0 96px 0 auto;
	padding: 0;
	
	display: block;
}

div.main_works .image {
	width: 50%;
	height: auto;
	margin: 0;
	padding: 0;
	
	display: block;
	box-shadow: 8px 8px 20px rgba(0,63,152,0.18);
}

div.main_works .image img{
	width: 100%;
	height: auto;
	margin: 0;
	padding: 0;
	
	display: block;
}

.main_topics {
	width: 100%;
	height: auto;
	margin: 0 auto;
	padding: 88px 0;
	
	background-color:#fafafa;
}

div.main_topics .text {
	width: 420px;
	height: auto;
	margin: 0 auto 0 96px;
	padding: 0;
	
	display: block;
}

div.main_topics .image {
	width: 50%;
	height: auto;
	margin: 0;
	padding: 0;
	
	display: block;
	box-shadow: 8px 8px 20px rgba(0,63,152,0.18);
}

div.main_topics .image img{
	width: 100%;
	height: auto;
	margin: 0;
	padding: 0;
	
	display: block;
}

/*modal*/

.remodal-wrapper {
	padding: 48px;
}

.remodal {
    width: 560px;
	height: auto;
    margin: 0 auto 48px;
	padding: 0;
	
	display: block;
    overflow:visible;
	
	-ms-overflow-style: none;
	scrollbar-width: none;
	
	position: relative;
  }

/* arrow */
.remodal a.next {
	width: 80px;
	height: 80px;
	
	display: block;
	
	content: '';
	background: url("../images/right-arrow.svg") no-repeat center;
	background-size: 32px;
	text-align: center;
	color: #fff;
	
	position: absolute;
	top: 50%;
	right: -80px;
	transform: translateY(-50%);
    -webkit-transform: translateY(-50%);
    -ms-transform: translateY(-50%);
}

.remodal a.prev {
	width: 80px;
	height: 80px;
	
	display: block;
	
	content: '';
	background: url("../images/left-arrow.svg") no-repeat center;
	background-size: 32px;
	text-align: center;
	color: #fff;
	
	position: absolute;
	top: 50%;
	left: -80px;
	transform: translateY(-50%);
    -webkit-transform: translateY(-50%);
    -ms-transform: translateY(-50%);
}

.remodal::-webkit-scrollbar{
  display:none;
}

.remodal-close {
	width: 80px;
	height: 32px;
	margin: 0;
	padding: 0;
	
	display: block;
	overflow: visible;
	
	position: absolute;
	bottom: -48px;
	left: 50%;
    transform: translateX(-50%);
    -webkit-transform: translateX(-50%);
    -ms-transform: translateX(-50%);

	cursor: pointer;
	-webkit-transition: color 0.2s;
	transition: color 0.2s;
	text-decoration: none;
	
	color: #95979c;
	border: 0;
	outline: 0;
	background: transparent;
}

.remodal-close:hover,
.remodal-close:focus {
  color: #2b2e38;
}

.remodal-close:before {
	content: "\00d7 close";
	width: 80px;

    display: block;
	
	position: absolute;
    top: 0;
    left: 0;
    
    font-family: Arial, "Helvetica CY", "Nimbus Sans L", sans-serif !important;
    text-align: center;
	font-size: 0.88rem;
    line-height: 32px;
}

.remodal .job_container {
	width: auto;
	height: auto;
	margin: 40px 64px 64px;
	padding: 0;
	
	display: block;
}

.remodal h1 {
	margin: 0 0 16px;
    padding: 0;
    
	text-align: center;
    font-size: 1.6em;
    line-height: 1;
    color: #0E4098;
}

.remodal .job_lead {
	margin: 0 0 16px;
	font-size: 0.8rem;
	text-align: center;
	font-weight: bold;
	line-height: 1.6;
}

.remodal .job_block {
	margin: 0 0 40px;
}

.remodal .job_block:last-child {
	margin: 0;
}

.remodal h2 {
	margin: 0 0 16px;
    padding: 0;
    
	text-align: center;
    font-size: 1.24em;
    line-height: 1;
    letter-spacing: 0.05em;
    color: #0E4098;
}

.remodal p {
	margin: 0;
	padding: 0;
	
	font-size: 1em;
	line-height: 2;
	text-align: justify;
}

.remodal ul {
	width: 100%;
	height: auto;
	margin: 0 auto;
	padding: 0;
	
	display: block;
	list-style: none;
}

.remodal ul li{
	margin: 0;
	padding: 0 0 0 1.5rem;
	
	display: block;
	line-height: 2;
	font-size: 1em;
	color: #212121;
	text-align: justify;
	
	position: relative;
}

.remodal ul li::before {
    content: '';
    width: 1.5rem;
    height: 2rem;
    display: inline-block;
    background: url(../images/footer_list_blue.png) 4px 12px no-repeat;
    background-size: 4px 4px;
    position: absolute;
    top: 0;
    left: 0;
}

.remodal ul li a{
	margin: 0;
	padding: 0;
	
	line-height: 2;
	font-size: 1em;
	color: #0E4098;
	text-align: justify;
	font-weight: bold;
	text-decoration: none;
}

.remodal img.jobimage_main {
	width: 100%;
	height: auto;
	margin: 0;
	padding: 0;
	
	display: block;
}

.remodal .job_container .modal_interview {
	width: 100%;
	height: auto;
	margin: 0 0 24px;
	padding: 0;
	
	display: flex;
	justify-content: space-between;
	flex-wrap: wrap;
}

.remodal .job_container .modal_interview:last-child {
	margin: 0;
}

.remodal .job_container .modal_interview_photo{
	width: 32%;
	height: auto;
	margin: 0;
	padding: 0;
	
	display: block;
}

.remodal .job_container .modal_interview_photo img{
	width: 100%;
	height: auto;
	margin: 0;
	padding: 0;
	
	display: block;
}

.remodal .job_container .modal_interview_text {
	width: 64%;
	height: auto;
	margin: 0 0 auto;
	padding: 0;
}

.remodal .job_container .modal_interview_text h3{
	margin: 0 0 8px;
	padding: 0;
	
	text-align: left;
	line-height: 1.4;
	font-size: 0.88rem;
	font-weight: bold;
	color: #212121;
}

.remodal .job_container .modal_interview_text .shimei{
	margin: 0 0 8px;
	padding: 0;
	
	font-weight: bold;
	font-size: 0.8rem;
	line-height: 1;
	color: #0E4098;
}

.remodal .job_container .modal_interview_text .modal_caption {
	margin: 0;
	padding: 0;
	
	font-size: 0.72em;
	line-height: 1;
	color: #212121;
}

.remodal .job_container .modal_interview_text .affiliation{
	margin: 0 0.72rem 0 0;
}

.remodal .job_container .modal_interview_text .join{
	
}

/*.remodal-wrapper:after {
	content: "閉じる";
	
	width: 25%;
	height: 48px;
	margin:0 auto;
	padding: 0;
	display: block;
	
	line-height: 48px;
	text-align: center;
	vertical-align: middle;
	color: #fefefe;
	border: solid 1px #fefefe;
	
}*/

.recruit_info {
	width: 100%;
	height: auto;
	margin: 0;
	padding: 88px 0;
	
	background-image: linear-gradient( to right, rgba(0,63,152,0.8), rgba(0,63,152,0.8) ),url("../images/bg_recruit_info.jpg");
	background-size: cover;
	background-repeat: no-repeat;
	background-position: center;
	position: relative;
}

.recruit_info h1 {
	margin: 0;
	padding: 0;
	
	color: #FFFFFF;
	text-align: center;
	font-size: 2.8em;
	line-height: 1;
}

.recruit_info h3{
	margin: 0;
	padding: 0;
	
	font-size: 2.4em;
	letter-spacing: 0.24em;
	text-align: center;
}

.recruit_info h3 a {
	margin: 0 auto;
	padding: 32px 64px;
	
	border: solid 1px #fff;
	color: #fff;
	text-decoration: none;
}

.recruit_info h3 a:hover {
	margin: 0 auto;
	padding: 32px 64px;
	
	border: solid 1px #fff;
	color: #0E4098;
	background-color: #fff;
	text-decoration: none;
}

.recruit_type {
	width: 100%;
	height: auto;
	margin: 48px 0 64px;
	padding: 0;
	
	display: flex;
    justify-content: space-between;
    flex-wrap: wrap;
	align-items: stretch;
	
	border-left: solid 1px rgba(255,255,255,0.65);
	border-right: solid 1px rgba(255,255,255,0.65);
}

.type_list {
	width: 33.2%;
	height: auto;
	margin: 0;
	padding: 8px 0 16px;
	
	display: block;
}

.type_list .list_box {
	width: auto;
	height: auto;
	margin: 0;
	padding: 0 12%;
	
	display: flex;
	flex-direction: column;
}

.right_line {
	border-right: solid 1px rgba(255, 255, 255, 0.65);
}

.type_list h1{
	margin: 0 auto 24px;
    padding: 0;
	
    font-size: 1.8em;
    letter-spacing: 0.16em;
    text-align: center;
}

.type_list p {
	margin: 0 auto;
	padding: 0;
	color:#fff;
}

.type_list p.target {
	margin: 8px 0 24px;
	color:#D4ECF3;
	font-size: 0.88em;
	letter-spacing: 0.025em;
}

.type_list h2 {
	margin: 0;
	padding: 0;
	
	font-size: 1.2em;
	letter-spacing: 0.24em;
	text-align: center;
	font-weight: normal;
}

.type_list h2 span{
	text-indent: 0.24em;
}

.type_list a {
	display: block;
	margin: auto auto 0;
	padding: 8px 0;
	border: solid 1px #fff;
	color: #fff;
}

.type_list a:hover {
	display: block;
	margin: auto auto 0;
	padding: 8px 0;
	border: solid 1px #fff;
	color: #0E4098;
	background-color: #fff;
}

.menu_items_first{
  width: 50%;
  justify-content: center;
  margin: 0 auto;
}

.menu_items {
	width: 50%;
	justify-content: center;
}

.menu_items_first img {
	width: 90%;
	max-width: 330px;
	margin: 20px auto;
	
	display: block;
}

.menu_items img {
	width: 90%;
	max-width: 330px;
	margin: 20px auto;
	
	display: block;
}

img.menu_btn{
	width: 60%;
	max-width: 180px;
	margin: 0 auto;
	
	display: block;
}

.about h2 {
 font-size:18px;
 width:350px;
 margin:0 auto;
 text-align:center;
 border-bottom:1px solid #000;
}

.about img {
 margin-top:10px;
 width:350px;
}

.recruitmentinfo {
 width:350px;
 float:left;
 margin-right:23px;
}

.recruitmentinfo h2 {
 font-size:18px;
 width:350px;
 margin:0 auto;
 text-align:center;
 border-bottom:1px solid #000;
}

.recruitmentinfo img {
 margin-top:10px;
 width:350px;
}

/*movie*/

.top_people_pickup {
 width:100%;
 /*background:#d3ecf3;*/
}

div.top_people_list {
	width: 100%;
	max-width: 1120px;
	height: auto;
	margin: 0 auto;
	padding: 0;
}

div.top_people_list ul {
list-style: none;
margin-top: 0;
}

div.top_people_list li {
  width: 300px;
  text-align: center!important;
  line-height: 150%;
  display: inline;
  float: left;
}
.people div.top_people_list li{
  margin-bottom: 100px;
}
div.top_people_list li div,
div.top_people_list li img{
display: block;
}
div.top_people_list li .balloon1 {
  position: relative;
  display: inline-block;
  margin: 1.5em 0;
  padding: 7px 10px;
  min-width: 120px;
  max-width: 100%;
  font-size: 16px;
  background: #044781;
  text-align: center;
}

div.top_people_list li .balloon1:before{
  content: "";
  position: absolute;
  top: 100%;
  left: 50%;
  margin-left: -12px;
  border: 12px solid transparent;
  border-top: 12px solid #044781;
}

div.top_people_list li .balloon1 p {
  margin: 0;
  padding: 0;
}

.second div.top_people_list li a div.pp{
  width:230px;
  height:230px;
  border-radius: 400px;
    margin: 0 auto;
  border:1px solid #fff;
  box-shadow: 0px 0px 10px #ccc,
  inset 0px 0px 10px rgba(0, 0, 0, 0.5);
}

div.movie_list li div,
div.movie_list li img{
	display: block;
}

div.movie_list li .balloon1 {
	width: 100%;
    margin: 0 0 12px;
    padding: 0;
    position: relative;
    display: inline-block;
    color: #0E4098;
}

div.movie_list li .balloon1 p {
	margin: 0;
	padding:0.25em 1em 0.25em 1.25em;
	display: inline-block;
	
	font-size: 1em;
    font-weight: bold;
	line-height: 1.4;
	letter-spacing: 0.15em;
	color: #0E4098;
	position: relative;
}

div.movie_list li .balloon1 p:before, div.movie_list li .balloon1 p:after { 
  content:'';
  width: 12px;
  height: 12px;
  position: absolute;
  display: inline-block;
}

div.movie_list li .balloon1 p:before {
  border-left: solid 1px #0E4098;
  border-top: solid 1px #0E4098;
  top:0;
  left: 0;
}

div.movie_list li .balloon1 p:after {
  border-right: solid 1px #0E4098;
  border-bottom: solid 1px #0E4098;
  bottom:0;
  right: 0;
}

div.movie_list {
  max-width:1120px;
  margin:0 auto;
}


#movie {
	width: 100%;
	height: auto;
	margin: 0 auto;
	padding: 0;
	
	display: flex;
	flex-wrap: wrap;
	list-style: none;
	justify-content: space-between;
}

#movie li.movie_episode01 {
	width: 72%;
	max-width: 720px;
    margin: 0 auto;
	padding-bottom: 64px;
	
	position:relative; 
    }

div.movie_episode01_wrapp {
	width:100%;
	height:0; 
    margin: 0 auto; 
	padding-bottom:56.25%;
	
    position:relative; 
    overflow:hidden;
    }

#movie li.movie_episode01 iframe {
  position: absolute;
  top: 0;
  left: 0;
  width: 100% !important;
  max-width: 1160px;
  height: 100% !important; 
}

#movie li {
	width: 48%;
	text-align: center!important;
	line-height: 120%;
	margin: 0px 0 64px;
	padding: 0px;
	
	display: block;
}

#movie li div.pp2 {
    position:relative; 
    padding-bottom:56.25%;
    height:0; 
    overflow:hidden;
    max-width:100%; 
}

#movie li div.pp2 iframe {
  position: absolute;
  top: 0;
  left: 0;
  width: 100% !important;
  height: 100% !important;
}

/*interview*/

a.interview_menu {
	width: 356px;
	height: auto;
	margin: 3em calc((100% - (356px * 3)) / 2) 0 0;
	padding: 0;
	overflow: hidden;
	display: block;
	text-decoration: none;
}

a.interview_menu:nth-child(-n+3){
	margin-top: 0;
}
a.interview_menu:nth-child(3n) {
	margin-right: 0;
}

.interview_menu_thumb{
	width: 100%;
	height: auto;
	margin: 0 0 12px;
	padding: 0;
	
	display: block;
	position: relative;
}

.interview_menu img{
	width: 100%;
	height: auto;
	margin: 0;
	padding: 0;
	
	display: block;
}

.interview_menu_thumb .job {
	margin: 0;
    padding: 8px 16px;
    display: inline-block;
    color: #fff;
    font-size: 0.72rem;
    line-height: 1;
    background: transparent linear-gradient(90deg, #4182CC 0%, #0E4098 100%);
	
	position: absolute;
	left: 0;
	bottom: 0;
}

.interview_menu h2{
	margin: 0 0 8px;
    padding: 0;
	
    font-size: 1.12rem;
    color: #212121;
    font-weight: bold;
    line-height: 1.4;
	letter-spacing: 0.04rem;
}

.interview_menu p.shimei{
	margin: 0 0 8px;
    padding: 0;
	
    font-size: 0.96rem;
	font-weight: bold;
    color: #0E4098;
    line-height: 1;
}

.interview_menu p.affiliation{
	margin: 0 0 8px;
    padding: 0;
	
    font-size: 0.8rem;
    color: #212121;
    line-height: 1;
}

.interview_menu p.join{
	margin: 0;
    padding: 0;
	
    font-size: 0.8rem;
    color: #212121;
    line-height: 1;
}

.iwahashi {
	
}

.nitadera {
	}

.kunihiro {
	
}

.okazawa_jr {
	
}

.okano {
	
}

.yoshimoto {
	
}

/*.toppada {
	margin: 0!important;
}*/

.okubo {
	
}

.yamasaki {
	
}

.nishimura {
	
}

.interview_menu div.kisha::before {
	
	margin: 0;
	padding: 8px 16px;
	
	content: "記者";
	font-size: 12px;
	color:#fff;
	font-weight: bold;
	background-color: #45B035;
	letter-spacing: 0.5em;
	text-indent: 0.5em;
	
	position: absolute;
	left:0;
	top: -40px;
	
	z-index: 10;
}

.interview_menu div.shinsotsu::before {
	
	margin: 0;
	padding: 8px 16px;
	
	content: "新卒";
	font-size: 12px;
	color:#fff;
	font-weight: bold;
	background-color: #45B035;
	letter-spacing: 0.5em;
	text-indent: 0.5em;
	
	position: absolute;
	left:0;
	top: -40px;
}

.interview_mv {
	width: 100%;
	height: 480px;
	margin: 0 auto 32px;
	padding: 64px 0 0;
	
	overflow: hidden;
	position: relative;
}

.interview_mv img{
	width: auto;
	height: 480px;
	margin: 64px auto 0;
	padding: 0;
	
	position: absolute;
    top: 0;
    left: 50%;
    transform: translateX(-50%);
    -webkit-transform: translateX(-50%);
    -ms-transform: translateX(-50%);
}

.mv_inner {
	width: 1120px;
	height: 100%;
	margin: 0 auto;
	padding: 0;
	
	display: block;
	
	position: absolute;
	top: 0;
	left: 0;
	right: 0;
	bottom: 0;	
}

.name {
	width: 448px;
	height: 160px;
	margin: 0;
	padding: 0;
	
	display: flex;
	flex-direction:row;
	justify-content:center;
	align-items:center;
	position: absolute;
	left: 0;
	bottom: 0;
	
	background-color: rgba(0,63,152,0.8);
}

.name div{
	margin: 0;
	padding: 0;
}

.name h2{
	margin: 0 auto 8px;
	padding: 0;
	
	display: block;
	color: #fff;
	font-size: 1.2em;
	line-height: 1;
	letter-spacing: 0.15em;
}

.name h2.kenmu{
	margin: 0 auto 8px;
	padding: 0;
	
	display: block;
	color: #fff;
	font-size: 1.2em;
	line-height: 1.2;
	letter-spacing: 0.15em;
}


.name h1{
	margin: 0 auto 8px;
	padding: 0;
	
	display: block;
	color: #fff;
	font-size: 2.4em;
	line-height: 1;
	letter-spacing: 0.25em;
}

.name p{
	margin: 0 auto;
	padding: 0;
	
	display: block;
	color: #fff;
	font-size: 0.88em;
	line-height: 1;
	letter-spacing: 0.25em;
}

.bgline {
	padding: 64px 0;
	background: none,repeating-linear-gradient(-90deg,#ccc 0,#f6fafc 2px,#f6fafc 2px,#f6fafc 4px);
	background-repeat: no-repeat;
	background-size: 50%,50%;
	background-position: left,right;
	}

.interview_bg {
	margin: 0;
	padding: 32px 0 0;
	background-color: #f6fafc;
}

.interview_container {
	width: 100%;
    height: auto;
    margin: 0;
    padding: 0;
    display: flex;
    flex-wrap: wrap;
    justify-content: flex-start;
}

.interview_inner {
	width: 1120px;
	height: auto;
	margin: 160px auto 64px;
	padding: 0 0 64px;
	
	display: block;
	background-color: #fff;
	
	position: relative;
}

.main_photo {
	width: 496px;
	height: auto;
	margin: 0;
	padding: 0;
	
	display: block;
	
	position: absolute;
	top: -96px;
	left: 0;
	filter: drop-shadow(8px 8px 20px rgb(14,64,152,0.12));
}

.main_01 {
	content: url("../images/interview_main_01.jpg");
	width: 100%;
    height: auto;
}

.main_02 {
	content: url("../images/interview_main_02.jpg");
	width: 100%;
    height: auto;
}

.main_03 {
	content: url("../images/interview_main_03.jpg");
	width: 100%;
    height: auto;
}

.main_04 {
	content: url("../images/interview_main_04.jpg");
	width: 100%;
    height: auto;
}

.main_05 {
	content: url("../images/interview_main_05.jpg");
	width: 100%;
    height: auto;
}

.main_06 {
	content: url("../images/interview_main_06.jpg");
	width: 100%;
    height: auto;
}

.main_07 {
	content: url("../images/interview_main_07.jpg");
	width: 100%;
    height: auto;
}

.main_08 {
	content: url("../images/interview_main_08.jpg");
	width: 100%;
    height: auto;
}

.main_09 {
	content: url("../images/interview_main_09.jpg");
	width: 100%;
    height: auto;
}

.interview_profile {
	width: 480px;
	height: auto;
    margin: 40px 80px 72px auto;
	padding: 0;
}

.interview_profile .label {
	margin: 40px 0 16px;
	padding: 8px 32px;
	
	display: inline-block;
	
	color: #fff;
	font-size: 0.88rem;
	line-height: 1;
	background: transparent linear-gradient(90deg, #4182CC 0%, #0E4098 100%);
}

.interview_profile .interview_maincopy {
	margin: 0 0 8px;
    padding: 0;
    text-align: left;
    color: #212121;
    font-size: 2rem;
    line-height: 1.4;
}

.interview_profile .interviewee p{
	display: inline-block;
}

.interview_profile .interviewee p.shimei{
	margin: 0 16px 0 0;
	padding: 0;
	
	color: #0E4098;
	font-size: 1.24rem;
	text-align: justify;
	line-height: 1;
	letter-spacing: 0.025em;
	font-weight: bold;
}

.interview_profile .interviewee p.affiliation{
	margin: 0 8px 0 0;
	padding: 0;
	
	color: #212121;
	font-size: 0.8rem;
	text-align: justify;
	line-height: 1;
	letter-spacing: 0.025em;
	font-weight: bold;
}

.interview_profile .interviewee p.join{
	margin: 0 8px 0 0;
	padding: 0;
	
	color: #212121;
	font-size: 0.8rem;
	text-align: justify;
	line-height: 1;
	letter-spacing: 0.025em;
	font-weight: bold;
}

.interview_profile .interviewee p.asterisk{
	margin: 0 8px 0 0;
	padding: 0;
	
	color: #212121;
	font-size: 0.72rem;
	text-align: justify;
	line-height: 1;
	letter-spacing: 0.025em;
	font-weight: normal;
	display: inline-block;
}

.career_summary{
	width: 720px;
	height: auto;
	margin: 0 auto 64px;
	padding: 64px 40px 56px;
	
	border-radius: 24px;
	
	background-image: url(.././images/bg_career_summary.png),linear-gradient(0deg, #F6F6F6 0%, #F6F6F6 100%);
    background-size: auto 64px,cover;
    background-position: -2px -4px,top;
    background-repeat: no-repeat,no-repeat;
}

.career_summary dl{
	width: 100%;
    height: auto;
    margin: 0;
    padding: 16px 0;
	
    border-bottom: 1px dotted #DDDFE1;
    line-height: 1.8;
    font-size: 0.88rem;
    display: -webkit-flex;
    display: -moz-flex;
    display: flex;
    flex-wrap: wrap;
	justify-content: space-between;
    align-items: stretch;
}

.career_summary dt{
	width: 64px;
    margin: 0 0 0 40px;
    text-align: left;
    font-weight: 700;
    color: #0E4098;
}

.career_summary dd{
	width: calc(100% - 172px);
	margin: 0 40px 0 0;
    text-align: left;
    font-weight: 500;
}

.career_summary dd span.event {
	margin: 0 16px 0 0;
	font-weight: bold;
}

.interview_outline {
	width: 100%;
	height: auto;
	margin: 0 auto;
	padding: 80px 0 0;
	
	/*background-image: linear-gradient(90deg, #528AD5 0%, #528AD5 25%, #D4ECF3 100%),linear-gradient(90deg, #FBFBFB 0%, #FBFBFB 100%);
    background-size: 100% 400px,cover;
    background-position: top,top;
    background-repeat: no-repeat,no-repeat;*/
}

.interview_message_container {
	width: 960px;
	height: auto;
	margin: 0 auto 64px ;
	padding: 0;
	
	display: block;
	position: relative;
}

.interview_message_container h1{
	width: auto;
	height: 40px;
	margin: 0;
	padding: 12px 18px;
	
	display: block;
	background-color: #d4ecf3;
	font-size: 20px;
	line-height: 40px;
	text-align: center;
	letter-spacing: 0.25em;
	
	position: absolute;
	top: 0;
	left: 0;
}

.interview_paragraph {
	width: 880px;
	height: auto;
	margin: 0 auto 64px;
	padding: 0;
}

.interview_paragraph h2{
	margin: 0 0 24px;
	padding: 0 0 0 24px;
	
	color: #0E4098;
	font-size: 1.24rem;
	line-height: 1;
	font-weight: bold;
	
	position: relative;
}
.interview_paragraph h2::before{
	content: '';
    width: 1.24rem;
    height: 1.24rem;
    display: inline-block;
    background: url(../images/footer_list_blue.png) left center no-repeat;
    background-size: 8px 8px;
    position: absolute;
    top: 0;
    left: 0;
}

.interview_paragraph p{
	margin: 0 0 0 40px;
	padding: 0;
	
	color: #212121;
	font-size: 1rem;
	line-height: 2;
	text-align: justify;
}

.interview_topic {
	width: 960px;
	height: auto;
	margin: 0 auto 128px;
	padding: 0;
	
	display: flex;
	flex-wrap: wrap;
	justify-content: space-between;
	
	position: relative;
}

.interview_topic .interview_topic_text {
	width: 490px;
	height: auto;
	margin: 0;
	padding: 64px 96px 64px 64px;
	
	background-color: #F6FAFC;
	border-radius: 24px;

}

.interview_topic_lead p{
	margin: 0 0 20px;
	padding: 0;
	
	line-height: 1;
	font-weight: bold;
}

.interview_topic_lead h2 {
	margin: 0 0 12px;
    padding: 0;
    color: #0E4098;
    font-size: 1.6em;
    line-height: 1.6;
    font-weight: bold;
    text-align: justify;
}

img.interview_topic_image {
	width: 360px;
	height: auto;
	margin: 0;
	padding: 0;
	
	position: absolute;
	bottom: -64px;
	right: 0;
	
	filter: drop-shadow(8px 8px 20px rgb(14,64,152,0.12));
}

.interview_topic_detail p{
	margin: 0;
	padding: 0;
	text-align: justify;
}

.interview_message {
	width: 528px;
    height: auto;
    margin: 128px 0 0 auto;
    padding: 64px 64px 64px 96px;
	
    display: block;
    background-color: #F6FAFC;
    border-radius: 24px;
}

.interview_message p.message_question {
	margin: 0 0 20px;
	padding: 0;
	
	font-weight: bold;
	line-height: 1;
}

.interview_message h2 {
	margin: 0 0 12px;
    padding: 0;
	
	color: #0E4098;
    font-size: 1.6em;
    line-height: 1.4;
    font-weight: bold;
    text-align: justify;
}

.interview_message_photo {
    width: 320px;
    height: auto;
    margin: 0;
    padding: 0;
    display: block;
    position: absolute;
    top: -64px;
    left: 0;
	
	filter: drop-shadow(8px 8px 20px rgb(14,64,152,0.12));
}

.message_01{
	content: url(../images/message_01.jpg);
}

.message_02{
	content: url(../images/message_02.jpg);
}

.message_03{
	content: url(../images/message_03.jpg);
}

.message_04{
	content: url(../images/message_04.jpg);
}

.message_05{
	content: url(../images/message_05.jpg);
}

.message_06{
	content: url(../images/message_06.jpg);
}

.message_07{
	content: url(../images/message_07.jpg);
}

.message_08{
	content: url(../images/message_08.jpg);
}

.message_09{
	content: url(../images/message_09.jpg);
}

.interview_message p {
	margin: 0;
	padding: 0;
}


.interview_bg p span{
	font-weight: bold;
	text-align: justify;
}

div.interview_inner hr{
	width: 960px;
    height: 1px;
    margin: 0 auto 64px;
    padding: 0;
	
	background-color: #f2f2f2;
    border: none;
}

.interview_portrait {
	width: 32%;
	height: auto;
	margin: 0;
	padding: 0;
	
	display: block;
}

.interview_finish {
	width: 50%;
	height: auto;
	margin: 0 auto;
	padding: 0;
	
	display: block;
	font-size: 0.96em;
	color: #0E4098;
}

.interview_finish p{
	margin: 0;
	padding: 0;
	
	font-size: 1.24em;
	color: #0E4098;
	text-align: justify;
	line-height: 2;
}

.interview_back {
	width: 100%;
	height: 64px;
	margin: 0 auto 0;
	padding: 0;
	
	display: block;
	color: #0E4098;
	font-size: 18px;
	font-weight: bold;
	text-align: center;
	line-height: 64px;
	background-color: #fff;
	border: solid 1px #0E4098;
	letter-spacing: 0.25em;
}

div.interview_navi_container {
	width: 960px;
	height: auto;
	margin: 0 auto 40px;
	padding: 0;
	
	display: flex;
	flex-wrap: wrap;
	justify-content: space-between;
}

.interview_navi {
	width: 460px;
	height: auto;
	margin: 0;
	padding: 0;
	
	display: flex;
	flex-wrap: wrap;
	justify-content: space-between;
	align-items: flex-start;
}

.interview_navi_image {
	width: 180px;
	height: auto;
	margin: 0;
	padding: 0;
	
	display: block;
	
	position: relative;
}

.interview_navi_image img {
	width: 100%;
	height: auto;
	margin: 0;
	padding: 0;
	
	display: block;
}

.interview_navi_image .job {
	margin: 0;
    padding: 4px 8px;
    display: inline-block;
    color: #fff;
    font-size: 10px;
    line-height: 1;
    background: transparent linear-gradient(90deg, #4182CC 0%, #0E4098 100%);
	
	position: absolute;
	bottom: 0;
	left: 0;
}

.interview_navi_text {
	width: calc(100% - 200px);
    height: auto;
    margin: 0;
    padding: 0;
}

.interview_navi_text h3 {
	margin: 0 0 8px;
	padding: 0;
	
	font-size: 1rem;
	line-height: 1.6;
	font-weight: bold;
	color: #212121;
	text-align: justify;
}

.interview_navi_text .shimei {
	margin: 0 0 12px;
	padding: 0;
	
	color: #0E4098;
	font-size: 0.88rem;
	line-height: 1;
	font-weight: bold;
}

.interview_navi_text .affiliation {
	width: auto;
	margin: 0 0 8px 0;
	padding: 0;
	
	color: #212121;
	font-size: 0.72rem;
	line-height: 1;
	font-weight: normal;
}

.interview_navi_text .join {
	width: auto;
	margin: 0;
	padding: 0;
	
	color: #212121;
	font-size: 0.72rem;
	line-height: 1;
	font-weight: normal;
}

.interview_submenu {
	width: 40%;
	height: 160px;
	margin: 48px 0 auto;
	padding: 0;
	
	position: relative;
}

.menuback {
	width: 320px;
	height: 64px;
	margin: 0 auto;
	padding: 0;
}

.menuinfo {
	position: absolute;
	bottom: 0;
}

div.main_contents {
	width:100%;
	height: auto;
}

div.title_top {
 position:absolute;
 top:50%;
 width:100%;
 z-index:10;
}

div.title_top h1 {
 color:#fff;
  text-shadow: 2px 4px 3px rgba(0,0,0,0.3);
 text-align:center;
 font-size:50px;
 font-family:'Noto Sans JP',"Roboto Slab" , Garamond , "Times New Roman" , "游明朝" , "Yu Mincho" , "游明朝体" , "YuMincho" , "ヒラギノ明朝 Pro W3" , "Hiragino Mincho Pro" , "HiraMinProN-W3" , "HGS明朝E" , "ＭＳ Ｐ明朝" , "MS PMincho" , serif;
 margin-left:100px;
 z-index:10;
line-height:140%;
}

div.title_top h1 span{
  display: block;
  font-size: 50%;
  text-align: center;
  margin: -20px auto auto auto;
  opacity: 0.6;
}

div.info_top a {
 position:absolute;
 top:5%;
 left:5%;
 padding:55px 18px 20px;
 width:164px;
 height:115px;
 z-index:10;
 color:#fff;
 font-size:18px;
 line-height:1.5em;
 font-weight:bold;
 background:#C33;
 border-bottom:4px solid #900;
 text-align:center;
 border-radius: 50%;        /* CSS3草案 */
 -webkit-border-radius:  50%;    /* Safari,Google Chrome用 */
 -moz-border-radius:  50%;   /* Firefox用 */
}

div.title {
 position:absolute;
 top:200px;
 min-width:280px;
 height:500px;
 right:13%;
}

div.title02 {
 position:absolute;
 top:200px;
 min-width:280px;
 height:450px;
 right:14%;
 padding:10px;
}

div.title h3 {
 color:#333;
 font-size:36px;
 line-height:1.7em;
 padding:0;
 font-family:'Noto Sans JP',"Roboto Slab" , Garamond , "Times New Roman" , "游明朝" , "Yu Mincho" , "游明朝体" , "YuMincho" , "ヒラギノ明朝 Pro W3" , "Hiragino Mincho Pro" , "HiraMinProN-W3" , "HGS明朝E" , "ＭＳ Ｐ明朝" , "MS PMincho" , serif;
  -webkit-writing-mode: vertical-rl;
  -ms-writing-mode: tb-rl;
  writing-mode: vertical-rl;
}

div.t10 h3 {
 font-size:40px;
}

div.t10 h3 {
 font-size:40px;
}

div.title02 h3 {
 color:#333;
 font-size:40px;
 line-height:1.9em;
 padding:0;
 font-family:'Noto Sans JP',"Roboto Slab" , Garamond , "Times New Roman" , "游明朝" , "Yu Mincho" , "游明朝体" , "YuMincho" , "ヒラギノ明朝 Pro W3" , "Hiragino Mincho Pro" , "HiraMinProN-W3" , "HGS明朝E" , "ＭＳ Ｐ明朝" , "MS PMincho" , serif;
  -webkit-writing-mode: vertical-rl;
  -ms-writing-mode: tb-rl;
  writing-mode: vertical-rl;
}

div.paragraph01_inner {
 width:100%;
 margin:0 auto;
}

div.paragraph02_inner {
 width:100%;
 margin:0 auto;
}

div.paragraph02_p {
 width:74%;
 margin-top:0;
 padding:20px 20px 30px;
 background:#fff;
 z-index:29;
 overflow:visible !important;
}

div.paragraph03_inner {
 width:100%;
 margin:0 auto;
}

div.paragraph03_p {
 width:40%;
 margin:0 10px 10px 10%;
 padding:20px 40px 20px;
 background:#fff;
 z-index:30;
 overflow:visible !important;
}

.entry_btn {
 clear:both;
 width:100%;
 margin:60px 0 10px !important;
 padding:50px 0 20px;
 background:#efefef;
 overflow:hidden;
}

.entry_btn ul {
 width:960px;
 height:100px;
 margin:0 auto;
}

.entry_btn ul li {
 list-style:none;
 float:left;
 margin-right:10px;
 width:300px;
 text-align:center;
}

.entry_btn ul li a {
 color:#fff;
 padding:1em 2.5em 1em 2.5em;
 display:block;
 margin:0 0 0 10px;
 background:#C33;
 border-bottom:3px solid #900;
 border-right:0 !important;
}


/*募集要項*/

.inner ul.recruit_list_container {
	color: #0E4098;
	list-style: none;
	display: flex;
	justify-content: flex-start;
	flex-wrap: wrap;
	width: 100%;
	height: auto;
	margin: -1.5em 0 0;
	padding: 0;
}
.inner ul.recruit_list_container li{
	font-size: 1em;
	color: inherit;
	text-align: center;
	display: block;
	width: calc((100% - 1em * 2) / 3);
	height: auto;
	box-sizing: border-box;
	border: 1px solid;
	margin: 1.5em 0 0;
	padding: 0;
}
.inner ul.recruit_list_container li:not(:nth-of-type(3n+1)){
	margin-left: 1em;
}
.inner ul.recruit_list_container li.gra_list{
	width: 50%;
	margin: 0 auto 0;
}
.middle ul.recruit_list_container li.gra_list{
	width: 75%;
}
.car_type .inner ul.recruit_list_container li{
	width: calc((100% - 1em * 2) / 2);
}
.car_type .inner ul.recruit_list_container li:not(:nth-of-type(3n+1)){
	margin-left: 0;
}
.car_type .inner ul.recruit_list_container li:not(:nth-of-type(2n+1)){
	margin-left: 1em;
}
.inner ul.recruit_list_container a{
	text-decoration: none;
	display: block;
	width: 100%;
	box-sizing: border-box;
	padding: 1.5em 1em;
}
.inner ul.recruit_list_container a:hover,
.inner ul.recruit_list_container a:active {
	background-color: #0E4098;
	color: #fff;
	opacity: 1;
	transition: all 0.5s;
}

.inner .recruit_grainfo {
	width: 100%;
	height: 88px;
	margin: 32px auto 0;
	padding: 0;
	display: block;
	color: #0E4098;
	font-size: 1.12em;
	border: solid 1px #0E4098;
	text-decoration: none;
	text-align: center;
	font-weight: bold;
	line-height: 88px;
}

.inner .recruit_grainfo:hover,
.inner .recruit_grainfo:active {
	background-color: #0E4098;
	color: #fff;
	text-decoration: none;
	opacity: 1;
	transition: all 0.5s;
}

.gra_type {
	margin: 0 auto 48px;
	padding: 0;
}

.gra_menu {
	margin: 80px 0;
}

.car_type {
	margin: 0 auto 64px;
	padding: 0;
}

.car_type:last-child {
	margin: 0;
	padding: 0;
}

section.car_type h3 {
	margin: 0 0 32px;
	line-height: 1;
	text-align: center;
}

.inner ul.recruit_list_container a.car_list{
	width: 548px;
	height: 88px;
	margin: 0 0 24px;
	padding: 0;
	
	display: flex;
	border: solid 1px #0E4098;
	background-color: #fff;
	color: #0E4098;
	text-decoration: none;
}

.intern_type {
	margin: 0 auto 32px!important;
	padding: 0;
}

.intern_term {
	width: 100%;
    height: auto;
    margin: 0;
    padding: 0;
    display: flex;
    justify-content: space-between;
    flex-wrap: wrap;
}

.intern_term div {
	width: 388px;
	height: auto;
	margin: 0;
	padding: 0;
}

.intern_term div img {
	width: 100%;
	height: auto;
	margin: 0 0 8px;
	padding: 0;
}

.intern_term div h3 {
	margin: 0 0 4px;
	padding: 0;
	
	font-size: 1.12rem;
	line-height: 1;
	color: #0E4098;
}

.intern_term div p {
	font-size: 0.8rem;
	line-height: 1.8;
}

.gra a,
.gra2 a {
	width:45%;
	height:auto;
	margin: 0 16px 32px;

	display:block;
	border:1px solid #ccc;
	border-bottom:3px solid #999;
	float:left;
	text-align:center;
	padding:20px 10px;
 border-radius: 3px;    /* CSS3草案 */
 -webkit-border-radius: 3px;  /* Safari,Google Chrome用 */
 -moz-border-radius: 3px; /* Firefox用 */
 text-decoration:none !important;
 font-weight:bold;
}

.gra a:hover,
 .gra2 a:hover{
 background:#efefef;
 text-decoration:none;
}

.gra_info {
 clear:both;
 width:80%;
 margin:0 auto;
 margin-bottom:30px;
 padding-bottom:20px;
 border:1px solid #ccc;
}

.gra_info h2 {
 font-size:18px;
 margin:10px 10px 0;
}

.gra_info ul {
 width:30%;
 padding:10px;
 margin:0 auto;
}

.gra_info ul li {
 list-style:none;
 float:left;
 margin-right:20px;
}

#car {
	margin: 0 0 64px;
	padding: 0;
}

.sche a,
.car a,
.car2 a {
 /*width:29%;*/
 width:20%;
 height:auto;
 display:block;
 border-top:1px solid #ccc;
 border-left:1px solid #ccc;
 border-right:1px solid #ccc;
 border-bottom:3px solid #999;
 float:left;
 margin:30px 10px 50px;
 text-align:center;
 padding:20px 10px;
 border-radius: 3px;    /* CSS3草案 */
 -webkit-border-radius: 3px;  /* Safari,Google Chrome用 */
 -moz-border-radius: 3px; /* Firefox用 */
 text-decoration:none !important;
 font-weight:bold;
}

.sche a:hover,
.car a:hover,
.car2 a:hover,
.active  {
 background:#efefef;
 text-decoration:none;
}

.car3 a {
 width:21%;
 height:auto;
 display:block;
 border-top:1px solid #ccc;
 border-left:1px solid #ccc;
 border-right:1px solid #ccc;
 border-bottom:3px solid #999;
 float:left;
 margin:30px 10px 50px;
 text-align:center;
 padding:20px 10px;
 border-radius: 3px;    /* CSS3草案 */
 -webkit-border-radius: 3px;  /* Safari,Google Chrome用 */
 -moz-border-radius: 3px; /* Firefox用 */
 text-decoration:none !important;
 font-weight:bold;
}

.car3 a:hover,
.active  {
 background:#efefef;
 text-decoration:none;
}

#car h3 {
	margin: 0 0 20px;
    background: none !important;
	line-height: 1;
    color: #0E4098;
}

.car_container {
 width:100%;
 height:auto;
 margin:0;
 padding:0;

 display: flex;
 justify-content: space-between;
 flex-wrap: wrap;
}

.car_container .car4 {
	width:32%;
	margin:0 0 16px;
	
	display:block;
	
	color: #333;
	background-color: #fff;
	border: 1px solid #0E4098;
}

.car_container .car4.blank {
	content: '';
	width:32%;
	display: block;
	
	background: none;
	border: none;
}

.car_container .car4:hover,.car_container .car4:active {
	color: #fff!important;
	background-color: #0E4098;
	border:solid 1px #fff;
	
	text-decoration: none;
	opacity: 1;
	transform: all 0.5s;
}

.car_container .car4.blank:hover,.car_container .car4.blank:active {
	content: '';
	width:32%;
	display: block;
	
	background: none;
	border: none;
}

.car_container .car4 a{
 display:block;
 padding:16px;
 text-decoration:none !important;
 font-weight:bold;
}

.car_container .car4 a:hover,.car_container .car4 a:active{
	 display:block;
 padding:16px;
	background-color: #0E4098;
	color: #fff!important;
	text-decoration: none;
	opacity: 1;
	transform: all 0.5s;
}

.car_container .car4 a span {
 font-weight:bold;
 color:#0E4098;
 padding:0 0.75em 0 0;
}

.car_container .car4:hover span, .car_container .car4:active span{
 font-weight:bold;
 color:#fff;
 padding:0 0.75em 0 0;
	border:solid 1px #0E4098;
}

.car2 a span {
 font-size:80%;
 font-weight:normal;
 background:#282E89;
 color:#fff;
	padding:2px 5px 2px 5px;
}

.car4 a:hover,
.car4 a:active  {
 background:#efefef;
 text-decoration:none;
}

/*common parts*/
a.btn {
	width: 320px;
	height: 64px;
	margin: 0 auto;
	padding: 0;
	
	display: block;
	
	background-color: #fff;
	
	border: 1px solid #0E4098;
	border-radius: 4px;
	text-decoration: none;
	
	position: relative;
}

a.btn p {
	margin: auto;
    padding: 0;
	
	color: #0E4098;
	font-weight: bold;

	line-height: 64px;
    text-align: center;
    text-decoration: none;
    font-size: 0.88rem;
    
	display: block;
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
	
}

ul.anchor {
	width: 100%;
	height: auto;
	margin: 0;
	padding: 24px 0;
	
	display: flex;
	
	border-top: solid 1px #F2F2F2;
	border-bottom: solid 1px #F2F2F2;
	
	list-style: none;
}

ul.anchor li {
	width: 50%;
	height: auto;
	margin: 0;
	padding: 0;
	
	text-align: center;
	
	list-style: none;
}

ul.anchor li a {
	margin: 0;
	padding: 0 32px 0 0;
	
	text-decoration: none;
	
	position: relative;
}

ul.anchor li a::before {
	content: '';
    width: 12px;
    height: 24px;
    display: inline-block;
    background: url(../images/anchor_blue.png) 0 9px no-repeat;
    background-size: 12px;
    position: absolute;
    top: 50%;
    right: 0;
    transform: translateY(-50%);
    -webkit-transform: translateY(-50%);
    -ms-transform: translateY(-50%);
}

ul.business_anchor {
	width: 100%;
	height: auto;
	margin: 40px 0 80px;
	padding: 24px 0;
	
	display: flex;
	
	border-top: solid 1px #F2F2F2;
	border-bottom: solid 1px #F2F2F2;
	
	list-style: none;
}

ul.business_anchor li {
	width: 20%;
	height: auto;
	margin: 0;
	padding: 0;
	
	text-align: center;
	
	list-style: none;
}

ul.business_anchor li a {
	margin: 0;
	padding: 0 32px 0 0;
	
	text-decoration: none;
	
	position: relative;
}

ul.business_anchor a::before {
	content: '';
    width: 12px;
    height: 24px;
    display: inline-block;
    background: url(../images/anchor_blue.png) 0 9px no-repeat;
    background-size: 12px;
    position: absolute;
    top: 50%;
    right: 0;
    transform: translateY(-50%);
    -webkit-transform: translateY(-50%);
    -ms-transform: translateY(-50%);
}

ul.works_anchor {
	width: 100%;
	height: auto;
	margin: 40px 0;
	padding: 24px 0;
	
	display: flex;
	
	border-top: solid 1px #F2F2F2;
	border-bottom: solid 1px #F2F2F2;
	
	list-style: none;
}

ul.works_anchor li {
	width: 50%;
	height: auto;
	margin: 0;
	padding: 0;
	
	text-align: center;
	
	list-style: none;
}

ul.works_anchor li a {
	margin: 0;
	padding: 0 32px 0 0;
	
	text-decoration: none;
	
	position: relative;
}

ul.works_anchor a::before {
	content: '';
    width: 12px;
    height: 24px;
    display: inline-block;
    background: url(../images/anchor_blue.png) 0 9px no-repeat;
    background-size: 12px;
    position: absolute;
    top: 50%;
    right: 0;
    transform: translateY(-50%);
    -webkit-transform: translateY(-50%);
    -ms-transform: translateY(-50%);
}

/*index page common*/

div.header_index_bg {
	width:100%;
	height:160px;
	margin:0;
	padding:80px 0 0;
	
	background-repeat: no-repeat;
	overflow:hidden;
}

.company_bg {
	background: url(../images/index_bg_pc_01.png),linear-gradient(0deg, #fcfcfc 0%, #fcfcfc 100%);
    background-position: right, center;
    background-size: auto 240px,cover;
}

.works_bg {
	background: url(../images/index_bg_pc_02.png),linear-gradient(0deg, #fcfcfc 0%, #fcfcfc 100%);
    background-position: right, center;
    background-size: auto 240px,cover;
}

.topics_bg {
	background: url(../images/index_bg_pc_03.png),linear-gradient(0deg, #fcfcfc 0%, #fcfcfc 100%);
    background-position: right, center;
    background-size: auto 240px,cover;
}

.requirements_bg {
	background: url(../images/index_bg_pc_04.png),linear-gradient(0deg, #fcfcfc 0%, #fcfcfc 100%);
    background-position: right, center;
    background-size: auto 240px,cover;
}

div.header_index_title {
	width:1440px;
	height:100%;
	margin:0 auto;
	padding:0;
	
	display: flex;
	justify-content: center;
    align-items: center;
	z-index:8;
}

div.header_index_title h1 {
	color: #0E4098;
}

div.contents_index_outline {
	width: 1120px;
    height: auto;
    margin: 40px auto 64px;
    padding: 64px 80px;
    display: block;
    background-color: #fff;
}

div.company_index_container {
	width: 100%;
    height: auto;
    margin: 0 auto;
    padding: 0;
	
    display: flex;
    flex-wrap: wrap;
	justify-content: space-between;
    align-items: flex-start;
}

div.contents_index_container {
	width:100%;
	height:auto;
	margin:0;
	padding:0;
	
	display: flex;
    flex-wrap: wrap;
	justify-content: space-between;
    align-items: center;	
}

a.contents_index_list {
	width: 344px;
	height: auto;
	margin: 0 0 48px;
	padding: 0;
	
	display: block;
}

a.contents_index_list img{
	width: 100%;
	height: auto;
	margin: 0 0 16px;
	padding: 0;
	
	display: block;
}

a.contents_index_list h2{
	margin: 0 0 8px;
	padding: 0;
	
	font-size: 1rem;
	font-weight: bold;
	line-height: 1;
	color: #0E4098;
}

a.contents_index_list span.another {
	padding: 0 1.6rem 0 0;
    position: relative;
}

a.contents_index_list span.another::after {
	content: '';
    width: 1rem;
    height: 1rem;
    margin: 0;
    padding: 0;
    display: inline-block;
    background-image: url(../images/another.svg);
    background-size: 1rem 1rem;
    position: absolute;
    top: 50%;
    right: 0%;
    transform: translateY(-50%);
    -webkit-transform: translateY(-50%);
    -ms-transform: translateY(-50%);
}

a.contents_index_list p{
	margin: 0;
	padding: 0;
	
	font-size: 0.88rem;
	line-height: 1.6;
	color: #212121;
}

div.contents_index_list.blank {
	content: "";
	width: 344px;
	height: auto;
	margin: 0;
	padding: 0;
	
	display: block;
}

/*a.contents_index_list:nth-last-child(-n+2) {
	margin: 0;
}*/

/*detail page common*/

div.header_detail_bg {
	width: 100%;
	height: 160px;
	margin: 0;
	padding: 80px 0 0;
	
	background-color: #f6fafc;
	position: relative;
}

div.header_detail_title {
    width: 1120px;
    height: 100%;
    margin: auto;
	padding: 0;
	
	position: relative;
  }

div.header_detail_title div{
    margin: 0;
	padding: 0;
	
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    -webkit-transform: translate(-50%, -50%);
    -ms-transform: translate(-50%, -50%);
  }

div.header_detail_title h1{
    margin: 0 0 0;
	padding: 0;
	
	color: #0E4098;
	text-align: center;
	font-size: 2em;
	font-weight: bold;
	letter-spacing: 0.1em;
	text-indent: -0.05em;
	line-height: 1;
  }

div.header_detail_title p{
    margin: 16px 0 0;
	padding: 0;
	
	color: #333;
	text-align: center;
	font-size: 0.96em;
	font-weight: bold;
	letter-spacing: 0.1em;
	text-indent: 0.1em;
	line-height: 1.8;
  }

div.contents_detail_outline {
	width: 1120px;
    height: auto;
    margin: 175px auto 64px;
    padding: 239px 80px 64px;
    display: block;
    background-color: #fff;
	
	position: relative;
}

div.contents_detail_outline.image_data {
	margin: 0 auto 64px;
	padding: 64px 80px 64px;
}

div.contents_detail_container {
    width: 100%;
    height: auto;
    margin: 0;
    padding: 0;
	
    display: block;
}

div.inner.small{
	width: 640px;
	height: auto;
	margin: 0 auto;
	padding: 0;
	
	display: block;
}

.inner h1{
	margin: 0 0 24px;
	padding: 0;
	
	text-align: center;
	font-size: 1.6rem;
	line-height: 1;
	letter-spacing: 0.15em;
	color: #0E4098;
}



/*about*/

.contents_detail_outline.image_about::before {
	content: "";
	width: 1120px;
	height: 350px;
	display: block;
	
	background-image:url("../images/detail_about_pc.jpg");
	
	position: absolute;
	top: -172px;
	left: 80px;
}

.company_profile {
	margin: 0;
	padding: 0;
	
	display: block;
	font-size: 1em;
	color: #333;
}

.company_profile dl {
	width: 100%;
    height: auto;
    margin: 0;
    padding: 16px 0;
	
    display: flex;
	display: -webkit-flex;
    display: -moz-flex;
    flex-wrap: wrap;
    align-items: stretch;
	
	border-bottom: 1px dotted #DDDFE1;
    line-height: 1.8;
    font-size: 0.96rem;
}

.company_profile dt {
	width: 120px;
    margin: 0 0 0 48px;
	
    text-align: left;
    font-weight: bold;
    color: #0E4098;
}

.company_profile dd {
	width: calc(100% - 208px);
	text-align: left;
}

.philosophy {
	width: fit-content;
	margin: 0 auto;
}

.philosophy ul {
	margin: 0 auto;
	padding: 0;
}

.philosophy li {
	margin: 0 0 24px 2em;
	padding: 0;
	color: #333;
	font-size: 1rem;
	line-height: 1;
	font-weight: bold;
}

/*business*/

.contents_detail_outline.image_business::before {
	content: "";
	width: 1120px;
	height: 350px;
	display: block;
	
	background-image:url("../images/detail_business_pc.jpg");
	
	position: absolute;
	top: -172px;
	left: 80px;
}

.inner.large .business_list {
	width: 100%;
	height: auto;
	margin: 0;
	padding: 0;
	
	display: flex;
	flex-wrap: wrap;
	justify-content: space-between;
}

.business_list_detail {
	width: 540px;
	height: auto;
	margin: 0 0 64px;
	padding: 0;
}

.business_list_detail:last-child {
	margin: 0;
}

.business_list_detail img{
	width: 100%;
	height: auto;
	margin: 0 0 12px;
	padding: 0;
}

.business_list_detail p.lead{
	margin: 0 0 12px;
	font-weight: bold;
	line-height: 1;
}

.business_list_detail h2 {
	margin: 0 0 8px;
	letter-spacing: 0.04em;
	text-align: left;
}

.business_list_detail p.summary{
	margin: 0 0 8px;
	line-height: 1.6;
}

.business_list_detail ul {
	margin: 0;
    padding: 0;
	list-style: none;
}

.business_list_detail ul li{
	margin: 0!important;
    padding: 0 0 0 24px;
    color: #212121;
    position: relative;
    line-height: 2;
    vertical-align: middle;
}

.business_list_detail ul li.list_blue::before {
    content: '';
    width: 24px;
    height: 24px;
    display: inline-block;
    background: url(../images/footer_list_blue.png) 4px 12px no-repeat;
    background-size: 6px 6px;
    position: absolute;
    top: 0;
    left: 0;
}

.business_list_detail ul li.list_gray::before {
    content: '';
    width: 24px;
    height: 24px;
    display: inline-block;
    background: url(../images/footer_list_gray.png) 4px 12px no-repeat;
    background-size: 6px 6px;
    position: absolute;
    top: 0;
    left: 0;
}

.business_list_detail ul li a {
	text-decoration: none;
}

.business_list_detail ul li a span.another {
	padding: 0 28px 0 0;
    position: relative;
}

.business_list_detail ul li a span.another::after {
    content: '';
    width: 20px;
    height: 20px;
    margin: 0;
    padding: 0;
    display: inline-block;
    background: url(../images/another.svg) 4px 2px no-repeat;
    background-size: 16px 16px;
    position: absolute;
    top: 50%;
    right: 0;
    transform: translateY(-50%);
    -webkit-transform: translateY(-50%);
    -ms-transform: translateY(-50%);
}

/*monotan*/

.contents_detail_outline.image_monotan::before {
	content: "";
	width: 1120px;
	height: 350px;
	display: block;
	
	background-image:url("../images/detail_monotan_pc.png");
	
	position: absolute;
	top: -172px;
	left: 80px;
}

.monotan_profile {
	margin: 0 48px 48px;
	padding: 0;
	
	display: block;
	font-size: 1em;
	color: #333;
}

.monotan_profile dl {
	width: 100%;
    height: auto;
    margin: 0;
    padding: 16px 0;
	
    display: flex;
	display: -webkit-flex;
    display: -moz-flex;
    flex-wrap: wrap;
    align-items: stretch;
	
	border-bottom: 1px dotted #DDDFE1;
    line-height: 1.8;
    font-size: 0.96rem;
}

.monotan_profile dt {
	width: 120px;
    margin: 0 0 0 48px;
	
    text-align: left;
    font-weight: bold;
    color: #0E4098;
}

.monotan_profile dd {
	width: calc(100% - 208px);
	text-align: left;
}

.monotan_sns {
	display: flex;
    justify-content: space-between;
    flex-wrap: wrap;
    align-items: center;
}

a.btn_twitter {
	width: 300px;
	height: 64px;
	margin: 0;
	padding: 0;
	
	display: flex;

	position: relative;
	border: solid 1px #1DA1F2;
}

a.btn_twitter img{
	width: auto;
	height: 40px;
	margin: auto 0 auto 16px;
	padding: 0;
	
	display: block;
}

a.btn_twitter p{
    margin: auto;
    padding: 0 0 0 40px;
	
	color: #1DA1F2;
    line-height: 64px;
	text-align: center;
	text-decoration: none;
	font-size: 0.88rem;
	font-weight: bold;
	
    display: block;
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
}

a.btn_instagram {
	width: 300px;
	height: 64px;
	margin: 0;
	padding: 0;
	
	display: flex;

	position: relative;
	border: solid 1px #D93177;
	background-color: #fff;
}

a.btn_instagram img{
	width: auto;
	height: 40px;
	margin: auto 0 auto 16px;
	padding: 0;
	
	display: block;
}

a.btn_instagram p{
	margin: auto;
    padding: 0 0 0 40px;
	
	color: #D93177;
    line-height: 64px;
	text-align: center;
	text-decoration: none;
	font-size: 0.88rem;
	font-weight: bold;
	
    display: block;
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
}

.stamp_series {
	width: 100%;
	height: auto;
	margin: 0 0 48px;
	padding: 0;
}

p.stamptitle{
	margin: 0 0 12px;
	
	font-size: 1.24em;
	line-height: 1;
	text-align: center;
	font-weight: bold;
}

img.monotan_linestickers{
	width: 100%;
	height: auto;
	margin: 0 auto;
	padding: 0;
	
	display: block;
}

/*data*/

.contents_detail_outline.image_data::before {
	display: none;
}

.data_container {
	width: 100%;
	height: auto;
	margin: 0;
	padding: 0;
	
	display: flex;
	flex-wrap: wrap;
	justify-content: space-between;
}

.data_container .data_tile_m{
	width: 352px;
	height: auto;
	margin: 0 0 40px;
	padding: 24px 0;
	
	display: block;

	border: solid 1px #E9F4F9;
	background-size: 104px, cover;
	background-repeat: no-repeat, no-repeat;
	background-position: top 24px right 24px, center;
}

.data_tile_m.data_bg_01 {
	background-image: url("../images/data_bg_01.png"),linear-gradient(0deg, #fff 0%, #fff 100%);
}

.data_tile_m.data_bg_02 {
	background-image: url("../images/data_bg_02.png"),linear-gradient(0deg, #fff 0%, #fff 100%);
}

.data_tile_m.data_bg_03 {
	background-image: url("../images/data_bg_03.png"),linear-gradient(0deg, #fff 0%, #fff 100%);
}

.data_container .data_tile_l{
	width: auto;
	height: auto;
	margin: 0 0 40px;
    padding: 40px 384px 40px 0;
	
	display: block;
	border: solid 1px #E9F4F9;
	
	background-size: 300px, cover;
    background-repeat: no-repeat, no-repeat;
    background-position: center right 64px, center;
}

.data_tile_l.data_bg_04 {
	background-image: url("../images/data_bg_04.png"),linear-gradient(0deg, #fff 0%, #fff 100%);
}

.data_container .data_tile_s{
	width: 262px;
    height: auto;
    margin: 0;
    padding: 24px 0;
    
	display: block;
    
	border: solid 1px #E9F4F9;
    
	background-size: 72px, cover;
    background-repeat: no-repeat, no-repeat;
    background-position: top 24px right 24px, center;
}

.data_tile_s.data_bg_05 {
	background-image: url("../images/data_bg_05.png"),linear-gradient(0deg, #fff 0%, #fff 100%);
}

.data_tile_s.data_bg_06 {
	background-image: url("../images/data_bg_06.png"),linear-gradient(0deg, #fff 0%, #fff 100%);
}

.data_tile_s.data_bg_07 {
	background-image: url("../images/data_bg_07.png"),linear-gradient(0deg, #fff 0%, #fff 100%);
}

.data_tile_s.data_bg_08 {
	background-image: url("../images/data_bg_08.png"),linear-gradient(0deg, #fff 0%, #fff 100%);
}

.data_container .data_label {
	width: auto;
	height: 88px;
	margin: 0;
	padding: 0;
}

.data_container .data_title {
	margin: 0 0 8px 32px;
    padding: 0;
    font-size: 0.96rem;
    line-height: 1.4;
    color: #212121;
    font-weight: bold;
}

.data_container .data_sub_title {
	margin: 0 0 0 32px;
	padding: 0;
	
	font-size: 0.8rem;
	line-height: 1;
	color: #0E4098;
	font-weight: bold;
}

.data_container .data_tile_l .data_label {
	width: auto;
	height: 88px;
	margin: 0;
	padding: 0;
}

.data_container .data_tile_l .data_title {
	margin: 0 0 8px 32px;
    padding: 0;
    font-size: 1.24rem;
    line-height: 1.4;
    color: #212121;
    font-weight: bold;
}

.data_container .data_tile_l .data_sub_title {
	margin: 0 0 0 32px;
	padding: 0;
	
	font-size: 0.96rem;
	line-height: 1;
	color: #0E4098;
	font-weight: bold;
}

.data_container .data_tile_m .data_contents {
	content: '';
	
	width: auto;
    height: 104px;
    margin: -12px 24px 32px;
	padding: 0;
	
	display: block;
	
	background-size: contain;
	background-position: center;
	background-repeat: no-repeat;
}

.data_container .data_tile_l .data_contents {
	content: '';
	
	width: 654px;
    height: 176px;
    margin: 12px 40px 16px;
    padding: 0;
	
	display: block;
	
	background-size: contain;
	background-position: center;
	background-repeat: no-repeat;
}

.data_container .data_tile_s .data_contents {
	content: '';
	
	width: auto;
    height: 88px;
    margin: 4px 24px 8px;
	padding: 0;
	
	display: block;
	
	background-size: contain;
	background-position: center;
	background-repeat: no-repeat;
}

.data_container .data_contents.data_01 {
/*	background-image: url("../images/data_01.png");*/
}

.data_container .data_contents.data_02 {
/*	background-image: url("../images/data_02.png");*/
}

.data_container .data_contents.data_03 {
/*	background-image: url("../images/data_03.png");*/
}

.data_container .data_contents.data_04 {
/*	background-image: url("../images/data_04.png");*/
}

.data_container .data_contents.data_05 {
/*	background-image: url("../images/data_05.png");*/
}

.data_container .data_contents.data_06 {
/*	background-image: url("../images/data_06.png");*/
}

.data_container .data_contents.data_07 {
/*	background-image: url("../images/data_07.png");*/
}

.data_container .data_contents.data_08 {
/*	background-image: url("../images/data_08.png");*/
}

.data_container .data_contents p{
	color: #0d4199;
	font-weight: bold;
	display: flex;
	justify-content: center;
	align-items: baseline;
}
.data_container .data_contents p span{
	font-family: 'arial';
	font-feature-settings: "liga" 0;
	font-size: 4.5em;
	line-height: 1em;
	letter-spacing: -0.03em;
	display: block;
	margin: 0 0.1em;
}
@media screen and (min-width: 1000px){
	.data_container .data_contents p span{
		font-size: 6em;
	}
	.data_container .data_contents.data_08 p span{
		margin: 0;
	}
	.data_container .data_tile_m .data_contents p{
		font-size: 2em;
	}
	.data_container .data_tile_m .data_contents p span{
		font-size: 3.5em;
	}
	.data_container .data_contents.data_04 {
		font-size: 1.75em;
	}
}


.data_container .data_caption {
	width: auto;
    height: auto;
    margin: 0 24px 0;
    padding: 16px 0 0;
    display: flex;
    align-items: center;
    border-top: solid 1px #F2F2F2;
}

.data_container .data_tile_l .data_caption {
	margin: 0 32px 0;
    padding: 24px 0 0;
}

.data_container .data_caption p{
	margin: 0 auto 0;
	padding: 0;
	
	font-size: 0.72rem;
	line-height: 1.6;
	color: #212121;
	font-weight: bold;
	text-align: center;
}

.data_container .data_caption p br.pconly{
	display: inherit;
}

.data_container .data_tile_l .data_caption p{
	margin: 0 auto 0;
	padding: 0;
	
	font-size: 0.96rem;
	line-height: 1.6;
	color: #212121;
	font-weight: bold;
	text-align: center;
}

/*works*/

.category_container {
	width: 100%;
	height: auto;
	margin: 0 0 48px;
	padding: 0;
	
	display: flex;
    justify-content: space-between;
    flex-flow: wrap;
}

.category_container img {
	width: 548px;
	height: auto;
	margin: 0;
	padding: 0;
	
	display: block;
}

.category_container .category_text {
	width: 492px;
    height: auto;
    margin: auto 0;
    padding: 0;
	
    display: block;
}

.category_container .category_text h2{
	margin: 0 0 20px;
	padding: 0;
	
	font-size: 1.6rem;
	line-height: 1;
	color: #0E4098;
}

a.work_category {
	width: 262px;
	height: auto;
	margin: 0 0 48px;
	
	text-decoration: none;
}

div.work_category.blank {
	display: none;
}

.style_01 a.work_category{
	margin: 0;
}

.style_01 a.work_category:nth-last-child(-n+2){
	margin: 0;
}

.style_02 a.work_category:nth-child(n+5){
	margin: 0;
}

.work_category img {
	width: 100%;
    height: auto;
    margin: 0 0 8px;
}

.category_detail {
	width: 100%;
	height: auto;
	margin: 0;
	padding: 0;
	
	display: flex;
    justify-content: space-between;
    flex-flow: wrap;
}

.category_detail h3{
	margin: 0 0 8px;
	padding: 0;
	font-size: 1.12rem;
    line-height: 1;
}

.category_detail p{
	margin: 0;
	padding: 0;
	
	font-size: 0.8rem;
	line-height: 1.6;
}

/*-----requirements-----*/

.recruit_top {
	width: 100%;
	height: auto;
	margin: 0 0 32px;
	padding: 0;
	
	display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
	    align-items: center;
	
	text-decoration: none!important;
}

.gra_image{
	flex-direction: row;
}

.car_image{
	flex-direction: row-reverse;
}

.recruit_top div {
	width: 332px;
	height: auto;
	margin: 0;
	padding: 0;
	
	display: block;
}

.recruit_top div h1{
	margin: 0 0 16px;
    padding: 0;
    color: #0E4098;
    line-height: 1.4;
    text-align: justify;
    font-size: 2rem;
}

.recruit_top div p{
	margin: 0;
	padding: 0;
	
	color: #212121;
	line-height: 2;
}

.recruit_top img {
	width: 740px;
	height: auto;
	margin: 0;
	padding: 0;
	
	display: block;
}

.recruit_top_list {
	width: 358px;
    height: 88px;
    margin: 0 0 24px;
    padding: 0;
    display: flex;
    border: solid 1px #0E4098;
    background-color: #fff;
    color: #0E4098;
    text-decoration: none!important;
}

.recruit_top_list:nth-last-child(-n+3){
	margin: 0;
}

.recruit_top_list.blank {
	content: '';
	width: 358px;
    height: 88px;
	border: none;
    background: none;
}

.recruit_contents_container {
	width: 100%;
	height: auto;
	margin: 0;
	padding: 0;
}

.graduate_container {
	width: 100%;
	height: auto;
	margin: 0;
	padding: 0;
}

.career_container {
	width: 100%;
	height: auto;
	margin: 0;
	padding: 0;
}

.recruit_contents {
	width: 100%;
	height: auto;
	margin: 0;
	padding: 0;
	
	display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
}

.recruit_contents .gra_contents {
	width: 548px;
	height: auto;
	margin: 0;
	padding: 0;
	
	display: block;
	text-decoration: none;
}

.recruit_contents .gra_contents img {
	width: 100%;
	height: auto;
	margin: 0 0 16px;
	padding: 0;
	
	display: block;
}

.recruit_contents .gra_contents h2 {
    margin: 0 0 8px;
    padding: 0;
    font-size: 1.12rem;
    font-weight: bold;
    line-height: 1;
    color: #0E4098;
}

.recruit_contents .gra_contents p {
    margin: 0;
    padding: 0;
    font-size: 0.88rem;
    line-height: 1.6;
    color: #212121;
}

.recruit_contents .sub_contents {
	width: 358px;
	height: auto;
	margin: 0;
	padding: 0;
	
	display: block;
	text-decoration: none;
}

.recruit_contents .sub_contents img {
	width: 100%;
	height: auto;
	margin: 0 0 16px;
	padding: 0;
	
	display: block;
}

.recruit_contents .sub_contents h2 {
    margin: 0 0 8px;
    padding: 0;
    font-size: 1rem;
    font-weight: bold;
    line-height: 1;
    color: #0E4098;
}

.recruit_contents .sub_contents p {
    margin: 0;
    padding: 0;
    font-size: 0.88rem;
    line-height: 1.6;
    color: #212121;
}


.recruit_menu_container {
	width: 100%;
	height: auto;
	margin: 80px 0 0;
	padding: 0;
	
	display: flex;
	flex-wrap: wrap;
	justify-content: space-between;
}

a.recruit_menu {
	width: 536px;
	height: auto;
	margin: 0 0 48px;
	padding: 0;
	
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	justify-content: space-between;
	text-decoration: none;
}

a.recruit_menu:nth-child(3), a.recruit_menu:nth-child(4){
	margin: 0;
}

.recruit_menu img {
	width: 200px;
	height: auto;
	margin: 0;
	padding: 0;
	
	display: block;
}

.recruit_menu div {
	width: calc(100% - 224px);
	height: auto;
	margin: 0;
	padding: 0;
	
	display: block;
}

.recruit_menu h2{
	margin: 0 0 12px;
}

.recruit_menu p {
	font-size: 0.88rem;
	line-height: 1.6;
}

.header_info_bg {
	width: 100%;
    height: 200px;
    margin: 0;
    padding: 80px 0 0;
}

.header_info_title {
	width: 1120px;
    height: 200px;
    margin: 0 auto;
    padding: 0;
	
    position: relative;
}

.header_info_title div{
	margin: 0;
    padding: 0;
	
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    -webkit-transform: translate(-50%, -50%);
    -ms-transform: translate(-50%, -50%);
}

.header_info_title h1{
	margin: 0 0 0;
    padding: 0;
	
    color: #fff;
    text-align: center;
    font-size: 2em;
    font-weight: bold;
    letter-spacing: 0.1em;
    text-indent: -0.05em;
    line-height: 1;
}

.header_info_title h1.deep{
	color: #0E4098;
}

.header_info_title p{
	margin: 16px 0 0;
    padding: 0;
	
    color: #fff;
    text-align: center;
    font-size: 0.96em;
    font-weight: bold;
    letter-spacing: 0.1em;
    text-indent: 0.1em;
    line-height: 1.8;
}

.header_info_title p.deep {
	color: #262626;
}

.info_detail_outline {
	width: 800px;
    height: auto;
	margin: 0 auto 64px;
	padding: 80px;
	background-color: #fff;
}

.info_detail_container {
	width: 100%;
	height: auto;
}

.info_detail_container section.announce {
	margin: 0 0 48px;
}

.info_detail_container .inner.intro p {
	font-size: 0.96rem;
}

.info_detail_container h2 {
	margin: 0 0 32px;
	text-align: center;
}

.seminar {
	width: 528px;
	height: auto;
	margin: 0 auto;
	padding: 40px 56px;
	
	background: linear-gradient(180deg, #528AD5 0%, #D4ECF3 100%);
	
	border-radius: 16px;
}

.seminar h3 {
	margin: 0 0 8px;
	padding: 0;
	
	font-size: 1.24rem;
	line-height: 1;
	text-align: center;
	color: #fff;
}

.seminar p {
	margin: 0 0 16px;
	padding: 0;
	
	font-size: 0.88rem;
	text-align: center;
	color: #fff;
}

/*-----requirements-----*/





div.header_img h1 {
  font-size: 48px;
  font-weight: bold;
  color: #0E4098;
  padding: 0;
  margin: 0;
	letter-spacing: 0.2em;
	text-indent: 0.2em;
}

div.header_img h1 img {
    vertical-align: text-bottom;
    width: 362px;
    height: 64px;
    margin-left: 30px;
  }

div.header_img_contentsbox_requirements {
	width:1120px;
	height:100%;
	margin:0 auto;
	padding:0;
	
	display: flex;
	justify-content: center;
    align-items: center;
	z-index:8;
}

/*div.interview_inner {
	width: 100%;
	height: auto;
	margin: 0;
	padding: 0;
}*/

div.text_over {
    margin: auto;
    padding: 0;
}

div.text_over a:hover,a:active {
    opacity: 1;
}

div.outline_text .text_over p{
    margin: 0 auto 24px;
    padding: 0;
	
    text-align: center;
    font-size: 1.24em;
    font-weight: bold;
    color: #fff;
    letter-spacing: 0.1em;
    line-height: 1;
}

div.outline_inner_gra {
	width:100%;
	height: auto;
	margin: 64px 0 0;
	padding: 0;
	
	display: flex;
    justify-content: space-between;
    flex-flow: wrap;
	
	background-image: url("../images/PC_requirements_gra.jpg");
	background-size: 100% auto;
	background-repeat: no-repeat;
	background-position-y: center;
}

div.outline_inner_car {
	width:100%;
	height: auto;
	margin: 64px 0 0;
	padding: 0;
	
	display: flex;
    justify-content: space-between;
    flex-flow: wrap;
	
	background-image: url("../images/PC_requirements_car.jpg");
	background-size: 100% auto;
	background-repeat: no-repeat;
	background-position-y: center;
}

div.outline_inner_int {
	width:100%;
	height: auto;
	margin: 64px 0 0;
	padding: 0;
	
	display: flex;
    justify-content: space-between;
    flex-flow: wrap;
	
	background-image: url("../images/PC_requirements_int.jpg");
	background-size: 100% auto;
	background-repeat: no-repeat;
	background-position-y: center;
}

h1.outline_gc{
	margin: 0 0 24px;
	padding: 0;
	
	display: block;
	font-size: 5.6em;
	line-height: 1;
	text-indent: 0.25em;
    letter-spacing: 0.25em;
	color: #fff;
	font-weight: bold;
	
	text-shadow: 4px 4px 0 rgba(50,50,50,0.9);
}

h1.outline_i{
	/*margin: 0 0 24px;*/
	margin: 0 0 0;
	padding: 0;
	
	display: block;
	font-size: 3.4em;
	line-height: 1.4;
	text-indent: 0.25em;
    letter-spacing: 0.1em;
	color: #fff;
	font-weight: bold;
	
	text-shadow: 4px 4px 0 rgba(50,50,50,0.9);
}



div.gra_bg {
	background:linear-gradient(90deg,rgba(0,63,152,1) 0%,rgba(0,63,152,1) 72%,rgba(18,46,104,0.6) 72%,rgba(18,46,104,0.6) 100%);
}

div.car_bg {
	background:linear-gradient(-90deg,rgba(0,63,152,1) 0%,rgba(0,63,152,1) 72%,rgba(18,46,104,0.6) 72%,rgba(18,46,104,0.6) 100%);
}


.contents_detail_outline.image_graduate::before {
	content: "";
	width: 1120px;
	height: 350px;
	display: block;
	
	background-image:url("../images/detail_graduate_pc.jpg");
	
	position: absolute;
	top: -172px;
	left: 80px;
}

.contents_detail_outline.image_career::before {
	content: "";
	width: 1120px;
	height: 350px;
	display: block;
	
	background-image:url("../images/detail_career_pc.jpg");
	
	position: absolute;
	top: -172px;
	left: 80px;
}


div.outline_inner {
	width:100%;
	height: auto;
	margin:0;
	padding: 64px 0 0;
	
	display: flex;
    justify-content: space-between;
    flex-flow: wrap;
}

div.outline_mirror {
	width:100%;
	height: auto;
	margin:0;
	padding: 64px 0 0;
	
	display: flex;
    justify-content: space-between;
    flex-flow: wrap;
}

div.outline_image {
	width:50%;
	height: auto;
	margin:0;
	padding: 0;
	
	display: block;
}

div.outline_image img{
	width:100%;
	height: auto;
	margin:0 0 0 auto;
	padding: 0;
	
	display: block;
}

div.outline_image img.pconly{
	width:100%;
	height: auto;
	margin:0 0 0 auto;
	padding: 0;
	
	display: block;
}

div.outline_image img.sponly{
	
	display: none;
}

div.outline_text {
	width:50%;
	height: auto;
	margin:0;
	padding: 0;
	
	display: flex;
}

div.outline_text h2{
	margin: 0;
    padding: 0;
	
	text-align: center;
    color: #0E4098;
    font-size: 1.5em;
    font-weight: bold;
    line-height: 1;
    letter-spacing: 0.08em;
}

div.outline_text p{
	margin: 0 0 24px;
    padding: 0;
	
	text-align: justify;
    color: #333;
    font-size: 1em;
    line-height: 2;
}

div.outline_text hr {
	width: 32px;
    height: 8px;
	margin: 24px auto;
    padding: 0;
    
	background-color: #d4ecf3;
    border: none;
}

div.outline_text div.text_right{
	width: 488px;
    height: auto;
    margin: auto auto auto 72px;
    padding: 0;
}

div.outline_text div.text_left{
	width: 488px;
    height: auto;
    margin: auto 72px auto auto;
    padding: 0;
}

div.main_contents_inner {
 width:1120px;
 margin:0 auto;
	overflow: hidden;
}

div.main_contents_inner a{
  color: #222;
}

div.main_contents_inner h2 {
	margin: 32px auto 16px;
	padding: 8px 0;
	display: block;
	text-align:center;
	clear:both;
}

div.main_contents_inner h3 a {
	width: 45%;
    height: auto;
	margin: 0 auto;
	padding: 24px 16px;
	
	display: block;
	clear:both;
	
	text-align:center;
	
    
    border: 1px solid #ccc;
    border-bottom: 3px solid #999;
    
    border-radius: 3px;
    -webkit-border-radius: 3px;
    -moz-border-radius: 3px;
    text-decoration: none !important;
    font-weight: bold;
}

div.main_contents_inner #gra {
	padding:32px 0 0;
}

.publication_data_container{
	width: 100%;
	height: auto;
	margin: 0 0;
	padding: 0;
	
	display: flex;
	justify-content: space-between;
	flex-wrap: wrap;
}

.publication_data_container dl {
	width: calc(100% / 3 + 1px);
	margin: 0 0 0 -1px;
	padding: 0;
	
	 border-collapse: collapse;
    white-space: nowrap;
}

.publication_data_container dt {
	margin: 0;
	padding: 32px 24px;
    background: #F6FAFC;
    border: 1px solid #eee;
    border-collapse: collapse;
    white-space: nowrap;
    text-align: center;
    color: #0E4098;
	font-weight: bold;
}

.publication_data_container dd {
	margin: -1px 0 0;
	padding: 32px 24px;
	background: #fff;
    border: 1px solid #eee;
    border-collapse: collapse;
	white-space: nowrap;
    text-align: center;
}

.contact_wrap{
	max-width:1120px;
	margin: 0 auto;
	padding: 0;
	display: block;
	background-color: #ffffff;
}

.contact_wrap .tblwrap {
	width: 100%;
	margin: 0 auto;
	font-size: 16px;
}

.tblwrap {
	width: 100%;
	margin: 0 auto;
}



.tblwrap table {
	  width: 100%;
	  margin: 0;
	  border-collapse:collapse;
	  border-spacing:0;
	  word-break: break-all;
	
	font-size: 0.96rem;
  }
  

.tblwrap table th {
    width: 152px;
	padding: 32px 24px;
	
	background: #F6FAFC;
    border: 1px solid #eee;
    border-collapse: collapse;
    
    white-space: nowrap;
	text-align: center;
	color: #0E4098;
  }

.tblwrap table td {
    width: 640px;
	padding: 36px 40px;
	
	border: 1px solid #eee;
    border-collapse: collapse;
  }

.tblwrap table ul {
	margin: 0 auto;
    padding: 0;
}

.tblwrap table li {
	font-size: 0.96rem;
	font-weight: normal;
}

.tblwrap table .info_date {
	margin: 0 0 16px;
}

.tblwrap table .info_date li {
	font-weight: bold;
}

.tblwrap table .space_top {
	margin: 16px auto 0;
    padding: 0;
	
	display: block;
}

.tblwrap table .space_bottom {
	margin: 0 auto 16px;
    padding: 0;
	
	display: block;
}

.tblwrap table span.job_type {
	font-weight: bold;
	color: #0E4098;
}

.tblwraph4 {
    font-size: 18px;
    font-weight: bold;
    margin: 0 20px 15px;
  }

.tblwrap .annivbox {
    width: 50%;
    float: left;
  }

dl.group{
	width: 22%;
	margin: 0;
	
	font-size: 16px;
	border-collapse: collapse;
}

dl.theme{
	width: 34%;
	margin: 0;
	font-size: 16px;
	border-collapse: collapse;
	line-height: 1.4;
}


.bgnone{
	background: none!important;
	border: none!important;
}

dt.term{
	margin: 0;
	padding: 16px 0;
	font-size: 16px;
	border-top: 1px solid #999;
	border-left: 1px solid #999;
	border-collapse: collapse;
	background: #efefef;
	text-align: center;
}


dd.percentage{
	margin: 0;
	padding: 16px 0;
	font-size: 16px;
	border-top: 1px solid #999;
	border-left: 1px solid #999;
	border-collapse: collapse;
	text-align: center;
	background-color: #fff;
}

/*採用までの流れ*/

.flow {
    margin: 0;
    padding: 0;
  }

.flow_evnet {
	width: 100%;
	min-height: 56px;
	margin: 0 0 32px;
    padding: 0 0 16px;
	
	display: flex;
	flex-wrap: wrap;
	justify-content: space-between;
	
    font-size: 1rem;
    line-height: 1.8;
	
	position: relative;
    }

.flow_evnet::before {
	content: '';
    width: 28px;
    height: 16px;
    margin: 0;
    padding: 0;
    position: absolute;
    display: block;
    bottom: 0;
    left: 50%;
    transform: translateX(-50%);
    -webkit-transform: translateX(-50%);
    -ms-transform: translateX(-50%);
    background-image: url("../images/flow_gray.png");
    background-size: 28px auto;
    background-repeat: no-repeat;
}

.flow_evnet:last-child {
	margin: 0;
	padding: 0;
}

.flow_evnet:last-child::before {
	display: none;
}

.flow_caption {
	width: 512px;
	margin: 0 0 32px;
}

.flow_evnet:last-child .flow_caption{
	margin: 0;
}

.flow_caption h3 {
	margin: 0 0 6px;
    padding: 4px 0 0;
    line-height: 1;
    font-size: 1.24rem;
    color: #0E4098;
}

.number {
	content: '';
    width: 128px;
    height: 56px;
}

.number.entry {
	background: url(../images/flow_01.png) 0 0 no-repeat;
	background-size: auto 56px;
    }

.flow div.lecture {
	background: url(../images/flow_02.png) 0 0 no-repeat;
	background-size: auto 56px;
      }

.flow div.paperwork {
	background: url(../images/flow_03.png) 0 0 no-repeat;
	background-size: auto 56px;
    }

.flow div.written {
	background: url(../images/flow_04.png) 0 0 no-repeat;
	background-size: auto 56px;
    }

.flow div.interview {
	background: url(../images/flow_05.png) 0 0 no-repeat;
	background-size: auto 56px;
    }

.flow div.interview_admn {
	background: url(../images/flow_06.png) 0 0 no-repeat;
	background-size: auto 56px;
    }

.flow div.offer {
	background: url(../images/flow_07.png) 0 0 no-repeat;
	background-size: auto 56px;
    }

.flow div.join {
	background: url(../images/flow_08.png) 0 0 no-repeat;
	background-size: auto 56px;
    }


/*採用Ｑ＆Ａ*/

 .qabox {
    overflow: hidden;
    margin: 0;
    padding: 0;
  }

.qabox ul {
    margin:0 0 40px;
	border-bottom: solid 1px #F2F2F2;
}

.qabox ul:last-child {
	margin:0;
}

.qabox li.question {
    margin: 0 40px 8px;
	padding: 0;
	
	display: flex;
	
    font-size: 1rem;
	line-height: 1.8;
	color: #0E4098;
	
	list-style:none;
	font-weight: bold;
	
	/*background: url(https://corp.nikkan.co.jp/images/recruit-question.png) 0 0 no-repeat;
    background-size: 30px 30px;
    padding: 45px;*/
}

.qabox li.question::before {
	content: 'Q.';
    color: #0E4098;
    font-size: 20px;
    margin: 2px 24px 0 0;
    vertical-align: text-top;
    line-height: 1;
}

.qabox li.answer {
	margin: 0 40px 40px;
	padding: 0;
	
	display: flex;
	
	font-size: 1rem;
	line-height: 1.8;
	color: #212121;
	
	list-style:none;
	font-weight: normal;
	
	/*background: url(https://corp.nikkan.co.jp/images/recruit-answer.png) 0 0 no-repeat;
	background-size: 30px 30px;
	padding-left: 45px;*/
    }

.qabox li.answer::before {
	content: 'A.';
	color: #212121;
	font-size: 20px;
	margin: 4px 24px 0 0;
	font-weight: bold;
	vertical-align: text-top;
    line-height: 1;
}

/*説明会*/

.read {
	margin: 0 0 32px;
	padding: 0;
}

.read p {
	margin: 0 0 16px;
	padding: 0;
	
	color: #333;
	font-size: 0.88em;
	line-height: 2;
}

/*説明会ここまで*/

 h3.fresh{
	 display: inline-block;
  color: #54230e;
  font-size: 180%;
  margin: 0;
  position: relative;
  /*float: left;*/
}

 h3.fresh span{
  font-size: 14px;
  display: block;
  line-height:0;
}

.wrap_jobs{
	width: 100%;
	margin: 32px 0;
	background-color: #fff;
}

.wrap_jobs h4 {
	margin: 0 0 24px;
	padding: 0;
	color: #0E4098;
	font-size: 28px;
	border-bottom: solid 2px #0E4098;
}

.wrap_jobs span{
  clear: borh;
  text-align: left;
}

.wrap_jobs span div{
	padding: 0;
}

.wrap_jobs span .flex img{
	width: 24% !important;
	margin: 0 0 auto;
	display: block;
}

.wrap_jobs span .flex .jobs_text {
	width: 72% !important;
	margin: 0 0 auto;
	padding: 0;
}

.wrap_jobs span h5,
.wrap_jobs h6{
	margin: 0;
	padding: 0;
	font-size: 20px;
	color: #333;
	font-weight: bold;
}
.wrap_jobs h6.senpai{
  margin-bottom: 15px;
}
.wrap_jobs span ul{
  list-style: none;
  padding: 0;
  margin: 0 0 24px;
}

.wrap_jobs span ul li{
  padding: 0;
}

.wrap_jobs .accbox {
	margin: 0;
    padding: 0;
}

/*ラベル*/
.wrap_jobs .accbox label {
	margin: 0;
    padding :8px 24px;
	
	display: block;
	font-size: 14px;
    color :#0E4098;
    font-weight: bold;
    background : #fff;
    cursor :pointer;
	
    transition: all 0.5s;
    border-radius: 4px;
    border: #0E4098 solid 1px;
	box-shadow: 2px 2px #0E4098;
}

.wrap_jobs .accbox label:hover {
    background :#0E4098;
    color:#fff;
	box-shadow: 2px 2px #fff;
}
/*チェックは隠す*/
.wrap_jobs .accbox input {
    display: none;
}

/*中身を非表示にしておく*/
.accbox .accshow {
    height: 0;
    padding: 0;
    overflow: hidden;
    opacity: 0;
    transition: 0.8s;
}

/*クリックで中身表示*/
.cssacc:checked + .accshow {
    height: auto;
    opacity: 1;
	text-align: justify;
}
.wrap_jobs .accbox dl dt{
  width: 80px;
  float: left;
  clear: left;
  text-align: center;
}
.wrap_jobs .accbox dl dd{
  float: left;
}
.wrap_jobs  h6{
  padding-top:20px;
}
.wrap_jobs .accbox img{
  margin:0 11px;
}
.wrap_jobs .top_people_list a{
text-decoration: none;
}
.wrap_jobs div.top_people_list li span {
    display: block;
    font-size: 130%;
    color: #044781;
    font-weight: bold;
    text-align: center;
    margin: 10px 0 0 0
}

.fresh .monotan_intro {
	width: 64%;
	margin: 0 auto 48px;
	padding: 40px 64px;
	border-radius: 24px;

	font-size: 1em;
	line-height: 1.8;
	background-color: #D4ECF3;
}

.fresh .monotan_intro span {
	margin:0 0 24px;
	
	display: block;
	text-align: center;
	font-weight: bold;
	font-size: 1.6em;
}

.fresh .attention p {
	margin: 24px 0 0;
	line-height: 1.8;
	text-align: justify;
}

.fresh .monotan_intro img {
	width: 160px;
	margin: 0 auto;
	display: block;
}

.report {
	
	width: 100%;
	height: auto;
	margin: 0 auto;
	padding:0;
	
	display: flex;
	flex-wrap: wrap;
	justify-content: space-between;
	-webkit-align-items: flex-start;  /* Safari etc. */
  -ms-align-items    : flex-start;  /* IE10        */
  align-items        : flex-start;
}

.report img{
	
	width: 34%;
	height: auto;
	margin: 0;
	padding:0;
	
	display: block;
	
}

.report div{
	
	width: 60%;
	height: auto;
	margin: 0 0 auto;
	padding:0;
	
	display: block;
}

.report div h2{
	
	margin: 0 0 8px;
    padding: 0;
    display: block;
    text-align: justify;
    font-size: 1.24em;
    line-height: 1;
    letter-spacing: 0.15em;
    color: #0E4098;
}

.report div h2:after{
	
	display: none;
}

.report ul.review{
	
	margin: 16px 0 0;
	padding: 24px 32px 24px 24px;
	
	background-color: #ECF6F9;
	font-weight: normal;
	font-size:0.88em;
	
	display: block;
}

.report ul.review li{
	text-align: justify;
	font-weight: normal;
}

/*トップへ戻る、フッター*/

/*div.pagetop {
  display: none;
  margin: 0;
  padding: 0;
}
div.pagetop p {
  margin: 0;
  padding: 0;
  position: fixed;
  right: 30px;
  bottom: 60px;
}

div.pagetop a {
  display: block;
  height: 74px;
  width: 74px;
}*/

#pagetop{
  display: none;
  bottom: 0px;
  position: fixed;
  right: 30px;
  z-index: 1000;
}
#pagetop a {
  display: none;
  /*display: block;*/
  text-align: right;
  height: 74px;
  width: 74px;
}

#footer {
	width: 100%;
	padding: 120px 0 32px;
	background: #F2F2F2;
	
	position: relative;
}

.footer_recruit_info {
	width: 672px;
	height: 152px;
	margin: 0 auto;
	padding: 32px 64px;
	
	display: flex;
	
	background: linear-gradient(0deg, #4182CC 0%, #4182CC 12%, #0E4098 100%);
	
	border-radius: 16px;
	
	position: absolute;
	top: -108px;
	left: 50%;
    transform: translateX(-50%);
    -webkit-transform: translateX(-50%);
    -ms-transform: translateX(-50%);
}

.footer_recruit_info_container {
	width: 100%;
	height: auto;
	margin: auto 0;
	padding: 0;
	
	display: block;
}

.footer_recruit_info_container h2 {
	margin: 0 0 16px;
	padding: 0;
	
	font-size: 1.44rem;
	text-align: center;
	color: #fff;
	line-height: 1;
}

.footer_recruit_info_container p {
	margin: 0 0 16px;
	padding: 0;
	
	font-size: 0.72rem;
	text-align: center;
	color: #fff;
	line-height: 1;
}

.footer_recruit_info_menu {
	width: 100%;
	height: auto;
	margin: 0 auto;
	padding: 0;
	
	display: flex;
	flex-wrap: wrap;
	justify-content: space-between;
}

.footer_recruit_info_menu a {
	width: 328px;
	height: 64px;
	margin: 0;
	padding: 0;
	
	display: block;
	
	position: relative;
	
    background-color: #fff;
    border: 1px solid #0E4098;
    border-radius: 4px;
    text-decoration: none;
 }

.footer_recruit_info_menu a p{
	margin: auto;
    padding: 0;
    color: #0E4098;
    font-weight: bold;
    line-height: 64px;
    text-align: center;
    text-decoration: none;
    font-size: 0.88rem;
    display: block;
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
}

.footer_recruit_info_menu a:hover{
	border: solid 1px #fff;
	background: none;
	color: #fff;
}

.footer_recruit_info_menu a p:hover, .footer_recruit_info_menu a p:active {
	color: #fff;
}

.footer_link {
	width:1120px;
	margin: 48px auto 64px;
	padding:0;
	
	display: flex;
	flex-wrap: wrap;
	justify-content: space-between;
}

.footer_link ul {
	width: 760px;
	margin:0;
	padding:0;
	
	display: flex;
	justify-content: space-between;
}

.footer_link ul a {
	width: 120px;
    margin: 0;
	padding: 0 0 0 18px;
    text-align: center;
    color: #212121;
	
	position: relative;
	
    /*
    padding: 0 0 0 14px;
	background: url(../images/footer_list_blue.png) 0px 4px no-repeat;
    background-size: 4px 4px;*/
}

.footer_link ul a::before {
	content: '';
	width: 12px;
	height: 12px;
	display: inline-block;
	
	background: url(../images/footer_list_blue.png) center no-repeat;
    background-size: 4px 4px;
	
    position: absolute;
    top: 50%;
    left: 0%;
    transform: translateY(-50%);
    -webkit-transform: translateY(-50%);
    -ms-transform: translateY(-50%);
}

.footer_link ul a:hover{
    cursor:pointer;
}

.footer_link ul a[target="_blank"] {
	background: url(../images/link.png) no-repeat 90px center;
}

.footer_link ul li {
	font-size:12px;
	list-style:none;
}

.footer_link ul li a.bold {
	padding: 0;
	font-size:14px;
	list-style:none;
	font-weight: bold;
	
	color: #0E4098;
}

.footer_link ul li a.bold::before {
    background: none;
}

.borderright {
  border-right:1px dotted #999;
}

#footer .companylogo {
	width: 240px;
    height: auto;
    margin: 0;
    text-align: center;
}

#footer .companylogo img{
	display: block;
	width: 100%;
	height: auto;
	margin: 0;
	padding: 0;
}
#footer .companylogo span{
	font-size: 6vw;
	font-weight: bold;
	color: #0d4199;
	line-height: 1em;
	display: inline-block;
	margin: 0.5em 0 0;
	padding: 0;
}
@media screen and (min-width: 1000px){
	#footer .companylogo span{
		font-size: 1.25em;
	}
}


#footer .sp_block {
    width: 48%;
}

.rights {
	width: 100%;
	margin: 0;
	border-top: solid 1px #ddd;
}

.rights p{
	margin: 20px 0 0;
	padding: 0;
	font-size: 10px;
	text-align:center;
	color: #0E4098;
	line-height: 1;
}

#footer a:hover{
 opacity:1;
}

#footer .fix_entry {
    position: fixed;
    right: 40px;
    bottom: 40px;
    z-index: 999;
    color: #FFF;
    text-align: center;
}

#footer .fix_entry p{
	width: 100px;
    height: 100px;
    margin: 32px auto 0;
    display: block;
    background: linear-gradient(120deg, #528AD5 0%, #528AD5 24%, #5FD192 100%);
    border-radius: 50%;
    font-size: 1.2rem;
    font-weight: bold;
    text-align: center;
    line-height: 100px;
    box-shadow: 4px 8px 32px rgb(0 0 0 / 8%);
}

#footer .fix_entry p img{
  vertical-align:text-top;
}

#c-modal {
    position: fixed;
    bottom: 0;
    width: 100%;
    box-sizing: border-box;
    z-index: 9999;
    padding: 20px;
    text-align: left;
    background: #000;
    color: #fff;
    display: flex;
    line-height: 1.7;
}
  #c-modal p {
    padding: 10px;
  }
  #c-modal a {
    color: #fff;
    text-decoration: underline;
  }
  #c-modal a:hover {
    text-decoration: none;
  }
#c-modal_close {
    cursor: pointer;
    background: #fff;
    padding: 10px 30px;
    width: 100px;
    text-align: center;
    color: #000;
    margin: auto;
}
  #c-modal_close a {
    color: #000;
    text-align: none;
  }