@charset "utf-8";

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

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

html, body, #topMv {
	height: 100%;
}

#topMv {
	padding-top: 50px;
}

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

#topMvSlider{
	height: 100%;
	padding-bottom: 40px;
	overflow: hidden;
	-webkit-box-sizing: border-box;
	-moz-box-sizing: border-box;
	box-sizing: border-box;
}

#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;
	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;
}

#topMvCopyTxt {
	width: 100%;
	height: 40px;
	display: flex;
	justify-content: center;
	align-items: center;
	vertical-align: middle;
	font-size:4.688vw;
	line-height: 1;
	letter-spacing: 0.1em;
	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;
}

#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 {
	padding: 0 15px;
}

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

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

#about {
	width: 100%;
	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: 155px;
}

#aboutHead span {
	display: block;
		margin-bottom: 7px;
}

.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%;
	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: 155px;
}

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


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

#serviceHead {
	margin-bottom: 30px;
}

#serviceList {
	max-width: 310px;
	margin: 0 auto;
}

#serviceList > ul > li {
	margin-bottom: 10px;
}

#serviceList > ul > li a {
	display: block;
	background-color: #fff;
	border: solid 3px #c9c9c9;
	border-radius: 10px;
}

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

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

.serviceListItemL {
	width: 125px;
	text-align: center;
}

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

#serviceListItem2 .serviceListItemL img {
	width: 81px;
}

#serviceListItem3 .serviceListItemL img {
	width: 64px;
}

#serviceListItem4 .serviceListItemL img {
	width: 60px;
}

#serviceListItem5 .serviceListItemL img {
	width: 58px;
}

.serviceListItemR {
	padding: 15px 0;
}

.serviceListItemTit {
	font-size: 1.4rem;
	font-weight: bold;
	line-height: 1;
	letter-spacing: 0.200em;
	color: #004098;
	margin-bottom: 5px;
}

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

.serviceListItemCont > ul > li {
	font-size: 1.0rem;
	line-height: 1.1;
	letter-spacing: 0;
/*	list-style: disc;*/
}

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

