@charset "UTF-8";


/*
■ パンくず
■ 共通
■ ページタイトル
■ キービジュアル
■ 導入
■ 監修
■ ページ内リンク
■ 商品紹介
■ サービス案内
*/



/* ■ パンくず ==================================================================================== */

@media only screen and (max-width: 767px) {

}

@media print, screen and (min-width: 768px) {

	#TopicPath {
	max-width: 1000px;
	margin: 0 auto;
	padding: 0 30px;
	}

}



/* ■ 共通 ==================================================================================== */

/*
フォント
カラー
リンク
レイアウト
ボタン
*/


/* フォント --------------------------------------------------- */

.DS_,
.DS_ * {
font-family: "Noto Sans JP", sans-serif;
font-weight: 400;
}


/* カラー --------------------------------------------------- */

.DS_ * {
--color1: #2e5d80;
--color2: #3eb0c7;
--color3: #e6f2f5;
--color4: #efefef;
}


/* リンク --------------------------------------------------- */

.DS_ a:link {
transition: color 0.2s ease 0.01s, background-color 0.2s ease 0.01s, opacity 0.2s ease 0.01s;
}


/* レイアウト --------------------------------------------------- */

.DS_ img {
max-width: 100%;
}

@media only screen and (max-width: 767px) {

	.DS_ {
	padding: 30px 20px 30px;
	}

	.DS_ .PC {
	display: none !important;
	}

}

@media print, screen and (min-width: 768px) {

	.DS_ {
	max-width: 1000px;
	margin: 0 auto;
	padding: 0 30px 150px;
	}

	.DS_ .SP {
	display: none !important;
	}

}


/* ボタン --------------------------------------------------- */

a.DS_Btn {
display: inline-block;
border-radius: 100vh;
line-height: 1;
font-weight: 700;
color: #fff;
background-color: var(--color2);
background-image: url(/images/pages/feature/developmental_support/Icon_Arrow_Foward_White.png);
background-repeat: no-repeat;
}

@media only screen and (max-width: 767px) {

	a.DS_Btn {
	width: 70%;
	padding: 12px 0 15px;
	font-size: 14px;
	background-position: top 48% right 12px;
	background-size: 18px auto;
	}

}

@media print, screen and (min-width: 768px) {

	a.DS_Btn {
	padding: 16px 80px 20px;
	font-size: 18px;
	background-position: top 49% right 16px;
	background-size: 22px auto;
	}

}

@media (hover: hover) {

	a.DS_Btn:hover {
	background-color: #228ea4;
	}

}



/* ■ ページタイトル ==================================================================================== */

.DS_PageTitle_ {
font-weight: 900;
letter-spacing: 0.075em;
text-align: center;
color: var(--color1);
}

@media only screen and (max-width: 767px) {

	.DS_PageTitle_ {
	padding: 5% 0;
	font-size: 20px;
	line-height: 1.4;
	}

}

@media print, screen and (min-width: 768px) {

	.DS_PageTitle_ {
	padding: 5% 0;
	font-size: 44px;
	line-height: 1.4;
	}

}



/* ■ キービジュアル ==================================================================================== */


@media only screen and (max-width: 767px) {

}

@media print, screen and (min-width: 768px) {

	.DS_KV_ {
	display: grid;
    grid-template-columns: repeat(2, 1fr);	
	}

}



/* ■ 導入 ==================================================================================== */

.DS_Intro_Lead {
font-weight: 500;
}

@media only screen and (max-width: 767px) {

	.DS_Intro_ {
	margin-top: 2.5%;
	}

	.DS_Intro_Lead {
	font-size: 14px;
	line-height: 2;
	}

}

@media print, screen and (min-width: 768px) {

	.DS_Intro_ {
	margin-top: 3%;
	}

	.DS_Intro_Lead {
	font-size: 16px;
	line-height: 2.2;
	text-align: center;
	}

}



