/******* Do not edit this file *******
Simple Custom CSS and JS - by Silkypress.com
Saved: May 25 2026 | 06:44:07 */
@charset "UTF-8";

/* .c-link-external のアイコンを external-link.svg に差し替え */
.c-link-external::after {
    width: 1em;
    height: 1em;
    background-image: url('/products/wp-content/uploads/icon/external-link.svg');
    background-position: center;
    background-size: contain;
    vertical-align: middle;
    margin-left: 0.4em;
}
.c-link-external:hover {
    text-decoration: underline !important;
    text-decoration-thickness: 1.5px !important;
}

/* __icon のCSS矢印を非表示にする */
.c-link-external__icon {
    display: none !important;
}



/* ================================================
   [00] リセット・共通
   ================================================ */

*, *::before, *::after {
  box-sizing: border-box;
  line-break: strict;
}

sup {
	font-size: 0.7em;
	vertical-align: text-top;
	line-height: 1.6;
}

a, a:hover {
  text-decoration-thickness: 1px !important;
}

.product-table_grid-td a:hover,
.c-accordion-content a:hover,
.product-solution__block-text p a:hover,
.product-info a:hover,
.external-link:hover,
.product-icon-blank:hover {
    text-decoration-thickness: 1.5px !important;
}


/* ================================================
   [01] product-main-visual
   ================================================ */

.product-main-visual_service{
	color:#124897;
	font-weight:600;
	font-size:1.4rem;
	line-height:1.6;
	letter-spacing:0.02em;
	display:inline-flex;
	align-items:center;
	padding-top:8px;
}

.product-main-visual_service:before{
	content: "";
	width:14px;
	height:14px;
	background-image: url('/products/wp-content/uploads/icon/icon_circle.svg');
	background-size:contain;
	background-repeat: no-repeat;
	background-position: center;
	margin-right: 0.6rem;
	flex-shrink: 0;
}

.product-main-visual h1{
	font-size:3.6rem;
	font-weight:600;
	line-height:1.5;
	letter-spacing:0.02em;
	padding-bottom:2rem;
}

.product-main-visual h1 > span{
	font-size:2.4rem;
	line-height:1.4;
	letter-spacing:0.02em;
}

.product-main-visual_service_h1_top {
	display: block;
	padding-bottom: 0.4rem;
}

.product-main-visual_image{
	background-image: url('/products/wp-content/uploads/icon/bg_section.png');
	background-size:contain;
	background-repeat: repeat;
	background-position: center;
	padding:4rem 0;
	border-radius:6px;
	display:flex;
	justify-content: center;
}

.product-main-visual_image img{
	max-width:640px;
	width:100%;
	height:auto;
	border-radius: 6px;
	box-shadow: 0 4px 20px 0 rgba(0, 0, 0, 0.10);
}

.product-main-visual__lead{
	padding:3.2rem 0 0;
}

.product-main-visual__lead h2{
	font-size:2.4rem;
	font-weight:600;
	line-height: 1.4;
	letter-spacing:0.02em;
	padding-bottom:0.8rem;
}

.product-main-visual__lead p{
	font-size:1.6rem;
	line-height: 1.6;
	letter-spacing:0.02em;
}

.product-main-visual-contact{
	padding:6.2rem 0 7.2rem;
	text-align:center;
}

.product-main-visual-contact a{
	font-size:1.8rem;
	font-weight:600;
	line-height: 1.4;
	letter-spacing:0.04em;
	border:1px solid #124897;
	border-radius:49px;
	color:#124897;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	height: 70px;
	box-sizing: border-box;
	padding:0 6.4rem;
}

.product-main-visual-contact a:hover{
	transform: scale(1.02,1.02);
	background-color: #143867;
	color: #fff;
	transition: transform 0.3s ease-in-out;
	opacity:1;
}

.product-main-visual_caution{
	padding-top:2rem;
	font-size: 1.2rem !important;
	line-height: 1.6;
}

/* SP */
@media (max-width: 768px) {
	.product-main-visual_service{
		padding: 0;
		align-items: flex-start;
	}
	.product-main-visual_service:before{
		margin-top: 0.4rem;
	}
	.product-main-visual h1{
		font-size:2.8rem;
		line-height:1.5;
		letter-spacing:0.02em;
		padding: 0 0 1.6rem;
	}
	.product-main-visual_service_h1_top {
	font-size:2rem !important;
	}
	.product-main-visual_image{
		border-radius:0;
		margin:0;
		margin-inline: calc(50% - 50vw);
		width: 100vw;
		height: auto;
		padding: 20px 24px;
		display: flex;
		justify-content: center;
		align-items: center;
		box-sizing: border-box;
	}
	.product-main-visual_image img {
		width: 100%;
		height: auto;
		max-width: 100%;
	}
	.product-main-visual__lead{
		padding:2.4rem 0 0;
	}
	.product-main-visual__lead h2{
		font-size:2rem;
		letter-spacing:0.02em;
		padding-bottom:1rem;
	}
	.product-main-visual__lead p{
		font-size:1.5rem;
		text-align:justify;
	}
	.product-main-visual-contact{
		padding: 4rem 0 4.8rem;
	}
	.product-main-visual-contact a{
		font-size:1.5rem;
		letter-spacing:0.02em;
		padding: 1.6rem 2.4rem;
	}
	.product-main-visual_caution{
		font-size: 1.1rem !important;
	}
}


/* ================================================
   [01-b] product-feature（機能詳細ページ用）
   ================================================ */

.product-feature {
	padding-bottom: 4.8rem;
}

.product-feature h1{
	font-size:2.8rem;
	font-weight:600;
	line-height:1.5;
	letter-spacing:0.02em;
	padding-top: 0.6rem;
}

.product-feature__lead{
	font-size:1.6rem;
	line-height:1.6;
	letter-spacing:0.02em;
	margin-top: 1rem;
}

/* SP */
@media (max-width: 768px) {
	.product-feature {
		padding-bottom: 4rem;
	}
	.product-feature h1{
		font-size:2.4rem;
	}
	.product-feature__lead{
		font-size:1.5rem;
	}
}


/* ================================================
   [01-c] product-feature-link（その他機能情報リンク）
   ================================================ */

.product-feature-link{
	padding:5.6rem 0 0;
}

.product-feature-link h3{
	font-size:2rem;
	font-weight:600;
	line-height:1.5;
	letter-spacing:0.02em;
	padding-bottom: 2.4rem;
}

.product-feature-link-16 h3{
	padding-bottom: 1.6rem;
}

.product-feature-link-list{
	padding:0;
	margin:0;
	display:flex;
	flex-wrap:wrap;
	gap:1rem 3.2rem;
}

.product-feature-link-list a{
	font-size:1.4rem;
	line-height:1.5;
	font-weight:600;
	letter-spacing:0.02em;
	padding-right: 28px;
}

.product-feature-link-list a:hover{
	color:#124897;
	text-decoration:underline;
}

/* SP */
@media (max-width: 768px) {
	.product-feature-link{
		padding:4rem 0 0;
	}
	.product-feature-link h3{
		font-size:1.8rem;
		font-weight:600;
		line-height:1.5;
		letter-spacing:0.02em;
	}
}


/* ================================================
   [02] product-toc（アンカーリンク）
   ================================================ */

.product-toc{
	padding:2.4rem 0;
	margin-bottom:8rem;
	border-top:1px solid #E8E9EB;
	border-bottom:1px solid #E8E9EB;
	display:flex;
	flex-wrap:wrap;
	gap:1rem 3.2rem;
}

/* SP */
@media (max-width: 768px) {
	.product-toc {
		margin:0 0 5.6rem;
	}
}


/* ================================================
   [03] product-tab（金融・事法 切替タブ）
   ================================================ */

.product-tab{
	padding:0 0 4.8rem;
	display:flex;
	width:100%;
}

.product-tab a{
	flex:1;
	text-align: center;
	padding:1.5rem 0;
}

.product-tab_on{
	color:#124897;
	font-size:1.6rem;
	font-weight:600;
	line-height: 1.6;
	letter-spacing:0.02em;
	border-bottom:2px solid #124897;
	background-color:#ECF0F7;
	pointer-events: none;
	cursor: default;
}

.product-tab_off{
	color:#5B5C5E;
	font-size:1.6rem;
	font-weight:600;
	line-height: 1.6;
	letter-spacing:0.02em;
	border-bottom:2px solid #D9DBDE;
	display: inline-flex;
	justify-content: center;
	align-items: center;
	position: relative;
	transition: color 0.2s ease-in-out;
}

.product-tab_off:hover{
	color:#124897;
	border-bottom:2px solid #124897;
	opacity: 1;
	transition: color 0.2s ease-in-out;
}

.product-tab_off span {
	position: relative;
	padding-right: 25px;
	display: inline-block;
}

.product-tab_off span:before,
.product-tab_off span:after {
	content: "";
	position: absolute;
	transition: 0.2s ease-in-out;
}

.product-tab_off span:before {
	background-image: url('/products/wp-content/uploads/icon/icon_blank_frame_b.svg');
	background-repeat: no-repeat;
	height: 20px;
	width: 20px;
	right: -8px;
	top: 55%;
	transform: translateY(-50%);
	z-index: 1;
}

.product-tab_off span:after {
	background-image: url('/products/wp-content/uploads/icon/icon_blank_arrow_b.svg');
	background-repeat: no-repeat;
	background-position: top center;
	background-size: 100% 100%;
	top: -4%;
	margin-top: 3px;
	height: 11px;
	width: 13px;
	right: -6px;
	z-index: 2;
}

.product-tab_off:hover span:before {
	transform: translateY(-50%);
}

.product-tab_off:hover span:after {
	height: 13px;
	right: -8px;
	margin-top: 1px;
}

/* SP */
@media (max-width: 768px) {
	.product-tab{
		width: 100%;
		padding: 5.6rem 0 0;
	}
	.product-tab a{
		font-size:1.2rem;
		letter-spacing:0.02em;
		padding: 1.45rem 0;
	}
	.product-tab_off span:after {
		top: -20%;
		margin-top: 3px;
		height: 10px;
		width: 12px;
		right: -6px;
	}
}


/* ================================================
   [04] product-problems（お悩み）
   ================================================ */
.product-problems {
	padding:0 0 8rem;
}
.product-problems h2{
	font-size:2.4rem;
	font-weight:600;
	line-height: 1.4;
	letter-spacing:0.02em;
	padding-bottom:2.4rem;
	display: flex;
	align-items: center;
}
.product-problems ul{
	display:flex;
	flex-wrap: wrap;
	gap:2.4rem 2.4rem;
}
.product-problems li{
	font-size:1.6rem;
	line-height: 1.6;
	letter-spacing:0.02em;
	background-color:#F8F9FA;
	flex-grow: 0;
	padding:2rem;
	box-sizing: border-box;
	border-radius:6px;
}
.product-problems li.is-narrow {
	padding: 2rem 1.8rem;
}
.product-problems li.is-tight {
	padding: 2rem 1.6rem;
}
.product-problems dl{
	display:flex;
	flex-wrap: wrap;
	gap:2.4rem 2.4rem;
	margin:0;
}
.product-problems_box{
	background-color:#F8F9FA;
	flex-grow: 0;
	padding:2rem;
	box-sizing: border-box;
	border-radius:6px;
	display: flex;
	flex-direction: column;
	justify-content: flex-start;
}
.product-problems_box.is-narrow {
	padding: 2rem 1.8rem;
}
.product-problems dt{
	font-size:1.6rem;
	font-weight:600;
	line-height: 1.4;
	letter-spacing:0.02em;
	padding-bottom:1rem;
	margin-bottom:1rem;
	border-bottom:1px solid #D9DBDE;
}
.product-problems dt.is-bottom{
	order: 2;
	display: block;
	width: 100%;
	margin-top: auto;
	text-align: right;
	border-bottom: none;
	border-top: 1px solid #D9DBDE;
	padding-top: 1rem;
	padding-bottom: 0;
	margin-bottom: 0;
}
.product-problems_box:has(dt.is-bottom) dd {
	margin-bottom: 1rem;
}
.product-problems dd{
	font-size:1.6rem;
	line-height: 1.6;
	letter-spacing:0.02em;
	margin:0;
}
.product-problems_b{
	font-weight:600 !important;
	letter-spacing:0.02em !important;
}
/* 3カラム */
.product-problems--col3 li{
	flex-basis: calc((100% - 4.8rem) / 3);
}
.product-problems--col3 .product-problems_box{
	flex-basis: calc((100% - 4.8rem) / 3);
}
/* 2カラム */
.product-problems--col2 li{
	flex-basis: calc((100% - 2.4rem) / 2);
}
.product-problems--col2 .product-problems_box{
	flex-basis: calc((100% - 2.4rem) / 2);
}

/* SP */
@media (max-width: 768px) {
	.product-problems {
		padding:5.6rem 0 5.6rem;
	}
	.product-problems h2{
		font-size:2rem;
		letter-spacing:0.02em;
		padding-bottom:1.6rem;
	}
	.product-problems ul{
		gap:1.6rem;
	}
	.product-problems li,
	.product-problems--col2 li,
	.product-problems--col3 li{
		font-size:1.5rem;
		letter-spacing:0.02em;
		flex-basis:auto;
		width:100%;
	}
	.product-problems dl{
		gap:1.6rem;
	}
	.product-problems dt{
		font-size:1.5rem;
		letter-spacing:0.02em;
	}
	.product-problems dd{
		font-size:1.5rem;
	}
	.product-problems_box,
	.product-problems--col2 .product-problems_box,
	.product-problems--col3 .product-problems_box{
		flex-basis: 100%;
		padding:2rem;
	}
}


/* ================================================
   [05] product-solution（解決）
   ================================================ */

/* --- ラッパー --- */
.product-solution_wrap1{
	padding:0 0 8rem;
}

.product-solution_wrap2{
	padding:4rem;
	margin-bottom:8rem;
	border:1px solid #ECF0F7;
	border-radius: 6px;
}

