  @charset "utf-8";
/* ----会社情報 common---- */

/* ----ヘッダー メニュー---- */

#gNav li:nth-child(5) {
	border-bottom: 4px solid #f19716;
}
#gNav li:nth-child(5) a {
	background: linear-gradient(to bottom, #fff 0%, #f5f5f5 100%);
	background-size: calc(100% - 1px) 100%;
	background-repeat: no-repeat;
	background-position: right;
}

.orgBar {
	border-bottom: 4px solid #f19716;
}

/* ----h1イメージ---- */

#service #tit div div {
	width: 980px;
	height: 96px;
	margin: 0px auto 3px;
	border: none;
	color: #000;
}

#service #tit div div h1 {
	font-size: 28px;
	font-weight: normal;
	letter-spacing: 2px;
	margin-bottom: 5px;
	padding-top: 30px;
}

#service #tit div div p {
	font-size: 14px;
	font-style: italic;
	letter-spacing: 1px;
	margin: 0px;
	padding: 0px;
}

#service #tit div div p span {
	font-size: 27px;
}

#service #tit {
    background-image: url(/wp/wp-content/themes/ios/service/img/h1_image.jpg);
}

/* ----h2イメージ---- */

#service #wrap #main h2 {
    text-align: left;
    margin-bottom: 40px;
}

.type1 {
    clear: both;
    position: relative;
    font-size: 22px;
    margin: 64px 0px 30px 0px;
    padding-bottom: 20px;
    border-bottom: 2px solid #dfdfdf;
}

.type1::after {
    position: absolute;
    bottom: -2px;
    left: 0;
    z-index: 2;
    content: '';
    width: 20%;
    height: 2px;
    background-color: #f19716;
    border-right: 1px solid #fff;
}

/* ----h3イメージ---- */

#service #wrap #main .type2 {
    clear: both;
    font-size: 15px;
    position: relative;
    line-height: 40px;
    height: 40px;
    margin: 60px 0px 20px 0px;
    padding-left: 18px;
    background-color: #f6f6f6;
    border-left: 2px solid #f19716;
	color: #333;
	text-align: left
}

#service #wrap #main .type2::after {
    position: absolute;
    left: 0;
    z-index: 2;
    content: '';
    width: 2px;
    height: 40px;
    border-left: 3px solid #fff;
}

/* ----wrap---- */

#service #main {
	float: left;
	width: 720px;
	padding-right: 39px;
	border-right: 1px solid #ededed;
	text-align: center;
}

/* ----main---- */

#service #main h2 {
	margin-bottom: 40px
}


/* ----sub---- */
#service #sub {
	float: right;
	width: 219px;
}

#service #sub ul {
	list-style: none;
	margin: 0px;
	margin-top: 62px;
	padding: 0px;
}

#service #sub ul li {
	width: 219px;
	height: 70px;
	background-color: #fff;
	border-top: 1px solid #ededed;
}

#service #sub ul li:last-child {
	border-bottom: 1px solid #ededed;
}

#service #sub ul li a {
	display: table-cell;
	vertical-align: middle;
	text-decoration: none;
	line-height: 20px;
	width: 197px;
	height: 68px;
	margin: 1px 0px 1px 0px;
	padding: 0px;
	padding-left: 22px;
}

.current {
	vertical-align: middle;
	background-color: #ededed;
	background-image: url(/wp/wp-content/themes/ios/common/img/cpr_current.jpg);
	background-position: left;
	background-repeat: no-repeat;
	background-size: 3px 22px;
}

/* #service #wrap #main p {
    font-size: 13px;
    letter-spacing: 2px;
    line-height: 1.7em;
    margin-bottom: 30px;
} */


#service #wrap #main .bythewayContactBlock {
    background-color: #FFF1DC;
    padding: 1em;
    margin-bottom: 1.5em;
    text-align: left;
}

#service #wrap #main .bythewayContactBlock p strong {
    display: block;
    margin-bottom: 10px;
    border-bottom: 1px solid #E27D15;
}

#service #wrap #main .bythewayContactBlock p {
    margin-bottom: 0;
    line-height: 1.7;
	letter-spacing: normal;
}

/* ----採用情報---- */

#recruitData {
	clear: both;
	padding-top: 60px;
	border-top: 1px solid #ededed;
	background-image: url(/wp/wp-content/themes/ios/common/img/img_bottom_shadow.jpg);
	background-position: top;
	background-repeat: no-repeat;
}


