@charset "utf-8";

/* =============================== */
/* トップページ */
/* =============================== */

/* メインビジュアル */
/* -------------------------------------------------- */

#topMv {
	position: relative;
	width: calc(100% - 80px);
	height: calc(100vh - 100px);
	padding-bottom: 80px;
	margin-left: 80px;
}

/* スライダー */
#topMvSlider,
#topMvSlider .sp-slides-container,
#topMvSlider .sp-slides{
	height: 100%;
}

#topMvSlider {
	overflow: hidden;
}

#topMvSlider .sp-slide {
	width: 100%;
	height: 100%;
	overflow: hidden;
}

#topMvSlider .sp-slide img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	font-family: 'object-fit: cover;';
	-webkit-transform: scale(1.2);
	transform: scale(1.2);
	transition: transform 3.7s cubic-bezier(.14,.69,.5,.94) 0s,-webkit-transform 3.7s cubic-bezier(.14,.69,.5,.94) 0s;
}

#topMvSlider .sp-slide.sp-selected img {
	-webkit-transform: scale(1);
	transform: scale(1);
	transition: transform 3.7s cubic-bezier(.14,.69,.5,.94) 0s,-webkit-transform 3.7s cubic-bezier(.14,.69,.5,.94) 0s;
}


#topMvCopy {
	position: absolute;
	bottom: 0;
	left: 0;
	width: 100%;
	background: #FFF;
	z-index: 999;
}

#topMvCopyTxt {
	width: 100%;
	display: flex;
	justify-content: flex-end;
	align-items: center;
	vertical-align: middle;
	height: 80px;
	font-size: 3.6rem;
	line-height: 1;
	letter-spacing: 0.300em;
	color: #222222;
	text-align: right;
	overflow: hidden;
	font-weight: bold;
}


/* お知らせ */
/* -------------------------------------------------- */

#topics {
	width: 100%;
	background-color: #f5f5f2;
	padding: 45px 0;
}

#topicsInner {
}

#topicsHead {
	margin-bottom: 40px;
}

#topicsTopList ul {
	letter-spacing: -.4em;
	margin-left: -1px;
	margin-right: -1px;
}

#topicsTopList ul li {
	letter-spacing: normal;
	display: inline-block;
	vertical-align: top;
	margin: 0 1px;
	width: calc(20% - 1px*2);
	-webkit-transition: 0.3s ease-in-out;
	-moz-transition: 0.3s ease-in-out;
	-o-transition: 0.3s ease-in-out;
	transition: 0.3s ease-in-out;
}

@media all and (min-width: 1024px) {
	#topicsTopList ul li:hover {
		opacity: 0.8;
	}
}

#topicsTopList .topicsPh img {
	width: 100%;
	height: auto;
}

#topicsTopList .topicsBody {
	background-color: #fff;
	border-top: solid 1px #eeeeee;
	padding: 20px;
}

#topicsTopList .topicsDate {
	display: inline-block;
	font-size: 1.1rem;
	line-height: 1;
	font-weight: 500;
	letter-spacing: 0.050em;
	border-left: solid 2px #bfbfbf;
	padding-left: 0.5em;
	margin-right: 10px;
}

#topicsTopList .topicsLabel {
	display: inline-block;
	font-size: 1.0rem;
	line-height: 1;
	font-weight: 500;
	letter-spacing: 0.050em;
	color: #333333;
	background-color: #e5e5e5;
	border-radius: 10px;
	padding: 5px 20px;
	margin-bottom: 5px;
}

#topicsTopList .topicsTit {
	font-size: 1.4rem;
	line-height: 1.2;
	letter-spacing: 0.100em;
	color: #222222;
}

#topicsGopage {
	width: 275px;
	margin: 0 auto;
}

/*スライダーリセット*/
#topicsTopList.sliderNone .sp-slide {
	position: relative !important; /* 追記 */
}
#topicsTopList.slider-pro.sliderNone {
	margin: 0 auto !important;
	overflow: hidden !important;
	cursor: auto !important;
	margin-bottom: 38px !important;
}
#topicsTopList.slider-pro.sliderNone .sp-slide {
	display: inline-block;
	left: auto !important;
	width: calc(20% - 1px*2) !important;
	height: auto !important;
}
#topicsTopList.slider-pro.sliderNone.sp-image-container {
	width: auto !important;
}
#topicsTopList.slider-pro.sliderNone .sp-slides {
	transform:none !important;
}
#topicsTopList.slider-pro.sliderNone .sp-grab {
	height: auto !important;
}
#topicsTopList.slider-pro.sliderNone .sp-buttons {
	display: none !important;
}
#topicsTopList.slider-pro.sliderNone .sp-arrow {
	display: none !important; /* 追記 */
}