.product-solution_wrap-pb-56{
	padding:0 0 5.6rem;
}

.product-solution_wrap-pb-64{
	padding:0 0 6.4rem;
}

/* --- 見出し --- */
.product-solution_wrap1 > .product-solution > h2{
	color:#124897;
	font-size:2.4rem;
	font-weight:600;
	line-height: 1.4;
	letter-spacing:0.02em;
	padding-bottom:4rem;
	display: flex;
	align-items: flex-start;
}

.product-solution_wrap1 > .product-solution > h2::before{
	content: "";
	width:28px;
	height:35px;
	background-image: url('/products/wp-content/uploads/icon/icon_light.png');
	background-size:contain;
	background-repeat: no-repeat;
	background-position: center;
	margin-right: 0.8rem;
	flex-shrink: 0;
	margin-top: -3px;
}

.product-solution_wrap1 > .product-solution2 > h2::before{
	content: "";
	width:16px;
	height:16px;
	background-image: url('/products/wp-content/uploads/icon/icon_circle.svg');
	background-size:contain;
	background-repeat: no-repeat;
	background-position: center;
	margin-right: 1rem;
	flex-shrink: 0;
	margin-top: 8px;
}

.product-solution_wrap2 > .product-solution > h2{
	color:#124897;
	font-size:2rem;
	font-weight:600;
	line-height: 1.5;
	letter-spacing:0.02em;
	padding-bottom:3.2rem;
}

/* --- リスト --- */
.product-solution_wrap1 > .product-solution > ul{
	display:flex;
	flex-direction: column;
	gap:5.6rem;
}

.product-solution_wrap1 > .product-solution > ul.is-narrow-gap {
	gap: 4rem;
}

.product-solution_wrap2 > .product-solution > ul{
	display:flex;
	flex-direction: column;
	gap:4rem;
}


/* --- li（画像+テキスト横並び） --- */
.product-solution li{
	display:flex;
	gap:4rem;
	align-items: flex-start;
	flex-direction: row-reverse;
}

.product-solution li img{
	flex:1;
	min-width: 0;
	width:100%;
	height:auto;
	object-fit:contain;
	border-radius:6px;
	border:1px solid #E8E9EB;
}

.product-solution li img.no-border{
	border: none !important;
}

/* --- テキストブロック --- */
.product-solution__block-text{
	flex:1;
}

.product-solution__block-text h3{
	font-size:2rem;
	font-weight:600;
	line-height: 1.5;
	letter-spacing:0.02em;
	padding-bottom:1rem;
}

.product-solution__block-text > h3 > span{
	font-size:1.6rem;
	line-height: 1.6;
	letter-spacing:0.02em;
}

.product-solution__block-text h4{
	font-size:1.6rem;
	line-height: 1.6;
	letter-spacing:0.02em;
	position: relative;
	margin: 1rem 0 0;
}

.product-solution__block-text h4 span{
	padding-left: 1em;
}

.product-solution__block-text h4 span::before {
	content: '';
	display: block;
	width: 4px;
	height: 4px;
	background-color: #232323;
	border-radius: 50%;
	position: absolute;
	left: 0.4em;
	top: 1rem;
}

.product-solution__block-text p{
	font-size:1.6rem;
	line-height: 1.6;
	letter-spacing:0.02em;
}

.product-solution__block-text p a{
	text-decoration:underline;
	display:inline;
	color:#124897;
}

.product-solution__block-text > .product-solution__caution{
	font-size:1.2rem;
	line-height:1.6;
	letter-spacing:0.02em;
	padding-top:1rem;
}
.product-solution > .product-solution__caution {
	font-size:1.2rem;
	line-height:1.6;
	letter-spacing:0.02em;
	padding-top:5.6rem;
}

/* --- 動画ブロック --- */
.product-solution__block-video {
	flex: 1;
	min-width: 0;
	position: relative;
	border-radius: 6px;
	border: 1px solid #E8E9EB;
	overflow: hidden;
	background: #f0f0f0;
}

.product-solution__block-video iframe {
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	border: 0;
}

/* --- 画像+ラベル ブロック --- */
.product-solution__block-media {
	flex: 1;
	min-width: 0;
	display: flex;
	flex-direction: column;
	gap: 0;
}

.product-solution__block-media > img {
	width: 20px;
	height: auto;
	object-fit: contain;
	border-radius: 0 0 6px 6px;
	border-top: none;
}

.product-solution__media-label {
	display: flex;
	align-items: center;
	gap: 1rem;
	padding: 0 2rem;
	height: 30px!important;
	border-radius: 15px;
	background-color: #F4F6FC;
	margin-bottom: 6px;
}

.product-solution__media-label img {
	width: 20px !important;
	height: 20px !important;
	flex-shrink: 0;
	flex: none !important;
	border: none !important;
	border-radius: 0 !important;
}

.product-solution__media-label span {
	font-size: 1.6rem;
	font-weight: 600;
	line-height: 1.6;
	letter-spacing: 0.02em;
	color: #143867;
}

/* --- リード・サブ見出し --- */
.product-solution_lead{
	font-size: 1.6rem;
	line-height: 1.6;
	letter-spacing:0.02em;
	padding-bottom:5.6rem;
	margin-top:-3rem;
}

.product-solution_h3-sub{
	display:block;
	padding-bottom:1rem;
	font-size: 1.6rem;
	line-height: 1.6;
	letter-spacing:0.02em;
}

.product-solution_h3-sub-target {
	font-size: 1.4rem !important;
	background-color:#F4F5F7;
	padding:5px 20px 4px 20px;
	border-radius: 17px;
	display: inline-block;
	margin-bottom:1rem;
}

.product-solution_h3-sub-target-w {
	font-size: 1.4rem !important;
	background-color:#F4F5F7;
	padding:5px 15px 4px 15px;
	border-radius: 17px;
	display: inline-block;
	margin-bottom:1rem;
}

.product-solution_h3-sub-service{
	display:flex;
	align-items: flex-start;
	padding-bottom:1rem;
	font-size: 1.4rem !important;
	font-weight:600;
	color:#124897;
	line-height: 1.6;
	letter-spacing:0.02em;
}

.product-solution_h3-sub-service::before{
	content: "";
	display: block;
	width:14px;
	height:14px;
	background-image: url('/products/wp-content/uploads/icon/icon_circle.svg');
	background-size:contain;
	background-repeat: no-repeat;
	background-position: center;
	margin-right: 0.6rem;
	margin-top:8px;
	flex-shrink: 0;
	transform: translateY(-4px);
}

/* --- alternate（画像・テキスト 交互配置） --- */
.product-solution--alternate .product-solution li:nth-child(even){
	flex-direction: row;
}

.product-solution--alternate .product-solution li{
	align-items: center;
}

.product-solution--alternate-reverse .product-solution li:nth-child(odd){
	flex-direction: row;
}

.product-solution--alternate-reverse .product-solution li{
	align-items: center;
}

/* SP */
@media (max-width: 768px) {
	.product-solution_wrap1{
		padding:0 0 5.6rem;
	}
	.product-solution_wrap1.is-sp-pt56 {
		padding-top: 5.6rem;
	}
	.product-solution_wrap2{
		padding:2.4rem 2rem;
		margin:0 0 5.6rem;
	}
	.product-solution_wrap-pb-64{
	padding:0 0 5.6rem;}
	.product-solution_wrap1 > .product-solution > h2{
		font-size:2rem;
		letter-spacing:0.02em;
		padding-bottom:2.4rem;
	}
	.product-solution_wrap2 > .product-solution > h2{
		font-size:1.8rem;
		letter-spacing:0.02em;
		padding-bottom:2.4rem;
	}
	.product-solution_wrap1 > .product-solution2 > h2::before{
		width:14px;
		height:14px;
		margin-right: 0.8rem;
		margin-top: 7px;
	}
	.product-solution ul{
		gap:4rem;
	}
	.product-solution_wrap1 > .product-solution li{
		flex-direction: column;
		gap: 1.6rem;
		align-items: stretch;
	}
	.product-solution_wrap2 > .product-solution li{
		flex-direction: column;
		gap: 1.6rem;
		align-items: stretch;
	}
	.product-solution--alternate .product-solution li:nth-child(even){
		flex-direction: column;
	}
	.product-solution--alternate .product-solution li img{
		order: -1;
	}
	.product-solution--alternate-reverse .product-solution li:nth-child(odd){
		flex-direction: column;
	}
	.product-solution--alternate-reverse .product-solution li img{
		order: -1;
	}
	.product-solution__block-video {
		order: -1;
		flex: none;
		width: 100%;
	}
	.product-solution__block-media {
		order: -1;
		flex: none;
		width: 100%;
	}
	.product-solution__media-label span {
		font-size: 1.5rem;
	}
	.product-solution__block-text h3{
		font-size:1.8rem;
		letter-spacing:0.02em;
	}
	.product-solution__block-text > h3 > span{
		font-size:1.5rem;
		line-height: 1.6;
		letter-spacing:0.02em;
	}
	.product-solution__block-text h4 {
		font-size: 1.5rem;
		margin:0.8rem 0 0;
	}
	.product-solution__block-text p{
		font-size: 1.5rem;
		letter-spacing:0.02em;
		text-align:justify;
	}
	.product-solution__block-text > .product-solution__caution{
		font-size:1.1rem;
		letter-spacing:0.02em;
		padding-top:1rem;
	}
	.product-solution > .product-solution__caution {
		font-size: 1.1rem;
		padding-top:4.8rem;
	}
	.product-solution_wrap1 > .product-solution > ul{
		gap:4rem;
	}
	.product-solution_lead{
		font-size: 1.5rem;
		letter-spacing:0.02em;
		padding-bottom:4rem;
		margin-top:-1.4rem;
	}
	.product-solution_h3-sub{
		font-size: 1.5rem;
		line-height: 1.6;
	}
	.product-solution_h3-sub-target {
		font-size:1.2rem !important;
	}
	.product-solution_h3-sub-target-w {
		font-size:1.2rem !important;
	}
}


/* ================================================
   [06] product-function（機能カード）
   ================================================ */
.product-function{
	padding:0 0 8rem;
}
.product-function h2{
	color: #124897;
	font-size:2.4rem;
	font-weight:600;
	line-height: 1.4;
	letter-spacing:0.02em;
	padding-bottom:2.4rem;
	display: flex;
	align-items: flex-start;
}
.product-function h2::before{
	content: "";
	width:16px;
	height:16px;
	background-image: url('/products/wp-content/uploads/icon/icon_circle.svg');
	background-size:contain;
	background-repeat: no-repeat;
	background-position: center;
	margin-right: 1rem;
	margin-top:8px;
	flex-shrink: 0;
}
.product-function ul{
	width:100%;
	display:flex;
	flex-wrap: wrap;
	gap:3.2rem 3.2rem;
}
.product-function li{
	flex-grow: 0;
	flex-basis: calc(50% - 3.2rem / 2);
	border:1px solid #ECF0F7;
	border-radius:6px;
	padding:2rem;
	box-sizing: border-box;
}
.product-function li h3{
	font-size:2rem;
	font-weight:600;
	line-height: 1.5;
	letter-spacing:0.02em;
	padding-bottom:0.8rem;
}
.product-function_label{
	font-size: 1.6rem;
	font-weight: 600;
	line-height: 1.6;
	letter-spacing: 0.02em;
	display: block;
	padding-bottom: 0.8rem;
	color: #232323 !important;
}
.product-function li p{
	font-size:1.4rem;
	line-height: 1.6;
	letter-spacing:0.02em;
}
@media (min-width: 1208px) {
    .product-function li p {
        word-break: auto-phrase;
    }
}
.product-function li a{
	color:#124897;
	font-size:1.4rem;
	line-height: 1.6;
	letter-spacing:0.02em;
	display: inline-flex;
	align-items: center;
}
.product-function li a:hover{
	text-decoration:underline;
}
.product-function li:has(a):hover h3,
.product-function li:has(a):hover p {
    color: #124897;
}

/* SP */
@media (max-width: 768px) {
	.product-function{
		padding:0 0 5.6rem;
	}
	.product-function h2{
		font-size:2rem;
		letter-spacing:0.02em;
		padding-bottom:1.6rem;
	}
	.product-function h2::before{
		width:14px;
		height:14px;
		margin-right: 0.8rem;
		margin-top: 7px;
	}
	.product-function ul{
		gap:1.6rem;
	}
	.product-function li{
		flex-basis:100%;
	}
	.product-function li h3{
		font-size:1.8rem;
		letter-spacing:0.02em;
	}
	.product-function_label{
		font-size: 1.5rem;
	}
	.product-function li p{
		font-size:1.2rem;
	}
	.product-function li a{
		font-size:1.2rem;
	}
}
/* --- リンクカード化 --- */
.product-function li:has(> a) {
	padding: 0;
}
.product-function li > a {
	display: block;
	padding: 2rem;
	text-decoration: none;
	color: inherit;
	height: 100%;
	box-sizing: border-box;
}
.product-function li > a:hover {
	color: inherit;
	text-decoration: none;
}
.product-function li > a h3 {
	font-size: 2rem;
	font-weight: 600;
	line-height: 1.5;
	letter-spacing: 0.02em;
	padding-bottom: 0.8rem;
	color: #232323;
}
.product-function li > a p {
	font-size: 1.4rem;
	line-height: 1.6;
	letter-spacing: 0.02em;
	color: #232323;
}
.product-function li > a .product-link-arrow {
	color: #124897;
	font-size: 1.4rem;
	line-height: 1.6;
	letter-spacing: 0.02em;
	display: inline-flex;
	align-items: center;
}
.product-function li > a:hover .product-link-arrow {
	text-decoration: underline;
}
.product-function li > a:hover .product-function_label{
	text-decoration: none;
	color: #124897 !important;
}
.product-function li:hover .product-link-arrow::before,
.product-function li:hover .product-link-arrow::after {
    transform: translateY(-50%);
    transition: 0.2s ease-in-out;
}

.product-function li:hover .product-link-arrow::after {
    right: 4px;
    width: 16px;
}

