/* ===============================
  追加構成CSS
=============================== */

.p-index_target{
  padding: 80px 0;
}

.targetList{
  margin-top: 30px;
  line-height: 2;
}

.p-index_position{
  padding: 80px 0 140px;
  background: #f7f7f7;
}

.p-index_works{
  padding: 100px 0;
}

.workItem{
  margin-top: 40px;
}

.p-index_target li{
  margin-bottom: 10px;
}

/* Works強化 */

.p-index_works{
  padding: 100px 0;
}

.workItem{
  margin-top: 60px;
}

.workItem img{
  width: 100%;
  max-width: 600px;
  margin-bottom: 20px;
}

.workItem h3{
  margin-bottom: 15px;
}

.workItem p{
  margin-bottom: 10px;
  line-height: 1.9;
}

.workCase {
	display: grid;
	grid-template-columns: 295px 1fr;
	gap: 50px;
	padding: 45px 0;
	border-bottom: 1px solid #e5e5e5;
	max-width: 1100px;
	margin: 0 auto;
}

.workCase__head {
	position: relative;
	padding-top: 10px;
}

.workCase__num {
	display: block;
	font-size: 48px;
	font-weight: 700;
	color: #e9f7fb;
	line-height: 1;
	margin-bottom: 10px;
}

.workCase__label {
	display: inline-block;
	font-size: 12px;
	font-weight: 700;
	letter-spacing: .12em;
	color: #35b6d4;
	margin-bottom: 14px;
}

.workCase__title {
	font-size: 28px;
	font-weight: 700;
	line-height: 1.4;
}

.workCase__meta {
	display: flex;
	flex-direction: column;
	gap: 8px;
	font-size: 15px;
	font-weight: 500;
	line-height: 1.7;
	margin-bottom: 24px;
	color:#555;
}

.workCase__box {
	padding: 20px 24px;
	background: #f7f8f9;
	border-radius: 10px;
	margin-top: 14px;
	min-height: 120px;
}

.workCase__box h4 {
	display:inline-block;
	font-size:12px;
	font-weight:700;
	letter-spacing:.08em;
	padding:4px 10px;
	border-radius:20px;
	background:#fff;
	margin-bottom:12px;
}

.workCase__box p {
	font-size: 16px;
	line-height: 1.8;
}

.workCase__box--result {
	background: #eef9fc;
}
@media screen and (max-width: 767px) {
	.workCase {
		grid-template-columns: 1fr;
		gap: 22px;
		padding: 35px 0;
	}

	.workCase__num {
		font-size: 40px;
	}

	.workCase__title {
		font-size: 22px;
	}

	.workCase__box {
		padding: 18px;
	}
}

.targetWrap {
	display: grid;
	grid-template-columns: 1.1fr .9fr;
	gap: 60px;
	align-items: center;
}

.targetList {
	display: grid;
	gap: 18px;
}

.targetList li {
	position: relative;
	padding: 18px 22px 18px 52px;
	background: #fff;
	border-radius: 14px;
	box-shadow: 0 8px 24px rgba(0,0,0,.05);
	font-weight: 600;
	line-height: 1.7;
}

.targetList li::before {
	content: "";
	position: absolute;
	left: 22px;
	top: 50%;
	width: 10px;
	height: 10px;
	border-radius: 50%;
	background: #35b6d4;
	transform: translateY(-50%);
}

.targetVisual {
	position: relative;
	text-align: center;
}

.targetVisual::before {
	content: "";
	position: absolute;
	inset: 8%;
	background: #eaf8fb;
	border-radius: 50%;
	z-index: -1;
}

.targetVisual img {
	max-width: 100%;
	height: auto;
	display: block;
	margin: 0 auto;
}
@media screen and (max-width: 767px) {
	.targetWrap {
		grid-template-columns: 1fr;
		gap: 35px;
	}

	.targetVisual {
		order: -1;
		max-width: 260px;
		margin: 0 auto;
	}

	.targetList li {
		padding: 16px 18px 16px 46px;
		font-size: 15px;
	}
}

.positionWrap {
	display: grid;
	grid-template-columns: 1.1fr .9fr;
	gap: 60px;
	align-items: center;
	max-width: 1100px;
	margin: 0 auto;
}

.positionLead {
	font-size: 30px;
	font-weight: 700;
	line-height: 2;
	margin-bottom: 24px;
}

.positionText .c-text02 {
	line-height: 2;
}

.positionTags {
	display: flex;
	flex-wrap: wrap;
	gap: 12px;
	padding: 34px;
	background:#fcfeff;
	border-radius: 24px;
}

.positionTags span {
	display: inline-flex;
	align-items: start;
	padding: 10px 16px;
	background: #fff;
	border: 1px solid #dff3f8;
	border-radius: 999px;
	font-size: 14px;
	font-weight: 700;
	color: #444;
	box-shadow: 0 6px 18px rgba(0,0,0,.04);
}