#topicsTopList {
	width: 100%!important;
}

#topicsTopList .sp-slides {
	display: flex;
	justify-content: center;
}


/* サービス */
/* -------------------------------------------------- */

#service {
	width: 100%;
	background: url(../../img/top/bg_topics.png);
	padding-top: 155px;
	padding-bottom: 100px;
}

#serviceInner {
	max-width: 1200px;
	margin: 0 auto;
}

#serviceHead {
	padding-bottom: 40px;
}

/* H1 */
#serviceCatch {
	width: 840px;
	margin: 0 auto 115px;
}

#serviceCatch1 {
	display: block;
	font-size: 1.6rem;
	line-height: 1;
	letter-spacing: 0.180em;
	color: #004098;
	margin-bottom: 1em;
	font-weight: 700;
}

#serviceCatch2 {
	display: block;
	font-size: 3.2rem;
	line-height: 1.281;
	letter-spacing: 0.280em;
	color: #000;
	margin-bottom: 0.5em;
}

#serviceCatch2 span {
	font-weight: 700;
}

#serviceCatch3 {
	display: block;
	font-size: 1.8rem;
	line-height: 1.667;
	letter-spacing: 0.200em;
	color: #000;
}

/* サービス一覧 */
#serviceList {
	width: 100%;
	max-width: 1220px;
	padding: 0 10px;
}

#serviceList > ul {
	display: flex;
	flex-wrap: wrap;
}

#serviceList > ul > li {
	letter-spacing: normal;
	margin-right: 40px;
	margin-bottom: 40px;
}

#serviceList > ul > li.col1 {
	width: calc(50% - 20px);
}

#serviceList > ul > li.col2 {
	width: calc(50% - 20px);
}

#serviceList > ul > li.col3 {
	width: calc(33.3% - 40px * 2 / 3);
}

#serviceList > ul > li:nth-child(2),
#serviceList > ul > li:nth-child(4),
#serviceList > ul > li:nth-child(7) {
	margin-right: 0;
}


#serviceList > ul > li a {
	display: block;
	background-color: #fff;
	border: solid 3px #c9c9c9;
	border-radius: 10px;
	-webkit-transition: 0.3s ease-in-out;
	-moz-transition: 0.3s ease-in-out;
	-o-transition: 0.3s ease-in-out;
	transition: 0.3s ease-in-out;
}

#serviceList > ul > li a .serviceListItemL img {
	width: 100%;
	-webkit-transition: 0.3s ease-in-out;
	-moz-transition: 0.3s ease-in-out;
	-o-transition: 0.3s ease-in-out;
	transition: 0.3s ease-in-out;
}

#serviceList > ul > li a:hover {
	border: solid 3px #004098;
}

#serviceList > ul > li a:hover .serviceListItemL img {
	transform: scale(1.1);
}

.serviceListItem {
	display: table;
	width: 100%;
	height: 265px;
	padding: 20px;
}

.serviceListItemL,
.serviceListItemR {
	display: table-cell;
	vertical-align: middle;
}

.serviceListItemL {
	text-align: center;
}

#serviceList > ul > li.col2 .serviceListItemL {
	width: 44%;
}

#serviceList > ul > li.col3 .serviceListItemL {
	width: 40%;
}

/* イラストサイズ個別調整 */
#serviceListItem1 .serviceListItemL img {
	max-width: 176px;
}

#serviceListItem2 .serviceListItemL img {
	max-width: 162px;
}

#serviceListItem3 .serviceListItemL img {
	max-width: 98px;
}

#serviceListItem4 .serviceListItemL img {
	max-width: 102px;
}

#serviceListItem5 .serviceListItemL img {
	max-width: 97px;
}

.serviceListItemTit {
	margin-left: 17px;
	font-size: 1.7rem;
	font-weight: 700;
	line-height: 1.3;
	letter-spacing: 0.200em;
	color: #004098;
	margin-bottom: 5px;
}

.serviceListItemCont > ul {
	margin-left: 17px;
	display: inline-block;
	text-align: left;
}

.serviceListItemCont > ul > li {
	font-size: 1.3rem;
	font-weight: 500;
	line-height: 1.154;
	letter-spacing: 0;
/*	list-style: disc;*/
}

.serviceListItem3Cont > ul > li:before {
	content:"・";
	display: inline-block;
	vertical-align: middle;
}