/* SP */
@media (max-width: 768px) {
	.product-function li > a h3 {
		font-size: 1.8rem;
		letter-spacing: 0.02em;
	}
	.product-function li > a p {
		font-size: 1.2rem;
	}
	.product-function li > a .product-link-arrow {
		font-size: 1.2rem;
	}
}


/* ================================================
   [07] product-table（表組）
   ================================================ */

.product-table{
	padding:0 0 8rem;
}

.product-table h2{
	color:#124897;
	font-size:2.4rem;
	font-weight:600;
	line-height: 1.4;
	letter-spacing:0.02em;
	padding-bottom:2.4rem;
	display: flex;
	align-items: flex-start;
}

.product-table h2::before{
	content: "";
	width:16px;
	height:16px;
	background-image: url('/products/wp-content/uploads/icon/icon_circle.svg');
	background-size:contain;
	background-repeat: no-repeat;
	background-position: center;
	margin-right: 1rem;
	margin-top:8px;
	flex-shrink: 0;
}

.product-table.is-baseline h2 {
	align-items: baseline;
}

.product-table h3{
	font-size:2rem;
	font-weight:600;
	line-height: 1.5;
	letter-spacing:0.02em;
	padding-bottom:1.6rem;
}

/* --- グリッド --- */
.product-table_grid{
	display: grid;
	gap:0;
	width: 100%;
	margin:0;
	border-top: 1px solid #E8E9EB;
	border-left: 1px solid #E8E9EB;
	font-size:1.6rem;
	line-height: 1.6;
	letter-spacing:0.02em;
	box-sizing: border-box;
}

.product-table_grid_pt1{ grid-template-columns: 220px minmax(0, 1fr); }
.product-table_grid_pt2{ grid-template-columns: 1fr; }
.product-table_grid_pt3{ grid-template-columns: 220px minmax(0, 1fr); }
.product-table_grid_pt4{ grid-template-columns: 220px 1fr; }
.product-table_grid_pt5{ grid-template-columns: 220px minmax(0, 1fr) 65px; }
.product-table_grid_pt-data{ grid-template-columns: 14rem 14rem minmax(0,1fr); }

.product-table_grid-th{
	padding: 1rem 1.6rem;
	border-right: 1px solid #E8E9EB;
	border-bottom: 1px solid #E8E9EB;
	background-color: #F8F9FA;
	font-weight:600;
}

.product-table_grid-td{
	padding: 1rem 1.6rem;
	border-right: 1px solid #E8E9EB;
	border-bottom: 1px solid #E8E9EB;
	word-break: break-all;
	overflow-wrap: anywhere;
}

.product-table_grid-td a{
	text-decoration:underline;
	color:#124897;
	display: inline;
}

.product-table_grid-td.is-label{
	display: flex;
	flex-direction: column;
	gap: 0;
}

.product-table_grid-label{
	font-size: 1.4rem;
	font-weight: 600;
	line-height: 1.6;
}

.product-table_grid-name{
	font-size: 1.6rem;
	font-weight: 600;
	line-height: 1.5;
}

.product-table_grid-td.is-pdf{
	display: flex;
	justify-content: center;
}

.product-table_grid-td.is-pdf a{
	color: #124897;
	text-decoration: underline;
	font-weight: 300;
}

.product-table_grid-td li{
	font-size: 1.6rem;
	line-height: 1.6;
	letter-spacing:0.02em;
	position: relative;
	padding-left: 1.5em;
}

.product-table_grid-td li::before {
	content: '';
	display: block;
	width: 4px;
	height: 4px;
	background-color: #232323;
	border-radius: 50%;
	position: absolute;
	left: 0.4em;
	top: 1rem;
}

.product-table_grid-td li:first-child { padding-top: 0; }
.product-table_grid-td li:first-child::before { top: 1.1rem; }
.product-table_grid-td li:last-child { border-bottom:none; }
.product-table_grid-td li.top-space{ margin-top: 1rem !important; }

.product-table-2{ margin: 5.6rem 0 0; }

.product-table_caution{
	font-size:1.2rem;
	line-height: 1.6;
	letter-spacing:0.02em;
	padding-top: 0.8rem;
	display: block;
}

.product-table_caution_below{
	font-size:1.2rem;
	line-height: 1.6;
	letter-spacing:0.02em;
	padding-top: 1.6rem;
	display: block;
}

/* --- row-span --- */
.row-span-2{grid-row:span 2}
.row-span-3{grid-row:span 3}
.row-span-4{grid-row:span 4}
.row-span-5{grid-row:span 5}
.row-span-6{grid-row:span 6}
.row-span-7{grid-row:span 7}
.row-span-8{grid-row:span 8}

/* SP */
@media (max-width: 768px) {
	.product-table{
		padding:0 0 5.6rem;
	}
	.product-table h2{
		font-size:2rem;
		letter-spacing:0.02em;
		padding-bottom:1.6rem;
	}
	.product-table h2::before{
		width:14px;
		height:14px;
		margin-right: 0.8rem;
		margin-top: 7px;
	}
	.product-table.is-baseline h2 {
		font-size: 2rem;
		letter-spacing: 0.02em;
		padding-bottom: 2.4rem;
		flex-wrap: wrap;
	}
	.product-table.is-baseline h2 .product-mini {
		display: block;
		width: 100%;
		padding-top: 0.4rem;
		padding-left: calc(16px + 0.9rem);
		box-sizing: border-box;
	}
	.product-table h3{
		font-size:1.8rem;
		letter-spacing:0.02em;
		padding-bottom:1rem;
	}
	.product-table_grid{
		margin:0;
		font-size:1.5rem;
		letter-spacing:0.02em;
	}
	.product-table_grid_pt1{ grid-template-columns: 100px minmax(0, 1fr); }
	.product-table_grid_pt3{ grid-template-columns: 100px minmax(0, 1fr); }
	.product-table_grid_pt4{ grid-template-columns: 1fr; }
	.product-table_grid_pt5{ grid-template-columns: 1fr; }
	.product-table_grid_pt-data{ grid-template-columns: 8rem 8rem minmax(0,1fr); }
	.product-table_grid-td li{
		font-size: 1.5rem;
		line-height: 1.6;
		letter-spacing:0.02em;
		position: relative;
		padding-left: 1.5em;
	}
	.product-table_grid-td.is-label{
		background-color: #F8F9FA;
		font-weight: 600;
	}
	.product-table_grid-label{
	font-size: 1.2rem;
	}
	.product-table_grid-name{
	font-size: 1.5rem;
	}
	.product-table_grid-td.is-pdf{
		justify-content: flex-start;
	}
	.product-table_caution{
		font-size:1.1rem;
		letter-spacing:0.02em;
	}
	.product-table_caution_below{
		font-size:1.1rem;
		letter-spacing:0.02em;
	}
	.product-table-2{
		margin: 4rem 0 0;
	}
}


/* ================================================
   [08] product-recommend（このような方におすすめ）
   ================================================ */

.product-recommend{
	padding:0 0 6.4rem;
}

.product-recommend h2{
	color:#124897;
	font-size:2.4rem;
	font-weight:600;
	line-height: 1.4;
	letter-spacing:0.02em;
	padding-bottom:2.4rem;
	display: flex;
	align-items: flex-start;
}

.product-recommend h2::before{
	content: "";
	width:16px;
	height:16px;
	background-image: url('/products/wp-content/uploads/icon/icon_circle.svg');
	background-size:contain;
	background-repeat: no-repeat;
	background-position: center;
	margin-right: 1rem;
	margin-top:8px;
	flex-shrink: 0;
}

.product-recommend > h2 > span{
	grid-column: 2;
	font-size:1.6rem;
	line-height: 1.6;
	display: block;
}

.product-recommend.is-baseline h2 {
	display: flex;
	align-items: baseline;
	column-gap: 0rem;
	flex-wrap: wrap;
}

.product-recommend.is-baseline > h2 > span {
	display: inline-block;
	width: auto; 
	white-space: normal;
}

.product-mini {
	vertical-align: baseline;
	font-size: 1.6rem;
}

.product-recommend ul{
	display:flex;
	flex-direction: column;
}

.product-recommend li{
	font-size: 1.6rem;
	line-height: 1.6;
	letter-spacing:0.02em;
	padding:1.6rem 0;
	border-bottom:1px solid #E8E9EB;
	position: relative;
	padding-left: 1.5em;
}

.product-recommend li::before {
	content: '';
	display: block;
	width: 4px;
	height: 4px;
	background-color: #232323;
	border-radius: 50%;
	position: absolute;
	left: 0.4em;
	top: 2.5rem;
}

.product-recommend li:first-child::before { top: 1.1rem; }
.product-recommend li:first-child { padding-top: 0; }
.product-recommend li:last-child { border-bottom:none; }

.product-recommend-b{
	font-weight:600 !important;
	padding-bottom:0.8rem;
	display:block;
}

.product-recommend-b.is-inline {
	display: inline;
}

/* SP */
@media (max-width: 768px) {
	.product-recommend{
		padding:0 0 4rem;
	}
	.product-recommend h2{
		font-size:2rem;
		letter-spacing:0.02em;
		padding-bottom:2.4rem;
	}
	.product-recommend h2::before{
		width:14px;
		height:14px;
		margin-right: 0.8rem;
		margin-top: 7px;
	}
	.product-mini {
		vertical-align: baseline;
		font-size: 1.5rem;
	}
	.product-recommend li{
		font-size: 1.5rem;
		letter-spacing:0.02em;
	}
	.product-recommend-b{
		padding-bottom:1rem;
	}
	.product-recommend h2 span {
		display: block;
		width: 100%;
		padding-top: 0.5rem;
		padding-left: calc(14px + 0.9rem);
		font-size:1.5rem;
	}
}


/* ================================================
   [09] product-spec（仕様）
   ================================================ */

.product-spec{
	padding:0 0 8rem;
}

.product-spec.is-pb40 {
	padding: 0 0 4rem;
}

.product-spec h2{
	color:#124897;
	font-size:2.4rem;
	font-weight:600;
	line-height: 1.4;
	letter-spacing:0.02em;
	padding-bottom:2.4rem;
	display: flex;
	align-items: flex-start;
}

.product-spec h2::before{
	content: "";
	width:16px;
	height:16px;
	background-image: url('/products/wp-content/uploads/icon/icon_circle.svg');
	background-size:contain;
	background-repeat: no-repeat;
	background-position: center;
	margin-right: 1rem;
	margin-top:8px;
	flex-shrink: 0;
}

.product-spec ul{
	display:flex;
	flex-wrap: wrap;
	gap:1.6rem 3.2rem;
}

.product-spec li{
	width: calc(50% - 1.6rem);
	font-size: 2rem;
	font-weight:600;
	line-height: 1.5;
	letter-spacing:0.02em;
	padding:1.6rem 2rem;
	border:1px solid #E8E9EB;
	border-radius: 6px;
	box-sizing: border-box;
}

/* SP */
@media (max-width: 768px) {
	.product-spec{
		padding:0 0 4.8rem;
	}
	.product-spec.is-pb40 {
	padding: 0 0 3.2rem;
	}
	.product-spec h2{
		font-size:2rem;
		letter-spacing:0.02em;
		padding-bottom:1.6rem;
	}
	.product-spec h2::before{
		width:14px;
		height:14px;
		margin-right: 0.8rem;
		margin-top: 7px;
	}
	.product-spec li{
		width:100%;
		font-size: 1.8rem;
		letter-spacing:0.02em;
	}
}


/* ================================================
   [10] product-voice（お客さまの声）
   ================================================ */

.product-voice{
	padding:0 0 8rem;
}

.product-voice h2{
	color:#124897;
	font-size:2.4rem;
	font-weight:600;
	line-height: 1.4;
	letter-spacing:0.02em;
	padding-bottom:2.4rem;
	display: flex;
	align-items: flex-start;
}

.product-voice h2::before{
	content: "";
	width:16px;
	height:16px;
	background-image: url('/products/wp-content/uploads/icon/icon_circle.svg');
	background-size:contain;
	background-repeat: no-repeat;
	background-position: center;
	margin-right: 1rem;
	margin-top:8px;
	flex-shrink: 0;
}

.product-voice_wrap{
	display:flex;
	flex-wrap: wrap;
	gap:4rem;
}

.product-voice_card{
	width: calc(50% - 2rem);
	display:flex;
	gap:1.6rem;
	flex-direction: column;
	justify-content: flex-start;
}

.product-voice_card-profile{
	display:flex;
	gap:2.4rem;
	align-items: center;
}

.product-voice_card-profile_image{
	max-width:110px;
}

.product-voice_card-profile_text{
	flex:1;
	font-size: 1.4rem;
	line-height: 1.6;
	letter-spacing:0.02em;
}

.product-voice_card-text{
	display:flex;
	align-items: flex-start;
	font-size: 1.6rem;
	line-height: 1.6;
	letter-spacing:0.02em;
}

.product-voice_card-text_head{
	display: block;
	width:100%;
	font-size:1.6rem;
	font-weight:600;
	letter-spacing:0.05em;
	margin:0.4rem 0 -0.8rem;
}

/* SP */
@media (max-width: 768px) {
	.product-voice{
		padding:0 0 5.6rem;
	}
	.product-voice h2{
		font-size:2rem;
		letter-spacing:0.02em;
		padding-bottom:2.4rem;
	}
	.product-voice h2::before{
		width:14px;
		height:14px;
		margin-right: 0.8rem;
		margin-top: 7px;
	}
	.product-voice_card{
		width:100%;
	}
	.product-voice_card-profile{
		gap:1.6rem;
	}
	.product-voice_card-profile_image{
		max-width:80px;
	}
	.product-voice_card-profile_text{
		font-size: 1.2rem;
		letter-spacing:0.02em;
	}
	.product-voice_card-text_head{
		font-size:1.5rem;
	}
	.product-voice_card-text{
		font-size: 1.5rem;
		letter-spacing:0.02em;
	}
}


/* ================================================
   [11] product-movie（動画）
   ================================================ */