.positionTags span::before {
	content: "";
	width: 7px;
	height: 7px;
	border-radius: 50%;
	background: #35b6d4;
	margin-right: 8px;
}

@media screen and (max-width: 767px) {
	.positionWrap {
		grid-template-columns: 1fr;
		gap: 30px;
	}

	.positionLead {
		font-size: 24px;
	}

	.positionTags {
		padding: 24px 18px;
		border-radius: 18px;
	}

	.positionTags span {
		font-size: 13px;
		padding: 9px 13px;
	}
}

.p-index_support {
	padding: 140px 0;
	background: #f8fcfd;
}

.supportBox {
	max-width: 1000px;
	margin: 0 auto;
	padding: 50px;
	background: #fff;
	border-radius: 30px;
	box-shadow: 0 15px 40px rgba(0,0,0,.05);
}

.supportTags {
	display: flex;
	flex-wrap: wrap;
	gap: 14px;
	margin-bottom: 40px;
}

.supportTags span {
	display: inline-flex;
	align-items: center;
	padding: 12px 18px;
	background: #f6fbfd;
	border: 1px solid #dff3f8;
	border-radius: 999px;
	font-size: 14px;
	font-weight: 700;
	line-height: 1.5;
	color: #333;
}

.supportTags span::before {
	content: "";
	width: 7px;
	height: 7px;
	border-radius: 50%;
	background: #35b6d4;
	margin-right: 10px;
	flex-shrink: 0;
}

.supportText {
	font-size: 24px;
	font-weight: 700;
	line-height: 1.8;
	text-align: center;
}

@media screen and (max-width: 767px) {

	.p-index_support {
		padding: 90px 0;
	}

	.supportBox {
		padding: 30px 20px;
		border-radius: 20px;
	}

	.supportTags {
		gap: 10px;
		margin-bottom: 30px;
	}

	.supportTags span {
		font-size: 13px;
		padding: 10px 14px;
	}

	.supportText {
		font-size: 20px;
		line-height: 1.7;
	}
}


.contactFormSec {
	max-width: 760px;
	margin: 80px 0;
}

.contactTitle {
	font-size: 30px;
	font-weight: 700;
	margin-bottom: 20px;
}

.contactLead {
	line-height: 1.9;
	margin-bottom: 35px;
}

.contactForm {
	display: grid;
	gap: 24px;
}

.formItem label {
	display: block;
	font-weight: 700;
	margin-bottom: 10px;
}

.formItem label span {
	display: inline-block;
	margin-left: 8px;
	padding: 2px 8px;
	border-radius: 20px;
	background: #35b6d4;
	color: #fff;
	font-size: 12px;
}

.formItem input,
.formItem select,
.formItem textarea {
	width: 100%;
	padding: 14px 16px;
	border: 1px solid #ddd;
	border-radius: 10px;
	background: #fff;
	font-size: 16px;
}

.formItem textarea {
	resize: vertical;
}

.formBtn button {
	padding: 14px 40px;
	border: none;
	border-radius: 999px;
	background: #35b6d4;
	color: #fff;
	font-size: 16px;
	font-weight: 700;
	cursor: pointer;
}

.formError {
	padding: 18px 22px;
	margin-bottom: 25px;
	background: #fff7f2;
	border: 1px solid #ffd9c7;
	border-radius: 10px;
	color: #c25b2b;
	font-weight: 700;
}

.formComplete {
	padding: 30px;
	background: #f0fbfd;
	border-radius: 16px;
	font-weight: 700;
	line-height: 1.8;
}

.hpField {
	position: absolute;
	left: -9999px;
}
.formError__title {
	margin-bottom: 10px;
	font-size: 18px;
}

.confirmBox {
	padding: 40px;
	background: #fff;
	border-radius: 24px;
	box-shadow: 0 15px 40px rgba(0,0,0,.05);
}

.confirmTitle {
	font-size: 24px;
	font-weight: 700;
	margin-bottom: 30px;
}

.confirmList {
	border-top: 1px solid #e5e5e5;
	margin-bottom: 30px;
}

.confirmList > div {
	display: grid;
	grid-template-columns: 180px 1fr;
	gap: 24px;
	padding: 20px 0;
	border-bottom: 1px solid #e5e5e5;
}

.confirmList dt {
	font-weight: 700;
}

.confirmList dd {
	line-height: 1.8;
}

.confirmBtn {
	margin-top: 20px;
	text-align: center;
}

.confirmBtn button {
	padding: 14px 32px;
	border-radius: 999px;
	font-weight: 700;
	cursor: pointer;
	border: none;
}

.confirmBtn__send {
	background: #35b6d4;
	color: #fff;
}

.confirmBtn__back {
	background: #eee;
	color: #333;
}