/* BOOKS と ABOUT US */
/* -------------------------------------------------- */

#booksabout {
	display: table;
	width: 100%;
	height: 100%;
}

#booksaboutL, #booksaboutR {
	display: table-cell;
	width: 50%;
	height: 100%;
	vertical-align: top;
}


/* BOOKS */
/* -------------------------------------------------- */

#books {
	width: 100%;
	background-color: #e5e5e5;
	padding: 35px 25px;
}

#bookseHead {
	margin-bottom: 25px;
}

#booksSliderWrap {
	padding: 0 45px;
}

#booksSlider img {
	width: 220px;
	height: auto;
}

a.booksSliderLink {
	display: block;
	transition: all 0.3s ease-in-out 0s!important;
}

a.booksSliderLink:hover {
	opacity: 0.7;
}

.booksSliderPh {
	margin-bottom: 10px;
}

.booksSliderTit {
	font-size: 1.4rem;
	font-weight: 500;
	line-height: 1.2;
	letter-spacing: 0.100em;
	color: #222222;
	margin-bottom: 5px;
}

.booksSliderTxt {
	font-size: 1.4rem;
	line-height: 1.2;
	letter-spacing: 0.100em;
	color: #666666;
}

/* スライダーのボタン */
#books .sp-horizontal .sp-next-arrow,
#books .sp-horizontal .sp-previous-arrow {
	width: 32px;
	height: 32px;
	transition: 0.3s ease-in-out;
		-webkit-transition: 0.3s ease-in-out;
		-moz-transition: 0.3s ease-in-out;
		-o-transition: 0.3s ease-in-out;
}
#books .sp-horizontal .sp-next-arrow {
	content: "";
	background: url(../../img/top/btn_right_pc.png) center center no-repeat;
	background-size: 32px auto;
	right: -45px;
	margin-right: 0
}
#books .sp-horizontal .sp-previous-arrow {
	content: "";
	background: url(../../img/top/btn_left_pc.png) center center no-repeat;
	background-size: 32px auto;
	left: -45px;
	margin-left: 0
}
#books .sp-horizontal .sp-next-arrow:before,
#books .sp-horizontal .sp-next-arrow:after,
#books .sp-horizontal .sp-previous-arrow:before,
#books .sp-horizontal .sp-previous-arrow:after {
	width: 0;
	height: 0;
}
#books .sp-horizontal .sp-next-arrow:hover,
#books .sp-horizontal .sp-previous-arrow:hover {
	opacity: 0.8;
}


/* ABOUT US */
/* -------------------------------------------------- */

#about {
	width: 100%;
	padding: 35px 25px;
}

a.aboutWrap {
	height: 100%;
	display: block;
	position: relative;
	overflow: hidden;
}

a.aboutWrap:after {
	position: absolute;
	z-index: -1;
	display: block;
	content: "";
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	background: url(../../img/top/ph_about_pc.jpg) no-repeat center center / cover;
	-webkit-transition: 0.3s ease-in-out;
	-moz-transition: 0.3s ease-in-out;
	-o-transition: 0.3s ease-in-out;
	transition: 0.3s ease-in-out;
}

a.aboutWrap:hover:after {
	transform: scale(1.1);
}

#aboutHead {
	width: 100%;
	margin-bottom: 25px;
	text-align: right;
}

.aboutrecruitbody {
	font-size: 1.4rem;
	font-weight: 500;
	line-height: 1.5;
	letter-spacing: 0.300em;
	color: #fff;
}

#about .aboutrecruitbody {
	text-align: right;
}


/* RECRUIT */
/* -------------------------------------------------- */

#recruit {
	width: 100%;
	margin-top: -1px;
}

#recruit a {
	display: block;
	width: 100%;
	height: 627px;
	padding: 35px 25px;
	position: relative;
	overflow: hidden;
}

#recruit a:after {
	position: absolute;
	z-index: -1;
	display: block;
	content: "";
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	background: url(../../img/top/ph_recruit_pc.jpg) no-repeat center center / cover;
	-webkit-transition: 0.3s ease-in-out;
	-moz-transition: 0.3s ease-in-out;
	-o-transition: 0.3s ease-in-out;
	transition: 0.3s ease-in-out;
}

#recruit a:hover:after {
	transform: scale(1.1);
}

#recruitHead {
	margin-bottom: 25px;
}

#recruitHead span {
	text-align: left;
	text-indent: 0;
}

#bookseHead span{
	display: inline-block;
}