.product-movie{
	padding:0 0 8rem;
}

.product-movie h2{
	color:#124897;
	font-size:2.4rem;
	font-weight:600;
	line-height: 1.4;
	letter-spacing:0.02em;
	padding-bottom:2.4rem;
	display: flex;
	align-items: flex-start;
}

.product-movie h2.is-align-adjust {
	padding-top: 0.6rem;
}

.product-movie h2::before{
	content: "";
	width:16px;
	height:16px;
	background-image: url('/products/wp-content/uploads/icon/icon_circle.svg');
	background-size:contain;
	background-repeat: no-repeat;
	background-position: center;
	margin-right: 1rem;
	margin-top:8px;
	flex-shrink: 0;
}

.product-movie_wrap {
	display: flex;
	justify-content:center;
	width: 100%;
	max-height: 400px;
	box-sizing: border-box;
	padding: 2rem 0;
	background-color:#F8F9FA;
	border-radius:6px;
}

.product-movie_wrap > div {
	width: 100%;
	max-width: 640px;
	margin: 0;
	padding: 0 !important;
	position: relative !important;
	aspect-ratio: 16 / 9;
}

.product-movie p{
	padding:2.4rem 0 0;
	font-size:1.6rem;
	line-height:1.6;
	letter-spacing:0.02em;
}

@media (max-width: 768px) {
	.product-movie{
		padding:0 0 5.6rem;
	}
	.product-movie h2{
		font-size:2rem;
		letter-spacing:0.02em;
		padding-bottom:1.6rem;
	}
	.product-movie h2::before{
		width:14px;
		height:14px;
		margin-right: 0.8rem;
		margin-top: 7px;
	}
	.product-movie_wrap {
		background-color:#fff;
		padding: 0;
		max-height: none;
	}
	.product-movie_wrap > div {
		margin:0;
	}
	.product-movie p{
		padding:1.6rem 0 0;
		font-size:1.5rem;
		letter-spacing:0.02em;
	}
}


/* ================================================
   [12] product-detail（詳細）
   ================================================ */

.product-detail{
	padding:0 0 8rem;
}

.product-detail h2{
	color:#124897;
	font-size:2.4rem;
	font-weight:600;
	line-height: 1.4;
	letter-spacing:0.02em;
	padding-bottom:1rem;
	display: flex;
	align-items: flex-start;
}

.product-detail h2::before{
	content: "";
	width:16px;
	height:16px;
	background-image: url('/products/wp-content/uploads/icon/icon_circle.svg');
	background-size:contain;
	background-repeat: no-repeat;
	background-position: center;
	margin-right: 1rem;
	margin-top:8px;
	flex-shrink: 0;
}

.product-detail-pb24 h2{
	padding-bottom:2.4rem;
}

.product-detail-minihead{
	font-size: 1.6rem;
	font-weight: 600;
	line-height: 1.6;
}

.product-detail p{
	font-size: 1.6rem;
	line-height: 1.6;
	letter-spacing:0.02em;
	padding-bottom:3.2rem;
	text-align:justify;
}

.product-detail_image-full{
	width:100%;
	text-align:center;
}

.product-detail_image-full img{
	width: 100%;
	height: auto;
}

.product-detail_image-full2 img{
	width: 100%;
	height: auto;
	border-radius:6px;
	border:1px solid #E8E9EB;
}

.product-detail_card_wrap{
	display:flex;
	flex-wrap: wrap;
	gap:3.2rem 4rem;
}

.product-detail_card{
	width: calc(50% - 2rem);
	display:flex;
	flex-wrap: wrap;
}

.product-detail_card img{
	width: 100%;
	height: auto;
	border-radius:6px;
}

.product-detail_card.has-border img {
	border: 1px solid #E8E9EB;
}

.product-detail_card h3{
	font-size: 2rem;
	font-weight: 600;
	line-height: 1.5;
	letter-spacing:0.02em;
	padding-top:2rem;
	padding-bottom:1rem;
}

.product-detail_card > h3 > span{
	font-size: 1.6rem;
	line-height: 1.6;
	letter-spacing:0.02em;
}

.product-detail_card p{
	padding-bottom:0.8rem;
}

.product-detail_card-caution{
	font-size: 1.2rem;
	line-height: 1.6;
	letter-spacing:0.02em;
	padding:1.6rem 0 0;
	text-align:left;
	display:block;
}

/* SP */
@media (max-width: 768px) {
	.product-detail{
		padding:0 0 5.6rem;
	}
	.product-detail h2{
		font-size:2rem;
		letter-spacing:0.02em;
		padding-bottom:1.6rem;
	}
	.product-detail h2::before{
		width:14px;
		height:14px;
		margin-right: 0.8rem;
		margin-top: 7px;
	}
	.product-detail-minihead{
		font-size: 1.5rem;
	}
	.product-detail p{
		font-size: 1.5rem;
		letter-spacing:0.02em;
		padding-bottom:2.4rem;
	}
	.product-detail_card{
		width:100%;
	}
	.product-detail_card h3{
		font-size: 1.8rem;
		letter-spacing:0.02em;
		padding-top:1.6rem;
	}
	.product-detail_card > h3 > span{
		font-size: 1.5rem;
		letter-spacing:0.02em;
	}
	.product-detail_card-caution{
		font-size: 1.1rem;
		letter-spacing:0.02em;
	}
}


/* ================================================
   [13] product-card（カード3列）
   ================================================ */

.product-card{
	padding:0 0 8rem;
}

.product-card h2{
	color:#124897;
	font-size:2.4rem;
	font-weight:600;
	line-height: 1.4;
	letter-spacing:0.02em;
	padding-bottom:2.4rem;
	display: flex;
	align-items: flex-start;
}

.product-card h2::before{
	content: "";
	width:16px;
	height:16px;
	background-image: url('/products/wp-content/uploads/icon/icon_circle.svg');
	background-size:contain;
	background-repeat: no-repeat;
	background-position: center;
	margin-right: 1rem;
	margin-top:8px;
	flex-shrink: 0;
}

.product-card ul{
	display:flex;
	flex-wrap: wrap;
	gap:2.4rem;
}

.product-card li{
	width: calc((100% - 4.8rem) / 3);
	font-size: 1.6rem;
	line-height: 1.6;
	letter-spacing:0.02em;
	padding:2rem;
	border:1px solid #E8E9EB;
	border-radius: 6px;
	box-sizing: border-box;
}

/* SP */
@media (max-width: 768px) {
	.product-card{
		padding:0 0 5.6rem;
	}
	.product-card h2{
		font-size:2rem;
		letter-spacing:0.02em;
		padding-bottom:1.6rem;
	}
	.product-card h2::before{
		width:14px;
		height:14px;
		margin-right: 0.8rem;
		margin-top: 7px;
	}
	.product-card ul{
		gap:1.6rem;
	}
	.product-card li{
		width:100%;
		font-size: 1.5rem;
		letter-spacing:0.02em;
	}
}


/* ================================================
   [14] case-studies（導入事例）
   ================================================ */

.case-studies {
	position: relative;
	padding:0 0 8rem;
	display: flex;
	flex-wrap: wrap;
	justify-content: space-between;
	align-items: flex-end;
}

.case-studies h2{
	color:#124897;
	font-size:2.4rem;
	font-weight:600;
	line-height: 1.4;
	letter-spacing:0.02em;
	padding-bottom:2.4rem;
	display: flex;
	align-items: flex-start;
}

.case-studies h2::before{
	content: "";
	width:16px;
	height:16px;
	background-image: url('/products/wp-content/uploads/icon/icon_circle.svg');
	background-size:contain;
	background-repeat: no-repeat;
	background-position: center;
	margin-right: 1rem;
	margin-top:8px;
	flex-shrink: 0;
}

.case-studies-header {
	width:auto;
	order:1;
}

/* --- ナビボタン --- */
.slider-nav{
	display: flex;
	gap:16px;
	align-items: center;
	order:2;
	position: absolute;
	top: 4px;
	right: 0;
	padding-bottom: 0;
	margin-left: 0;
}

.slider-nav .nav-btn {
	width: 32px;
	height: 32px;
	border:1px solid #124897;
	border-radius: 50%;
	cursor: pointer;
	background-color: #fff;
	display: flex;
	align-items: center;
	padding: 0;
	overflow: hidden;
}

.slider-nav .nav-btn:hover {
    opacity: 1 !important;
}

.slider-nav .nav-btn img {
	width:25px;
	height:auto;
	transition: transform 0.3s cubic-bezier(0.25, 0.8, 0.25, 1);
}

.slider-nav #prev-btn { justify-content: flex-end; }
.slider-nav #prev-btn img{ transform-origin: right center; transform: translateX(3px); }
.slider-nav #prev-btn:hover img{ transform: translateX(0px); }
.slider-nav #next-btn{ justify-content: flex-start; }
.slider-nav #next-btn img{ transform: translateX(-3px); }
.slider-nav #next-btn:hover img{ transform: translateX(0px); }
.slider-nav .nav-btn:disabled { cursor: default; opacity: 0.5; pointer-events: none; }

.slider-nav--sp-only {
	display: none;
}

/* --- スライダー --- */
.slider-viewport {
	overflow: hidden;
	width: 100%;
	order:3;
}

.slider-track {
	display: flex;
	gap: 4rem;
	transition: transform 0.4s ease-in-out;
	touch-action: pan-y;
	-webkit-user-select: none;
	-moz-user-select: none;
	-ms-user-select: none;
	user-select: none;
}

.slider-track.is-dragging { cursor: grabbing; }

/* --- カード --- */
.card {
	flex: 0 0 calc((100% - 8rem) / 3);
	background-color: #fff;
	overflow: hidden;
	display: block;
	text-decoration: none;
	color: inherit;
	box-sizing: border-box;
	cursor: pointer;
	transition: opacity 0.3s;
}

.card-img-wrap {
	overflow: hidden;
	width: 100%;
	line-height: 0;
	border-radius: 6px;
    border: 1px solid #E8E9EB;  
}

.card-image {
	width: 100%;
	height: 144px;
	object-fit: cover;
	display: block;
	transition: transform 0.3s ease;
	border-radius: 6px;
	border: none;
}

.card:hover .card-image { transform: scale(1.03); }

.card:hover .card-category,
.card:hover .card-company {
    color: #124897;
}

.card-content { padding: 1.6rem 0 0; }

.card-content img{
	height:3.3rem;
	width:auto;
	max-width: 100%;
	object-fit: contain;
	object-position: left;
}

.card-logo { margin-bottom: 0.8rem; }

.card-label{
	display: block;
	font-size: 1.4rem;
	font-weight: 600;
	line-height: 1.6;
	letter-spacing: 0.02em;
	color: #124897;
	margin-bottom: 1rem;
}

.card-category {
	display: block;
	font-weight:300;
	font-size:1.2rem;
	letter-spacing:0.02em;
	line-height:1.6;
	color:#5B5C5E;
	margin-bottom: 2px;
}

.card-company {
	font-weight:600;
	font-size:1.6rem;
	letter-spacing:0.02em;
	line-height:1.6;
	color:#232323;
	margin-bottom: 8px;
}

.card-content .card-link-text {
	font-weight: 300;
	font-size: 1.4rem;
	line-height: 1;
	letter-spacing:0.02em;
	color: #124897;
	display: inline-flex;
	align-items: center;
	margin: 0;
}

/* --- カード矢印 --- */
.card-content .card-link-text-arrow {
	display: inline-flex;
	align-items: center;
	padding-right: 28px;
	position: relative;
}

.card-content .card-link-text-arrow:before,
.card-content .card-link-text-arrow:after {
	content: "";
	position: absolute;
	top: 50%;
	transform: translateY(-50%);
	transition: 0.2s ease-in-out;
}

.card-content .card-link-text-arrow:before {
	border: 1px solid #124897;
	border-radius: 50%;
	box-sizing: border-box;
	height: 20px;
	right: 0;
	width: 20px;
}

.card-content .card-link-text-arrow:after {
	background-image: url('/products/wp-content/uploads/icon/icon_arrow_right_b.svg');
	background-repeat: no-repeat;
	background-position: right center;
	background-size: auto 100%;
	height: 8px;
	right: 6px;
	width: 13px;
}

.card:hover .card-link-text-arrow{ text-decoration:underline; }

.card:hover .card-link-text-arrow::before,
.card:hover .card-link-text-arrow::after {
	transform: translateY(-50%);
	transition: 0.2s ease-in-out;
}

.card:hover .card-link-text-arrow::after {
	right: 4px;
	width: 16px;
}

/* --- 導入事例を見る --- */
.view-all-link {
	text-align:right;
	width:100%;
	order:4;
}

.view-all-link a{
	font-weight:300;
	font-size:1.4rem;
	line-height: 1;
	letter-spacing:0.02em;
	color:#124897;
	display: inline-flex;
	align-items: center;
}

.view-all-link a:hover{
	text-decoration:underline;
}

/* SP */
@media (max-width: 768px) {
	.case-studies {
		padding:0 0 5.6rem;
	}
	.case-studies h2{
		flex-wrap: wrap;
		align-items: flex-start;
		font-size:2rem;
		letter-spacing:0.02em;
		padding-bottom:1.6rem;
	}
	.case-studies h2::before{
		width:14px;
		height:14px;
		margin-right: 0.8rem;
		margin-top: 7px;
	}
	.case-studies-header {
		order: 1;
		width: 100%;
	}
	.slider-viewport {
		order: 2;
		margin-top: 0;
	}
	.slider-nav {
		position: static;
		order: 3;
		margin-left: auto;
		width: fit-content;
		margin-top: 1rem;
	}
	.slider-nav--sp-only {
		display: flex;
	}
	.slider-track {
		display: flex;
		gap: 8px;
	}
	.card {
		flex: 0 0 300px;
		padding-left:0;
		width:300px;
	}
	.card-img-wrap {
		width:300px;
		border-radius: 6px;
	}
	.card-image {
		width: 100%;
		height: 169px;
	}
	.card-content{
		padding: 1.6rem 0 0;
	}
	.card-content .card-link-text {
		font-size: 1.2rem;
		margin-bottom:0.8rem;
	}
	.card-logo {
		margin-bottom: 0.8rem;
	}
	.card-label{
		font-size: 1.2rem;
	}
	.card-company {
		font-size:1.5rem;
	}
	.view-all-link {
		order: 4;
	}
	.view-all-link a{
		font-size:1.2rem;
		padding-right:0;
	}
}