/* ----Service info ---- */
#service .service_info_title {
	width: 100%;
	height: 200px;
	background-repeat: no-repeat;
	background-size: cover;
	background-position: center;
	position: relative;
	display: flex;
	justify-content: center;
	align-items: center;
}
#service .service_info_title::before {
	content: "";
	width: 100%;
	height: 100%;
	background-color: #000;
	opacity: 0.4;
	position: absolute;
	top: 0;
	right: 0;
	bottom: 0;
	left: 0;
	margin: auto;
	z-index: 1;
}
#service .service_info_title--ibm {
	background-image: url(/wp/wp-content/themes/ios/service/img/top_image-ibm.jpg);
}
#service .service_info_title--open {
	background-image: url(/wp/wp-content/themes/ios/service/img/top_image-open.jpg);
	background-position: top;
}
#service .service_info_title p {
	font-weight: 600;
	color: #fff;
	font-size: 25px;
	line-height: 1.45;
	position: relative;
	z-index: 2;
}
#service .service_info_title--ibm p {
	text-shadow: 4px 0 14px #083244, -4px 0 14px #083244, 0 -4px 14px #083244, 0 4px 14px #083244;
}
#service .service_info_title--open p {
	text-shadow: 4px 0 14px #246d80, -4px 0 14px #246d80, 0 -4px 14px #246d80, 0 4px 14px #246d80;
}
#service .service_info_contents {
	background-color: #ecf4ff;
	padding: 30px 20px;
	margin-top: 20px;
}
#service .service_info_contents_block {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 20px;
}
#service .service_info_contents_item {
	background-color: #fff;
	padding: 15px 10px 50px;
	text-align: left;
}
#service .service_info_contents_item_num {
	display: inline-block;
	padding-left: 10px;
}
#service .service_info_contents_item_num .num {
	display: flex;
	align-items: center;
	justify-content: center;
	position: relative;
}
#service .service_info_contents_item_num .num > p {
	color: #fff;
	font-size: 12px;
	position: relative;
	z-index: 2;
	padding-bottom: 2px;
}
#service .service_info_contents_item_num .num::after {
	content: "";
	background-image: url(/wp/wp-content/themes/ios/service/img/icon_speech_bubble.svg);
	background-repeat: no-repeat;
	display: inline-block;
	aspect-ratio: 131 / 75;
	width: 3em;
	height: auto;
	position: absolute;
	z-index: 1;
}
#service .service_info_contents_item_head {
	display: flex;
	align-items: center;
	gap: 8px;
	margin-top: 10px;
}
#service .service_info_contents_item_head .head {
	color: #E27D15;
	font-size: 18px;
	font-weight: 600;
	line-height: 1.2;
}
#service .service_info_contents_item_head::before {
	content: "";
	background-image: url(/wp/wp-content/themes/ios/service/img/icon_check.svg);
	background-repeat: no-repeat;
	display: inline-block;
	aspect-ratio: 1 / 1;
	width: 30px;
	min-width: 30px;;
	height: auto;
}
#service .service_info_contents_item .line {
	background-image: url(/wp/wp-content/themes/ios/service/img/icon_line.svg);
	background-repeat: no-repeat;
	display: inline-block;
	aspect-ratio: 48 / 1;
	width: 100%;
	height: auto;
	margin: 10px 0 20px;
}
#service .service_info_contents_item .text {
	line-height: 1.5;
}

#service .service_mf_link {
	margin: 60px 0 100px 0;
}
#service .service_mf_link .link {
	display: inline-block;
}
#service .service_mf_link .link > img {
	max-width: 100%;
}

/* 実績 */
#service .implementation-record {
  font-size: 14px;
  line-height: 1.8;
  letter-spacing: 0.05em;
}
#service .implementation-record > div:not(:last-child) {
  margin-bottom: 40px;
}
#service .implementation-record-title {
  clear: both;
  position: relative;
  font-size: 16px;
  font-weight: 600;
  margin: 30px 0px;
  padding-bottom: 10px;
  border-bottom: 2px solid #EDEDED;
}
#service .implementation-record-title::after {
  position: absolute;
  bottom: -2px;
  left: 0;
  z-index: 2;
  content: '';
  width: 30px;
  height: 2px;
  background-color: #f19716;
}
#service .implementation-record-color {
  color: #ED7F1E;
  font-weight: 600;
  margin-bottom: 5px;
}
#service .implementation-record-square {
  font-size: 14px;
  line-height: 1.8;
  display: flex;
  align-items: center;
  column-gap: 7px;
  margin-bottom: 20px;
}
#service .implementation-record-square::before {
  content: "";
  width: 11px;
  height: 11px;
  background-color: #F19716;
}
#service .implementation-record-detail .implementation-record-color {
  margin-bottom: 10px;
}
#service .implementation-record-purpose ul {
  margin-left: 1em;
}
#service .implementation-record-purpose li:not(:last-child) {
  margin-bottom: 20px;
}
#service .implementation-record-purpose li .implementation_record_purpose_title{
  font-weight: 600;
  margin-bottom: 5px;
  position: relative;
}
#service .implementation-record-purpose li .implementation_record_purpose_title::before{
  content: "?";
  position: absolute;
  top: 0;
  left: 0;
  transform: translateX(-100%);
}
#service .implementation-record-purpose img{
  margin-top: 40px;
}

/*
****     SP     ***
**/
@media (max-width: 767px) {
	
	#main img {
		width: 100%;
		height: auto;
	}
	
	#service #wrap #main h2 {
		margin-bottom: 20px;
	}
	
	.type1 {
		margin-top: 20px;
		padding-bottom: 10px;
		font-size: 18px;
	}
	
	#service #tit {
		background-position: 20%;
	}
	#service #main {
		width: 100%;
		padding-right: 10px;
		padding-bottom: 40px;
	}
	#service #main h2 {
    margin-bottom: 20px;
	}
	#service #sub {
		width: 100%;
		text-align: center;
	}
	#service #sub ul li a {
		display: block;
		width: 100%;
		box-sizing: border-box;
		padding: 0;
		height: 40px;
		line-height: 40px;
	}
	#service #sub ul li {
		width: 100%;	
		height: 40px;
	}
	#service #sub ul {
		margin-top: 0;
	}
	#service #sub ul li:last-child {
		border-bottom: 1px solid #f19716;
	}
	#service #sub ul li:first-child a {
		margin-top:0;
	}
	.current {
		background-image: none;
	}
	
	#service #wrap #main .bythewayContactBlock {
		margin: 0px 0 20px;
		padding: 10px;
	}
	
	#service #wrap #main .type2 {
		margin: 0px 0 10px;
		line-height: 22px;
		padding: 5px 10px;
		height: auto;
		font-size: 15px;
	}

	#service .service_info_contents_block {
		grid-template-columns: 1fr;
	}

	#service .service_mf_link {
		margin: 60px 0 0 0;
	}
	#service .service_mf_link .link {
		border: 2px solid #eaeaeb;
		width: 90%;
	}
}