@charset "UTF-8";

/* ==================================================
トップ
================================================== */
/* visual
============================== */
#visual {
	position:relative;
	clear:both;
}
#visual_caption {
	position:absolute;
	left:40px;
	bottom:40px;
	z-index:1;
}
#visual .visual_slide img {
	max-width:none;
	width:100%;
}
#visual .slick-dots {
	list-style:none;
	position:absolute;
	right:40px;
	bottom:40px;
	z-index:1;
	background:#000;
	padding:10px 5px;
}
#visual .slick-dots li {
	float:left;
	padding:0 5px;
}
#visual .slick-dots li button {
	cursor:pointer;
	border:1px solid #fff;
	background-color:#fff;
	color:#000;
	display:block;
	padding:0;
	width:40px;
	height:5px;
	overflow:hidden;
	text-indent:-9999px;
	white-space:nowrap;
}
#visual .slick-dots li.slick-active button {
	border:1px solid #ffd700;
	background-color:#ffd700;
}
/* instgram_view
============================== */
#instgram_view {
	background:url(../images/top/inst_bg.png) no-repeat 0 0;
	padding:34px 0;
	min-height:400px;
	clear:both;
}
#instgram_view_ttl {
	margin:0 0 15px;
}
#instgram_view_cnt .item {
	text-align:center;
	border:5px solid #ccc;
	background:#f5f5f5;
	padding:80px 0;
}
/* 投稿エリア */
.instagram-container {
	display: flex;
	flex-wrap: wrap;
	margin: 0 -1px;
}
.instagram-item {
	width: 16.6%;
	padding: 1px;
	margin-bottom: 16px;
}
.instagram-item a {
	display: block;
	position: relative;
	overflow:hidden;
	height:70%;
	background:#141c36;
	color:#fff;
	text-decoration:none;
}
.instagram-item a img {
	max-width: 100%;
	height: auto;
	display: block;
	transition:0.6s all;
}
.instagram-item a:hover img {
	transform:scale(1.2,1.2);
	opacity:0.7;
}
.instagram-item .item_caption {
	position:absolute;
	left:0;
	bottom:0;
	width:100%;
	background-color:rgba(0, 0, 0, 0.7);
	color:#fff;
	padding:10px 8px;
	font-size: 0.8rem;
	overflow: hidden;
	text-overflow: ellipsis;
	white-space: nowrap;
}
/* top_sec
============================== */
.top_sec {
	margin:0 0 80px;
	clear:both;
}
.top_sec .container {
	max-width:1440px;
	margin:0 auto;
}
.top_sec_ttl {
	text-align:center;
	margin:0 0 50px;
}
.top_sec_ttl h2 {
	display:inline-block;
	padding:0 260px;
	position:relative;
}
.top_sec_ttl h2::before,
.top_sec_ttl h2::after {
	content:"";
	position:absolute;
	top:18px;
	width:240px;
	height:5px;
	background:url(../images/top/ttl_line.gif) repeat-x 0 0;
}
.top_sec_ttl h2::before {
	left:0;
}
.top_sec_ttl h2::after {
	right:0;
}
/* job
============================== */
#sec_job .job_main {
	float:left;
	width:calc(100% - 540px);
}
#sec_job .job_img {
	float:right;
	width:500px;
}
#sec_job .job_img p {
	position:relative;
}
#sec_job .job_img p::before {
	content:"";
	position:absolute;
	top:20px;
	left:20px;
	width:100%;
	height:100%;
	background:#eceff9;
	z-index:-1;
}
#sec_job .job_main h3 {
	display:inline-block;
	font-size:187.5%;
	font-weight:bold;
	line-height:1.8;
	margin:0 0 20px;
}
#sec_job .job_main h3 span{
	position:relative;
	padding:0 30px 0 10px;
}
#sec_job .job_main h3 span::before {
	content:"";
	position:absolute;
	left:0;
	bottom:5px;
	z-index:-1;
	width:100%;
	height:15px;
	background-color:#fff799;
}
#sec_job .job_main p {
	line-height:2;
	margin:0 0 30px;
}
/* works
============================== */
#sec_works .top_sec_cnt {
	margin:0 -20px;
}
#sec_works .wrap_works {
	float:left;
	width:33.33%;
	padding:0 20px;
}
#sec_works .works {
	border:1px solid #9bacee;
	padding:10px;
	margin:0 0 50px;
}
#sec_works .works_img {
	float:left;
	width:100px;
}
#sec_works .works_cnt {
	float:right;
	width:calc(100% - 120px)
}
#sec_works .works_cnt p {
	margin:0 0 5px;
}
#sec_works .works .label {
	display:inline-block;
	font-size:87.5%;
	background-color:#3f59bf;
	color:#ffffff;
	padding:2px 5px;
}
/* company
============================== */
#sec_company .top_sec_cnt ul {
	margin:0 -20px;
	list-style:none;
}
#sec_company .top_sec_cnt ul li {
	float:left;
	width:33.33%;
	padding:0 20px;
	font-size:150%;
	font-weight:bold;
	line-height:1.2;
}
#sec_company .top_sec_cnt ul li a {
	display:block;
	position:relative;
	text-decoration:none;
	border:2px solid #293e54;
	padding:15px 20px 15px 40px;
	color:#293e54;
	-webkit-border-radius:6px;
	-moz-border-radius:6px;
	border-radius:6px;
    transition: .8s;
}
#sec_company .top_sec_cnt ul li a::before {
    content: "";
    position: absolute;
    top: calc(50% - 2px);
	left:0;
    width: 20px;
    height: 3px;
	background:#293e54;
}
#sec_company .top_sec_cnt ul li a::after {
    content: "";
    display: block;
    position: absolute;
    top: calc(50% - 10px);
    right: 20px;
    width: 20px;
    height: 20px;
	background: url(../images/top/arrow_icon_s.png) no-repeat;
    transition: .3s;
}
#sec_company .top_sec_cnt ul li a:hover {
	background-color:#f0f8ff;
}
#sec_company .top_sec_cnt ul li a:hover::after {
    right: 10px;
}
/* more_btn
============================== */
.more_btn {
	line-height:1.4 !important;
	margin:30px 0 !important;
	font-size:112.5% !important;
	font-weight:bold;
}
.more_btn a {
	text-decoration:none;
	padding:20px;
	min-width:350px;
	display:inline-block;
	border:2px solid #3f59bf;
	position:relative;
	overflow:hidden;
	box-shadow: 0 5px 15px rgba(0, 0, 0, 0.18);
}
.more_btn a::before {
    content:"";
    display: block;
    position: absolute;
    top: 0;
    left: 50%;
    bottom: 0;
    right:0;
    background-color: #f0f2fa;
    transform-origin: bottom left;
    transform: skewX(-55deg);
    z-index: -1;
}
.more_btn span {
	position:relative;
	display:block;
}
.more_btn span::after {
    content: "";
    display: block;
    position: absolute;
    top: calc(50% - 17px);
    right: 0;
    width: 60px;
    height: 34px;
	background:url(../images/top/more_arrow.png) no-repeat;
    transition: .3s;
}
.more_btn a:hover span::after {
    right: -10px;
}
#sec_works .more_btn {
	text-align:center;
}
#sec_works .more_btn a {
	margin:0 auto;
}
/* ==================================================
clearfix
================================================== */
.top_sec:after,
.top_sec_cnt:after,
#sec_works .works:after {
	content: ""; 
	display: table;
	clear: both;
}

@media screen and (max-width: 1200px) {
#sec_job .job_main {
	width:calc(100% - 320px);
}
#sec_job .job_img {
	width:300px;
}
#sec_job .job_main h3 {
	font-size:150%;
}
}