/* ================================================
   [15] FAQ
   ================================================ */

.faq{
	padding:0;
}

.faq h2{
	color:#124897;
	font-size:2.4rem;
	font-weight:600;
	line-height: 1.4;
	letter-spacing:0.02em;
	padding-bottom:2.4rem;
	display: flex;
	align-items: flex-start;
}

.faq h2::before{
	content: "";
	width:16px;
	height:16px;
	background-image: url('/products/wp-content/uploads/icon/icon_circle.svg');
	background-size:contain;
	background-repeat: no-repeat;
	background-position: center;
	margin-right: 1rem;
	margin-top:8px;
	flex-shrink: 0;
}

.c-block-faq{
	font-size:1.6rem;
	margin-top: 0;
}

.c-block-faq .c-accordion { border-bottom: 1px solid #E8E9EB; }
.c-block-faq .c-accordion-item { border-top: 1px solid #E8E9EB; }

.c-block-faq .c-accordion-head a {
	cursor: pointer;
	color: #232323;
	display: block;
	font-weight: bold;
	padding: 24px 40px 24px 0;
	position: relative;
}

.c-block-faq .c-accordion-head .icon-open {
	border: 1px solid #124897;
	border-radius: 50%;
	display: block;
	height: 20px;
	position: absolute;
	right: 0;
	top: 50%;
	transform: translateY(-50%);
	width: 20px;
}

.c-block-faq .c-accordion-head .icon-open:before,
.c-block-faq .c-accordion-head .icon-open:after {
	background-color: #124897;
	content: "";
	position: absolute;
	top: 50%;
	left: 50%;
	transform: translate(-50%,-50%);
	transition: 0.2s ease-in-out;
}

.c-block-faq .c-accordion-head .icon-open:before { height: 9px; width: 1px; }
.c-block-faq .c-accordion-head .icon-open:after { height: 1px; width: 9px; }
.c-block-faq .c-accordion-head.is-open .icon-open:before { height: 0; }

.c-block-faq .c-accordion-content {
	display: none;
	border-top: 1px solid #E8E9EB;
	padding: 24px 0;
}

.c-accordion{
	border:none;
}

.c-accordion-content a{
	text-decoration:underline;
	display:inline;
	color:#124897;
}

.c-accordion-inner p a{
	display:inline;
	color:#124897;
}

.c-accordion-content ul{
	padding:0.8rem 0 0;
	display:flex;
	flex-direction: column;
}

.c-accordion-content li{
	font-size: 1.6rem;
	line-height: 1.6;
	letter-spacing:0.02em;
	position: relative;
	padding-left: 1.5em;
}

.c-accordion-content li::before{
	content: '';
	display: block;
	width: 4px;
	height: 4px;
	background-color: #232323;
	border-radius: 50%;
	position: absolute;
	left: 0.4em;
	top: 1.1rem;
}

.product-faq_caution{
	padding-top:8px;
	font-size:1.2rem;
}

.faq-b{
	font-weight:600 !important;
}

/* SP */
@media (max-width: 768px) {
	.faq h2 {
		font-size:2rem;
		padding-bottom: 1.6rem;
	}
	.faq h2::before{
		width:14px;
		height:14px;
		margin-right: 0.8rem;
		margin-top: 7px;
	}
	.c-block-faq{
		font-size:1.5rem;
	}
	.c-accordion-content li {
		font-size: 1.5rem;
	}
	.product-faq_caution{
		font-size:1.1rem;
	}
}


/* ================================================
   [16] product-button1（CTAボタン：枠線のみ）
   ================================================ */

.product-button1{
	padding:1.6rem 0 9.6rem;
	text-align:center;
}

.product-button1 a{
	font-size:1.8rem;
	font-weight:600;
	line-height: 1;
	letter-spacing:0.04em;
	border:1px solid #124897;
	border-radius:49px;
	color:#124897;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	height: 70px;
	box-sizing: border-box;
	padding:0 6.4rem;
}

.product-button1 a:hover{
	transform: scale(1.02,1.02);
	background-color:#143867;
	color: #fff;
	transition: transform 0.3s ease-in-out;
	opacity:1;
}

@media (max-width: 768px) {
	.product-button1{
		padding:1rem 0 6.6rem;
	}
	.product-button1 a{
		padding:1.6rem 2.4rem;
		font-size:1.5rem;
		line-height: 1.6;
		letter-spacing:0.04em;
	}
}


/* ================================================
   [17] product-button2（CTAボタン：塗りつぶし）
   ================================================ */

.product-button2{
	padding:1.6rem 0 9.6rem;
	text-align:center;
}

.product-button2 a{
	font-size:1.8rem;
	font-weight:600;
	line-height: 1.4;
	letter-spacing:0.04em;
	border:1px solid #124897;
	border-radius:49px;
	color:#fff;
	background-color:#124897;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	height: 70px;
	box-sizing: border-box;
	padding:0 6.4rem;
}

.product-button2-lg a{
	border-radius:6px;
	min-height: 90px;
	padding:0 4rem;
}

.product-button2 a:hover{
	transform: scale(1.02,1.02);
	background-color:#143867;
	color: #fff;
	transition: transform 0.3s ease-in-out;
	opacity:1;
}


@media (max-width: 768px) {
	.product-button2{
		padding:1rem 0 6.6rem;
	}
	.product-button2 a{
		padding:1.6rem 2.4rem;
		font-size:1.5rem;
		letter-spacing:0.04em;
	}
	.product-button2-lg a{
		padding:1.6rem 2.4rem;
}
}


/* ================================================
   [18] product-list（番号リスト）
   ================================================ */

.product-list{
	padding:0 0 8rem;
}

.product-list h2{
	color:#124897;
	font-size:2.4rem;
	font-weight:600;
	line-height: 1.4;
	letter-spacing:0.02em;
	padding-bottom:4rem;
	display: flex;
	align-items: flex-start;
}

.product-list h2::before{
	content: "";
	width:16px;
	height:16px;
	background-image: url('/products/wp-content/uploads/icon/icon_circle.svg');
	background-size:contain;
	background-repeat: no-repeat;
	background-position: center;
	margin-right: 1rem;
	margin-top:8px;
	flex-shrink: 0;
}

.product-list p{
	padding-top:3.2rem;
	font-size:1.6rem;
	line-height:1.6;
	letter-spacing:0.02em;
}

.product-list ul{
	display:flex;
	flex-wrap:wrap;
	gap: 4rem;
}

.product-list li{
	display:flex;
	width: calc(50% - 2rem);
	align-items: flex-start;
}

.product-list_flex-num {
	color: #124897;
	font-size: 3.6rem;
	font-weight: 600;
	line-height: 1.2;
	letter-spacing: 0.072rem;
	margin-right: 1.6rem;
	flex-shrink: 0;
}

.product-list_flex-text {
	font-size: 1.6rem;
	font-weight: 600;
	line-height: 1.6;
	letter-spacing:0.02em;
}

/* SP */
@media (max-width: 768px) {
	.product-list{
		padding: 5.6rem 0;
	}
	.product-list h2{
		font-size:2rem;
		letter-spacing:0.02em;
		padding-bottom:2.4rem;
	}
	.product-list h2::before{
		width:14px;
		height:14px;
		margin-right: 0.8rem;
		margin-top: 7px;
	}
	.product-list p{
	padding-top:2.4rem;
	font-size:1.5rem;
	}
	.product-list ul{
		gap:2.4rem;
	}
	.product-list li{
		width:100%;
	}
	.product-list_flex-num {
		min-width: 3rem;
		margin-right: 1rem;
		text-align: center;
	}
	.product-list_flex-text {
		font-size: 1.5rem;
		letter-spacing:0.02em;
	}
}


/* ================================================
   [19] product-contact（お問い合わせ）
   ================================================ */

.c-conversion {
	margin-top:8rem !important;
	padding:0;
}

.product-contact{
	width: 100%;
	background-image: url('/products/wp-content/uploads/icon/bg_dark.webp');
	background-repeat: no-repeat;
	background-position: center center;
	background-size: cover;
	height: 524px;
	gap: 3.2rem;
	display: flex;
	flex-direction: column;
	align-items: center;
	justify-content: center;
	position: relative;
	overflow: hidden;
}

.product-contact h1 {
	font-size: 3rem;
	line-height: 1.6;
	font-weight:600;
	letter-spacing:0.02em;
	text-align: center;
	color: #fff;
}

.product-contact h1 > span{
	font-size: 2.4rem;
}

.product-contact-btn{
	display: flex;
	align-items: center;
	justify-content: center;
	font-size: 1.8rem;
	font-weight: 600;
	background-color: #fff;
	border-radius: .6rem;
	width: min(64vw, 240px);
	height: 70px;
}

.product-contact-btn:hover {
	color: #124897;
	opacity: initial;
	transform: scale(1.05, 1.05);
}

/* SP */
@media (max-width: 959px) {
	.c-conversion {
		margin-top:4rem !important;
		height: 330px !important;
	}
	.c-breadcrumb {
		margin-top:4rem !important;
	}
	.product-contact {
		background-image: url('/products/wp-content/uploads/icon/bg_dark_sp.webp');
		background-position: center center;
		background-repeat: no-repeat;
		background-size: cover;
		height: 330px !important;
		display: flex;
		flex-direction: column;
		justify-content: center;
		align-items: center;
		padding: 0;
	}
	.product-contact h1 {
		font-size: 2.4rem;
	}
	.product-contact h1 > span{
		font-size: 2rem;
	}
}

@media (max-width: 768px) {
	.c-breadcrumb {
		margin-top:0;
	}
}


/* ================================================
   [20] product-catalog（カタログ）
   ================================================ */

.product-catalog{
	padding-bottom:8rem;
}

.product-catalog h2{
	color:#124897;
	font-size:3rem;
	font-weight:600;
	line-height: 1.6;
	letter-spacing:0.06em;
	display: flex;
	align-items: flex-start;
}

.product-catalog h2::before{
	content: "";
	width:16px;
	height:16px;
	background-image: url('/products/wp-content/uploads/icon/icon_circle.svg');
	background-size:contain;
	background-repeat: no-repeat;
	background-position: center;
	margin-right: 1rem;
	margin-top:8px;
	flex-shrink: 0;
}

.product-catalog h3{
	font-weight: 600;
	font-size: 2.4rem;
	line-height: 1.6;
	letter-spacing: 0.02em;
	position: relative;
	padding-left: 1.6rem;
}

.product-catalog h3::before {
	content: "";
	position: absolute;
	left: 0;
	top: 0.3em;
	width: 4px;
	height: 1.1em;
	background-color: #124897;
}

.product-catalog a{ text-decoration:underline; }
.product-catalog-h60{ margin-top:6rem; }
.product-catalog-h80{ margin-top:8rem; }

.product-catalog p{
	font-size: 1.8rem;
	font-weight: 300;
	line-height: 1.75;
	letter-spacing: 0.02em;
	margin-top:2rem;
}

/* --- テーブル --- */
.table-wrapper {
	margin-top:4rem;
	color: #333;
}

.main-table {
	width: 100%;
	border-collapse: collapse;
	border-top: 1px solid #E8E9EB;
}

.main-table th, .main-table td {
	padding: 3.2rem 0;
	text-align: left;
	border-bottom: 1px solid #e0e0e0;
	vertical-align: top;
}

.main-table th {
	width: 160px;
	font-size: 1.8rem;
	font-weight: 600;
	line-height: 1.6;
	letter-spacing: 0.04em;
	padding-right:4rem;
}

.main-table td {
	font-size: 1.8rem;
	line-height: 1.75;
	letter-spacing: 0.02em;
}

.list-bullet { margin: 0; }

.list-bullet li{
	position: relative;
	padding-left: 1em;
	margin-left:1rem;
}

.list-bullet li::before {
	content: "";
	position: absolute;
	left: 0;
	top: 50%;
	transform: translateY(-50%);
	width: 3px;
	height: 3px;
	background-color: #333;
	border-radius: 50%;
}

.inner-table {
	width: 100%;
	border-collapse: collapse;
	background-color: #fff;
}

.inner-table th, .inner-table td {
	padding: 1rem 1.6rem;
	border: 1px solid #E8E9EB;
}

.inner-table th {
	background-color: #F8F9FA;
	width: auto;
	font-size: 1.8rem;
	line-height: 1.75;
	letter-spacing: 0.02em;
}

.inner-table th:first-child {
	width:220px;
	box-sizing: border-box;
}

.inner-table td {
	width: auto;
	font-size: 1.8rem;
	line-height: 1.75;
	letter-spacing: 0.02em;
}

.code { font-family: monospace; }

.caption {
	font-size: 1.4rem;
	line-height: 1.71;
	letter-spacing: 0.04em;
	margin-top:1.6rem;
}

/* SP */
@media (max-width: 768px) {
	.product-catalog {
		padding-bottom: 4rem;
	}
	.product-catalog h2{
		font-size:2rem;
		font-weight:600;
		line-height: 1.4;
		letter-spacing:0.05em;
	}
	.product-catalog h2::before {
		width:14px;
		height:14px;
		margin-right: 0.8rem;
		margin-top: 7px;
	}
	.product-catalog h3 {
		font-size: 1.8rem;
		line-height: 1.5;
	}
	.product-catalog-h60{ margin-top:2.6rem; }
	.product-catalog-h80{ margin-top:2.6rem; }
	.product-catalog p {
		font-size: 1.5rem;
		line-height: 1.6;
		margin-top: 1.6rem;
	}
	.main-table th, .main-table td {
		display: block;
		width: 100%;
		box-sizing: border-box;
	}
	.main-table th {
		background-color: #fff;
		padding-top:1.6rem;
		padding-bottom: 0.8rem;
		border-bottom: none;
		font-size:1.5rem;
		letter-spacing:0.02em;
	}
	.main-table td {
		padding-top: 0;
		padding-bottom: 1.6rem;
		font-size:1.5rem;
		letter-spacing:0.02em;
	}
	.inner-table-scroll {
		width: 100%;
		overflow-x: auto;
		-webkit-overflow-scrolling: touch;
		border: 1px solid #E8E9EB;
	}
	.inner-table {
		display: table;
		width: 100%;
		border: none;
		table-layout: fixed;
		word-break: break-all;
	}
	.inner-table th, .inner-table td {
		display: table-cell;
		width: auto;
		padding: 1rem 1.6rem;
		font-size:1.5rem;
		line-height:1.6;
		overflow-wrap: break-word;
	}
	.inner-table th:first-child {
		width: 35%;
		min-width: auto;
	}
	.inner-table td{ width: 65%; }
	.inner-table th{ background-color: #F8F9FA; }
}


/* ================================================
   [21] product-catalog-list（カタログリスト）
   ================================================ */

.product-catalog-list{
	padding-bottom:8rem;
}

.product-catalog-list h3{
	font-weight: 600;
	font-size: 2.4rem;
	line-height: 1.6;
	letter-spacing: 0.02em;
	margin-bottom: 4rem;
	position: relative;
	padding-left: 1.6rem;
}

.product-catalog-list h3::before {
	content: "";
	position: absolute;
	left: 0;
	top: 0.3em;
	width: 4px;
	height: 1.1em;
	background-color: #124897;
}

.product-catalog-list li{
	position: relative;
	padding-left: 1em;
	font-size: 1.8rem;
	line-height: 1.75;
	letter-spacing: 0.02em;
	margin-left:1rem;
}

.product-catalog-list li::before {
	content: "";
	position: absolute;
	left: 0;
	top: 50%;
	transform: translateY(-50%);
	width: 3px;
	height: 3px;
	background-color: #333;
	border-radius: 50%;
}

/* SP */
@media (max-width: 768px) {
	.product-catalog-list h3{
		font-size: 1.8rem;
		line-height: 1.5;
	}
	.product-catalog-list li{
		font-size: 1.5rem;
		line-height: 1.6;
	}
}


/* ================================================
   [22] product-hr（区切り線）
   ================================================ */

.product-hr{
	display:block;
	border:none;
	height:1px;
	background-color:#E8E9EB;
	margin:0 0 8rem 0;
}

.product-hr-0{
	display:block;
	border:none;
	height:1px;
	background-color:#E8E9EB;
	margin:0;
}

.product-hr-56{
	display:block;
	border:none;
	height:1px;
	background-color:#E8E9EB;
	margin-bottom:5.6rem;
}

/* SP */
@media (max-width: 768px) {
	.product-hr{
		margin:0;
	}
	.product-hr-56{
	margin-bottom:4rem;
}
}


/* ================================================
   [23] product-info（関連情報）
   ================================================ */

.product-info{
	padding: 8rem 0 1rem;
}

.product-info > img {
	width: auto;
	height: 38px;
	object-fit: cover;
}
.product-info p{
	padding:2.4rem 0 3.2rem 0;
	font-size:1.6rem;
	line-height:1.6;
	letter-spacing:0.02em;
}

.product-info a{
	font-size:1.6rem;
	line-height:1.6;
	letter-spacing:0.02em;
	text-decoration:underline;
	color:#124897;
}

.external-link {
	position: relative;
	display: inline; 
	text-decoration: underline !important;
	text-decoration-thickness: 1px !important;
	box-decoration-break: clone;
	-webkit-box-decoration-break: clone;
}

.external-link::after {
	content: "";
	display: inline-block;
	position: relative; 
	vertical-align: middle;
	margin-left: 0.4em;
	right: auto;
	top: auto;
	transform: none;
	width: 1em;
	height: 1em;
	background-image: url('/products/wp-content/uploads/icon/external-link.svg');
	background-repeat: no-repeat;
	background-position: center;
	background-size: contain;
}

/* SP */
@media (max-width: 768px) {
	.product-info{
		padding:6rem 0 2rem;
	}
	.product-info > img{
		height: 30px;
		max-width:327px;
	}
	.product-info p{
		padding:2rem 0 1.6rem;
		font-size:1.5rem;
	}
	.product-info a{
		font-size:1.5rem;
	}
}


/* ================================================
   [24] solution-detail（ソリューション詳細）
   ================================================ */

.solution-detail_wrap1{
	padding:0 0 5.6rem;
}

.solution-detail_wrap2{
	padding:4rem;
	margin-bottom:8rem;
	border:1px solid #ECF0F7;
	border-radius: 6px;
}

/* --- 見出し --- */
.solution-detail_wrap1 > .solution-detail > h1{
	font-size:2.8rem;
	font-weight:600;
	line-height: 1.5;
	letter-spacing:0.02em;
	display: flex;
	flex-direction: column;
	gap: 6.5px;
	align-items: flex-start;
}

.solution-detail_wrap1 > .solution-detail > h1 > span {
	color:#124897;
	font-size:1.4rem;
	font-weight:600;
	line-height: 1.6;
	display: flex;
	align-items: flex-start;
}

.solution-detail_wrap1 > .solution-detail > h1 > span::before{
	content: "";
	display: block;
	width:14px;
	height:14px;
	background-image: url('/products/wp-content/uploads/icon/icon_circle.svg');
	background-size:contain;
	background-repeat: no-repeat;
	background-position: center;
	margin-right: 0.9rem;
	flex-shrink: 0;
	margin-top: 0.4rem;
}

.solution-detail_wrap2 > .solution-detail > h2{
	color:#124897;
	font-size:2rem;
	font-weight:600;
	line-height: 1.5;
	letter-spacing:0.02em;
	padding-bottom:3.2rem;
}

/* --- リスト --- */
.solution-detail_wrap1 > .solution-detail > ul{
	margin-top:3.2rem;
	display:flex;
	flex-direction: column;
	gap:5.4rem;
}

.solution-detail_wrap2 > .solution-detail > ul{
	display:flex;
	flex-direction: column;
	gap:4rem;
}

.solution-detail li{
	display:flex;
	gap:4rem;
	align-items: center;
	flex-direction: row-reverse;
}

.solution-detail li img{
	flex:1;
	min-width: 0;
	width:100%;
	height:auto;
	object-fit:contain;
	border-radius:6px;
	border:1px solid #E8E9EB;
}

/* --- テキストブロック --- */
.solution-detail__block-text{
	flex:1;
}

.solution-detail__block-text h2{
	font-size:2rem;
	font-weight:600;
	line-height: 1.5;
	letter-spacing:0.02em;
	padding-bottom:1rem;
}

.solution-detail__block-text > h2 > span{
	font-size:1.6rem;
	line-height: 1.6;
	letter-spacing:0.02em;
}

.solution-detail__block-text p{
	font-size:1.6rem;
	line-height: 1.6;
	letter-spacing:0.02em;
}

.solution-detail__block-text > .solution-detail__caution{
	font-size:1.2rem;
	line-height:1.6;
	letter-spacing:0.02em;
	padding-top:0.8rem;
}

.solution-detail_lead{
	font-size: 1.6rem;
	line-height: 1.6;
	letter-spacing:0.02em;
	padding-bottom:4rem;
	margin-top:-3rem;
}

.solution-detail_h3-sub{
	display:block;
	padding-bottom:1rem;
	font-size: 1.6rem;
	line-height: 1.6;
	letter-spacing:0.02em;
}

/* SP */
@media (max-width: 768px) {
	.solution-detail_wrap1{
		padding:0 0 5.6rem;
	}
	.solution-detail_wrap2{
		padding:2.4rem 2rem;
		margin:0 2.4rem 5.6rem;
	}
	.solution-detail_wrap1 > .solution-detail > h1{
		font-size:2.4rem;
	}
	.solution-detail ul{
		margin-top:3.2rem;
		gap:4rem;
	}
	.solution-detail_wrap1 > .solution-detail li{
		display:flex;
		flex-direction: column;
		gap: 1.6rem;
		align-items: stretch;
	}
	.solution-detail_wrap2 > .solution-detail li{
		display:flex;
		flex-direction: column;
		gap: 1.6rem;
		align-items: stretch;
	}
	.solution-detail li img { order: 1; }
	.solution-detail__block-text { order: 2; }
	.solution-detail__block-text h2{
		font-size:1.8rem;
		letter-spacing:0.02em;
	}
	.solution-detail__block-text > h2 > span{
		font-size:1.5rem;
		line-height: 1.6;
		letter-spacing:0.02em;
	}
	.solution-detail__block-text p{
		font-size: 1.5rem;
		letter-spacing:0.02em;
		text-align:justify;
	}
	.solution-detail__block-text > .solution-detail__caution{
		font-size:1.1rem;
		letter-spacing:0.02em;
		padding-top:1rem;
	}
	.solution-detail_wrap1 > .solution-detail > ul{
		gap:4rem;
	}
	.solution-detail_lead{
		font-size: 1.5rem;
		letter-spacing:0.02em;
		padding-bottom:4rem;
		margin-top:-1.4rem;
	}
	.solution-detail_h3-sub{
		font-size: 1.5rem;
		line-height: 1.6;
	}
}


/* ================================================
   [25] solution-others（その他ソリューション）
   ================================================ */

.solution-others{
	padding:3.2rem 0 0;
	margin-bottom:8rem;
	border-top:1px solid #E8E9EB;
}

.solution-others h2{
	font-size: 2rem;
	font-weight: 600;
	line-height: 1.5;
	letter-spacing: 0.02em;
	padding-bottom:2.4rem;
}

.solution-toc{
	display:flex;
	flex-wrap:wrap;
	gap:1rem 3.2rem;
}

.solution-toc li a{
	color:#232323;
	font-size:1.4rem;
	font-weight:600;
	line-height:1.6;
	letter-spacing:0.02em;
}

/* SP */
@media (max-width: 768px) {
	.solution-others {
		padding:4rem 0 4rem;
		margin:0 0 0;
	}
	.solution-toc {
		margin:0 0 5.6rem;
	}
}


/* ================================================
   [26] product-flow（ご利用の流れ）
   ================================================ */

.product-flow{
	padding:0 0 8rem;
}

.product-flow_box{
	display:flex;
	flex-direction:column;
	gap:3.2rem;
}

.product-flow h2{
	color:#124897;
	font-size:2.4rem;
	font-weight:600;
	line-height:1.4;
	letter-spacing:0.02em;
	padding-bottom:2.4rem;
	display:flex;
	align-items:flex-start;
}

.product-flow h2::before{
	content:"";
	width:16px;
	height:16px;
	background-image:url('/products/wp-content/uploads/icon/icon_circle.svg');
	background-size:contain;
	background-repeat:no-repeat;
	background-position:center;
	margin-right:1rem;
	margin-top:8px;
	flex-shrink:0;
}

.product-flow_row{
	display:flex;
}

/* --- カード --- */
.product-flow_card{
	display:flex;
	flex-direction:column;
	flex:1;
	min-width:0;
}

.product-flow_card-header{
	background-color:#ECF0F7;
	display:flex;
	align-items:center;
	height:3rem;

	width:100%;
	border-radius:0;
	gap:0;
}

.product-flow_card-num{
	background-color:#124897;
	color:#fff;
	width:3rem;
	height:3rem;
	display:flex;
	align-items:center;
	justify-content:center;
	font-size:1.8rem;
	font-weight:500;
	line-height:1;
	flex-shrink:0;
}

.product-flow_card-title{
	font-size:1.6rem;
	font-weight:600;
	line-height:1.6;
	letter-spacing:0.02em;
	padding-left:1rem;
	color:#124897;
}

.product-flow_card-body{
	padding:1rem 0 0;
	width:100%;
	flex:1;
}

.product-flow_card-body p{
	font-size:1.4rem;
	font-weight:300;
	line-height:1.6;
	letter-spacing:0.02em;
}

.product-flow_card-body .product-flow_caution{
	display:block;
	font-size:1.2rem;
	font-weight:300;
	line-height:1.6;
	letter-spacing:0.02em;
	padding-top:0.8rem;
}

/* --- 矢印（右向き） --- */
.product-flow_arrow{
	display:flex;
	align-items:center;
	justify-content:center;
	padding:0 2rem;
}

.product-flow_arrow::after{
	content:"";
	display:block;
	width:0;
	height:0;
	border-style:solid;
	border-width:1.2rem 0 1.2rem 1.6rem;
	border-color:transparent transparent transparent #94A9DF;
}

/* --- 矢印（下向き：SP用） --- */
.product-flow_arrow-down{
	display:none;
}

/* --- 上段末尾の矢印を非表示（3→の後） --- */
.product-flow_row:first-child > .product-flow_arrow:last-child{
	display:none;
}

/* SP */
@media (max-width: 768px) {
	.product-flow{
		padding:0 0 5.6rem;
	}
	.product-flow_box{
		gap: 0;
	}
	.product-flow h2{
		font-size:2rem;
		padding-bottom:1.6rem;
	}
	.product-flow h2::before{
		width:14px;
		height:14px;
		margin-right:0.8rem;
		margin-top:7px;
	}
	.product-flow_row{
		flex-direction:column;
	}
	.product-flow_arrow{
		display:none;
	}
	.product-flow_arrow-down{
		display:flex;
		align-items:center;
		justify-content:center;
		padding:1.4rem 0 1.6rem;
	}
	.product-flow_arrow-down::after{
		content:"";
		display:block;
		width:0;
		height:0;
		border-style:solid;
		border-width:1.6rem 1.2rem 0 1.2rem;
		border-color:#94A9DF transparent transparent transparent;
	}
	.product-flow_card{
		width:100%;
	}
	.product-flow_card-header{
		width:100%;
	}
	.product-flow_card-num{
		font-size:1.7rem;
	}
	.product-flow_card-title{
		font-size:1.5rem;
		line-height:1.6;
	}
	.product-flow_card-body{
		width:100%;
	}
	.product-flow_card-body p{
		font-size:1.2rem;
	}
	.product-flow_card-body .product-flow_caution{
		font-size:1.1rem;
	}
}


/* ================================================
   [27] product-jump（別サイトへジャンプ）
   ================================================ */

.product-jump{
	padding:4rem 0 0;
	text-align:center;
}

.product-jump h3{
	color:#124897;
	font-size:2rem;
	font-weight:600;
	line-height: 1.5;
	letter-spacing:0.02em;
	padding-bottom:1rem;
}

.product-jump p{
	font-size:1.6rem;
	line-height:1.6;
	letter-spacing:0.02em;
	padding-bottom:3.2rem;
}

/* SP */
@media (max-width: 768px) {
	.product-jump{
		padding:1.6rem 0 0;
	}
	.product-jump h3{
		font-size:1.8rem;
		letter-spacing:0.02em;
	}
	.product-jump p{
		font-size:1.5rem;
		letter-spacing:0.02em;
		padding-bottom:1.6rem;
	}
}


/* ================================================
   [28] product-content-grid（コンテンツグリッド）
   ================================================ */

.product-content-grid {
	padding: 0;
}

.product-content-grid__lead {
	font-size: 1.6rem;
	line-height: 1.6;
	letter-spacing: 0.02em;
	padding-bottom: 2.4rem;
}

/* --- アンカーリンク --- */
.product-content-grid__nav {
	display: flex;
	flex-wrap: wrap;
	gap: 1rem 3.2rem;
	padding: 2.4rem 0;
	border-top: 1px solid #E8E9EB;
	border-bottom: 1px solid #E8E9EB;
	margin-bottom: 4rem;
}

/* --- セクション --- */
.product-content-grid__section {
	margin-bottom: 5.6rem;
	scroll-margin-top: 120px;
}

.product-content-grid__section:last-child {
	margin-bottom: 0;
}

.product-content-grid__section > h2 {
	font-size: 2.4rem;
	font-weight: 600;
	line-height: 1.5;
	letter-spacing: 0.02em;
	padding-bottom: 2.4rem;
}

.product-content-grid__section > h3 {
	font-size: 2rem;
	font-weight: 600;
	line-height: 1.5;
	letter-spacing: 0.02em;
	padding-bottom: 2.4rem;
}

/* --- カードグリッド --- */
.product-content-grid__cards {
	display: grid !important;
	grid-template-columns: repeat(3, 1fr) !important;
	gap: 4rem 4rem;
}

/* --- カード --- */
.product-content-grid__card {
	display: flex;
	flex-direction: column;
	width: 100%;
}

.product-content-grid__card-img {
	position: relative;
	width: 100%;
	aspect-ratio: 16 / 9;
	overflow: hidden;
	border-radius: 6px;
	border: 1px solid #E8E9EB;
	margin-bottom: 1.6rem;
	cursor: pointer;
}

.product-content-grid__card-img img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	display: block;
}

.product-content-grid__card-img::after {
	content: "";
	position: absolute;
	right: 8px;
	bottom: 8px;
	width: 4rem;
	height: 4rem;
	background-image: url('/products/wp-content/uploads/icon/icon_zoom.svg');
	background-repeat: no-repeat;
	background-position: center;
	background-size: contain;
	transition: transform 0.2s ease;
}

.product-content-grid__card-img:hover::after {
	transform: scale(1.1);
}

.product-content-grid__card-title {
	font-size: 1.6rem;
	font-weight: 600;
	line-height: 1.5;
	letter-spacing: 0.02em;
	margin: 0 0 0.8rem;
}

.product-content-grid__card-title > span {
	font-size: 1.2rem;
	line-height: 1.4;
}

.product-content-grid__card-text {
	font-size: 1.4rem;
	font-weight: 300;
	line-height: 1.6;
	letter-spacing: 0.02em;
}

/* --- ライトボックス --- */
.product-lightbox {
	display: none;
	position: fixed;
	top: 0;
	left: 0;
	width: 100vw;
	height: 100vh;
	background-color: rgba(0, 0, 0, 0.7);
	z-index: 9999;
	justify-content: center;
	align-items: center;
	padding: 4rem;
}

.product-lightbox.is-open {
	display: flex;
}

.product-lightbox__inner {
	position: relative;
	max-width: 1068px;
	width: 100%;
}

.product-lightbox__inner img {
	width: 100%;
	height: auto;
	display: block;
	border-radius: 6px;
}

.product-lightbox__close {
	position: absolute;
	top: -34px;
	right: 0;
	width: 24px;
	height: 24px;
	background: none;
	border: none;
	cursor: pointer;
	display: flex;
	align-items: center;
	justify-content: center;
	z-index: 1;
	padding: 0;
}

.product-lightbox__close::before {
	content: "";
	width: 24px;
	height: 24px;
	background-image: url('/products/wp-content/uploads/icon/icon_close.svg');
	background-repeat: no-repeat;
	background-position: center;
	background-size: contain;
}

.product-lightbox__close::after {
	display: none;
}

.product-lightbox__close:hover {
	opacity: 0.8;
}

html:has(.product-lightbox) {
    overflow-y: scroll;
    scrollbar-gutter: stable;
    scroll-behavior: auto !important;
}


/* SP */
@media (max-width: 768px) {
	.product-content-grid__section {
		margin-bottom: 4rem;
		scroll-margin-top: 100px;
	}
	.product-content-grid__lead {
		font-size: 1.5rem;
		padding-bottom: 1.6rem;
	}
	.product-content-grid__nav {
		gap: 0.8rem 2rem;
		padding: 1.6rem 0;
		margin-bottom: 3.2rem;
	}
	.product-content-grid__section > h2 {
		font-size: 2rem;
	}
	.product-content-grid__section > h3 {
		font-size: 1.8rem;
		padding-bottom: 1.6rem;
	}
	.product-content-grid__cards {
		grid-template-columns: repeat(2, 1fr) !important;
		gap: 2.4rem 2rem;
	}
	.product-content-grid__card-img {
	margin-bottom: 1rem;
	}
	.product-content-grid__card-title {
		font-size: 1.5rem;
	}
	.product-content-grid__card-title > span {
	font-size: 1.1rem;
	}
	.product-content-grid__card-text {
		font-size: 1.2rem;
	}
	.product-lightbox {
		padding: 2rem;
	}
	.product-content-grid__card-img::after {
		width: 3rem;
		height: 3rem;
	}
	.product-lightbox__close {
		top: -34px;
		right: 0;
	}
}


/* ================================================
   [29] product-interview（講師インタビュー）
   ================================================ */

/* --- 全体ラッパー --- */
.product-interview-wrap {
	border: 1px solid #ECF0F7;
	border-radius: 6px;
	padding: 3.2rem 4rem 4rem;
	margin: 2.4rem 0 8rem;
}

/* --- タイトル（h2） --- */
.product-interview-wrap .product-main-visual h2 {
	font-size: 2.4rem;
	font-weight: 600;
	line-height: 1.5;
	letter-spacing: 0.02em;
}

/* --- プロフィール写真＋氏名 --- */
.product-interview-profile {
	position: relative;
	padding: 3.2rem 0;
}

.product-interview-profile__image {
	max-width: 626px;
	width: 100%;
}

.product-interview-profile__image img {
	width: 100%;
	height: auto;
}

.product-interview-profile__name {
	position: absolute;
	right: 0;
	bottom: calc(3.2rem + 4rem);
	font-size: 1.6rem;
	line-height: 1.8;
	font-weight: 600;
	letter-spacing: 0.02em;
	background-color: #F8F9FA;
	padding: 2rem 2.4rem;
	border-radius: 6px;
}

/* --- リード文 --- */
.product-interview-lead {
	padding-bottom: 2.4rem;
}

.product-interview-lead p {
	font-size: 1.6rem;
	line-height: 1.6;
	letter-spacing: 0.02em;
	text-align: justify;
}

/* --- プロフィールボックス --- */
.product-interview-profile-box {
	border: 1px solid #E8E9EB;
	padding: 2rem;
}

.product-interview-profile-box dl {
	margin: 0;
}

.product-interview-profile-box dt {
	font-size: 1.4rem;
	font-weight: 300;
	line-height: 1.6;
	letter-spacing: 0.02em;
	padding-bottom: 0.8rem;
}

.product-interview-profile-box dd {
	font-size: 1.4rem;
	line-height: 1.6;
	letter-spacing: 0.02em;
	margin: 0;
}

/* --- Q見出し（青左ボーダー） --- */
.product-interview-question {
	font-size: 2rem;
	font-weight: 600;
	line-height: 1.5;
	letter-spacing: 0.02em;
	position: relative;
	padding-left: 1.6rem;
	margin: 4.8rem 0 2.4rem;
}

.product-interview-question::before {
	content: "";
	position: absolute;
	left: 0;
	top: 0;
	bottom: 0;
	width: 4px;
	background-color: #124897;
}

.product-interview-question__image img {
	display: block;
	margin-left: auto;
	margin-right: auto;
	max-width: 626px;
	width: 100%;
	height: auto;
	padding: 5.6rem 0 0.8rem;
}

/* --- 回答テキスト --- */

.product-interview-answer p {
	font-size: 1.6rem;
	line-height: 1.6;
	letter-spacing: 0.02em;
	text-align: justify;
	padding-bottom: 1.6rem;
}

.product-interview-answer p:last-child {
	padding-bottom: 0;
}

/* SP */
@media (max-width: 768px) {
	.product-interview-wrap {
		padding: 2.4rem 2rem;
		margin: 0 0 5.6rem;
	}
	.product-interview-wrap .product-main-visual h2 {
		font-size: 2rem;
	}
	.product-interview-profile {
		position: static;
		display: flex;
		flex-direction: column;
		align-items: center;
		gap: 0;
		padding: 2.4rem 0;
	}
	.product-interview-profile__image {
		max-width: 100%;
	}
	.product-interview-profile__name {
		position: static;
		text-align: left;
		font-size: 1.5rem;
		line-height: 1.6;
		width: 100%;
		background-color: transparent;
		padding: 1.4rem 0 0;
		border-radius: 0;
	}
	.product-interview-lead {
		padding-bottom: 1.6rem;
	}
	.product-interview-lead p {
		font-size: 1.5rem;
	}
	.product-interview-profile-box {
		padding: 1.6rem 2rem;
	}
	.product-interview-profile-box dt {
		font-size: 1.2rem;
	}
	.product-interview-profile-box dd {
		font-size: 1.2rem;
	}
	.product-interview-question {
		font-size: 1.8rem;
		margin: 3.2rem 0 1.6rem;
	}
	.product-interview-answer p {
		font-size: 1.5rem;
	}
	.product-interview-question__image img {
		padding: 4.8rem 0 1.6rem;
	}
}


/* ================================================
   [30]  共通パーツ：矢印・外部リンク
   ================================================ */

/* --- 下矢印（目次用） --- */
.product-link-arrow-bottom {
	display: inline-flex;
	align-items: center;
	padding-right: 28px;
	position: relative;
	text-decoration: none;
	font-size:1.4rem;
	font-weight:600;
	line-height:1.6;
	letter-spacing:0.02em;
	color:#232323 !important;
}

.product-link-arrow-bottom:before,
.product-link-arrow-bottom:after {
	content: "";
	position: absolute;
	transition: 0.2s ease-in-out;
}

.product-link-arrow-bottom:before {
	border: 1px solid #124897;
	border-radius: 50%;
	box-sizing: border-box;
	height: 20px;
	width: 20px;
	right: 0;
	top: 50%;
	transform: translateY(-50%);
}

.product-link-arrow-bottom:after {
	background-image: url('/products/wp-content/uploads/icon/icon_arrow_right_b.svg');
	background-repeat: no-repeat;
	background-size: 16px 8px;
	background-position: right 6px center;
	top: 50%;
	transform: translateY(-50%) rotate(90deg);
	width: 20px;
	height: 20px;
	right: 0;
}

.product-link-arrow-bottom:hover {
	text-decoration: underline;
	color: #124897 !important;
}
.product-link-arrow-bottom:hover::before { transform: translateY(-50%); }
.product-link-arrow-bottom:hover::after {
	background-position: right 4px center;
}

/* --- 右矢印（汎用） --- */
.product-link-arrow {
	display: inline-flex;
	align-items: center;
	padding-right: 28px;
	position: relative;
	font-size: 1.4rem;
}

.product-link-arrow-mt-16 {
	margin-top: 1.6rem;
}

.product-link-arrow:before,
.product-link-arrow:after {
	content: "";
	position: absolute;
	top: 50%;
	transform: translateY(-50%);
	transition: 0.2s ease-in-out;
}

.product-link-arrow:before {
	border: 1px solid #124897;
	border-radius: 50%;
	box-sizing: border-box;
	height: 20px;
	right: 0;
	width: 20px;
}

.product-link-arrow:after {
	background-image: url('/products/wp-content/uploads/icon/icon_arrow_right_b.svg');
	background-repeat: no-repeat;
	background-position: right center;
	background-size: auto 100%;
	height: 8px;
	right: 6px;
	width: 13px;
}

.product-link-arrow:hover::before,
.product-link-arrow:hover::after {
	transform: translateY(-50%);
	transition: 0.2s ease-in-out;
}

.product-link-arrow:hover::after {
	right: 4px;
	width: 16px;
}

/* 外部リンクアイコン（汎用） */
.product-icon-blank {
	position: relative;
	padding-right: 25px;
	display: inline-block;
	text-decoration: underline;
}

.product-icon-blank::before,
.product-icon-blank::after {
	content: "";
	position: absolute;
	transition: 0.2s ease-in-out;
}

.product-icon-blank::before {
	background-image: url('/products/wp-content/uploads/icon/icon_blank_frame_b.svg');
	background-repeat: no-repeat;
	height: 20px;
	width: 20px;
	right: -8px;
	top: 55%;
	transform: translateY(-50%);
	z-index: 1;
}

.product-icon-blank::after {
	background-image: url('/products/wp-content/uploads/icon/icon_blank_arrow_b.svg');
	background-repeat: no-repeat;
	background-position: top center;
	background-size: 100% 100%;
	top: -4%;
	margin-top: 3px;
	height: 11px;
	width: 13px;
	right: -6px;
	z-index: 2;
}

a:hover .product-icon-blank {
	color: #124897;
}

a:hover .product-icon-blank::before {
	transform: translateY(-50%);
}

a:hover .product-icon-blank::after {
	height: 13px;
	right: -8px;
	margin-top: 1px;
}

@media (max-width: 768px) {
	.product-icon-blank::after {
		top: -20%;
		margin-top: 3px;
		height: 10px;
		width: 12px;
		right: -6px;
	}
}


/* ================================================
   [31] 共通パーツ：common（汎用セクション）
   ================================================ */

.common{
	padding:8rem 0 0;
}

.common h2{
	color:#124897;
	font-size:2.4rem;
	font-weight:600;
	line-height: 1.4;
	letter-spacing:0.02em;
	padding-bottom:1.6rem;
	display: flex;
	align-items: flex-start;
}

.common h2::before{
	content: "";
	width:16px;
	height:16px;
	background-image: url('/products/wp-content/uploads/icon/icon_circle.svg');
	background-size:contain;
	background-repeat: no-repeat;
	background-position: center;
	margin-right: 1rem;
	margin-top:8px;
	flex-shrink: 0;
}

.common p{
	font-size: 1.6rem;
	line-height: 1.6;
	letter-spacing:0.02em;
	text-align:justify;
}

/* SP */
@media (max-width: 768px) {
	.common{
		padding:5.6rem 0 0;
	}
	.common h2{
		font-size:2rem;
	}
	.common h2::before{
		width:14px;
		height:14px;
		margin-right: 0.8rem;
		margin-top: 7px;
	}
	.common p{
		font-size: 1.5rem;
	}
}


/* ================================================
   [32] 共通パーツ：ユーティリティ
   ================================================ */

.is-v-center {
	display: flex;
	align-items: center;
}

.is-v-center-onlypc {
	display: flex;
	align-items: center;
}

/* SP */
@media (max-width: 768px) {
	.is-v-center-onlypc {
		align-items: flex-start;
	}
} 

	
.product-b{
	font-weight:600;
}

.main-color{
	color:#124897;
}

/* --- 余白 --- */
.pt-0{  padding-top:0 !important; }
.pt-8{  padding-top:0.8rem !important; }
.pt-10{ padding-top:1rem !important; }
.pt-16{ padding-top:1.6rem !important; }
.pb-0{ padding-bottom:0 !important; }
.pb-8{ padding-bottom:0.8rem !important; }
.pb-16{ padding-bottom:1.6rem !important; }
.pb-24{ padding-bottom:2.4rem !important; }
.pb-32{ padding-bottom:3.2rem !important; }
.pb-56{ padding-bottom:5.6rem !important; }
.mt-30{ margin-top:3rem !important; }
.mb-56{ margin-bottom:5.6rem !important; }

/* SP */
@media (max-width: 768px) {
	.pb-56{ padding-bottom:4rem !important; }
	.mb-56{ margin-bottom:4rem !important; }
}

/* --- 文字詰め --- */
.letter-spacing-zero{   letter-spacing:0em !important; }
.letter-spacing-narrow{ letter-spacing:-0.01em !important; }
.letter-spacing-narrow3{ letter-spacing:-0.03em !important; }
.letter-spacing-narrow4{ letter-spacing:-0.04em !important; }
.letter-spacing-narrow5{ letter-spacing:-0.05em !important; }
.letter-spacing-wide3{   letter-spacing:0.03em !important; }
.letter-spacing-wide{   letter-spacing:0.05em !important; }
.letter-spacing-wide8{   letter-spacing:0.08em !important; }

/* --- 注釈 --- */
.product-precautions{
	padding-top:8rem;
	font-size: 1.2rem !important;
	line-height: 1.6 !important;
	letter-spacing: 0.02em;
}

.product-precautions-list{
	margin: 0;
	padding: 0;
	display: flex;
	flex-direction: column;
	gap: 0.2rem;
}

.product-precautions-list li{
	font-size: 1.2rem !important;
	line-height: 1.6 !important;
	letter-spacing: 0.02em;
	position: relative;
	padding-left: 1.5em;
	margin: 0;
	padding-top: 0;
	padding-bottom: 0;
}

.product-precautions-list li::before{
	content: '';
	display: block;
	width: 3px;
	height: 3px;
	background-color: #232323;
	border-radius: 50%;
	position: absolute;
	left: 0.4em;
	top: 0.8em;
}

/* SP */
@media (max-width: 768px) {
	.product-precautions{
		padding:4rem 0 0;
		font-size: 1.1rem !important;
	}
	.product-precautions-list li{
		font-size: 1.1rem !important;
	}
}

/* --- リスト --- */
.product-list-inline {
	margin: 0;
	display: flex;
	flex-direction: column;
}

.product-list-inline li {
	font-size: 1.6rem;
	line-height: 1.6;
	letter-spacing: 0.02em;
	position: relative;
	padding-left: 1.5em;
}

.product-list-inline li::before {
	content: '';
	display: block;
	width: 4px;
	height: 4px;
	background-color: #232323;
	border-radius: 50%;
	position: absolute;
	left: 0.4em;
	top: 1rem;
}

/* SP */
@media (max-width: 768px) {
	.product-list-inline li {
		font-size: 1.5rem;
	}
}

/* ================================================
   [33] 共通パーツ：表示切替
   ================================================ */

@media (max-width: 768px) {
	.l-wrapper {
		padding-top:8.8rem;
	}
}


/* ================================================
   [34] 共通パーツ：改行
   ================================================ */

@media (max-width: 768px) {
	.product-onlypc{
		display:none;
	}
}

@media (min-width: 769px) {
	.product-onlysp{
		display:none;
	}
}

@media (min-width: 414px) {
	.product-onlysp-s{
		display:none;
	}
}

@media (min-width: 560px) {
	.product-onlysp-lg{
		display:none;
	}
}

@media (max-width: 1208px) {
	.product-onlypc_1112{
		display:none;
	}
}

@media (min-width: 1208px) {
    .nowrap-1112 {
        white-space: nowrap;
    }
}


/* ================================================
   [35] 一覧ページ用：画像ホバーズーム
   ================================================ */

.c-card.is-show .c-card__figure {
	border: 1px #e8e9eb solid;
	border-radius: 6px;
}

.c-card.is-show .c-card__figure img {
	border: none;
	transition: transform 0.3s ease;
}

.c-card.is-show:has(.c-card__link:hover) .c-card__figure img {
	transform: scale(1.05);
}


/* ================================================
   [36] 一覧ページの文字サイズ縮小
   ================================================ */

.c-heading-3 .is-small {
	font-size: clamp(1.5rem, 2vw, 1.6rem);
}

.c-heading-3.fs-m .is-small {
	font-size: clamp(1.2rem, 2vw, 1.4rem);
}

@media (max-width: 959px) {
    .c-link-arrow {
        font-size: 12px;
    }
}


/* ================================================
   [37] 共通パーツ：絞り込み機能
   ================================================ */

.c-card__tags {
	gap: 0 1rem;
	margin-bottom: 1.6rem;
}

.c-card__tag {
	color: #5B5C5E;
}

.c-sort__clear {
    font-size: clamp(1.1rem, 3vw, 1.2rem);
}

.c-sort__box .c-accordion__icon::before,
.c-sort__box .c-accordion__icon::after {
    width: 10px;
    left: 50%;
    top: 50%;
    transform: translate(-50%, -50%);
}

.c-sort__box .c-accordion__icon::after {
    transform: translate(-50%, -50%) rotate(90deg);
}

.c-sort__box:has(.c-sort__header-toggle-btn:checked) .c-accordion__icon::after {
    transform: translate(-50%, -50%) rotate(180deg);
}

.c-sort__box .c-sort__header-toggle:hover .c-accordion__icon::before,
.c-sort__box .c-sort__header-toggle:hover .c-accordion__icon::after {
    width: 12px;
    left: 50%;
}

@media (hover: none) {
    .c-sort__item:hover {
        background: transparent;
        color: #2a54bf;
    }
    .c-sort__item.selected:hover {
        background: #2a54bf;
        color: #fff;
    }
}


/* ================================================
   [38] 共通パーツ：パンくず近くのアイコン削除
   ================================================ */
.wp-block-navigation__responsive-container-open:not(.always-shown) {
	display: none !important;
}

/* コメントアウト開始
.c-link-external::after {
	content: "";
	display: inline-block;
	width: 20px;
	height: 20px;
	background-image: url(/products/wp-content/themes/quick/assets/images/common/ico_link-external.svg);
	background-repeat: no-repeat;
	vertical-align: -8px;
	margin-left: .6rem;
}
コメントアウト終了 */


/* ================================================
   [39] 共通パーツ：サイドメニュー矢印向き／閉じる
   ================================================ */
.c-link-navset.is-open > .c-link-nav.parent::after {
    transform: rotate(180deg);
}

/* is-closed中はホバーでもサブメニューを開かない */
.c-link-navset.is-closed:has(.c-link-nav.parent:hover) .l-aside__sub-nav {
    grid-template-rows: 0fr;
}

.c-link-navset.is-closed:has(.l-aside__sub-nav:hover) .l-aside__sub-nav {
    grid-template-rows: 0fr;
}

/* is-closed中は矢印も下向きのまま */
.c-link-navset.is-closed .c-link-nav.parent:hover::after {
    transform: rotate(0deg);
}


/* ================================================
   [40] 共通パーツ：ヘッダーに高さを合わせる
   ================================================ */
/* TAB */
@media (min-width: 769px) and (max-width: 959px) {
	.l-wrapper {
		padding-top: 13.4rem;
	}
}


/* ================================================
   [41] 共通パーツ：TOPに戻る矢印
   ================================================ */
#l-pagetop {
    display: block !important;
    opacity: 0;
    pointer-events: none;
    transition: height 0.2s ease-in-out, width 0.2s ease-in-out, opacity 0.5s ease;
}
#l-pagetop.is-visible {
    opacity: 1;
    pointer-events: auto;
}


