@charset "utf-8";
/**
 * 製造業（ホームページ制作）固有スタイル（manufacturing.css）
 *
 * 概要: 製造業向けホームページ制作ページ固有のスタイル
 * 仕様: .service-manufacturing スコープでCSS変数を定義
 *       共通スタイルは foundation.css / layout.css / components/*.css を参照
 * 制限: 共通コンポーネント（faq, form, voice）の基本スタイルは含まない
 */


/* === CSS変数（bodyクラススコープ） ===
-----------------------------------------------------------*/
.service-manufacturing {
	--dark-blue: #09203f;
	--dark-blue-rgb: 9, 32, 63;
	--silver-gradients: linear-gradient(5deg, #FCFCFC 0%, #9E9E9E 45%, #E8E8E8 70%, #DBDADA 85%, #FDFDFD 90% 100%);
	--black-gradients: repeating-linear-gradient(12deg, #3F3F3F, rgba(0, 0, 0, 1) 6%, rgba(22, 19, 19, 1) 11%);

	/* FAQ テーマ上書き（ダークブルー系 + bg-gradients非表示） */
	--faq-bg-gradient-color: transparent;
	--faq-border-color: var(--dark-blue);
	--faq-label-bg: var(--dark-blue);
	--faq-label-color: #fff;
	--faq-scrollbar-color: var(--dark-blue);
	--faq-hover-shadow-color: var(--dark-blue);
	--faq-arrow-color: var(--dark-blue);

	/* お客様の声テーマ上書き（ダーク系） */
	--voice-card-bg: var(--dark-color-second);
	--voice-body-bg: var(--dark-color-second);
	--voice-title-color: #fff;
	--voice-company-color: rgba(255, 255, 255, .8);
}


/* === 製造業共通 ===
-----------------------------------------------------------*/
.manufacturing-sec h2 { line-height: 1.4; margin-bottom: 40px; }
.manufacturing-sec { margin: 48px 0; padding: 80px 0; }

.silver-text {
	color: #fff; display: inline-block; -webkit-text-fill-color: transparent;
	background: var(--silver-gradients); -webkit-background-clip: text;
}
.black-text {
	color: #fff; display: inline-block; -webkit-text-fill-color: transparent;
	background: var(--black-gradients); -webkit-background-clip: text;
}
.black-mark {
	font-weight: 900; position: relative; padding: 0 .2em .1em;
	background: linear-gradient(transparent 20%, #000 20%);
}

.page-id-6667 .progress { background-color: #000; }

@media (max-width: 599px) {
	.manufacturing-sec h2 { margin-bottom: 24px; }
}


/* === mv-sec ===
-----------------------------------------------------------*/
.mv-sec .inner { position: relative; height: 100svh; }
.main-lead { position: absolute; z-index: 2; }
.main-lead1 h1 {
	margin: 24px 0 0 40px; color: #fff; line-height: 1.4;
	font-size: 120%; text-shadow: 0px 0px 4px rgba(0, 0, 0, .8);
}
.main-lead2 { top: 80px; width: 640px; }
.main-lead2 img { height: auto; }
.flare { width: 400px; position: absolute; left: -160px; top: 50px; z-index: 2; }
.top-lead1 {
	display: inline-block; border-radius: 24px; padding: 4px 16px;
	background-color: var(--gbp-yellow-color-primary); font-size: 90%;
}
.mpoint-list { position: absolute; z-index: 3; right: 0; bottom: 80px; }
.mpoint-item {
	display: flex; justify-content: center; align-items: center;
	width: 160px; position: relative; margin-left: 24px;
}
.mpoint-item:first-child { margin-left: 0px; }
.mpoint-item h2 {
	color: #000; font-size: 100%; position: relative; letter-spacing: 1.2px;
	z-index: 2; line-height: 1.2; margin-top: 48px; text-align: center;
}
.mpoint-item img { position: absolute; width: 100%; height: auto; bottom: -36px; }
.cover-image {
	position: absolute; top: 50%; left: 50%;
	transform: translate(-50%, -50%); width: 100%;
}
.cover-image img {
	width: 100%; height: auto; height: 100svh;
	object-fit: cover; object-position: center right;
}

@media (max-width: 1280px) {
	.mpoint-list { right: 4%; }
}
@media (max-width: 980px) {
	.main-lead2 { top: 64px; width: 520px; }
	.mpoint-item { width: 120px; margin-left: 16px; }
}
@media (max-width: 599px) {
	.main-lead1 h1 { margin: 16px 0 0 24px; }
	.main-lead2 { top: 80px; width: 92%; }
	.flare { width: 320px; position: absolute; left: -120px; top: 32px; }
	.mpoint-list { width: 280px; justify-content: flex-end; }
	.mpoint-item { width: 48%; margin-left: 2%; }
	.mpoint-item:nth-child(3), .mpoint-item:nth-child(4) { margin-top: 22%; }
}


/* === worries-sec ===
-----------------------------------------------------------*/
.worries-sec { padding: 0; margin: 0; }
.worries-sec-inner { background-color: var(--dark-color-primary); padding-top: 56px; }
.worries-sec-inner h2 { color: #fff; }
.worries-list { padding: 0px 0px 24px; }
.worries-list-item {
	padding: 24px; border-radius: 24px; font-weight: 900; text-align: center;
	position: relative; background-color: var(--dark-color-second); color: #fff;
	box-shadow: rgba(0, 0, 0, 0.6) 0px 8px 16px; border: 2px solid #000; margin-bottom: 4%;
}
.worries-list-item:nth-child(2n) { animation-delay: .8s; }
.worries-list .worries-list-item:nth-child(3n-1) { margin: 0 4% 4%; }
.worries-iteminner:before {
	content: ''; position: absolute; bottom: -20px; left: 50%; transform: translatex(-50%);
	border-width: 20px 14px 0; border-style: solid; border-color: #000 transparent transparent;
}
.worries-iteminner:after {
	content: ''; position: absolute; bottom: -12px; left: 50%; transform: translateX(-50%);
	border-width: 12px 10px 0; border-style: solid;
	border-color: var(--dark-color-second) transparent transparent;
}
.guruguru {
	width: 64px; height: auto; position: absolute;
	right: 0px; bottom: 0px; filter: revert; opacity: .2;
}
.triangle-bottom {
	width: 100%; overflow: hidden; line-height: 0;
	background-color: var(--dark-color-second);
}
.triangle-bottom svg {
	position: relative; display: block;
	width: calc(100% + 1.3px); height: 64px;
}
.triangle-bottom .shape-fill { fill: var(--dark-color-primary); }

@media (max-width: 991px) {
	.worries-list .worries-list-item { width: 48%; }
	.worries-list .worries-list-item:nth-child(2n-1) { margin: 0 2% 4% 0; }
	.worries-list .worries-list-item:nth-child(2n) { margin: 0 0 4% 2%; }
	.worries-list .worries-list-item:nth-child(9) { margin: auto; }
}
@media (max-width: 599px) {
	.worries-list .worries-list-item { width: 90%; }
	.worries-list .worries-list-item:nth-child(2n-1) { margin: 0 8% 8% 2%; }
	.worries-list .worries-list-item:nth-child(2n) { margin: 0 2% 8% 8%; }
}


/* === solution-sec ===
-----------------------------------------------------------*/
.solution-sec {
	padding: 24px 0 64px; margin: 0;
	background-color: var(--dark-color-second);
	position: relative; overflow: hidden;
}
.solution-sec:before {
	content: 'LIVALEST'; color: var(--dark-color-primary); font-size: 1600%;
	position: absolute; letter-spacing: -2px; top: 0; left: 50%;
	transform: translateX(-50%); font-family: 'Impact', sans-serif !important; line-height: 1;
}
.solution-sec .inner { position: relative; }
.solution-sec .sub-lead {
	font-size: 110%; display: inline-block; background-color: #000;
	padding: 4px 16px; margin-bottom: 8px; color: #fff;
}
.solution-sec .solution-heading { line-height: 1.36; margin-top: 4px; color: #fff; }
.solution-sec .strong-heading { margin: 64px 0 96px; }
.strong-heading span {
	display: inline-block; background-color: var(--dark-color-primary);
	width: 64px; height: 64px; color: #fff; font-weight: 900;
	padding-top: 12px; font-size: 160%; margin: 0 2px;
	line-height: 1; letter-spacing: 0; border-radius: 50%;
}

.strong-point { align-items: center; }
.strong-point:not(:first-child) { margin-top: 96px; }
.strong-image { width: 36%; position: relative; z-index: 3; }
.strong-number { position: absolute; font-size: 160px; line-height: 0; top: 0px; }
.strong-image img {
	height: auto; filter: grayscale(.4) brightness(.8);
	position: relative; z-index: 2;
}
.strong-point .text-area { width: 60%; position: relative; z-index: 2; }
.strong-point .text-area:before {
	content: ""; width: 100%; height: 140%;
	position: absolute; background-color: var(--dark-color-primary);
	bottom: -40px; z-index: -1;
}
.strong-point1 .text-area, .strong-point3 .text-area,
.strong-point5 .text-area { margin-left: 4%; }
.strong-point1 .text-area:before, .strong-point3 .text-area:before,
.strong-point5 .text-area:before { transform: rotate(4deg); right: -16%; }
.strong-point2 .text-area:before, .strong-point4 .text-area:before,
.strong-point6 .text-area:before { transform: rotate(-4deg); left: -16%; }
.strong-point2 .text-area, .strong-point4 .text-area,
.strong-point6 .text-area { margin-right: 4%; }
.strong-point2, .strong-point4, .strong-point6 { flex-direction: row-reverse; }
.strong-point1 .strong-number, .strong-point3 .strong-number,
.strong-point5 .strong-number { left: -4%; }
.strong-point2 .strong-number, .strong-point4 .strong-number,
.strong-point6 .strong-number { right: -4%; }
.text-area h3 {
	margin-bottom: 24px; font-weight: 900; color: #fff;
	line-height: 1.4; text-shadow: 2px 2px #000;
}
.text-area p { color: rgba(255, 255, 255, 0.8); }

@media (max-width: 960px) {
	.strong-point:not(:first-child) { margin-top: 120px; }
	.strong-area { margin: auto; width: 80%; }
	.strong-area .left-inner-margin { margin-left: 2%; }
	.strong-area .right-inner-margin { margin-right: 2%; }
	.strong-image { width: 100%; }
	.strong-area .strong-point .text-area { width: 100%; margin: 12px 0 0; }
}
@media (max-width: 767px) {
	.solution-sec:before { font-size: 1200%; }
	.solution-sec .solution-heading .line2 { font-size: 120% !important; }
	.strong-area { width: 100%; }
	.text-area h3 { margin-bottom: 12px; }
}
@media (max-width: 599px) {
	.solution-sec .strong-heading { margin: 64px 0 48px; }
	.solution-sec:before { font-size: 800%; }
	.strong-heading { margin-top: 40px; }
	.strong-heading span { padding-top: 14px; font-size: 120%; width: 48px; height: 48px; }
}
@media (max-width: 420px) {
	.solution-sec .solution-heading .line2 { font-size: 100% !important; }
}


/* === price-sec ===
-----------------------------------------------------------*/
.price-sec { margin-top: 0; background-color: var(--dark-color-second); margin: 0; padding: 0; }
.price-sec-inner {
	background-color: #D5DEE7;
	background: linear-gradient(to bottom, #D5DEE7 0%, #E8EBF2 50%, #E2E7ED 100%),
	            linear-gradient(to bottom, rgba(0, 0, 0, 0.02) 50%, rgba(255, 255, 255, 0.02) 61%, rgba(0, 0, 0, 0.02) 73%),
	            linear-gradient(33deg, rgba(255, 255, 255, 0.20) 0%, rgba(0, 0, 0, 0.20) 100%);
	background-blend-mode: normal, color-burn;
	padding: 120px 0 80px;
	clip-path: polygon(0 64px, 100% 0%, 100% calc(100% - 0px), 0% 100%);
}
.price-example-wrap { justify-content: center; }
.price-example3 { margin-top: 4%; width: 48%; }
.price-exambox {
	position: relative; padding: 40px 40px 24px;
	background-image:
		repeating-linear-gradient(90deg, rgb(245, 245, 243) 0px, rgb(245, 245, 243) 1px, transparent 1px, transparent 96px),
		repeating-linear-gradient(0deg, rgb(245, 245, 243) 0px, rgb(245, 245, 243) 1px, transparent 1px, transparent 96px),
		repeating-linear-gradient(0deg, rgb(245, 245, 243) 0px, rgb(245, 245, 243) 1px, transparent 1px, transparent 12px),
		repeating-linear-gradient(90deg, rgb(245, 245, 243) 0px, rgb(245, 245, 243) 1px, transparent 1px, transparent 12px),
		linear-gradient(90deg, rgb(255, 255, 255), rgb(255, 255, 255));
	border-radius: 4px;
}
.price-exambox:before {
	position: absolute; z-index: 2; left: 40px; bottom: 24px;
	font-size: 240%; text-transform: uppercase; line-height: 1;
	color: transparent; font-family: 'Impact', sans-serif;
	-webkit-text-stroke: 1px var(--dark-blue);
}
.price-exambox1:before { content: "Case1"; }
.price-exambox2:before { content: "Case2"; }
.price-exambox3:before { content: "Case3"; }
.price-exambox h3 {
	display: inline-block; line-height: 1.4;
	background-color: var(--dark-color-primary); padding: 8px 12px;
	color: #fff; font-weight: 900; margin-bottom: 12px;
	background-image: linear-gradient(to top, var(--dark-color-primary) 0%, var(--dark-blue) 100%);
}
.price-exambox ul { margin-left: 12px; }
.price-exambox li { color: var(--dark-blue); font-weight: 900; }
.price-text { font-size: 140%; line-height: 1; font-weight: 900; margin-top: 16px; }
.price-text .num {
	font-size: 240%; color: transparent; font-family: 'Impact', sans-serif;
	-webkit-text-stroke: 1px var(--dark-blue);
}

.original-contents-area { margin-top: 64px; }
.contents-item {
	color: var(--dark-blue); background-color: #fff;
	border: 2px solid var(--dark-blue); margin-bottom: 2% !important;
	font-weight: 900; border-radius: 8px; padding: 16px 0px;
	filter: drop-shadow(4px 4px 0px var(--dark-blue)); text-align: center;
}
.original-contents-text { margin-top: 24px; }

.contents-case-area { margin-top: 64px; }
.contents-case-area-inner {
	padding: 40px;
	background-image:
		repeating-linear-gradient(90deg, rgb(245, 245, 243) 0px, rgb(245, 245, 243) 1px, transparent 1px, transparent 96px),
		repeating-linear-gradient(0deg, rgb(245, 245, 243) 0px, rgb(245, 245, 243) 1px, transparent 1px, transparent 96px),
		repeating-linear-gradient(0deg, rgb(245, 245, 243) 0px, rgb(245, 245, 243) 1px, transparent 1px, transparent 12px),
		repeating-linear-gradient(90deg, rgb(245, 245, 243) 0px, rgb(245, 245, 243) 1px, transparent 1px, transparent 12px),
		linear-gradient(90deg, rgb(255, 255, 255), rgb(255, 255, 255));
	border-radius: 16px;
}
.case-item { margin-bottom: 4%; align-items: center; }
.case-item:nth-child(3), .case-item:nth-child(4) { margin-bottom: 0%; }
.case-image { width: 64px; margin-right: 24px; }
.case-image img { height: auto; }
.case-text { width: calc(100% - 88px); }
.case-text h3 { color: var(--dark-blue); margin-bottom: 4px; font-size: 110%; line-height: 1.4; }
.case-text p { font-size: 90%; line-height: 1.5; }
.spot-area h2 { margin-bottom: 24px; }
.spot-list { margin-top: 40px; color: var(--dark-blue); }
.spot-area { margin-top: 64px; }
.spot-item {
	padding: 12px 4px 12px 16px; font-size: 90%; margin-bottom: 8px !important;
	line-height: 1.2; text-align: left; vertical-align: middle;
	background-color: #fff; border-left: 4px solid var(--dark-blue);
}

@media (max-width: 991px) {
	.price-example-wrap { flex-direction: column; }
	.price-sec .price-example-wrap { margin: 0 8%; }
	.price-sec .price-example { width: 100%; }
	.price-sec .price-example-wrap .price-example1 { margin-right: inherit; margin: auto; }
	.price-sec .price-example-wrap .price-example2 { margin-left: inherit; margin: 4% auto 0; }
	.contents-list { justify-content: center; }
	.contents-list > li:nth-child(3n-1) { margin: inherit; }
	.contents-list .contents-item { width: 48%; margin-bottom: 4%; }
	.contents-list .contents-item:nth-child(2n-1) { margin-right: 2%; }
	.contents-list .contents-item:nth-child(2n) { margin-left: 2%; }
	.price-sec .case-list .case-item { width: 100%; margin: 0 0 6.4%; }
	.price-sec .case-list .case-item:nth-child(4) { margin-bottom: 0; }
	.spot-list { justify-content: center; }
	.price-sec .spot-list .spot-item { width: 48%; margin: 0; margin-bottom: 4%; }
	.price-sec .spot-list .spot-item:nth-child(2n-1) { margin-right: 2%; }
	.price-sec .spot-list .spot-item:nth-child(2n) { margin-left: 2%; }
}
@media (max-width: 599px) {
	.price-sec-inner { padding: 96px 0 64px; }
	.price-sec-inner .inner2 { margin-inline: 0; }
	.price-sec .price-example-wrap { margin: 0; }
	.contents-case-area-inner { padding: 24px; }
	.price-exambox { padding: 24px; }
	.spot-list { margin-top: 24px; }
}
@media (max-width: 480px) {
	.contents-item { font-size: 90%; }
	.spot-item { padding: 14px 4px 12px 12px; font-size: 75%; letter-spacing: 1px; }
}


/* === cta-sec ===
-----------------------------------------------------------*/
.cta-sec {
	background-image:
		radial-gradient(circle at center center, transparent, rgb(33, 33, 33)),
		repeating-linear-gradient(135deg, rgb(33, 33, 33) 0px, rgb(33, 33, 33) 2px, transparent 2px, transparent 10px, rgb(33, 33, 33) 10px, rgb(33, 33, 33) 11px, transparent 11px, transparent 21px),
		repeating-linear-gradient(45deg, rgb(47, 47, 47) 0px, rgb(47, 47, 47) 4px, transparent 4px, transparent 8px),
		linear-gradient(90deg, rgb(33, 33, 33), rgb(33, 33, 33));
	margin: 0; padding: 48px 0; margin-top: 0px;
}
.cta-lead { color: #fff; font-size: 80%; }
.cta-sec h2 { color: #fff; margin-top: 24px; }
.cta-sec h2 .line2 {
	line-height: 1.2; font-size: 160%; margin: 8px 0;
	background-color: var(--dark-color-second); padding: 0 8px;
	border: 4px solid var(--dark-color-second);
}
.manufacturing-button { width: 480px; margin: 64px auto 0; }
.manufacturing-button-link {
	color: #fff; font-weight: 900; background-size: 400% 100%;
	transition: background-position var(--base-duration) var(--base-easing),
	            box-shadow var(--base-duration) var(--base-easing),
	            background-color var(--base-duration) var(--base-easing);
	border: none; border: 4px solid #fff; position: relative;
	display: inline-block; font-size: 120%; padding: 32px 16px;
	text-shadow: 1px 1px 1px rgba(0, 0, 0, .6);
}
.manufacturing-button-link:active {
	background-position: 100% 0;
	box-shadow: 0 6px 24px 0 rgba(var(--red-color-primary-rgb), 0.85);
}
.manufacturing-button-text { color: #fff; font-weight: 900; }
.manufacturing-button-text:before { border-color: #fff transparent transparent transparent; }
.manufacturing-button-text:after { border-color: transparent transparent #fff transparent; }

@media (hover: hover) and (pointer: fine) {
	.manufacturing-button-link:hover {
		background-color: var(--dark-color-primary);
		background-position: 100% 0;
		box-shadow: 0 6px 24px 0 rgba(var(--dark-color-primary-rgb), 0.85);
	}
}
@media (max-width: 599px) {
	.manufacturing-button { width: 100%; }
}
@media (max-width: 480px) {
	.cta-sec h2 { line-height: 1.8; }
	.cta-sec h2 .line1 { font-size: 90%; letter-spacing: 0; }
	.cta-sec h2 .line2 { font-size: 136%; }
	.cta-sec h2 .line2:before { width: 104%; height: 24px; }
}


/* === works-sec ===
-----------------------------------------------------------*/
.works-sec {
	position: relative; margin: 0; padding: 64px 0px 40px;
	background-color: var(--dark-color-second);
}
.works-link { background-color: var(--dark-color-primary); display: block; }
.works-image { height: auto; }
.works-body { padding: 16px 12px 16px 16px; }
.works-title { color: #fff; font-size: 110%; margin-bottom: 8px; }
.works-title br { display: none; }
.works-description { color: rgba(255, 255, 255, 0.8); font-size: 90%; }

@media (max-width: 767px) {
	.works-sec .works-list-item:nth-child(3n-1) { margin-right: 0%; margin-left: 0%; }
	.works-sec .works-list-item { width: 100%; }
	.works-sec .works-list-item:not(:nth-child(-n+1)) { margin-top: 6.4%; }
}


/* === voice-sec 固有スタイル ===
   共通カードスタイルは components/voice.css を参照
   ここではダークテーマ上書き + renewal-point-area を定義
-----------------------------------------------------------*/
.voice-sec { padding: 0; margin: 0; background-color: var(--dark-color-second); }
.voice-sec-inner {
	background-color: var(--dark-color-primary);
	background-blend-mode: normal, color-burn;
	padding: 120px 0 80px;
	clip-path: polygon(0 64px, 100% 0%, 100% calc(100% - 64px), 0% 100%);
}
.interview-item-body { background-color: var(--voice-body-bg); }

/* --- renewal-point-area（manufacturing固有） --- */
.renewal-point-area { margin-top: 80px; }
.renewal-point-area-inner { justify-content: space-between; }
.renewal-point-title { width: calc(92% / 3); text-align: center; }
.renewal-point-title h2 {
	width: 100%; position: sticky; top: 96px; margin-bottom: 0; color: #fff;
	-ms-writing-mode: tb-rl; writing-mode: vertical-rl; text-orientation: upright;
	line-height: 2; font-size: 140%; padding: 24px; text-align: justify;
}
.renewal-point-list {
	width: calc(92% / 3 * 2 + 4%);
	background-color: var(--dark-color-second); padding: 40px;
}
.renewal-point-item:not(:first-child) { margin-top: 40px; }
.renewal-point-item picture { display: block; width: 64%; }
.renewal-point-item img { height: auto; filter: grayscale(.4) brightness(.8); }
.renewal-point-item h3 { font-size: 120%; color: #fff; margin: 16px 0; line-height: 1.4; }
.renewal-point-item p { font-size: 95%; color: rgba(255, 255, 255, 0.8); }
.renewal-summary { background-color: var(--dark-color-primary); padding: 8px 12px; }

@media (max-width: 991px) {
	.case-area-inner .other-support { width: 100%; margin: 0 4% !important; }
	.case-area-inner .other-support:not(:nth-child(-n+1)) { margin-top: 4%; }
}
@media (max-width: 767px) {
	.renewal-point-list { width: 80%; margin-left: 4%; }
	.renewal-point-title { width: 16%; }
	.renewal-point-title h2 {
		line-height: 1.6; padding: 0; font-size: 140%;
		text-align: justify; margin-right: 16px;
	}
	.renewal-point-title h2 .sp-no { display: none; }
}
@media (max-width: 599px) {
	.voice-sec-inner { padding: 96px 0; }
	.renewal-point-list { width: 88%; margin-left: 4%; }
	.renewal-point-title { width: 8%; }
	.renewal-point-title h2 { font-size: 110%; line-height: 1.4; }
	.renewal-point-item picture { width: 100%; }
}


/* === flow-sec ===
-----------------------------------------------------------*/
.flow-sec {
	margin: 0; padding: 64px 0; position: relative;
	background-color: var(--dark-color-second);
}

/* --- 横カルーセル --- */
.flow-sec .horizontal-carousel .simplebar-track { background: #333; border-radius: 8px; }
.horizontal-carousel .simplebar-track.simplebar-horizontal { height: 16px; }
.horizontal-carousel .simplebar-track.simplebar-horizontal .simplebar-scrollbar { height: 16px; }
.horizontal-carousel .simplebar-scrollbar:before {
	opacity: 1 !important; transition: opacity 0s linear;
	background-color: var(--yellow-color-primary); border-radius: 8px;
}
.horizontal-carousel {
	scroll-snap-type: x mandatory; white-space: nowrap;
	overflow-x: auto; counter-reset: number 0;
}
.horizontal-carousel-item {
	scroll-snap-align: center; margin: 0px 24px 24px 0px; padding: 40px 32px 40px 40px;
	background-color: var(--dark-color-primary);
	display: inline-block; width: 32%; white-space: normal;
	transition: var(--base-duration) var(--base-easing); overflow: hidden;
	position: relative; box-shadow: 0 2px 4px rgb(0 0 0 / 8%); border-radius: 8px;
}
.horizontal-carousel-item:last-child { margin-right: 4%; }
.horizontal-carousel-item:before {
	counter-increment: number 1; content: counter(number) "";
	line-height: 0; font-family: 'Impact', sans-serif; font-size: 120px;
	position: absolute; top: 48px; left: 0px; color: var(--dark-blue);
}
.horizontal-carousel-item:after {
	position: absolute; right: -40px; bottom: -40px; z-index: 1;
	content: ""; border-radius: 40px; width: 80px; height: 80px;
	background-color: var(--dark-blue);
}
.horizontal-carousel-item figure img { width: 100%; position: relative; z-index: 2; }
.horizontal-carousel-item h3 {
	position: relative; z-index: 2; line-height: 1.4; margin: 12px 0 8px; color: #fff;
}
.horizontal-carousel-item p {
	font-size: 95%; color: rgba(255, 255, 255, 0.8); line-height: 1.6; height: 120px;
}

/* --- メッセージ・チャートエリア --- */
.message-area {
	margin-top: 80px; padding: 40px; background-color: var(--dark-color-primary);
	border-radius: 16px; box-shadow: 0 4px 30px rgba(0, 0, 0, 0.4);
}
.message-area h2 { margin-bottom: 24px; }
.chart-area1 { align-items: center; }
.chart1-wrap { margin-right: 4%; }
.chart-text1 { width: calc(100% - 4% - 240px); }
.chart {
	width: 240px; height: 240px; border-radius: 50%;
	position: relative; margin: auto;
}
.chart1 {
	display: flex; align-items: center; justify-content: center;
	background-image: conic-gradient(var(--dark-blue) 0deg 300deg, #ccc 300deg 360deg);
}
.chart1:before {
	content: ""; position: absolute; width: 120px; height: 120px;
	border-radius: 50%; background-color: #FFF;
}
.number {
	font-size: 36px; z-index: 2; position: absolute;
	font-family: "Helvetica Neue", Arial; letter-spacing: -.4px; font-weight: 900;
}
.chart-text h3 { line-height: 1.4; margin-bottom: 8px; color: #fff; }
.chart-text p { font-size: 90%; color: #fff; }
.summarize {
	font-size: 100%; border-radius: 8px; padding: 8px 16px; margin-top: 16px;
	background-color: var(--dark-color-second); color: #fff;
}
.chart-area2 { margin-top: 48px; flex-direction: row-reverse; align-items: center; }
.chart2-wrap { margin-left: 4%; }
.chart-text2 { width: calc(100% - 4% - 240px); }
.chart2 {
	background-color: #fff; position: relative;
	background-image: conic-gradient(
		rgba(var(--dark-blue-rgb), 1) 0deg 129.6deg,
		rgba(var(--dark-blue-rgb), .8) 129.6deg 208.8deg,
		rgba(var(--dark-blue-rgb), .6) 208.8deg 280.8deg,
		rgba(var(--dark-blue-rgb), .4) 280.8deg 300deg,
		rgba(var(--dark-blue-rgb), .1) 300deg 360deg
	);
}
.priceband {
	font-size: 90%; font-family: "Helvetica Neue", Arial; letter-spacing: 0px;
	font-weight: 900; position: absolute; display: inline-block;
	padding: 4px; line-height: 1; color: #000;
}
.priceband1 { top: 72px; right: 8px; background-color: rgba(255, 255, 255, .8); }
.priceband2 { bottom: 16px; right: 64px; background-color: rgba(255, 255, 255, .8); }
.priceband3 { bottom: 72px; left: 8px; background-color: rgba(255, 255, 255, .8); }
.priceband4 { top: 60px; left: 0px; background-color: rgba(255, 255, 255, .8); }
.priceband5 { top: 4px; left: 56px; background-color: rgba(255, 255, 255, .8); }

@media (max-width: 1495px) {
	.horizontal-carousel-item p { height: 140px; }
}
@media (max-width: 1280px) {
	.horizontal-carousel-item { width: 40%; }
}
@media (max-width: 991px) {
	.horizontal-carousel-item { width: 48%; }
	.chart1-wrap { width: 100%; margin-right: 0%; }
	.chart { margin: 0 auto 12px; }
	.chart-text { margin-top: 16px; }
	.chart-text1 { width: 100%; }
	.chart2-wrap { width: 100%; margin-left: 0%; }
	.chart-text2 { width: 100%; }
}
@media (max-width: 767px) {
	.horizontal-carousel-item { width: 56%; padding: 24px 20px 24px 24px; }
	.horizontal-carousel-item p { height: 120px; }
}
@media (max-width: 599px) {
	.flow-sec .breakout-right { margin-right: calc(50% - 46vw); }
	.horizontal-carousel-item { width: 80%; }
	.message-area { padding: 24px; }
}
@media (max-width: 420px) {
	.horizontal-carousel-item p { height: 164px; }
}


/* === blog-sec ===
-----------------------------------------------------------*/
.blog-sec { padding: 0; margin: 0px; background-color: var(--dark-color-second); }
.blog-sec-inner {
	background-color: var(--dark-color-primary);
	background-blend-mode: normal, color-burn;
	padding: 120px 0 80px;
	clip-path: polygon(0 64px, 100% 0%, 100% calc(100% - 0px), 0% 100%);
}

/* --- suggestion-area --- */
.suggestion-area { margin-top: 64px; position: relative; }
.suggestion-item {
	padding: 24px; background-color: var(--dark-color-second); border-radius: 8px;
	box-shadow: 0 4px 30px rgba(0, 0, 0, 0.1);
	justify-content: center; align-items: center;
}
.suggestion-list .suggestion-item { width: 48%; }
.suggestion-list .suggestion-item:nth-child(2n-1) { margin-right: 2%; }
.suggestion-list .suggestion-item:nth-child(2n) { margin-left: 2%; }
.suggestion-item:nth-child(3), .suggestion-item:nth-child(4) { margin-top: 4%; }
.suggestion-icon { width: 24%; margin-right: 4%; }
.suggestion-icon svg { width: 100%; height: auto; }
.suggestion-body { width: 72%; }
.suggestion-item img { width: 100%; height: auto; }
.suggestion-item h3 { font-size: 120%; color: #fff; margin-bottom: 8px; line-height: 1.4; }
.suggestion-item h3 br { display: none; }
.suggestion-item p { font-size: 90%; color: rgba(255, 255, 255, .8); }

/* --- blog-area --- */
.blog-area { margin-top: 80px; position: relative; z-index: 2; }
.blog-area h2 { margin-bottom: 16px; }
.blog-list { margin-top: 40px; position: relative; }
.blog-list-item {
	width: calc(92% / 3); background-color: var(--dark-color-second);
	box-shadow: rgb(149 157 165 / 20%) 0px 8px 24px;
	transition: transform var(--base-duration) var(--base-easing);
}
.blog-list-item:not(:nth-child(-n+3)) { margin-top: 4%; }
.blog-list-item:nth-child(3n-1) { margin-right: 4%; margin-left: 4%; }
.blog-image-head { overflow: hidden; }
.blog-first-image {
	width: 100%; height: auto;
	transition: transform var(--base-duration) var(--base-easing);
}
.blog-item-body { padding: 16px 24px; }
.modified_date { color: #ccc; font-size: 90%; }
.blog-title { color: #fff; font-weight: 900; line-height: 1.4; font-size: 110%; }
.blog-cat-label { color: #bbb; font-size: 90%; text-align: right; margin-top: 16px; }
.blog-list-item:active { transform: translateY(-8px); }
.blog-link:active .interview-image { transform: rotate(-4deg) scale(1.1); }

@media (hover: hover) and (pointer: fine) {
	.blog-list-item:hover { transform: translateY(-8px); }
	.blog-link:hover .blog-first-image { transform: rotate(-4deg) scale(1.1); }
}
@media (max-width: 1280px) {
	.comptable-area { overflow-x: scroll; padding: 40px 0 16px; }
	.comptable-livalest { bottom: 8px; }
}
@media (max-width: 991px) {
	.blog-list-item { width: calc(96% / 2); }
	.blog-list-item:not(:nth-child(-n+2)) { margin-top: 4%; }
	.blog-list-item:nth-child(3n-1) { margin-right: 0%; margin-left: 0%; }
	.blog-list-item:nth-child(2n-1) { margin-right: 2%; }
	.blog-list-item:nth-child(2n) { margin-left: 2%; }
}
@media (max-width: 767px) {
	.suggestion-list .suggestion-item { width: 100%; margin: 0; }
	.suggestion-list .suggestion-item:nth-child(2n-1) { margin-right: 0; }
	.suggestion-list .suggestion-item:nth-child(2n) { margin-left: 0; }
	.suggestion-list .suggestion-item:not(:first-child) { margin-top: 4%; }
}
@media (max-width: 599px) {
	.blog-sec-inner { padding: 96px 0 80px; }
	.blog-list-item:not(:nth-child(-n+1)) { margin-top: 6.4%; }
	.blog-list-item { width: 100%; }
	.blog-list-item:nth-child(2n-1) { margin-right: 0%; }
	.blog-list-item:nth-child(2n) { margin-left: 0%; }
}
@media (max-width: 480px) {
	.suggestion-icon { width: 100%; margin-right: 0; }
	.suggestion-icon svg { width: 40px; margin: 0 auto 8px; display: block; }
	.suggestion-body { width: 100%; display: contents; }
	.suggestion-item p { margin-top: 12px; }
}


/* === question-sec 固有スタイル（h2ブラケット装飾 + ダークブルーカラー） ===
   共通QAスタイルは components/faq.css を参照
   カラーはCSS変数（--faq-*）で制御済み
-----------------------------------------------------------*/
.question-sec { background-color: #D5DEE7; margin-top: 0; }

/* --- h2ブラケット装飾 --- */
.question-sec h2 { color: var(--dark-blue); display: flex; justify-content: center; align-items: center; }
.question-sec h2::before, .question-sec h2::after { content: ""; width: 8px; height: 8px; }
.question-sec h2::before {
	margin: -32px 16px 0 0;
	border-top: 8px solid var(--dark-blue); border-left: 8px solid var(--dark-blue);
}
.question-sec h2::after {
	margin: 0 0 -32px 16px;
	border-right: 8px solid var(--dark-blue); border-bottom: 8px solid var(--dark-blue);
}

/* --- QA見出しカラー --- */
.qa-box h3 { color: var(--dark-blue); }

@media (max-width: 960px) {
	.question-sec h2:before { top: -40%; }
}
@media (max-width: 599px) {
	.question-sec h2:before { top: -80%; }
}


/* === form-sec 固有スタイル ===
   共通フォームスタイルは components/form.css を参照
-----------------------------------------------------------*/
.form-sec { padding-top: 24px; }