/* ■ 監修 ==================================================================================== */

.DS_Supervisor_ {
position: relative;
background-color: var(--color3);
}

.DS_Supervisor_Mds {
display: inline-block;
position: absolute;
line-height: 1;
font-weight: 700;
color: #fff;
background-color: var(--color1);
}

.DS_Supervisor_Name em {
font-weight: 700;
}

@media only screen and (max-width: 767px) {

	.DS_Supervisor_ {
	margin-top: 8%;
	padding: 50px 20px 20px;
	}

	.DS_Supervisor_Mds {
	left: 20px;
	top: 0;
	padding: 8px 16px 10px;
	font-size: 13px;
	}

	.DS_Supervisor_Photo {
	padding: 0 20%;
	}

	.DS_Supervisor_Name {
	margin-top: 10px;
	font-size: 13px;
	}

	.DS_Supervisor_Name em {
	margin-left: 8px;
	font-size: 15px;
	}

	.DS_Supervisor_Lead {
	margin-top: 5px;
	font-size: 13px;
	line-height: 2;
	}

}

@media print, screen and (min-width: 768px) {

	.DS_Supervisor_ {
	margin-top: 8%;
	padding: 40px;
	}

	.DS_Supervisor_Mds {
	left: 40px;
	top: 0;
	padding: 8px 16px 10px;
	}

	.DS_Supervisor_Unit_Wrap {
	display: flex;
	}

	.DS_Supervisor_Unit {
	flex: 1;
	padding-top: 10px;
	padding-right: 40px;
	}

	.DS_Supervisor_Name {
	font-size: 14px;
	}

	.DS_Supervisor_Name em {
	margin-left: 10px;
	font-size: 18px;
	}

	.DS_Supervisor_Lead {
	margin-top: 10px;
	font-size: 15px;
	line-height: 2;
	}

	.DS_Supervisor_Photo {
	order: 2;
	width: 180px;
	}

}



/* ■ ページ内リンク ==================================================================================== */

.DS_InPageNav_ {
display: grid;
}

.DS_InPageNav_ a {
display: grid;
align-items: center;
font-weight: 700;
text-align: center;
color: var(--color1);
background-color: #fff;
background-image: url(/images/pages/feature/developmental_support/Icon_Arrow_Below.png);
background-repeat: no-repeat;
}

@media only screen and (max-width: 767px) {

	.DS_InPageNav_ {
    grid-template-columns: repeat(3, 1fr);
	margin-top: 12%;
	}

	.DS_InPageNav_ a {
	padding: 15px 0 40px;
	border-right: 1px solid #000;
	border-bottom: 1px solid #000;
	font-size: 11px;
	line-height: 1.6;
	letter-spacing: 0.05em;
	font-feature-settings: "palt";
	background-position: 50% 86%;
	background-size: 16px auto;
	}

	.DS_InPageNav_ a:nth-child(1),
	.DS_InPageNav_ a:nth-child(2),
	.DS_InPageNav_ a:nth-child(3) {
	border-top: 1px solid #000;
	}

	.DS_InPageNav_ a:nth-child(1),
	.DS_InPageNav_ a:nth-child(4) {
	border-left: 1px solid #000;
	}

	.DS_InPageNav_ a:nth-child(3) {
	border-right: 1px solid #000;
	}

}

@media print, screen and (min-width: 768px) {

	.DS_InPageNav_ {
    grid-template-columns: repeat(5, 1fr);
	margin-top: 10%;
	}

	.DS_InPageNav_ a {
	padding: 20px 0 50px;
	border-left: 1px solid #000;
	border-top: 1px solid #000;
	border-bottom: 1px solid #000;
	font-size: 16px;
	line-height: 1.6;
	background-position: 50% 86%;
	background-size: 20px auto;
	}

	.DS_InPageNav_ a:last-child {
	border-right: 1px solid #000;
	}

}