/* ================================================
   [42] 共通パーツ：フォント
   ================================================ */
@font-face {
    font-family: "EuclidCircularB";
    font-style: normal;
    font-weight: 300;
    src: url("/assets/font/EuclidCircularB/EuclidCircularB-Light-WebS.woff2") format('woff2'),
         url("/assets/font/EuclidCircularB/EuclidCircularB-Light-WebS.woff") format('woff');
    font-display: swap;
}
@font-face {
    font-family: "EuclidCircularB";
    font-style: normal;
    font-weight: 400;
    src: url("/assets/font/EuclidCircularB/EuclidCircularB-Regular-WebS.woff2") format('woff2'),
         url("/assets/font/EuclidCircularB/EuclidCircularB-Regular-WebS.woff") format('woff');
    font-display: swap;
}
@font-face {
    font-family: "EuclidCircularB";
    font-style: normal;
    font-weight: 500;
    src: url("/assets/font/EuclidCircularB/EuclidCircularB-Medium-WebS.woff2") format('woff2'),
         url("/assets/font/EuclidCircularB/EuclidCircularB-Medium-WebS.woff") format('woff');
    font-display: swap;
}
@font-face {
    font-family: "EuclidCircularB";
    font-style: normal;
    font-weight: 600;
    src: url("/assets/font/EuclidCircularB/EuclidCircularB-Semibold-WebS.woff2") format('woff2'),
         url("/assets/font/EuclidCircularB/EuclidCircularB-Semibold-WebS.woff") format('woff');
    font-display: swap;
}
@font-face {
    font-family: "EuclidCircularB";
    font-style: normal;
    font-weight: 700;
    src: url("/assets/font/EuclidCircularB/EuclidCircularB-Bold-WebS.woff2") format('woff2'),
         url("/assets/font/EuclidCircularB/EuclidCircularB-Bold-WebS.woff") format('woff');
    font-display: swap;
}

