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


/* === CSS変数（bodyクラススコープ） ===
-----------------------------------------------------------*/
.service-nurture {
	--green-color-primary: #3fdc07;
	--green-color-primary-rgb: 63, 220, 7;
	--green-color-second: #b2e800;
	--green-color-second-rgb: 178, 232, 0;
	--green-gradients: linear-gradient(to right top, var(--yellow-color-second), #daed1f, var(--green-color-second), #82e300, var(--green-color-primary));
	--nurture-ctabg: linear-gradient(to right, rgba(var(--yellow-color-second-rgb), .4), rgba(218, 237, 31, .4), rgba(var(--green-color-second-rgb), .4), rgba(130, 227, 0, .4), rgba(var(--green-color-primary-rgb), .4));
	--gradientsbg-left: linear-gradient(to left, rgba(var(--yellow-color-second-rgb), .2), rgba(218, 237, 31, .2), rgba(var(--green-color-second-rgb), .2), rgba(130, 227, 0, .2), rgba(var(--green-color-primary-rgb), .2));
	--gradientsbg-right: linear-gradient(to right, rgba(var(--yellow-color-second-rgb), .2), rgba(218, 237, 31, .2), rgba(var(--green-color-second-rgb), .2), rgba(130, 227, 0, .2), rgba(var(--green-color-primary-rgb), .2));
}


/* === セクション基本 ===
-----------------------------------------------------------*/
.nurture-sec h2 { line-height: 1.6; margin-bottom: 40px; }
.nurture-sec { margin: 40px 0; padding: 64px 0; }


/* === リスト・ボタン・ユーティリティ ===
-----------------------------------------------------------*/
.topfeature-list { display: inline-block; }
.topfeature-list li {
	line-height: 1.4; position: relative; font-weight: 900;
	padding: 4px 0px 0px 24px; margin-bottom: 8px;
}
.topfeature-list li:last-child { margin-bottom: 0px; }
.topfeature-list li:after, .topfeature-list li:before { content: ''; position: absolute; }
.topfeature-list li:before {
	top: 50%; transform: translateY(-50%) rotate(64deg); left: 9px;
	width: 12px; height: 12px; background-color: var(--yellow-color-second);
}
.topfeature-list li:after {
	top: 50%; transform: translateY(-50%) rotate(45deg); left: 4px;
	width: 8px; height: 8px; border: 2px solid var(--red-color-primary);
}
.topfeature-list li span {
	display: inline-block;
	background: linear-gradient(transparent 56%, rgba(255, 255, 255, .8) 56%);
}

.red { color: var(--red-color-primary); }
.green { color: var(--green-color-primary); }
.green-mark {
	font-weight: 900; position: relative; padding: 0 .2em .1em;
	background: linear-gradient(transparent 60%, var(--green-color-second) 60%);
}

.nurture-button-wrap { margin-top: 48px; text-align: center; }
.nurture-button { width: 480px; margin: auto; }
.nurture-button-link {
	color: var(--text-color); font-weight: 900;
	background-size: 400% 100%;
	transition: background-position var(--base-duration) var(--base-easing),
	            box-shadow var(--base-duration) var(--base-easing);
	border: none; border: 4px solid rgba(255, 255, 255, .6);
	background-image: var(--warm-gradients2);
	box-shadow: 0 4px 16px 0 rgba(var(--orange-color-second-rgb), 0.75);
	position: relative; display: inline-block; font-size: 120%; padding: 32px 16px;
	text-shadow: 1px 1px 1px rgba(255, 255, 255, .4);
}
.nurture-button-link:active {
	background-position: 100% 0;
	box-shadow: 0 6px 24px 0 rgba(var(--red-color-primary-rgb), 0.85);
}
.nurture-button-text { color: var(--text-color); font-weight: 900; }
.nurture-button-text:before { border-color: var(--text-color) transparent transparent transparent; }
.nurture-button-text:after { border-color: transparent transparent var(--text-color) transparent; }

@media (hover: hover) and (pointer: fine) {
	.nurture-button-link:hover {
		background-position: 100% 0;
		box-shadow: 0 6px 24px 0 rgba(var(--red-color-primary-rgb), 0.85);
	}
}

@media (max-width: 599px) {
	.nurture-sec h2 { line-height: 1.4; margin-bottom: 24px; }
	.nurture-button { width: 100%; }
}


/* === mv-sec ===
-----------------------------------------------------------*/
.mv-sec { position: relative; overflow: hidden; padding-bottom: 64px; }
.main-lead { padding-top: 4vh; }
.mv-icon { width: 160px; height: 160px; opacity: .1; position: absolute; transform: rotate(45deg); }
.mv-icon1 { right: -8px; top: -8px; }
.mv-icon2 { right: -16px; top: 240px; }
.mv-icon3 { right: 240px; top: -16px; }
.mv-icon4 { right: 200px; top: 200px; }
.mv-icon5 { right: -80px; top: 480px; }
.mv-icon6 { right: 160px; top: 480px; }
.mv-icon7 { right: 40px; top: 720px; }
.mv-icon8 { left: -8px; top: -8px; }
.mv-icon9 { left: -16px; top: 240px; }
.mv-icon10 { left: 240px; top: -16px; }
.mv-icon11 { left: 200px; top: 200px; }
.mv-icon12 { left: -80px; top: 480px; }
.mv-icon13 { left: 160px; top: 480px; }
.mv-icon14 { left: 40px; top: 720px; }

.mv-sec { background-color: #fff; }
.mv-sec .inner { position: relative; z-index: 2; }
.top-lead {
	display: inline-block; border-radius: 24px; padding: 4px 16px;
	background-color: var(--yellow-color-second); font-size: 90%;
}
.pageh1 {
	font-size: 500%; text-align: center; line-height: 1.2; margin-top: 8px;
	text-shadow: 4px 4px 0px var(--green-color-second);
	-webkit-text-stroke: 2.4px #444; color: transparent;
	font-family: "ヒラギノ角ゴシック", Hiragino Sans, Meiryo, sans-serif;
}
.pageh1 br { display: none; }
.mv-price { margin: 32px 0; }
.mv-price img { width: 240px; }
.mv-plan-feature { justify-content: center; }
.mv-plan-feature .plan-feature-item { width: calc(56% / 3); }
.plan-feature-item { text-align: center; }
.plan-feature-item-inner {
	width: 100%; aspect-ratio: 1/1; margin: 0 auto; background-color: #fff;
	border-radius: 50%;
	box-shadow: rgba(var(--yellow-color-primary-rgb), 0.2) 0px 8px 24px;
	display: flex; align-items: center; justify-content: center;
}
.mv-plan-feature .plan-feature-item-inner {
	border: 2px solid var(--green-color-second);
	box-shadow: rgba(var(--green-color-primary-rgb), 0.2) 0px 0px 16px;
}
.plan-feature-item .price-icon { width: 120px; height: 120px; display: block; margin: auto; }
.mv-plan-feature .price-icon { width: 64px; height: 64px; }
.plan-feature-item1 .plan-feature-item-inner { margin-right: inherit; }
.plan-feature-item3 .plan-feature-item-inner { margin-left: inherit; }
.plan-feature-text {
	font-size: 100%; font-weight: 900; position: relative;
	padding-bottom: 4px; line-height: 1.6; display: inline-block; margin-top: 8px;
	background: radial-gradient(circle farthest-side, var(--yellow-color-second), var(--yellow-color-second) 50%, #fff 50%, #fff);
	background-repeat: repeat-x; background-position: left 0 bottom 0; background-size: 8px 8px;
}
.mv-plan-feature .plan-feature-text { background: none; }
.plan-feature-text span { font-size: 180%; color: var(--red-color-primary); margin-left: 4px; }
.mv-plan-feature .plan-feature-text span { font-size: 140%; }
.mv-sec .sub-lead { margin-top: 24px; font-size: 90%; }

@media (max-width: 1280px) {
	.mv-plan-feature .plan-feature-item { width: calc(80% / 3); }
	.plan-feature-item .price-icon { width: 96px; height: 96px; }
	.mv-plan-feature .price-icon { width: 80px; height: 80px; }
}

@media (max-width: 991px) {
	.mv-sec { height: inherit; padding-bottom: 48px; }
	.pageh1 br { display: block; }
	.pageh1 .line2 { font-size: 150%; }
	.mv-icon { width: 120px; height: 120px; }
	.mv-plan-feature .plan-feature-item { width: calc(92% / 3); }
	.plan-feature-item .price-icon { width: 96px; height: 96px; }
	.plan-feature-text { font-size: 90%; background: none; }
	.plan-feature-text span { font-size: 120%; }
}

@media (max-width: 767px) {
	.mv-icon { width: 96px; height: 96px; }
	.mv-icon1 { right: -8px; top: -8px; }
	.mv-icon2 { right: -16px; top: 200px; }
	.mv-icon3 { right: 160px; top: -16px; }
	.mv-icon4 { right: 120px; top: 160px; }
	.mv-icon5 { right: -16px; top: 440px; }
	.mv-icon6 { right: 120px; top: 320px; }
	.mv-icon7 { right: 64px; top: 640px; }
	.mv-icon8 { left: -8px; top: -8px; }
	.mv-icon9 { left: -16px; top: 200px; }
	.mv-icon10 { left: 160px; top: -16px; }
	.mv-icon11 { left: 120px; top: 160px; }
	.mv-icon12 { left: -16px; top: 440px; }
	.mv-icon13 { left: 120px; top: 320px; }
	.mv-icon14 { left: 64px; top: 640px; }
	.plan-feature .plan-feature-item:nth-child(2) { margin: 0 4%; }
	.plan-feature-item .price-icon { width: 64px; height: 64px; }
}

@media (max-width: 599px) {
	.mv-sec { padding-bottom: 40px; }
	.main-lead { padding-top: 2.4vh; }
	.mv-price img { width: 160px; }
	.mv-icon { width: 80px; height: 80px; }
	.mv-icon1 { left: -2%; top: -2%; right: inherit; }
	.mv-icon2 { left: 50%; transform: translateX(-50%); top: 8%; right: inherit; }
	.mv-icon3 { right: -2%; top: -2%; }
	.mv-icon4 { left: calc(25% - 80px); top: 20%; right: inherit; }
	.mv-icon5 { right: calc(25% - 80px); top: 20%; }
	.mv-icon6 { left: -2%; top: 48%; right: inherit; }
	.mv-icon7 { left: 50%; transform: translateX(-50%); top: 32%; right: inherit; }
	.mv-icon8 { right: -2%; top: 48%; left: inherit; }
	.mv-icon9 { left: 50%; transform: translateX(-50%); top: 54%; right: inherit; }
	.mv-icon10 { left: calc(25% - 80px); top: 72%; }
	.mv-icon11 { right: calc(25% - 80px); top: 72%; left: inherit; }
	.mv-icon12 { left: 50%; transform: translateX(-50%); top: 84%; right: inherit; }
	.mv-icon13 { left: calc(25% - 80px); top: 96%; }
	.mv-icon14 { right: calc(25% - 80px); top: 96%; left: inherit; }
	.pageh1 {
		font-size: 400%;
		text-shadow: 3px 3px 0px var(--green-color-second);
		-webkit-text-stroke: 1.5px #444;
	}
	.pageh1 .line2 { font-size: 140%; }
	.plan-feature-wrap { margin: 0 !important; }
	.plan-feature-item .price-icon { width: 40px; height: 40px; }
	.plan-feature-text { font-size: 75%; letter-spacing: 0; line-height: 1.2; }
	.plan-feature-text span { font-size: 110%; }
}

@media (max-width: 420px) {
	.pageh1 { font-size: 320%; }
	.plan-feature-item .price-icon { width: 40px; height: 40px; }
}


/* === worries-sec ===
-----------------------------------------------------------*/
.worries-sec { background-color: #fff; padding: 0; margin: 0; }
.worries-sec-inner { background-color: var(--gray-color-second); padding-top: 40px; }
.worries-list { padding: 0px 0px 24px; }
.worries-list-item {
	padding: 24px; border-radius: 24px; font-weight: 900; text-align: center;
	animation: vertical-moving 2.4s ease-in-out infinite alternate; position: relative;
	background-color: #fff;
	box-shadow: rgba(149, 157, 165, 0.2) 0px 8px 24px;
	border: 2px solid var(--gray-color-primary); 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: var(--gray-color-primary) 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: #fff transparent transparent;
}
.guruguru { width: 64px; height: auto; position: absolute; right: 0px; bottom: 0px; z-index: -1; }

@keyframes vertical-moving {
	0% { transform: translateY(0px); }
	100% { transform: translateY(8px); }
}

.triangle-bottom { width: 100%; overflow: hidden; line-height: 0; background-color: var(--gray-color-primary); }
.triangle-bottom svg { position: relative; display: block; width: calc(100% + 1.3px); height: 64px; }
.triangle-bottom .shape-fill { fill: var(--gray-color-second); }

@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%; border-radius: 80px; }
	.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-top: 24px; padding-bottom: 0; margin: 0;
	background-color: var(--gray-color-primary); position: relative; overflow: hidden;
}
.solution-sec:before {
	content: 'LIVALEST'; color: rgba(var(--yellow-color-second-rgb), .1); 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; }
.strong-point { margin-top: 80px; align-items: center; position: relative; }
.solution-sec .sub-lead {
	font-size: 110%; display: inline-block;
	background-color: var(--yellow-color-second); padding: 4px 16px; margin-bottom: 8px;
}
.nurture-sec .solution-heading { line-height: 1.36; margin-top: 4px; }
.strong-heading { margin-top: 80px; }
.strong-heading span {
	display: inline-block; background-color: var(--green-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-heading br { display: none; }
.feature-number { position: absolute; font-size: 240px; line-height: 0; top: 80px; left: -4%; }
.feature-image { width: 40%; position: relative; }
.feature-image img { width: 800px; height: auto; position: relative; z-index: 2; }
.strong-point .text-area { width: 60%; }
.strong-point1 .text-area, .strong-point3 .text-area, .strong-point5 .text-area { padding-left: 4%; }
.strong-point2, .strong-point4 { flex-direction: row-reverse; }
.strong-point2 .feature-number, .strong-point4 .feature-number { left: inherit; right: -4%; }
.strong-point2 .text-area, .strong-point4 .text-area { padding-right: 4%; }
.text-area h3 { margin-bottom: 24px; font-weight: 900; color: var(--green-color-primary); line-height: 1.4; }
.strong-bg { line-height: 0; margin-bottom: -16px; }

@media (max-width: 767px) {
	.strong-heading br { display: block; }
	.solution-sec .right-inner-margin, .solution-sec .left-inner-margin { margin: 96px 0 0; }
	.solution-sec .strong-point1 { margin: 40px 0 0 !important; }
	.solution-sec:before { font-size: 800%; }
	.strong-point1 .text-area, .strong-point3 .text-area, .strong-point5 .text-area { padding-left: 0%; }
	.strong-point2 .text-area, .strong-point4 .text-area { padding-right: 0%; }
	.text-area h3 { margin-bottom: 16px; }
	.feature-number { font-size: 160px; top: 40px; }
	.feature-image { width: 100%; }
	.feature-image img { width: 80%; display: block; margin: auto; }
	.strong-point .text-area { width: 100%; margin-top: 16px; }
}

@media (max-width: 599px) {
	.solution-sec .sub-lead { font-size: 80%; }
	.solution-sec:before { font-size: 400%; }
	.text-area h3 { font-size: 150%; }
	.strong-heading span { width: 48px; height: 48px; padding-top: 12px; font-size: 130%; margin: 4px; }
}

@media (max-width: 480px) {
	.feature-number { top: 24px; }
	.feature-image img { width: 100%; }
}


/* === nurture-cta-sec ===
-----------------------------------------------------------*/
.nurture-cta-sec { background-image: var(--nurture-ctabg); margin: 0; padding: 48px 0; margin-top: 64px; }
.nurture-cta-sec2 { margin-top: 80px; }
.nurture-cta-sec .inner { position: relative; }
.nurture-cta-wrap { margin: 64px auto 0; }
.nurture-cta-sec h2 .line2 {
	line-height: 1.2; font-size: 160%; position: relative; z-index: 2;
	text-shadow: 2px 2px #fff;
}
.nurture-cta-sec h2 .line2:before {
	content: ''; position: absolute;
	background-image: var(--green-gradients);
	border-radius: 24px; display: block; width: 108%; height: 32px; bottom: -4px;
	z-index: -1; left: 50%; transform: translateX(-50%);
}
.nurture-cta-sec .nurture-button-wrap { margin-top: 64px; }
.fluffy { position: absolute; z-index: 2; width: 320px; stroke-width: 0; z-index: -1; }
.fluffy path { transform: translate(50%, 50%); }
.fluffy1 { right: 0; top: -40%; }
.fluffy2 { right: 0; bottom: -56%; width: 280px; }
.fluffy1 path { transform: translate(65%, 50%); }
.fluffy2 path { transform: translate(70%, 50%); }
.fluffy3 path { transform: translate(60%, 50%); }
.fluffy3 { right: 0; top: -56%; }
.fluffy4 { left: -12%; bottom: -56%; width: 400px; }
.fluffy5 { left: -4%; bottom: -12%; }
.fluffy6 { left: -2%; bottom: -64%; }

@media (max-width: 1280px) {
	.fluffy { width: 240px; }
	.fluffy1 { right: 2%; }
	.fluffy2 { right: 2%; }
	.fluffy3 { right: 2%; top: -6%; }
	.fluffy4 { left: -12%; bottom: -56%; width: 320px; }
}

@media (max-width: 767px) {
	.fluffy5 { left: -12%; bottom: -52%; }
}

@media (max-width: 599px) {
	.fluffy { width: 160px; }
	.fluffy1 { right: 2%; }
	.fluffy2 { right: 0%; bottom: -48%; }
	.fluffy3 { right: 1.6%; top: -12%; }
	.fluffy4 { left: -12%; bottom: -56%; width: 240px; }
	.fluffy5 { left: -8%; bottom: -4%; }
	.fluffy6 { left: -2%; bottom: -48%; }
}

@media (max-width: 480px) {
	.nurture-cta-sec h2 { line-height: 1.8; }
	.nurture-cta-sec h2 .line1 { font-size: 90%; letter-spacing: 0; }
	.nurture-cta-sec h2 .line2 { font-size: 136%; }
	.nurture-cta-sec h2 .line2:before { width: 104%; height: 24px; }
	.fluffy1 { top: -32%; }
	.fluffy2 { bottom: -32%; }
	.fluffy3 { width: 120px; top: 0; }
}


/* === plan-sec ===
-----------------------------------------------------------*/
.plan-sec {
	margin-top: 0; padding-top: 24px; position: relative;
	background-image: linear-gradient(var(--yellow-color-second) 0% 24%, var(--gray-color-primary) 24% 100%);
}
.planbg { line-height: 0; position: absolute; top: 24%; }
.paln-list { margin-top: 80px; }
.paln-list li {
	padding: 40px 24px; background-color: rgba(255, 255, 255, .6); border-radius: 16px;
	box-shadow: 0 4px 30px rgba(0, 0, 0, 0.1);
	backdrop-filter: blur(4px); -webkit-backdrop-filter: blur(4px);
	width: 23.5%; margin-right: 2%;
}
.paln-list li:last-child { margin-right: 0; }
.paln-list li img { width: 64%; margin: 0 18%; }
.paln-list li h3 { text-align: center; margin-top: 16px; }

.option-area {
	margin-top: 80px; padding: 48px 0;
	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;
}
.option-area h2 {
	background-image: var(--green-gradients);
	-webkit-background-clip: text; -webkit-text-fill-color: transparent;
}
.option-frame { background-color: #fff; border-radius: 8px; border: 2px solid; }
.option-frame1 { border-color: var(--yellow-color-second); background-color: #fffef4; }
.option-frame2 { border-color: var(--green-color-second); background-color: #faffe8; }
.option-frame3 { border-color: var(--green-color-primary); background-color: #f7fff4; }

.option-frame h3 { text-align: center; padding: 16px 8px; }
.option-frame1 h3 { background-color: var(--yellow-color-second); }
.option-frame2 h3 { background-color: #b2e800; }
.option-frame3 h3 { background-color: var(--green-color-primary); }
.option-frame .price-icon {
	width: 120px; height: 120px; border: 2px solid; border-radius: 50%;
	background: #fff; margin: 12px auto 0; display: block; padding: 4px;
}
.option-frame1 .price-icon { border-color: var(--yellow-color-second); }
.option-frame2 .price-icon { border-color: var(--green-color-second); }
.option-frame3 .price-icon { border-color: var(--green-color-primary); }
.option-list { padding: 16px; }
.option-list li {
	margin-bottom: 8px; padding: 0 4px 4px;
	border-bottom: 1px dotted #666; font-size: 90%;
}
.option-list li:last-child { margin-bottom: 0; border-bottom: none; }

.modal__overlay {
	position: fixed; top: 0; left: 0; right: 0; bottom: 0; z-index: var(--z-index-overlay);
	background: rgba(var(--text-color-rgb), .9);
	display: flex; justify-content: center; align-items: center;
}
.modal__container {
	background-color: #fff; padding: 40px; max-width: 640px; width: 100%;
	max-height: 100vh; border-radius: 8px; overflow-y: auto; z-index: var(--z-index-modal);
}
.modal__header { display: flex; justify-content: space-between; align-items: center; }
h2.modal__title { line-height: 1.4; color: var(--text-color); font-weight: 900; }
.modal__container h3 { margin-top: 24px; }
.modal__container .topfeature-list { margin: 8px 0px; }
.modal__close { background: transparent; border: 0; }
.modal__header .modal__close:before { content: "\2715"; }
.modal__content { margin-top: 8px; }
.modal__btn {
	width: 24px; height: 24px; background-color: var(--yellow-color-primary);
	font-weight: 900; color: #fff; border-radius: 40px; cursor: pointer;
	margin: 0px 0px 2px 8px;
	-webkit-appearance: button; text-transform: none; line-height: 1.2;
	will-change: transform; -moz-osx-font-smoothing: grayscale;
	-webkit-backface-visibility: hidden; backface-visibility: hidden;
	transform: translateZ(0);
	transition: transform var(--base-duration) var(--base-easing);
}
.modal__btn:focus, .modal__btn:active { transform: scale(1.1); }
.micromodal-slide { display: none; }
.micromodal-slide.is-open { display: block; }
.plan-image { margin-bottom: 16px; display: block; }
.micromodal-slide[aria-hidden="false"] .modal__overlay { animation: mmfadeIn .3s cubic-bezier(0.0, 0.0, 0.2, 1); }
.micromodal-slide[aria-hidden="false"] .modal__container { animation: mmslideIn .3s cubic-bezier(0, 0, .2, 1); }
.micromodal-slide .modal__container, .micromodal-slide .modal__overlay { will-change: transform; }

@media (hover: hover) and (pointer: fine) {
	.modal__btn:hover { transform: scale(1.1); }
}

@keyframes mmslideIn {
	from { transform: translateY(15%); opacity: 0; }
	to { transform: translateY(0); opacity: 1; }
}

.spot-area { margin-top: 80px; }
.column3 .spot-item:nth-child(3n-1) { margin: 0 4% 2%; }
.spot-item {
	margin-bottom: 2%; background-color: #fff; border: 2px solid #333;
	border-radius: 8px; padding: 16px 0px;
	filter: drop-shadow(4px 4px 0px #444); text-align: center;
}

@media (max-width: 1280px) {
	.paln-list li { width: 49%; margin-right: 0; }
	.paln-list li:nth-child(2n-1) { margin-right: 1%; }
	.paln-list li:nth-child(2n) { margin-left: 1%; }
	.paln-list li:nth-child(3), .paln-list li:nth-child(4) { margin-top: 2%; }
	.paln-list li img { width: 48%; margin: 0 26%; }
	.option-service > div:nth-child(3n-1) { margin: 0 18% 4%; }
	.option-area .option-frame { width: 64%; margin: 0 18% 4%; }
	.option-area .option-frame3 { margin-bottom: 0; }
}

@media (max-width: 991px) {
	.column3 .spot-item:nth-child(3n-1) { margin: 0 0 2%; }
	.column3 .spot-item { width: 48%; margin-bottom: 2%; }
	.column3 .spot-item:nth-child(2n-1) { margin-right: 2%; }
	.column3 .spot-item:nth-child(2n) { margin-left: 2%; }
}

@media (max-width: 767px) {
	.option-area { padding: 8% 0; }
	.column3 > div:nth-child(3n-1) { margin: 0 0 4%; }
	.option-area .option-frame { width: 100%; margin: 0 0 4%; }
	.option-area .option-frame3 { margin-bottom: 0; }
}

@media (max-width: 599px) {
	.plan-sec {
		background-image: linear-gradient(var(--yellow-color-second) 0% 16%, var(--gray-color-primary) 16% 100%);
	}
	.planbg { top: 16%; }
	.plan-heading .line1 { font-size: 75%; }
	.paln-list { margin-top: 40px; }
	.paln-list li img { width: 64%; margin: 0 18%; }
	.paln-list li { padding: 4% 2%; }
	.spot-area .inner2 { margin: 0; }
	.option-area, .spot-area { margin-top: 40px; }
}

@media (max-width: 480px) {
	.spot-item { font-size: 75%; letter-spacing: .4px; }
	.paln-list li { width: 88%; margin: 0 6% 2% !important; }
	.paln-list li:nth-child(4) { margin-bottom: 0 !important; }
}

@media (max-width: 420px) {
	.paln-list li img { width: 52%; margin: 0 24%; }
	.paln-list li { width: 88%; margin: 0 6% 4% !important; padding: 6% 4% 4%; }
	.paln-list li:nth-child(4) { margin-bottom: 0 !important; }
	.paln-list li h3 { margin-top: 8px; }
}


/* === その他支援エリア（voice-sec 内ページ固有部分） ===
-----------------------------------------------------------*/
.other-support-area { margin-top: 80px; }
.other-support-area-inner { justify-content: space-between; }
.title-area { width: calc(92% / 3); text-align: center; }
.title-area h2 {
	-ms-writing-mode: tb-rl; writing-mode: vertical-rl; display: inline-block;
	margin-bottom: 0; position: sticky; top: 96px; font-size: 160%;
	background-color: rgba(255, 255, 255, .8); padding: 12px 4px; text-align: justify;
}
.case-area {
	width: calc(92% / 3 * 2 + 4%); background-color: #fff;
	padding: 40px; border-radius: 8px; box-shadow: 0 2px 4px rgb(0 0 0 / 8%);
}
.other-support { padding: 24px 0px; }
.other-support figure { text-align: center; }
.other-support img { width: 160px; height: auto; }
.other-support h3 { text-align: center; margin-top: 4px; }
.flow-shape {
	position: absolute; width: 800px; height: auto;
	left: 0; bottom: -200px; transform: rotate(45deg); z-index: -1;
}

@media (max-width: 1280px) {
	.flow-shape { width: 640px; left: -12%; }
}

@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) {
	.flow-shape { width: 480px; bottom: -200px; }
}

@media (max-width: 599px) {
	.other-support-area { margin-top: 6.4%; }
	.title-area { width: 80px; text-align: left; }
	.title-area h2 { top: 64px; font-size: 132%; padding: 12px 4px; }
	.case-area { width: calc(100% - 80px); padding: 6.4% 4%; }
	.other-support img { width: 240px; }
	.flow-shape { width: 320px; bottom: -120px; }
}


/* === flow-sec ===
-----------------------------------------------------------*/
.flow-sec { padding: 80px 0; position: relative; }
.horizontal-carousel .simplebar-track { background: #fff; 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: #fff; 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;
}
.horizontal-carousel-item:after {
	position: absolute; right: -40px; bottom: -40px; z-index: 1;
	content: ""; border-radius: 40px; width: 80px; height: 80px;
}
.horizontal-carousel-item:nth-child(1):before { color: var(--yellow-color-second); }
.horizontal-carousel-item:nth-child(1):after { background-color: var(--yellow-color-second); }
.horizontal-carousel-item:nth-child(2):before { color: #e4ef26; }
.horizontal-carousel-item:nth-child(2):after { background-color: #e4ef26; }
.horizontal-carousel-item:nth-child(3):before { color: #c7eb10; }
.horizontal-carousel-item:nth-child(3):after { background-color: #c7eb10; }
.horizontal-carousel-item:nth-child(4):before { color: #abe702; }
.horizontal-carousel-item:nth-child(4):after { background-color: #abe702; }
.horizontal-carousel-item:nth-child(5):before { color: #8ae300; }
.horizontal-carousel-item:nth-child(5):after { background-color: #8ae300; }
.horizontal-carousel-item:nth-child(6):before { color: var(--green-color-primary); }
.horizontal-carousel-item:nth-child(6):after { background-color: var(--green-color-primary); }
.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: 8px 0 4px; }
.horizontal-carousel-item p { font-size: 95%; color: rgba(var(--text-color-rgb, 0.9)); line-height: 1.6; height: 120px; }

.message-area {
	margin-top: 80px; padding: 40px;
	background: rgba(255, 255, 255, .8); border-radius: 16px;
	box-shadow: 0 4px 30px rgba(0, 0, 0, 0.1);
	backdrop-filter: blur(4px); -webkit-backdrop-filter: blur(4px);
}
.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(--green-color-primary) 0deg 308deg, var(--gray-color-second) 308deg 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; }
.chart-text p { font-size: 90%; }
.summarize {
	font-size: 100%; border-radius: 8px; padding: 8px 16px; margin-top: 16px;
	background-color: rgba(var(--gray-color-second-rgb), .5);
	backdrop-filter: blur(4px); -webkit-backdrop-filter: blur(4px);
}
.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(--green-color-primary-rgb), 1) 0deg 129.6deg,
		rgba(var(--green-color-primary-rgb), .5) 129.6deg 208.8deg,
		rgba(var(--green-color-second-rgb), 1) 208.8deg 280.8deg,
		rgba(var(--green-color-second-rgb), .5) 280.8deg 324deg,
		rgba(var(--yellow-color-second-rgb), 1) 324deg 352.8deg,
		rgba(var(--gray-color-second-rgb), 1) 352.8deg 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;
}
.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: 16px; left: 40px; background-color: rgba(255, 255, 255, .8); }
.priceband6 { top: -12px; left: 88px; background-color: rgba(255, 255, 255, .8); }
.macbook { position: absolute; right: 0; bottom: -120px; width: 720px; height: auto; z-index: -1; }
.macbook img { width: 100%; height: auto; }

@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; }
	.macbook { bottom: -120px; width: 80%; }
}

@media (max-width: 599px) {
	.horizontal-carousel-item { width: 80%; }
	.message-area { padding: 24px; }
	.flow-sec .breakout-right { margin-right: calc(50% - 48vw); }
}

@media (max-width: 420px) {
	.horizontal-carousel-item p { height: 164px; }
}


/* === comparison-blog-sec ===
-----------------------------------------------------------*/
.comparison-blog-sec { padding: 80px 0; margin-top: 120px; position: relative; }
.comparison-blog-sec:before {
	font-family: 'Impact', sans-serif !important;
	-ms-writing-mode: tb-rl; writing-mode: vertical-rl; line-height: .4;
	color: rgba(255, 255, 255, .6);
	content: attr(data-deco); position: absolute; left: 0; top: -8px; font-size: 1600%;
}
.comptable-area { position: relative; z-index: 2; width: 100%; margin: 0 auto; }
.comptable-livalest {
	position: absolute; bottom: -8px; left: 180px; width: 320px;
	border-radius: 8px; box-shadow: 8px 8px 24px rgb(0 0 0 / 16%);
}
.comptable-livalest-title {
	display: flex; align-items: center; justify-content: center;
	height: 82px; text-align: center; font-weight: 900;
	background-image: var(--green-gradients); border-radius: 8px 8px 0 0;
}
.comptable-livalest p {
	text-align: center; font-weight: 900; height: 56px; line-height: 56px;
	background-color: #fff; border-bottom: 1px solid var(--gray-color-second);
}
.comptable-livalest p.last { height: 64px; line-height: 64px; }

.comptable { border-collapse: collapse; width: 1008px; }
.comptable th {
	height: 64px; text-align: center; vertical-align: middle;
	background-color: var(--gray-color-primary);
	border-top: 1px solid var(--gray-color-second);
	border-right: 1px solid var(--gray-color-second);
}
.comptable th.top-left-th { opacity: 0; border-top: 0; }
.comptable td {
	width: 280px; height: 56px; text-align: center; vertical-align: middle;
	background-color: #fff; z-index: -1; position: relative;
	border-right: 1px solid var(--gray-color-second);
	border-bottom: 1px solid var(--gray-color-second);
}
.comptable td:first-child {
	padding-left: 16px; text-align: left; width: 240px;
	background-color: var(--yellow-color-second); border-right: none;
}
.comptable td:nth-child(2) { width: 280px; border: none; }
.comptable-area .graybg { background-color: var(--gray-color-primary); }
.comptable-area .circle {
	position: absolute; top: 50%; left: 50%;
	transform: translate(-50%, -50%); width: 20px; height: 20px;
	border-radius: 50%; border: 4px solid var(--green-color-primary);
}
.comptable-area .cross {
	width: 20px; height: 20px; display: inline-block;
	position: relative; top: 4px;
}
.comptable-area .cross:before, .comptable-area .cross:after {
	content: ""; top: 50%; left: 50%; display: block;
	width: 100%; height: 4px; border-radius: 4px;
	background: var(--red-color-primary);
	position: absolute; transform: translate(-50%, -50%) rotate(45deg);
}
.comptable-area .cross:after { transform: translate(-50%, -50%) rotate(-45deg); }

.merit-area { margin-top: 80px; position: relative; }
.merit-item {
	padding: 2%; background-color: rgba(255, 255, 255, .6); border-radius: 8px;
	box-shadow: 0 4px 30px rgba(0, 0, 0, 0.1);
	backdrop-filter: blur(4px); -webkit-backdrop-filter: blur(4px);
	justify-content: center; align-items: center;
}
.merit-list .merit-item { width: 49%; }
.merit-list .merit-item:nth-child(2n-1) { margin-right: 1%; }
.merit-list .merit-item:nth-child(2n) { margin-left: 1%; }
.merit-item:nth-child(3), .merit-item:nth-child(4) { margin-top: 2%; }
.merit-item picture { display: block; width: 32%; margin-right: 4%; }
.merit-body { width: 64%; }
.merit-area img { width: 100%; height: auto; }
.merit-area h3 { font-size: 120%; margin-bottom: 8px; line-height: 1.4; }
.merit-area h3 br { display: none; }
.merit-area p { font-size: 90%; }

.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: #fff;
	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: var(--text-color); font-weight: 900; line-height: 1.4; font-size: 110%; }
.blog-cat-label { color: #bbb; font-size: 90%; text-align: right; }
.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; }
	.merit-list .merit-item { width: 80%; }
	.merit-list .merit-item:nth-child(2n-1) { margin-right: 20%; }
	.merit-list .merit-item:nth-child(2n) { margin-left: 20%; }
	.merit-list .merit-item:not(:nth-child(-n+1)) { margin-top: 2%; }
}

@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) {
	.merit-list .merit-item { width: 92%; }
	.merit-list .merit-item:nth-child(2n-1) { margin-right: 8%; }
	.merit-list .merit-item:nth-child(2n) { margin-left: 8%; }
}

@media (max-width: 599px) {
	.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%; }
	.merit-list .merit-item { width: 96%; padding: 4%; align-items: flex-start; }
	.merit-list .merit-item:not(:nth-child(-n+1)) { margin-top: 4%; }
	.merit-list .merit-item:nth-child(2n-1) { margin-right: 4%; }
	.merit-list .merit-item:nth-child(2n) { margin-left: 4%; }
}

@media (max-width: 480px) {
	.merit-item picture { width: 24%; margin-right: 4%; }
	.merit-body { width: 72%; }
	.merit-area h3 { margin-top: 12px; }
	.merit-area h3 br { display: block; }
	.merit-area p { margin-top: 20px; margin-left: calc(48% - 50vw); }
}


/* === question-sec（h2装飾 — ページ固有） ===
   基本スタイルは components/faq.css を参照
-----------------------------------------------------------*/
.question-sec h2 { position: relative; }
.question-sec h2:before {
	content: ""; position: absolute; top: -36%;
	left: 50%; width: 80px; height: 80px; border-radius: 50%;
	border: 4px solid var(--green-color-primary);
	border-left-color: transparent; border-right-color: transparent;
	transform: translateX(-50%);
}

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

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