@media (hover: hover) {

	.DS_InPageNav_ a:hover {
	background-color: var(--color3);
	}

}



/* ■ 商品紹介 ==================================================================================== */

/*
セクション間の余白
見出し・導入
商品一覧
コメント
*/


/* セクション間の余白 --------------------------------------------------- */

@media only screen and (max-width: 767px) {

	.DS_Item_ {
	padding-top: 12%;
	}

}

@media print, screen and (min-width: 768px) {

	.DS_Item_ {
	padding-top: 10%;
	}

}


/* 見出し・導入 --------------------------------------------------- */

.DS_Item_Mds {
line-height: 1;
font-weight: 700;
letter-spacing: 0.1em;
text-align: center;
color: #fff;
background-color: var(--color2);
}

.DS_Item_Intro {
display: flex;
}

@media only screen and (max-width: 767px) {

	.DS_Item_Mds {
	padding: 16px 0 18px;
	font-size: 17px;
	}

	.DS_Item_Intro {
	flex-flow: column;
	}

	.DS_Item_Intro_Lead {
	order: 2;
	margin-top: 5px;
	font-size: 14px;
	line-height: 1.8;
	}

	.DS_Item_Intro_Photo {
	margin-top: 10px;
	}

}

@media print, screen and (min-width: 768px) {

	.DS_Item_Mds {
	padding: 22px 0 24px;
	font-size: 28px;
	}

	.DS_Item_Intro {
	padding: 4.5% 0 0;
	}

	.DS_Item_Intro_Lead {
	flex: 1;
	padding-right: 30px;
	font-size: 15px;
	line-height: 2.2;
	}

	.DS_Item_Intro_Photo {
	width: 320px;
	}

}


/* 商品一覧 --------------------------------------------------- */

.DS_Item_Each_Mds {
display: flex;
justify-content: center;
align-items: center;
font-weight: 700;
letter-spacing: 0.05em;
font-feature-settings: "palt";
text-align: center;
color: var(--color2);
}

.DS_Item_Each_Mds span {
line-height: 1;
color: #fff;
background-color: var(--color2);
}

.DS_Item_Each_Photo {
display: grid;
grid-template-columns: repeat(2, 1fr);
place-items: center;
}

.DS_Item_Each_Photo_Single {
display: flex;
justify-content: center;
}

.DS_Item_Each_Photo_Single .DS_Item_Each_Photo_Each {
width: 50%;
}

.DS_Item_Each_Name {
text-align: center;
}

.DS_Item_Each_Name a {
display: inline-block;
line-height: 1;
text-decoration: underline;
text-underline-offset: 3px;
color: var(--color1);
background-image: url(/images/pages/feature/developmental_support/Icon_Arrow_Foward.png);
background-repeat: no-repeat;
}

.DS_Item_Each_Photo img {
border: 1px solid #e4e4e4;
}

@media only screen and (max-width: 767px) {

	.DS_Item_Each {
	margin-top: 8%;
	}

	.DS_Item_Each_Mds {
	flex-flow: column;
	padding: 14px 0 16px;
	border-top: 3px solid var(--color2);
	font-size: 17px;
	line-height: 1.5;
	}

	.DS_Item_Each_Mds span {
	margin-bottom: 4px;
	padding: 4px 12px 7px 14px;
	font-size: 14px;
	}

	.DS_Item_Each_Photo {
	gap: 8px;
	}

	.DS_Item_Each_Name {
	margin-top: -3px;
	}

	.DS_Item_Each_Name a {
	padding: 10px 0 10px 18px;
	font-size: 13px;
	background-position: 0 56%;
	background-size: 12px auto;
	}

}