/* スペースあり版（h1,h2,h3 等で使用） */
@font-face {
    font-family: "Euclid Circular B";
    font-style: normal;
    font-weight: 300;
    src: url("/assets/font/EuclidCircularB/EuclidCircularB-Light-WebS.woff2") format('woff2'),
         url("/assets/font/EuclidCircularB/EuclidCircularB-Light-WebS.woff") format('woff');
    font-display: swap;
}
@font-face {
    font-family: "Euclid Circular B";
    font-style: normal;
    font-weight: 400;
    src: url("/assets/font/EuclidCircularB/EuclidCircularB-Regular-WebS.woff2") format('woff2'),
         url("/assets/font/EuclidCircularB/EuclidCircularB-Regular-WebS.woff") format('woff');
    font-display: swap;
}
@font-face {
    font-family: "Euclid Circular B";
    font-style: normal;
    font-weight: 500;
    src: url("/assets/font/EuclidCircularB/EuclidCircularB-Medium-WebS.woff2") format('woff2'),
         url("/assets/font/EuclidCircularB/EuclidCircularB-Medium-WebS.woff") format('woff');
    font-display: swap;
}
@font-face {
    font-family: "Euclid Circular B";
    font-style: normal;
    font-weight: 600;
    src: url("/assets/font/EuclidCircularB/EuclidCircularB-Semibold-WebS.woff2") format('woff2'),
         url("/assets/font/EuclidCircularB/EuclidCircularB-Semibold-WebS.woff") format('woff');
    font-display: swap;
}
@font-face {
    font-family: "Euclid Circular B";
    font-style: normal;
    font-weight: 700;
    src: url("/assets/font/EuclidCircularB/EuclidCircularB-Bold-WebS.woff2") format('woff2'),
         url("/assets/font/EuclidCircularB/EuclidCircularB-Bold-WebS.woff") format('woff');
    font-display: swap;
}