@charset "utf-8";

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

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

html, body {
	height: 100%;
}

#topMv {
	height: 100%;
	padding-top: 50px;
}

#topMvSlider {
	overflow: hidden;
}

#topMvSlider .sp-selected {
	z-index: 2; /* 最後のスライドが少し見切れるのを防ぐ */
}

#topMvSlider,
#topMvSlider .sp-slides-container,
#topMvSlider .sp-slides{
	height: 100%;
}

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

#topMvSlider .sp-slide img {
	width: 100%;
	height: 100%;
	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.1);
	transform: scale(1.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
}

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

#main {
	padding-top: 0;
}


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

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

#topicsHead {
	margin-bottom: 30px;
}

#topicsTopList {
}

#topicsTopList li {
}

#topicsTopList li a {
	display: block;
}

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

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

#topicsTopList .topicsDate {
	display: inline-block;
	font-size: 1.2rem;
	line-height: 1;
	letter-spacing: 0.050em;
}

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

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

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

/* スライド */
#topicsTopList ul li {
	width: 250px;
}

#topicsTopList ul li img {
	width: 260px;
	height: 150px;
}

/* スライダーのボタン */
#topics .sp-horizontal .sp-next-arrow,
#topics .sp-horizontal .sp-previous-arrow {
	width: 35px;
	height: 35px;
}
#topics .sp-horizontal .sp-arrows {
	top: 50%;
}
#topics .sp-horizontal .sp-next-arrow {
	content: "";
	background: url(../../img/top/btn_right_sp.png) no-repeat center center;
	-webkit-background-size: 35px auto;
	background-size: 35px auto;
	right: 50%;
	margin-right: -150px
}
#topics .sp-horizontal .sp-previous-arrow {
	content: "";
	background: url(../../img/top/btn_left_sp.png) no-repeat center center;
	-webkit-background-size: 35px auto;
	background-size: 35px auto;
	left: 50%;
	margin-left: -150px
}
#topics .sp-horizontal .sp-next-arrow:before,
#topics .sp-horizontal .sp-next-arrow:after,
#topics .sp-horizontal .sp-previous-arrow:before,
#topics .sp-horizontal .sp-previous-arrow:after {
	width: 0;
	height: 0;
}


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

#service {
	width: 100%;
	background: url(../../img/top/bg_topics.png) left top repeat;
	-webkit-background-size: 16px auto;
	background-size: 16px auto;
	padding-top: 55px;
	padding-bottom: 60px;
}

#serviceInner {
	padding: 0 15px;
}

/* H1 */
#serviceCatch {
	margin: 0 auto 55px;
}

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

#serviceCatch2 {
	display: block;
	font-size: 2.5rem;
	line-height: 1.12;
	letter-spacing: 0.180em;
	color: #000;
	margin-bottom: 0.5em;
}

#serviceCatch2 span {
	font-weight: bold;
}

#serviceCatch3 {
	display: block;
	font-size: 1.4rem;
	font-weight: 500;
	line-height: 1.5;
	letter-spacing: 0.200em;
	color: #000;
}


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

#books {
	width: 100%;
	background-color: #e5e5e5;
	padding: 40px 0;
}

#bookseHead {
	margin-bottom: 20px;
	text-align: left;
}

#booksSliderWrap {
	padding: 0 45px;
}

a.booksSliderLink {
	display: block;
}

.booksSliderPh {
	margin-bottom: 10px;
}

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

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

/* スライダーのボタン */
#books .sp-horizontal .sp-next-arrow,
#books .sp-horizontal .sp-previous-arrow {
	width: 35px;
	height: 35px;
}
#books .sp-horizontal .sp-arrows {
	top: 50%;
}
#books .sp-horizontal .sp-next-arrow {
	content: "";
	background: url(../../img/top/btn_right_sp.png) no-repeat center center;
	-webkit-background-size: 35px auto;
	background-size: 35px auto;
	right: 50%;
	margin-right: -150px
}
#books .sp-horizontal .sp-previous-arrow {
	content: "";
	background: url(../../img/top/btn_left_sp.png) no-repeat center center;
	-webkit-background-size: 35px auto;
	background-size: 35px auto;
	left: 50%;
	margin-left: -150px
}
#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;
}

#bookseHead.topSubhead.lineHV .topSubheadEn {
	margin: 0 0 -3px 0;
}

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

#about {
	width: 100%;
/* 	max-width: 600px; */
	margin: 0 auto;
}

a.aboutWrap {
	display: block;
	position: relative;
	padding: 25px 15px;
}

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_sp.jpg) no-repeat center center / cover;
}

#aboutHead {
	text-align: left;
	margin-bottom: 350px;
}

#aboutHead.topSubhead.lineHV .topSubheadEn {
	display: block;
}

.aboutrecruitbody {
	font-size: 1.4rem;
	line-height: 1.286;
	letter-spacing: 0.200em;
	color: #fff;
	text-align: right;
}


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

#recruit {
	width: 100%;
	position: relative;
}

#recruitInner {
	width: 100%;
/* 	max-width: 600px; */
	margin: 0 auto;
}

#recruit a {
	display: block;
	width: 100%;
	padding: 25px 15px;
}

#recruit:after {
	position: absolute;
	z-index: -1;
	display: block;
	content: "";
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	background: url(../../img/top/ph_recruit_sp.jpg) no-repeat center center / cover;
}

#recruitHead {
	margin-bottom: 350px;
}

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


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

#serviceHead {
	margin-bottom: 40px;
}

#serviceList {
	width: 100%;
	max-width: 1220px;
	padding: 0 10px;
}

#serviceList > ul {
	letter-spacing: -.4em;
	margin-left: -15px;
	margin-right: -15px;
	text-align: center;
}

#serviceList > ul > li {
	letter-spacing: normal;
	display: inline-block;
	vertical-align: top;
	margin: 0 15px 20px;
	width: calc(50% - 15px*2);
}

#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:hover {
	border: solid 3px #004098;
}

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

.serviceListItem {
	display: table;
	height: 165px;
	width: 100%;
}

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

.serviceListItemL {
	width: 110px;
	text-align: center;
	padding-left: 20px;
}

.serviceListItemR {
	padding: 10px 0;
	text-align: left;
}

.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;*/
}

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