@media print, screen and (min-width: 768px) {

	.DS_Item_Each {
	margin-top: 6%;
	}

	.DS_Item_Each_Mds {
	padding: 24px 0;
	border-top: 2px solid var(--color2);
	font-size: 22px;
	}

	.DS_Item_Each_Mds span {
	margin-right: 10px;
	padding: 5px 18px 8px 20px;
	font-size: 21px;
	}

	.DS_Item_Each_Photo {
	gap: 20px;
	}

	.DS_Item_Each_Name {
	margin-top: 5px;
	}

	.DS_Item_Each_Name a {
	padding: 10px 0 10px 24px;
	font-size: 18px;
	background-position: 0 60%;
	background-size: 16px auto;
	}

}

@media (hover: hover) {

	.DS_Item_Each_Name a:hover {
	color: #000;
	}

	.DS_Item_Each_Photo:hover img {
	opacity: 1;
	}

}


/* コメント --------------------------------------------------- */

.DS_Item_Supervisor {
position: relative;
background-color: #eef5f7;
}

.DS_Item_Supervisor_Mds {
display: inline-block;
position: absolute;
line-height: 1;
font-weight: 700;
color: #fff;
background-color: var(--color2);
}

.DS_Item_Supervisor_Mds::after {
position: absolute;
left: 15%;
bottom: 4px;
border-style: solid;
border-width: 20px 0 0 20px;
border-color: var(--color2) transparent transparent;
translate: calc(-50% + 0.4px) 100%;
content: "";
}

.DS_Item_Supervisor_Photo img {
border-radius: 100vh;
}

@media only screen and (max-width: 767px) {

	.DS_Item_Supervisor {
	margin-top: 12%;
	padding: 35px 20px 25px;
	border: 3px solid var(--color3);
	}

	.DS_Item_Supervisor_Photo {
	float: right;
	width: 35%;
	margin-left: 10px;
	}

	.DS_Item_Supervisor_Lead {
	margin-top: 10px;
	font-size: 13px;
	line-height: 1.8;
	}

	.DS_Item_Supervisor_Mds {
	left: 50%;
	top: -22px;
	width: 88%;
	padding: 12px 10px 14px;
	font-size: 14px;
	text-align: center;
	transform: translate(-50%, 0%);
	}

}

@media print, screen and (min-width: 768px) {

	.DS_Item_Supervisor {
	margin-top: 3%;
	padding: 40px 40px 30px;
	border: 4px solid var(--color3);
	}

	.DS_Item_Supervisor_Unit {
	display: flex;
	align-items: center;
	}

	.DS_Item_Supervisor_Photo {
	width: 120px;
	}

	.DS_Item_Supervisor_Lead {
	flex: 1;
	padding-left: 30px;
	font-size: 15px;
	line-height: 2;
	}

	.DS_Item_Supervisor_Mds {
	left: 30px;
	top: -30px;
	padding: 16px 20px 18px;
	font-size: 16px;
	}

}



/* ■ サービス案内 ==================================================================================== */

.DS_Service_Mds {
border-top: 3px solid var(--color1);
font-weight: 700;
letter-spacing: 0.1em;
text-align: center;
color: var(--color1);
}

.DS_Service_Photo {
display: grid;
grid-template-columns: repeat(2, 1fr);
}

.DS_Service_Btn {
text-align: center;
}

@media only screen and (max-width: 767px) {

	.DS_Service_ {
	padding-top: 13%;
	}

	.DS_Service_Mds {
	padding: 12px 0 15px;
	font-size: 18px;
	line-height: 1.6;
	}

	.DS_Service_Lead {
	margin-top: 1.5%;
	font-size: 14px;
	line-height: 1.8;
	}

	.DS_Service_Btn {
	margin-top: 5%;
	}

}

@media print, screen and (min-width: 768px) {

	.DS_Service_ {
	padding-top: 10%;
	}

	.DS_Service_Mds {
	padding: 20px 0 30px;
	font-size: 26px;
	}

	.DS_Service_Lead {
	margin-top: 2%;
	font-size: 16px;
	line-height: 2.2;
	text-align: center;
	}

	.DS_Service_Btn {
	margin-top: 3.5%;
	}

}


