@charset "UTF-8";
/* ==========================================================================
   まるまる経理 - front-page.css (Figma正本ベース・全セクション)
   Figma: y4wLGKghFkbChozYIrOo0B / Root: 487:4289 / 1440×14207px
   各セクションのFigma node IDをコメントで明記。
   ========================================================================== */

/* ===========================================================
   Header (Figma 487:5153, 1440×94)
   =========================================================== */
.site-header {
	position: fixed;
	top: 0; left: 0; right: 0;
	z-index: 100;
	width: 100%;
	max-width: 100vw;
	height: var(--header-h);
	overflow: hidden;
	background: transparent !important;
	backdrop-filter: none !important;
	-webkit-backdrop-filter: none !important;
	box-shadow: none !important;
	border: 0;
	transition: box-shadow .25s ease, background .25s ease, backdrop-filter .25s ease;
}
.site-header.is-scrolled {
	background: rgba(255, 255, 255, .98) !important;
	backdrop-filter: blur(8px) !important;
	-webkit-backdrop-filter: blur(8px) !important;
	box-shadow: 0 2px 12px rgba(0, 0, 0, .04) !important;
}
/* フロントページのみ: ヒーローの上に重なるためヘッダー初期は透明 */
body.home .lp-main { padding-top: 0; }
.site-header__inner {
	display: flex;
	align-items: center;
	justify-content: space-between;
	width: 100%;
	max-width: 1328px;
	min-width: 0;
	margin-inline: auto;
	padding: 16px 56px;
	height: 100%;
	box-sizing: border-box;
}
.site-logo {
	align-self: center;
	min-width: 0;
	padding-bottom: 0;
	margin-top: 4px;
}
.site-logo img { height: 52px; width: auto; display: block; }
.site-nav { display: flex; align-items: center; gap: 0; }
.site-nav__link {
	display: inline-flex;
	align-items: center;
	height: 53px;
	padding: 16px 4px;
	margin-inline: 16px;
	font-size: 16px;
	font-weight: 700;
	color: var(--color-text);
	letter-spacing: 0.04em;
	transition: color .25s ease;
}
.site-nav__link:hover { color: var(--color-primary); }
/* ヘッダーCTA (Figma 487:4940 と同じコンポーネント, 230×54 縮小版) */
.site-header__cta {
	position: relative;
	display: inline-block;
	width: 230px; height: 54px;
	border-radius: 9999px;
	background: var(--color-accent);
	color: var(--color-text-warm);
	font-family: var(--font-base);
	font-weight: 700;
	text-decoration: none;
	box-shadow: var(--shadow-md);
	transition: transform .2s ease, box-shadow .25s ease, background .25s ease;
	cursor: pointer;
	flex-shrink: 0;
}
.site-header__cta:hover {
	background: var(--color-accent-warm);
	transform: translateY(-2px);
	box-shadow: 0 8px 18px rgba(61, 91, 98, .25);
}
.site-header__cta-highlight {
	position: absolute;
	inset: 4px 4px;
	border-radius: 9999px;
	background: linear-gradient(to bottom, rgba(255,255,255,.55), rgba(255,255,255,0));
	filter: blur(6px);
	pointer-events: none;
	z-index: 0;
}
.site-header__cta-frame {
	position: absolute;
	inset: 3px 4px;
	border: 1px solid #fff;
	border-radius: 9999px;
	display: flex; align-items: center; justify-content: center;
	gap: 6px;
	padding-right: 8px;
	box-sizing: border-box;
	z-index: 1;
}
.site-header__cta-icon {
	display: inline-flex; align-items: center; justify-content: center;
	width: 26px; height: 26px;
}
.site-header__cta-icon img {
	width: 22px; height: 17px;
	display: block;
}
.site-header__cta-label {
	font-size: 14px;
	line-height: 1.4;
	color: #494439;
	letter-spacing: 0.04em;
}
.site-header__cta-arrow {
	position: absolute;
	right: 12px; top: 50%;
	width: 10px; height: 10px;
	margin-top: -5px;
	background: #494439;
	border-radius: 50%;
	pointer-events: none;
	z-index: 1;
}
.site-header__cta-arrow::before {
	content: "";
	position: absolute;
	left: 50%; top: 50%;
	transform: translate(-30%, -50%);
	width: 0; height: 0;
	border-style: solid;
	border-width: 2px 0 2px 3px;
	border-color: transparent transparent transparent var(--color-accent);
}
.site-burger { display: none; }
.site-burger:focus,
.site-burger:focus-visible,
.site-burger:active {
	outline: none;
	box-shadow: none;
}
/* フロントページはヘッダーが透明オーバーレイ → padding-top 不要 (line 30 で再定義) */
body:not(.home) #content { padding-top: var(--header-h); }

/* ===========================================================
   Footer (Figma 487:4865, 1440×338, bg #40916c, pad 64/220)
   =========================================================== */
.site-footer {
	background: var(--color-primary);
	color: #fff;
	padding: 64px 220px;
}
.site-footer__container {
	max-width: 1000px;
	margin-inline: auto;
	display: flex;
	flex-direction: column;
	gap: 64px;
}
.site-footer__top { display: flex; align-items: flex-start; gap: 64px; }
.site-footer__brand {
	display: flex; flex-direction: column; gap: 19px;
	width: 168px; flex-shrink: 0;
}
.site-footer__brand img { width: 158px; height: auto; }
.site-footer__desc { font-size: 13px; line-height: 1.8; color: #fff; opacity: .9; }
.site-footer__nav {
	display: flex; flex-wrap: wrap; gap: 8px 28px;
	align-items: center; height: 53px;
}
.site-footer__nav a { color: #fff; font-size: 14px; font-weight: 500; text-decoration: none; }
.site-footer__nav a:hover { opacity: .8; }
.site-footer__bottom {
	display: flex; align-items: center; justify-content: space-between;
	gap: 24px; font-size: 13px; color: rgba(255, 255, 255, .85);
}
.site-footer__legal { display: flex; gap: 16px; }
.site-footer__legal a { color: rgba(255, 255, 255, .85); text-decoration: none; }
.site-footer__legal a:hover { color: #fff; }

/* ===========================================================
   Hero / FV (Figma 487:4901, 1440×717)
   =========================================================== */
.hero { position: relative; width: 100%; }
.hero__fv {
	position: relative;
	width: 100%;
	height: 640px;
	background-color: var(--color-bg-mint-lightest);
	overflow: hidden;
}

/* 装飾4要素: Figma 487:4904 (FV-bg) 内の Vector / Group をフルワイド対応で配置
   画面の左端/右端を基準に絶対座標 → ワイドビューポートでも装飾が画面端に貼り付く */
.hero__deco-wrap {
	position: absolute;
	inset: 0;
	pointer-events: none;
	z-index: 0;
	overflow: hidden;
}
.hero__deco {
	position: absolute;
	background-repeat: no-repeat;
	background-size: 100% 100%;
	pointer-events: none;
}
/* 右上の白曲線 (Figma 1440内 left=944, 1440-944-527=-31 → 右端から-31px) */
.hero__deco--arc-tr {
	right: -31px; top: -34px;
	width: 527px; height: 309px;
	background-image: url('../../img/front/figma/hero-deco-left-top-487-4905@2x.webp');
}
/* 左下の白曲線 */
.hero__deco--arc-bl {
	left: -99px; top: 405px;
	width: 552px; height: 300px;
	background-image: url('../../img/front/figma/hero-deco-right-top-487-4906@2x.webp');
}
/* 左下の階段アイコン */
.hero__deco--stairs {
	left: -48px; top: 354px;
	width: 140px; height: 140px;
	background-image: url('../../img/front/figma/hero-deco-icon-top-487-4907@2x.webp');
}
/* 右下の明ミント大曲線 (Figma 1440内 left=636, 1440-636-1079=-275 → 右端から-275px) */
.hero__deco--arc-br {
	right: -275px; top: 414px;
	width: 1079px; height: 790px;
	background-image: url('../../img/front/figma/hero-deco-arc-487-4925@2x.webp');
}

.hero__inner {
	position: relative; z-index: 1;
	max-width: 1074px; margin-inline: auto;
	padding-inline: 24px;
	padding-top: 40px;
	height: 100%;
	display: flex; align-items: center; gap: 52px;
}
.hero__text {
	width: 489px; flex-shrink: 0;
	display: flex; flex-direction: column; gap: 32px;
}

/* h1 タイトル (Figma 487:4928, 488×221)
   Zen Maru Gothic (--font-emphasis) を採用 */
.hero__title {
	font-family: var(--font-emphasis);
	color: var(--color-text);
	letter-spacing: 3.36px;
	margin: 0;
	display: flex; flex-direction: column;
	gap: 12px;
}
.hero__title-row {
	display: block;
	font-family: var(--font-emphasis);
	font-size: 56px;
	line-height: 1.3;
}
/* デザイン指示: 1行目/2行目とも fw=900 (Black) で統一 */
.hero__title-row--1 { font-weight: 900; }
.hero__title-row--2 { font-weight: 900; }
.hero__title-accent { color: var(--color-primary); }
.hero__title-maru {
	position: relative;
	display: inline-block;
	margin-right: 14px;
	z-index: 1;
}
.hero__title-maru::before {
	content: "";
	position: absolute;
	left: -20px; top: -8px;
	width: 148px; height: 111px;
	background-image: url('../../img/front/figma/hero-maru-deco-487-4935.svg');
	background-repeat: no-repeat;
	background-size: 100% 100%;
	z-index: -1;
	pointer-events: none;
}

/* サブヘッディング (Figma 487:4936, 横並び) */
.hero__sub {
	display: flex; flex-wrap: wrap; align-items: center;
	gap: 4px;
}
.hero__sub-label {
	font-family: var(--font-base);
	font-size: 18px; font-weight: 500;
	line-height: 1.6;
	color: var(--color-text);
}
.hero__sub-badge {
	display: inline-flex; align-items: center;
	padding: 0 8px;
	background: var(--color-primary);
	border: 1px solid var(--color-primary);
	color: #fff;
	font-family: var(--font-base);
	font-size: 18px; font-weight: 500;
	line-height: 1.6;
	border-radius: 0;
}

/* CTA専用ボタン (Figma 487:4940 = 487:4790 と同じコンポーネント, 300×72) */
.hero__btn {
	position: relative;
	display: inline-block;
	width: 300px; height: 72px;
	border-radius: 9999px;
	background: var(--color-accent);
	color: var(--color-text-warm);
	font-family: var(--font-base);
	font-weight: 700;
	text-decoration: none;
	box-shadow: var(--shadow-md);
	transition: transform .2s ease, box-shadow .25s ease, background .25s ease;
	cursor: pointer;
	align-self: flex-start;
}
.hero__btn:hover {
	background: var(--color-accent-warm);
	transform: translateY(-2px);
	box-shadow: 0 8px 18px rgba(61, 91, 98, .25);
}
/* 内側ハイライト (Figma I487:4940;70:411 - GRADIENT_LINEAR opacity 0.55 + LAYER_BLUR 8) */
.hero__btn-highlight {
	position: absolute;
	inset: 4px 4px;
	border-radius: 9999px;
	background: linear-gradient(to bottom, rgba(255,255,255,.55), rgba(255,255,255,0));
	filter: blur(8px);
	pointer-events: none;
	z-index: 0;
}
.hero__btn-frame {
	position: absolute;
	inset: 4px 4px;
	border: 1px solid #fff;
	border-radius: 9999px;
	display: flex; align-items: center; justify-content: center;
	gap: 8px;
	padding-right: 10px;
	box-sizing: border-box;
	z-index: 1;
}
.hero__btn-icon {
	display: inline-flex; align-items: center; justify-content: center;
	width: 32px; height: 32px;
	transform: translateY(1px);
}
.hero__btn-icon img {
	width: 28px; height: 22px;
	display: block;
}
.hero__btn-label {
	font-size: 18px;
	line-height: 1.6;
	color: #494439;
	letter-spacing: 0.04em;
}
.hero__btn-arrow {
	position: absolute;
	right: 14px; top: 50%;
	width: 12px; height: 12px;
	margin-top: -6px;
	background: #494439;
	border-radius: 50%;
	pointer-events: none;
}
.hero__btn-arrow::before {
	content: "";
	position: absolute;
	left: 50%; top: 50%;
	transform: translate(-30%, -50%);
	width: 0; height: 0;
	border-style: solid;
	border-width: 2.5px 0 2.5px 4px;
	border-color: transparent transparent transparent var(--color-accent);
}

.hero__illust {
	width: 533px; height: 428px; flex-shrink: 0;
	background-image: url('../../img/front/figma/hero-illust-487-4941@2x.webp');
	background-size: contain; background-position: center; background-repeat: no-repeat;
}
.hero__band {
	background: var(--color-primary);
	height: 77px; padding: 24px 10px;
	display: flex; align-items: center; justify-content: center;
}
.hero__badges {
	max-width: 1420px; width: 100%;
	display: flex; align-items: center; justify-content: center;
	gap: 40px;
}

/* ==========================================================================
   #2 お悩み (Figma 487:4390, 1440×751.6)
   - Section background (487:4391, 1440×552, bg #E9F1EE)
       - Title container (487:4394) : h2 40px + dots ×3 (#FFC630)
       - Illustration (487:4400, 1000×342, horizontal, gap 48, padding 0/32)
           - nayami-illust (487:4401, 288×326)
           - List ×6 (462:3857..., each 600×57, padding 16/24, gap 16)
   - Illustration container (487:4450, 551×229.6) : 下向きポリゴン + ロゴ + ピッチ
   ※ 背景緑(#E9F1EE)はピッチエリアの下端まで連続させる
   ========================================================================== */
.problems {
	position: relative;
	background: var(--color-bg-mint-lightest);
	padding: 60px 10px 0;
}
.problems__inner {
	max-width: 1000px;
	margin-inline: auto;
	display: flex;
	flex-direction: column;
	gap: 32px;
	margin-bottom: 79px;  /* リスト下端 ~ polygon中央 までを緑bgで埋める (polygon半分41px + 余白38px) */
}
.problems__head {
	text-align: center;
	display: flex;
	flex-direction: column;
	align-items: center;
	gap: 16px;
}
.problems__title {
	font-family: var(--font-base);
	font-weight: 700;
	font-size: 40px;
	line-height: 1.4;
	color: var(--color-text);
	letter-spacing: 0.04em;
	margin: 0;
	padding-top: 18px;       /* ドット用に上余白を確保 */
}
/* 「お悩み」: 緑色 + 上に黄色ドット3つ */
.problems__title-emphasis {
	position: relative;
	display: inline-block;
	color: var(--color-primary);
}
.problems__title-emphasis::before {
	content: "";
	position: absolute;
	left: 50%;
	top: -10px;
	transform: translateX(-50%);
	width: 120px;
	height: 8px;
	background-image: radial-gradient(circle, var(--color-accent) 4px, transparent 4.5px);
	background-size: 40px 8px;
	background-repeat: repeat-x;
	background-position: 0 0;
}
.problems__body {
	display: grid;
	grid-template-columns: 288px 1fr;
	gap: 48px;
	padding: 0 32px;
	align-items: center;
}
.problems__illust {
	margin: 0;
}
.problems__illust img {
	width: 288px;
	height: auto;
	max-width: 100%;
}
.problems__list {
	display: flex;
	flex-direction: column;
	margin: 0;
	padding: 0;
	list-style: none;
}
.problems__item {
	display: flex;
	align-items: center;
	gap: 16px;
	padding: 16px 24px;
	border-bottom: 1px dashed var(--color-primary);
}
.problems__item:last-child {
	border-bottom: 0;
}
.problems__check {
	flex-shrink: 0;
	width: 24px;
	height: 24px;
	border-radius: 50%;
	background: var(--color-primary);
	display: inline-flex;
	align-items: center;
	justify-content: center;
}
.problems__check svg { display: block; }
.problems__text {
	margin: 0;
	font-family: var(--font-base);
	font-weight: 500;
	font-size: 16px;
	line-height: 1.55;
	color: var(--color-text);
}
.problems__text em {
	color: var(--color-primary);
	font-weight: 700;
	font-style: normal;
}

/* 独立配置 Illustration container (Figma 487:4450)
   黄色逆三角の中央あたりで、緑bg → 白方眼 (about セクション系の bg-note) に切り替え */
.problems__pitch {
	position: relative;
	background: #fff;
	background-image: url('../../img/front/figma/bg-note-487-4290@2x.png');
	background-size: 1440px auto;
	background-position: center top;
	background-repeat: repeat;
	padding: 41px 10px 60px;  /* polygon 半分 (41px) を白方眼側に確保。残り半分は緑bg側 (.problems padding-bottom) */
	display: flex;
	flex-direction: column;
	align-items: center;
	gap: 32px;
}
.problems__polygon {
	width: 320px;
	height: 82px;
	margin-top: -82px;        /* 全体を上に持ち上げて、上半分が緑bgセクション内、下半分が白方眼にかかる */
	background-image: url('../../img/front/figma/polygon-down-487-4451.svg');
	background-size: contain;
	background-position: center;
	background-repeat: no-repeat;
	flex-shrink: 0;
}
.problems__pitch-text {
	margin: 0;
	font-family: var(--font-base);
	font-weight: 700;
	font-size: 32px;
	line-height: 1.6;
	letter-spacing: 0.04em;
	color: var(--color-text);
	text-align: center;
}
.problems__pitch-line {
	display: block;
}
.problems__pitch-line--first {
	display: inline-block;
}
.problems__pitch-line--sp {
	display: none;
}
.problems__pitch-logo {
	display: inline-block;
	height: 2.2em;
	width: auto;
	vertical-align: middle;
	margin-right: 8px;
	position: relative;
	top: -2px;
}

/* ==========================================================================
   #3 まるまる経理とは (Figma 487:4469, 1440×1125, bg white, pad 80/10)
   ========================================================================== */
/* ==========================================================================
   #3 まるまる経理とは (Figma 487:4469, 1440×1125, white, padding 80/10)
   - About section container (487:4470, 1000×733, vertical, gap 64)
       - h2 (487:4473): "About" eyebrow + 「まるまる経理 とは？」(中央配置)
       - 説明文 (487:4478): 18px Medium, line-height 1.6, center, gap 16
       - about-cards (487:4481, 1000×427, horizontal, gap 16)
           - 各カード (322.67×427, bg #E9F1EE, padding 32/16, radius 10)
               - ステップ番号円 (50×50, 緑) ※絶対配置(top -25px)で上に飛び出す
               - アイコン (90×90)
               - タイトル (18px Bold center 緑#40916C)
               - 説明 (14px Medium left)
               - 黄色下向き三角 (78×23 #FFC630)
               - 効果テキスト (18px Bold center 緑#40916C)
   - 下部ピッチ (487:4485, 1420×200): 22px Bold + 32px Bold + 黄色マーカー
   ========================================================================== */
.about {
	background: #fff;
	background-image: url('../../img/front/figma/bg-note-487-4290@2x.png');
	background-size: 1440px auto;
	background-position: center top;
	background-repeat: repeat;
	padding: 80px 10px;
	display: flex;
	flex-direction: column;
	gap: 48px;
}

/* ハンバーガーメニュークリック時のスクロール位置調整 */
#about,
#pricing {
	scroll-margin-top: calc(var(--header-h) + 140px);
}
.about__inner {
	max-width: 1000px;
	margin-inline: auto;
	display: flex;
	flex-direction: column;
	gap: 48px;
	width: 100%;
}
.about__head {
	display: flex;
	flex-direction: column;
	align-items: center;
	gap: 8px;
	text-align: center;
}
.about__eyebrow {
	margin: 0;
	font-family: var(--font-numeric);
	font-weight: 800;
	font-size: 16px;
	line-height: 1.4;
	letter-spacing: 0.06em;
	color: var(--color-primary);
	text-transform: capitalize;
}
.about__title {
	margin: 0;
	font-family: var(--font-base);
	font-weight: 700;
	font-size: 40px;
	line-height: 1.4;
	letter-spacing: 0.04em;
	color: var(--color-text);
	display: inline-flex;
	gap: 8px;
	align-items: baseline;
}
.about__title-accent { color: var(--color-primary); }
.about__title-rest { color: var(--color-text); }

.about__intro {
	display: flex;
	flex-direction: column;
	gap: 16px;
	margin: -24px 0 0;
}
.about__intro p {
	margin: 0;
	font-family: var(--font-base);
	font-weight: 500;
	font-size: 18px;
	line-height: 1.6;
	color: var(--color-text);
	text-align: center;
}
.about__intro-accent {
	color: var(--color-primary);
	font-weight: 700;
}

/* ===== 3カード横並び (Figma 521:2150) ===== */
.about__cards {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: 16px;
}
.about-card {
	position: relative;
	background: var(--color-bg-mint-lightest);
	border-radius: 10px;
	padding: 32px 16px;
	display: flex;
	flex-direction: column;
	align-items: center;
	gap: 8px;
	text-align: center;
}
.about-card__title-row {
	display: block;
}
.about-card__step {
	position: absolute;
	top: -25px;
	left: 50%;
	transform: translateX(-50%);
	width: 50px;
	height: 50px;
	border-radius: 50%;
	background: var(--color-primary);
	color: #fff;
	font-family: var(--font-numeric);
	font-weight: 800;
	font-size: 22px;
	line-height: 1;
	letter-spacing: 0;
	display: inline-flex;
	align-items: center;
	justify-content: center;
}
.about-card__icon {
	width: 90px;
	height: 90px;
	display: flex;
	align-items: center;
	justify-content: center;
}
.about-card__icon img {
	width: 90px;
	height: 90px;
	display: block;
}
.about-card__title {
	margin: 0;
	font-family: var(--font-base);
	font-weight: 700;
	font-size: 18px;
	line-height: 1.6;
	color: var(--color-primary);
	text-align: center;
}
.about-card__desc {
	margin: 0;
	font-family: var(--font-base);
	font-weight: 500;
	font-size: 16px;
	line-height: 1.7;
	color: var(--color-text);
	text-align: left;
	width: 100%;
}
.about-card__arrow {
	width: 0;
	height: 0;
	border-left: 39px solid transparent;
	border-right: 39px solid transparent;
	border-top: 23px solid var(--color-accent);
	margin-top: auto;  /* 説明文の長さに関わらず、矢印・コピーをカード下端に揃える */
}
.about-card__effect {
	margin: 0;
	font-family: var(--font-base);
	font-weight: 700;
	font-size: 18px;
	line-height: 1.6;
	color: var(--color-primary);
	text-align: center;
}

/* ===== 下部ピッチ (Figma 487:4485) ===== */
.about__pitch {
	max-width: 1420px;
	margin-inline: auto;
	width: 100%;
	display: flex;
	flex-direction: column;
	align-items: center;
	gap: 16px;
	text-align: center;
}
.about__pitch-line {
	margin: 0;
	font-family: var(--font-base);
	font-weight: 700;
	font-size: 22px;
	line-height: 1.8;
	color: var(--color-text);
}
.about__pitch-emphasis {
	margin: 0;
	font-family: var(--font-base);
	font-weight: 700;
	font-size: 32px;
	line-height: 1.5;
	letter-spacing: 0.04em;
	color: var(--color-text);
}
.about__pitch-mark {
	display: inline-block;
	background: linear-gradient(transparent 70%, var(--color-accent) 70%, var(--color-accent) 90%, transparent 90%);
	padding: 0 .08em;
}
.about__pitch-mark--green { color: var(--color-primary); }

/* ==========================================================================
   #4 選ばれる理由 / Strengths (Figma 488:7773, 1440×1119, padding 80/10)
   - 背景: #E9F1EE + 罫線テクスチャ (strengths-bgnote-487-6968)
   - 装飾: 左に 488:7774 group, タイトル「3」の上に 488:7537 黄色バースト
   - h2 (487:4496): "Reasons" eyebrow + 2行タイトル
   - reasonst-cards (487:4504, 1000×759, vertical, gap 24): 3カード縦並び
       - 各カード (1000×237, white, padding 32/40, radius 10, horizontal gap 16)
           - reason0X-img (260×173, クリーム#FAF4DA bg + イラスト)
           - テキスト (620×149, vertical, gap 14):
               - タイトル行: 黄色#FFC630バッジ「01」+ h3 (22px Bold 緑#40916C)
               - 説明文 (14px Medium left)
   ========================================================================== */
.strengths {
	position: relative;
	background-color: var(--color-bg-mint-lightest);
	background-image: url('../../img/front/figma/strengths-bgnote-487-6968@2x.webp');
	background-size: 1440px auto;
	background-position: center top;
	background-repeat: repeat-y;
	padding: 80px 10px;
	overflow: hidden;
}
.strengths::before {
	content: "";
	position: absolute;
	left: -88px;
	top: 864px;
	width: 430px;
	height: 272px;
	background-image: url('../../img/front/figma/strengths-deco-2-488-7774@2x.webp');
	background-size: contain;
	background-repeat: no-repeat;
	pointer-events: none;
	z-index: 0;
}
.strengths::after {
	content: "";
	position: absolute;
	right: -150px;
	top: -26px;
	width: 527px;
	height: 309px;
	background-image: url('../../img/front/figma/strengths-deco-1-488-7507@2x.webp');
	background-size: contain;
	background-repeat: no-repeat;
	pointer-events: none;
	z-index: 0;
}
.strengths__inner {
	max-width: 1000px;
	margin-inline: auto;
	position: relative;
	z-index: 1;
	display: flex;
	flex-direction: column;
	gap: 40px;
	width: 100%;
}
.strengths__head {
	display: flex;
	flex-direction: column;
	align-items: center;
	gap: 8px;
	text-align: center;
}
.strengths__eyebrow {
	margin: 0;
	font-family: var(--font-numeric);
	font-weight: 800;
	font-size: 16px;
	line-height: 1.4;
	letter-spacing: 0.06em;
	color: var(--color-primary);
}
.strengths__title {
	margin: 0;
	font-family: var(--font-base);
	font-weight: 700;
	font-size: 40px;
	line-height: 1.4;
	letter-spacing: 0.04em;
	color: var(--color-text);
	display: flex;
	flex-direction: column;
	align-items: center;
	gap: 8px;  /* Figma: 1行目と2行目の余白 */
}
.strengths__title-line {
	display: inline-block;
}
.strengths__title-line--accent {
	color: var(--color-primary);
	display: inline-flex;
	align-items: baseline;
	gap: 12px;  /* Figma: 「選ばれる」「３つ」「の理由」の間 */
}
.strengths__title-num {
	position: relative;
	display: inline-flex;
	align-items: baseline;
	z-index: 0;
}
.strengths__title-num-three {
	font-family: var(--font-numeric);
	font-weight: 800;
	font-size: 53px;
	line-height: 1;
	letter-spacing: 0.06em;
	color: var(--color-primary);
}
.strengths__title-num-burst {
	position: absolute;
	top: calc(50% + 4px);
	left: 50%;
	transform: translate(-50%, -50%);
	width: 110px;
	height: 82px;
	background-image: url('../../img/front/figma/strengths-burst-488-7537.svg');
	background-size: contain;
	background-repeat: no-repeat;
	background-position: center;
	z-index: -1;
	pointer-events: none;
}

.strengths__list {
	display: flex;
	flex-direction: column;
	gap: 24px;
}
.strength-card {
	background: #fff;
	border-radius: 10px;
	padding: 32px 40px;
	display: flex;
	align-items: center;
	gap: 40px;
}
.strength-card__illust {
	flex-shrink: 0;
	width: 260px;
	height: 173px;
	display: flex;
	align-items: center;
	justify-content: center;
}
.strength-card__illust img {
	width: 260px;
	height: 173px;
	display: block;
	border-radius: 8px;
}
.strength-card__body {
	flex: 1;
	display: flex;
	flex-direction: column;
	gap: 14px;
	min-width: 0;
}
.strength-card__heading {
	display: inline-flex;
	align-items: center;
	gap: 10px;
	width: fit-content;
}
.strength-card__num {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	min-width: 55px;
	height: 47px;
	padding: 8px 7px;
	background: var(--color-accent);
	border-radius: 10px;
	font-family: var(--font-numeric);
	font-weight: 800;
	font-size: 31px;
	line-height: 1;
	color: var(--color-primary);
	letter-spacing: 0;
}
.strength-card__title {
	margin: 0;
	font-family: var(--font-base);
	font-weight: 700;
	font-size: 22px;
	line-height: 1.6;
	color: var(--color-primary);
	letter-spacing: 0.04em;
}
.strength-card__desc {
	margin: 0;
	font-family: var(--font-base);
	font-weight: 500;
	font-size: 16px;
	line-height: 1.8;
	color: var(--color-text);
	text-align: left;
}

/* ==========================================================================
   #5 おまかせいただける業務 / Services (Figma 487:4507, 1440×970, padding 80/10)
   - 背景: #40916C (緑)
   - h2 (487:4512): "Services" eyebrow(白) + h2「おまかせいただける業務」(40px 白)
   - 説明文 (487:4517): 18px Medium center 白
   - services-cards (487:4518, 1000×312, horizontal, gap 23): 3カード横並び
       - 各カード (318×312, white, padding 32/24, radius 10, vertical, gap 8)
           - アイコン (90×90, 中央)
           - タイトル (22px Bold center 緑#40916C)
           - リスト: 黄色ドット(6×6 #FFC630 radius 3) + テキスト(14px Medium left)
   - 下部 softwares カード (487:4547, 1000×258, white, radius 10, padding 24, gap 16)
   ========================================================================== */
.services {
	background: var(--color-primary);
	color: #fff;
	padding: 80px 10px;
	display: flex;
	flex-direction: column;
	gap: 32px;
}
.services__inner {
	max-width: 1000px;
	margin-inline: auto;
	width: 100%;
	display: flex;
	flex-direction: column;
	gap: 40px;
}
.services__head {
	display: flex;
	flex-direction: column;
	align-items: center;
	gap: 8px;
	text-align: center;
}
.services__eyebrow {
	margin: 0;
	font-family: var(--font-numeric);
	font-weight: 800;
	font-size: 16px;
	line-height: 1.4;
	letter-spacing: 0.06em;
	color: #fff;
}
.services__title {
	margin: 0;
	font-family: var(--font-base);
	font-weight: 700;
	font-size: 40px;
	line-height: 1.4;
	letter-spacing: 0.04em;
	color: #fff;
	text-align: center;
}
.services__intro {
	margin: 0;
	font-family: var(--font-base);
	font-weight: 500;
	font-size: 18px;
	line-height: 1.6;
	color: #fff;
	text-align: center;
}
.services__grid {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: 23px;
}
.service-card {
	background: #fff;
	border-radius: 10px;
	padding: 32px 24px;
	display: flex;
	flex-direction: column;
	align-items: center;
	gap: 8px;
	color: var(--color-text);
	/* Figma 462:4993: drop shadow rgba(255,255,255,0.44) offset (4,4) blur 0
	 * → 緑背景上で薄いグリーン色の段違いカード状エフェクトとして見える */
	box-shadow: 4px 4px 0 rgba(255, 255, 255, 0.44);
}
.service-card__icon {
	width: 90px;
	height: 90px;
	display: flex;
	align-items: center;
	justify-content: center;
}
.service-card__icon img {
	width: 90px;
	height: 90px;
	display: block;
}
.service-card__name {
	margin: 0;
	font-family: var(--font-base);
	font-weight: 700;
	font-size: 22px;
	line-height: 1.8;
	color: var(--color-primary);
	text-align: center;
}
.service-card__list {
	list-style: none;
	padding: 0;
	margin: 0;
	display: flex;
	flex-wrap: wrap;
	column-gap: 20px;
	row-gap: 4px;
	width: 100%;
}
.service-card__item {
	display: flex;
	align-items: center;
	gap: 6px;
	font-family: var(--font-base);
	font-weight: 500;
	font-size: 14px;
	line-height: 1.6;
	color: var(--color-text);
}
.service-card__item::before {
	content: "";
	flex-shrink: 0;
	width: 6px;
	height: 6px;
	border-radius: 3px;
	background: var(--color-accent);
}

/* ===== 対応会計ソフト 白カード (Figma 487:4547, 1000×258, padding 24, radius 10) ===== */
.services__softwares-wrap {
	max-width: 1420px;
	margin-inline: auto;
	width: 100%;
	padding: 0 10px;
}
.services__softwares {
	max-width: 1000px;
	margin-inline: auto;
	background: #fff;
	border-radius: 10px;
	padding: 24px;
	display: flex;
	flex-direction: column;
	align-items: center;
	gap: 16px;
	color: var(--color-text);
	/* Figma Frame 1321316524: drop shadow rgba(255,255,255,0.44) offset (4,4) blur 0 */
	box-shadow: 4px 4px 0 rgba(255, 255, 255, 0.44);
}
.services__softwares-title {
	margin: 0;
	font-family: var(--font-base);
	font-weight: 700;
	font-size: 22px;
	line-height: 1.8;
	color: var(--color-text);
	text-align: center;
}
.services__softwares-divider {
	width: 100%;
	max-width: 952px;
	height: 1px;
	background: var(--color-border);
	border: 0;
	margin: 0;
}
.services__softwares-list {
	display: flex;
	align-items: center;
	justify-content: center;
	flex-wrap: nowrap;
	gap: 16px;
	width: 100%;
}
.services__softwares-item {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	height: 160px;
	flex: 1 1 0;
	min-width: 0;
}
.services__softwares-item img {
	max-height: 160px;
	width: auto;
	max-width: 100%;
	object-fit: contain;
}
.services__softwares-note {
	margin: 0;
	font-family: var(--font-base);
	font-weight: 500;
	font-size: 14px;
	line-height: 1.6;
	color: var(--color-text);
	text-align: center;
}

/* ==========================================================================
   #6 料金プラン / Pricing (Figma 487:4554, 1440×2103, padding 80/10, gap 40)
   - 背景: #E9F1EE
   - 装飾: 488:7775 (左上 白), 488:7776 (右下 緑円)
   - h2 (490:3663): yen-icon + "Pricing" eyebrow + 「料金プラン」(40px Bold 緑、中央)
   - 税抜き注意書き (16px Medium center)
   - 「導入時」「毎月のご契約」サブセクション (緑バッジヘッダ + 説明)
       - クラウドカード (640×208 中央配置)
       - プランカード3つ (横並び、中央プラン -18pxせり上がり、緑円バッジ「おすすめ」)
   - 注意書きリスト + CTAボタン (黄色丸 500×72)
   ========================================================================== */
.pricing {
	position: relative;
	background: var(--color-bg-mint-lightest);
	padding: 80px 10px;
	display: flex;
	flex-direction: column;
	gap: 40px;
	overflow: hidden;
}
.pricing::before {
	content: "";
	position: absolute;
	left: -127px;
	top: 0;
	width: 527px;
	height: 309px;
	background-image: url('../../img/front/figma/pricing-deco-1-488-7775@2x.webp');
	background-size: contain;
	background-repeat: no-repeat;
	pointer-events: none;
	z-index: 0;
}
.pricing::after {
	content: "";
	position: absolute;
	right: -100px;
	bottom: -60px;
	width: 300px;
	height: 300px;
	background-image: url('../../img/front/figma/pricing-deco-2-488-7776@2x.webp');
	background-size: contain;
	background-repeat: no-repeat;
	pointer-events: none;
	z-index: 0;
}
.pricing__inner {
	position: relative;
	z-index: 1;
	max-width: 1000px;
	margin-inline: auto;
	width: 100%;
	display: flex;
	flex-direction: column;
	gap: 24px;
}
.pricing__head {
	display: flex;
	flex-direction: column;
	align-items: center;
	gap: 16px;
	text-align: center;
}
.pricing__icon { width: 64px; height: 64px; display: block; }
.pricing__eyebrow {
	margin: 0;
	font-family: var(--font-numeric);
	font-weight: 800;
	font-size: 16px;
	line-height: 1.4;
	letter-spacing: 0.06em;
	color: var(--color-primary);
}
.pricing__title {
	margin: 0;
	font-family: var(--font-base);
	font-weight: 700;
	font-size: 40px;
	line-height: 1.4;
	letter-spacing: 0.04em;
	color: var(--color-primary);
}

.pricing__body {
	display: flex;
	flex-direction: column;
	gap: 40px;
}
.pricing__tax-note {
	margin: 0;
	font-family: var(--font-base);
	font-weight: 500;
	font-size: 16px;
	line-height: 1.6;
	color: var(--color-text);
	text-align: center;
}

/* ===== サブセクション (導入時 / 毎月のご契約) ===== */
.pricing__sub {
	display: flex;
	flex-direction: column;
	gap: 24px;
}
.pricing__sub-head {
	display: flex;
	flex-direction: column;
	gap: 16px;
}
.pricing__sub-label {
	background: var(--color-primary);
	color: #fff;
	border-radius: 8px;
	padding: 4px 0;
	font-family: var(--font-base);
	font-weight: 700;
	font-size: 32px;
	line-height: 1.5;
	text-align: center;
}
.pricing__sub-desc {
	margin: 0;
	font-family: var(--font-base);
	font-weight: 500;
	font-size: 18px;
	line-height: 1.6;
	color: var(--color-text);
	text-align: center;
}
.pricing__sub-desc-emphasis {
	font-weight: 700;
	color: var(--color-primary);
}

/* ===== クラウドカード (Figma 487:4571, 640×208 中央) ===== */
.pricing__cloud {
	max-width: 640px;
	margin-inline: auto;
	width: 100%;
	background: #fff;
	border: 1px solid var(--color-primary);
	border-radius: 10px;
	padding: 32px 24px;
	display: flex;
	flex-direction: column;
	align-items: center;
	gap: 10px;
	text-align: center;
}
.pricing__cloud-name {
	margin: 0;
	font-family: var(--font-base);
	font-weight: 700;
	font-size: 26px;
	line-height: 1.6;
	color: var(--color-primary);
}
/* Figma Line 61: タイトルと説明の間の緑横ボーダー (stroke #40916C 2px, full width) */
.pricing__cloud-divider {
	width: 100%;
	height: 0;
	margin: 0;
	border: 0;
	border-top: 2px solid var(--color-primary);
}
.pricing__cloud-desc {
	margin: 0;
	font-family: var(--font-base);
	font-weight: 500;
	font-size: 14px;
	line-height: 1.6;
	color: var(--color-text);
}
.pricing__cloud-price {
	margin: 0;
	display: inline-flex;
	align-items: baseline;
	gap: 2px;
	color: var(--color-primary);
}
.pricing__cloud-num {
	font-family: var(--font-numeric);
	font-weight: 800;
	font-size: 36px;
	line-height: 1.4;
	color: var(--color-primary);
}
.pricing__cloud-unit {
	font-family: var(--font-numeric);
	font-weight: 800;
	font-size: 26px;
	line-height: 1.4;
	color: var(--color-primary);
}
.pricing__cloud-tilde {
	font-family: var(--font-numeric);
	font-weight: 800;
	font-size: 26px;
	line-height: 1.4;
	color: var(--color-primary);
	margin: 0 4px;
}
.pricing__cloud-frequency {
	margin-left: 6px;
	font-family: var(--font-base);
	font-weight: 500;
	font-size: 14px;
	line-height: 1.6;
	color: var(--color-text);
}

/* ===== プラン3つ (Figma 487:4585, horizontal, gap 23) ===== */
.pricing__plans {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: 23px;
	align-items: start;
	padding-top: 32px;
}
.plan-card {
	position: relative;
	background: #fff;
	border: 1px solid var(--color-primary);
	border-radius: 30px;
	padding: 32px 24px;
	display: flex;
	flex-direction: column;
	gap: 24px;
	transition: transform .3s ease, box-shadow .3s ease;
}
.plan-card:hover {
	transform: translateY(-6px);
	box-shadow: 0 14px 28px rgba(64, 145, 108, .15);
}
.plan-card.is-recommended {
	border: 5px solid var(--color-accent);
	padding: 48px 24px;
	margin-top: -18px;
}
.plan-card.is-recommended:hover {
	box-shadow: 0 14px 28px rgba(255, 198, 48, .3);
}
@media (prefers-reduced-motion: reduce) {
	.plan-card { transition: none; }
	.plan-card:hover { transform: none; box-shadow: none; }
}
.plan-card__badge {
	position: absolute;
	top: -31px;
	left: 50%;
	transform: translateX(-50%);
	width: 62px;
	height: 62px;
	background: var(--color-primary);
	border: 2px solid var(--color-primary);
	box-shadow: inset 0 0 0 2px #fff;
	border-radius: 50%;
	color: #fff;
	font-family: var(--font-base);
	font-weight: 700;
	font-size: 12px;
	line-height: 1.4;
	display: flex;
	align-items: center;
	justify-content: center;
}

.plan-card__header {
	display: flex;
	flex-direction: column;
	gap: 10px;
}
.plan-card__tagbox {
	background: var(--color-bg-mint-lightest);
	border-radius: 10px;
	padding: 6px 0;
	display: flex;
	flex-direction: column;
	align-items: center;
}
.plan-card.is-recommended .plan-card__tagbox {
	background: #FAF4DA;
}
.plan-card__tag {
	margin: 0;
	font-family: var(--font-base);
	font-weight: 700;
	font-size: 18px;
	line-height: 1.6;
	color: var(--color-text);
	text-align: center;
}
.plan-card__name {
	margin: 0;
	font-family: var(--font-base);
	font-weight: 700;
	font-size: 26px;
	line-height: 1.6;
	color: var(--color-primary);
	text-align: center;
}
.plan-card__desc {
	margin: 0;
	font-family: var(--font-base);
	font-weight: 500;
	font-size: 14px;
	line-height: 1.6;
	color: var(--color-text);
	text-align: center;
}

.plan-card__pricing {
	display: flex;
	flex-direction: column;
	align-items: center;
	gap: 4px;
}
.plan-card__price {
	margin: 0;
	display: inline-flex;
	align-items: baseline;
	gap: 2px;
	color: var(--color-primary);
}
.plan-card__price-num {
	font-family: var(--font-numeric);
	font-weight: 800;
	font-size: 36px;
	line-height: 1.4;
	color: var(--color-primary);
}
.plan-card__price-unit {
	font-family: var(--font-numeric);
	font-weight: 800;
	font-size: 26px;
	line-height: 1.4;
	color: var(--color-primary);
}
.plan-card__price-tilde {
	font-family: var(--font-numeric);
	font-weight: 800;
	font-size: 26px;
	line-height: 1.4;
	color: var(--color-primary);
	margin: 0 4px;
}
.plan-card__price-frequency {
	margin-left: 6px;
	font-family: var(--font-base);
	font-weight: 500;
	font-size: 14px;
	line-height: 1.6;
	color: var(--color-text);
}
.plan-card__init {
	margin: 0;
	font-family: var(--font-base);
	font-weight: 500;
	font-size: 12px;
	line-height: 1.4;
	color: var(--color-text);
	text-align: center;
}

/* ===== アコーディオン (Figma 495:3664 toggle-list) ===== */
.plan-card__accordions {
	display: flex;
	flex-direction: column;
	gap: 8px;
}
.plan-acc {
	background: #fff;
	border-radius: 8px;
	border: none;
}
.plan-acc__head {
	background: var(--color-bg-mint-lightest);
	border-radius: 8px;
	padding: 10px;
	font-family: var(--font-base);
	font-weight: 500;
	font-size: 14px;
	line-height: 1.6;
	color: var(--color-text);
	text-align: center;
	cursor: pointer;
	list-style: none;
	display: flex;
	align-items: center;
	justify-content: center;
	position: relative;
}
.plan-acc__head::-webkit-details-marker { display: none; }
.plan-acc__icon {
	position: absolute;
	right: 13px;
	top: 50%;
	transform: translateY(-50%);
	width: 16px;
	height: 16px;
	background: transparent;
}
.plan-acc__icon::before,
.plan-acc__icon::after {
	content: "";
	position: absolute;
	background: #9caaa4;
}
.plan-acc__icon::before {
	top: 50%;
	left: 0;
	width: 16px;
	height: 2px;
	transform: translateY(-50%);
}
.plan-acc__icon::after {
	top: 0;
	left: 50%;
	width: 2px;
	height: 16px;
	transform: translateX(-50%);
	transition: transform .25s ease;
}
.plan-acc[open] .plan-acc__icon::after { transform: translateX(-50%) scaleY(0); }
.plan-acc__body {
	padding: 8px 16px 0;
}

.plan-acc__list {
	list-style: none;
	padding: 0;
	margin: 0;
	display: flex;
	flex-direction: column;
	gap: 6px;
}
.plan-acc__item {
	display: flex;
	align-items: center;
	gap: 8px;
	font-family: var(--font-base);
	font-weight: 500;
	font-size: 14px;
	line-height: 1.6;
	color: var(--color-text);
	white-space: nowrap;
}
.plan-acc__check {
	flex-shrink: 0;
	width: 16px;
	height: 16px;
	display: inline-flex;
	align-items: center;
	justify-content: center;
}
.plan-acc__check svg { display: block; width: 16px; height: 16px; }

.plan-acc__limits {
	list-style: none;
	padding: 0;
	margin: 0;
	display: flex;
	flex-direction: column;
	gap: 6px;
}
.plan-acc__limit-item {
	display: flex;
	justify-content: space-between;
	align-items: baseline;
	gap: 8px;
	font-family: var(--font-base);
	font-size: 14px;
	line-height: 1.6;
	color: var(--color-text);
	padding: 4px 0;
	border-bottom: 1px dashed var(--color-border);
}
.plan-acc__limit-label { font-weight: 500; }
.plan-acc__limit-value { font-weight: 700; color: var(--color-primary); }

/* ===== 注意書きリスト (487:4664) ===== */
.pricing__notes {
	list-style: none;
	padding: 0;
	margin: 0;
	display: flex;
	flex-direction: column;
	gap: 4px;
}
.pricing__notes li {
	font-family: var(--font-base);
	font-weight: 500;
	font-size: 14px;
	line-height: 1.6;
	color: var(--color-text-warm);
}

/* ===== CTAボタン (Figma 487:4668, 500×72)
 * cta-banner__btn / hero__btn と同じ立体装飾コンポーネント
 * 黄ピル + 内側ハイライト(blur) + 白1px枠 + mail-icon + 右端の黒丸+黄三角 ===== */
.pricing__cta {
	position: relative;
	z-index: 1;
	display: flex;
	justify-content: center;
}
.pricing__btn {
	position: relative;
	display: inline-block;
	width: 500px; height: 72px;
	border-radius: 9999px;
	background: var(--color-accent);
	color: var(--color-text-warm);
	font-family: var(--font-base);
	font-weight: 700;
	text-decoration: none;
	box-shadow: var(--shadow-md);
	transition: transform .2s ease, box-shadow .25s ease, background .25s ease;
	cursor: pointer;
}
.pricing__btn:hover {
	background: var(--color-accent-warm);
	transform: translateY(-2px);
	box-shadow: 0 8px 18px rgba(61, 91, 98, .25);
}
.pricing__btn-highlight {
	position: absolute;
	inset: 4px 6px;
	border-radius: 9999px;
	background: linear-gradient(to bottom, rgba(255,255,255,.55), rgba(255,255,255,0));
	filter: blur(8px);
	pointer-events: none;
	z-index: 0;
}
.pricing__btn-frame {
	position: absolute;
	inset: 4px 6px;
	border: 1px solid #fff;
	border-radius: 9999px;
	display: flex; align-items: center; justify-content: center;
	gap: 8px;
	z-index: 1;
}
.pricing__btn-icon {
	display: inline-flex; align-items: center; justify-content: center;
	width: 32px; height: 32px;
	transform: translateY(1px);
}
.pricing__btn-icon img {
	width: 28px; height: 22px;
	display: block;
}
.pricing__btn-label {
	font-size: 18px;
	line-height: 1.6;
	color: #494439;
	letter-spacing: 0.04em;
}
.pricing__btn-label--sp { display: none; }
.pricing__btn-arrow {
	position: absolute;
	right: 18px; top: 50%;
	width: 12px; height: 12px;
	margin-top: -6px;
	background: #494439;
	border-radius: 50%;
	pointer-events: none;
}
.pricing__btn-arrow::before {
	content: "";
	position: absolute;
	left: 50%; top: 50%;
	transform: translate(-30%, -50%);
	width: 0; height: 0;
	border-style: solid;
	border-width: 2.5px 0 2.5px 4px;
	border-color: transparent transparent transparent var(--color-accent);
}

/* ==========================================================================
   #7 比較表 (Figma 487:4680, 1440×720, bg white)
   ========================================================================== */
.cost-compare {
	position: relative;
	background: #fff;
	padding: 80px 10px;
	overflow: hidden;
}
.cost-compare::after {
	content: ""; position: absolute;
	left: -86px; bottom: 20px;
	width: 240px; height: 240px;
	background-image: url('../../img/front/figma/compare-deco-488-7794@2x.webp');
	background-size: contain; background-repeat: no-repeat;
	pointer-events: none; opacity: .8;
	z-index: 0;
}
.cost-compare__container {
	max-width: 1000px; margin-inline: auto;
	position: relative; z-index: 1;
	display: flex; flex-direction: column; gap: 64px;
}
.cost-compare__head {
	display: flex; flex-direction: column; align-items: center;
	gap: 24px;
}
.cost-compare__eyebrow {
	font-family: var(--font-numeric);
	font-weight: 800;
	font-size: 16px;
	color: var(--color-primary);
	letter-spacing: .04em;
	margin: 0;
}
.cost-compare__title {
	display: flex;
	align-items: center;
	justify-content: center;
	gap: 16px;
	flex-wrap: wrap;
	font-family: var(--font-base);
	font-weight: 700;
	font-size: 40px; line-height: 1.4;
	color: var(--color-text);
	margin: 0;
}
.cost-compare__title-logo {
	height: 2em;
	width: auto;
	display: inline-block;
	object-fit: contain;
	vertical-align: middle;
	position: relative;
	top: 4px;
}
.cost-compare__title-brand { color: var(--color-primary); }
.cost-compare__title-text { display: inline-block; }
.cost-compare__desc {
	font-size: 18px; line-height: 1.6; font-weight: 500;
	color: var(--color-text); text-align: center;
	margin: 0;
}

.cost-compare__matrix {
	display: grid;
	grid-template-columns: 156px 1fr;
	gap: 0;
	align-items: start;
	position: relative;
}
.cost-compare__matrix::before,
.cost-compare__matrix::after {
	content: "";
	position: absolute;
	left: 0; right: 0;
	height: 2px;
	background: var(--color-primary);
	pointer-events: none;
	z-index: 2;
}
.cost-compare__matrix::before { top: 54px; }
.cost-compare__matrix::after  { top: 134px; }
.cost-compare__rowlabels {
	padding-top: 54px;
	display: flex; flex-direction: column;
	gap: 0;
}
.cost-compare__rowlabel {
	min-height: 80px;
	padding: 15px 6px;
	box-sizing: border-box;
	display: flex; flex-direction: column; justify-content: center;
}
.cost-compare__rowlabel strong {
	font-size: 16px; font-weight: 700; color: #2c3e2d;
	line-height: 1.5;
}
.cost-compare__rowlabel small {
	display: block;
	font-size: 12px; font-weight: 500;
	color: var(--color-text);
	margin-top: 2px;
	line-height: 1.5;
	white-space: nowrap;
}

.cost-compare__plans {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: 16px;
}
.cost-compare__plan {
	display: grid;
	grid-template-columns: minmax(0, 1fr) minmax(0, 1fr);
	gap: 4px;
	align-items: stretch;
}
.cost-compare__col {
	border-radius: 10px;
	display: flex; flex-direction: column;
	box-sizing: border-box;
	height: 100%;
}
.cost-compare__col--service {
	background: var(--color-bg-mint-lightest);
	border: 4px solid var(--color-primary);
}
.cost-compare__plan.is-recommended .cost-compare__col--service {
	background: #faf4da;
	border-color: var(--color-accent);
}
.cost-compare__col--hire {
	background: transparent;
	border: 1px solid #9caaa4;
}
.cost-compare__col-head {
	min-height: 54px;
	padding: 14px 4px;
	display: flex; align-items: center; justify-content: center;
	text-align: center;
	box-sizing: border-box;
	white-space: nowrap;
}
.cost-compare__col--service .cost-compare__col-head {
	color: var(--color-primary);
	font-size: 16px; font-weight: 700;
	line-height: 1.4;
}
.cost-compare__col--hire .cost-compare__col-head {
	min-height: 50px;
	color: #2c3e2d;
	font-size: 14px; font-weight: 500;
	line-height: 1.4;
}
.cost-compare__col-cell {
	min-height: 80px;
	padding: 16px 8px;
	display: flex; flex-direction: column;
	align-items: center; justify-content: center;
	text-align: center;
	gap: 2px;
	box-sizing: border-box;
}
@media (min-width: 901px) {
	.cost-compare__col--hire .cost-compare__col-head {
		position: relative;
		top: 4px;
	}
	.cost-compare__col--hire .cost-compare__col-cell {
		padding-top: 23px;
		padding-bottom: 9px;
	}
	.cost-compare__col--hire .cost-compare__col-head + .cost-compare__col-cell + .cost-compare__col-cell {
		padding-top: 33px;
		padding-bottom: 0;
	}
}
.cost-compare__col-cell::before {
	content: attr(data-row);
	display: none;
}
.cost-compare__col--service .cost-compare__col-cell .cost-compare__price {
	color: var(--color-primary);
	font-size: 18px; font-weight: 800;
	line-height: 1.4;
}
.cost-compare__col--hire .cost-compare__col-cell .cost-compare__price {
	color: #2c3e2d;
	font-size: 16px; font-weight: 500;
	line-height: 1.4;
}
.cost-compare__price-sub {
	display: block;
	font-size: 11px; font-weight: 500;
	color: var(--color-text);
	line-height: 1.4;
	white-space: nowrap;
	letter-spacing: -0.04em;
	text-align: center;
}

.cost-compare__notes {
	list-style: none; padding: 0; margin: 0;
	display: flex; flex-direction: column; gap: 4px;
	font-size: 14px; font-weight: 500;
	color: var(--color-text-warm);
	text-align: left;
}
.cost-compare__notes li { margin: 0; }

/* ==========================================================================
   #8 ご利用の流れ (Figma 488:7219, 1440×836, white + 罫線背景)
   ========================================================================== */
.flow {
	position: relative;
	background-color: #fff;
	background-image: url('../../img/front/figma/flow-bgnote-487-7120@2x.png');
	background-size: 1440px auto;
	background-position: center top;
	background-repeat: repeat;
	padding: 80px 10px;
}
.flow__container {
	max-width: 1000px; margin-inline: auto;
	display: flex; flex-direction: column; gap: 64px;
	position: relative; z-index: 1;
}
.flow__head {
	display: flex; flex-direction: column; align-items: center;
	gap: 8px;
	text-align: center;
}
.flow__eyebrow {
	font-family: var(--font-numeric);
	font-weight: 800;
	font-size: 16px;
	color: var(--color-primary);
	letter-spacing: .04em;
	margin: 0;
}
.flow__title {
	font-family: var(--font-base);
	font-weight: 700;
	font-size: 40px; line-height: 1.4;
	color: var(--color-primary);
	margin: 0;
}
.flow__lead {
	font-family: var(--font-base);
	font-weight: 700;
	font-size: 22px; line-height: 1.7;
	color: var(--color-primary);
	margin: 24px 0 0;
}
.flow__intro {
	font-size: 18px; line-height: 1.6; font-weight: 500;
	color: var(--color-text);
	margin: 4px 0 0;
}
.flow__steps {
	display: grid;
	grid-template-columns: repeat(4, 1fr);
	gap: 32px;
	position: relative;
}
.flow__steps::before {
	content: "";
	position: absolute;
	top: 25px;
	left: calc((100% - 32px * 3) / 8);
	right: calc((100% - 32px * 3) / 8);
	height: 5px;
	background: none;
	background-image: radial-gradient(circle, var(--color-primary) 2px, transparent 2.5px);
	background-size: 9px 5px;
	background-repeat: repeat-x;
	background-position: 0 center;
	z-index: 0;
	pointer-events: none;
}
.flow-step {
	display: flex; flex-direction: column; gap: 17px; align-items: center;
	position: relative;
	z-index: 1;
}
.flow-step__num {
	width: 50px; height: 50px;
	border-radius: 50%;
	background: var(--color-primary);
	color: #fff;
	font-family: var(--font-numeric);
	font-weight: 800;
	font-size: 26px;
	line-height: 1;
	display: flex; align-items: center; justify-content: center;
	flex-shrink: 0;
}
.flow-step__body {
	display: flex; flex-direction: column; gap: 24px; align-items: center;
	width: 100%;
}
.flow-step__icon {
	width: 140px; height: 120px;
	background: #fff;
	display: flex; align-items: center; justify-content: center;
	flex-shrink: 0;
}
.flow-step__icon img {
	width: 140px; height: 120px;
	object-fit: contain;
}
.flow-step__textwrap {
	display: flex; flex-direction: column; gap: 8px;
	width: 100%;
}
.flow-step__label {
	background: var(--color-primary);
	color: #fff;
	border-radius: 6px;
	padding: 4px 8px;
	font-size: 18px; font-weight: 700;
	line-height: 1.5;
	text-align: center;
}
.flow-step__desc {
	font-size: 14px; font-weight: 500;
	line-height: 1.7;
	color: var(--color-text);
	text-align: left;
	margin: 0;
}
.flow__cta { display: flex; justify-content: center; }
/* CTAボタン (Figma 487:4732, 500×72)
 * cta-banner__btn / hero__btn と同じ立体装飾コンポーネント
 * 黄ピル + 内側ハイライト(blur) + 白1px枠 + mail-icon + 右端の黒丸+黄三角 */
.flow__btn {
	position: relative;
	display: inline-block;
	width: 500px; height: 72px;
	border-radius: 9999px;
	background: var(--color-accent);
	color: var(--color-text-warm);
	font-family: var(--font-base);
	font-weight: 700;
	text-decoration: none;
	box-shadow: var(--shadow-md);
	transition: transform .2s ease, box-shadow .25s ease, background .25s ease;
	cursor: pointer;
}
.flow__btn:hover {
	background: var(--color-accent-warm);
	transform: translateY(-2px);
	box-shadow: 0 8px 18px rgba(61, 91, 98, .25);
}
.flow__btn-highlight {
	position: absolute;
	inset: 4px 6px;
	border-radius: 9999px;
	background: linear-gradient(to bottom, rgba(255,255,255,.55), rgba(255,255,255,0));
	filter: blur(8px);
	pointer-events: none;
	z-index: 0;
}
.flow__btn-frame {
	position: absolute;
	inset: 4px 6px;
	border: 1px solid #fff;
	border-radius: 9999px;
	display: flex; align-items: center; justify-content: center;
	gap: 8px;
	z-index: 1;
}
.flow__btn-icon {
	display: inline-flex; align-items: center; justify-content: center;
	width: 32px; height: 32px;
	transform: translateY(1px);
}
.flow__btn-icon img {
	width: 28px; height: 22px;
	display: block;
}
.flow__btn-label {
	font-size: 18px;
	line-height: 1.6;
	color: #494439;
	letter-spacing: 0.04em;
}
.flow__btn-arrow {
	position: absolute;
	right: 18px; top: 50%;
	width: 12px; height: 12px;
	margin-top: -6px;
	background: #494439;
	border-radius: 50%;
	pointer-events: none;
}
.flow__btn-arrow::before {
	content: "";
	position: absolute;
	left: 50%; top: 50%;
	transform: translate(-30%, -50%);
	width: 0; height: 0;
	border-style: solid;
	border-width: 2.5px 0 2.5px 4px;
	border-color: transparent transparent transparent var(--color-accent);
}

/* ==========================================================================
   #9 FAQ (Figma 487:4743, 1440×1808, bg #E9F1EE, container 840px)
   ========================================================================== */
.faq {
	background: var(--color-bg-mint-lightest);
	padding: 80px 10px;
}
.faq__container {
	max-width: 840px; margin-inline: auto;
	display: flex; flex-direction: column; gap: 64px;
}
.faq__head {
	display: flex; flex-direction: column; align-items: center;
	gap: 8px;
	text-align: center;
}
.faq__eyebrow {
	font-family: var(--font-numeric);
	font-weight: 800;
	font-size: 16px;
	color: var(--color-primary);
	letter-spacing: .04em;
	margin: 0;
}
.faq__title {
	font-family: var(--font-base);
	font-weight: 700;
	font-size: 40px; line-height: 1.4;
	color: var(--color-text);
	margin: 0;
}
.faq__list { display: flex; flex-direction: column; gap: 24px; }
.faq-item {
	background: #fff;
	border-radius: 10px;
	overflow: hidden;
}
.faq-item__question {
	width: 100%;
	display: flex; align-items: center; gap: 24px;
	padding: 24px 48px;
	background: none; border: none; cursor: pointer;
	font-family: inherit; text-align: left;
	color: var(--color-text);
	font-size: 18px; font-weight: 700; line-height: 1.6;
}
.faq-item__q-icon {
	flex-shrink: 0;
	width: 48px; height: 48px;
	background: var(--color-primary);
	color: #fff;
	border-radius: 50%;
	display: flex; align-items: center; justify-content: center;
	font-family: var(--font-numeric);
	font-weight: 800;
	font-size: 25px;
	line-height: 1;
}
.faq-item__q-text { flex: 1; }
.faq-item__toggle {
	flex-shrink: 0;
	width: 36px; height: 36px;
	position: relative;
	display: inline-block;
	background: var(--color-primary);
	border-radius: 50%;
}
.faq-item__toggle-bar {
	position: absolute;
	left: 50%; top: 50%;
	width: 18px; height: 2.5px;
	background: #fff;
	border-radius: 2px;
	transform-origin: center;
	transition: transform .25s ease, opacity .25s ease;
}
.faq-item__toggle-bar--h {
	transform: translate(-50%, -50%);
}
.faq-item__toggle-bar--v {
	transform: translate(-50%, -50%) rotate(90deg);
}
.faq-item.is-open .faq-item__toggle-bar--h {
	transform: translate(-50%, -50%);
}
.faq-item.is-open .faq-item__toggle-bar--v {
	transform: translate(-50%, -50%) rotate(90deg) scaleX(0);
	opacity: 0;
}
.faq-item__answer {
	max-height: 0; overflow: hidden;
	transition: max-height .4s ease;
}
.faq-item.is-open .faq-item__answer { max-height: 800px; }
.faq-item__answer-divider {
	height: 1px;
	background: #9caaa4;
	margin: 0 48px;
}
.faq-item__answer-row {
	display: flex;
	align-items: flex-start;
	gap: 16px;
	padding: 24px 48px;
}
.faq-item__a-icon {
	flex-shrink: 0;
	width: 48px; height: 48px;
	border: 1px solid var(--color-primary);
	color: var(--color-primary);
	background: #fff;
	border-radius: 50%;
	display: flex; align-items: center; justify-content: center;
	font-family: var(--font-numeric);
	font-weight: 800;
	font-size: 25px;
	line-height: 1;
}
.faq-item__answer-text {
	flex: 1;
	font-size: 14px; font-weight: 500; line-height: 1.7;
	color: var(--color-text);
	padding-top: 12px;
}

/* ==========================================================================
   #10 お客様の声 (Figma 490:5350, 1440×609, white + 罫線(#c5f1e0))
   ========================================================================== */
.voice {
	background-color: #fff;
	background-image: url('../../img/front/figma/voice-bgnote-490-5092@2x.png');
	background-size: 1440px auto;
	background-position: center top;
	background-repeat: repeat;
	padding: 80px 10px;
}
.voice__container {
	max-width: 1000px; margin-inline: auto;
	position: relative; z-index: 1;
	display: flex; flex-direction: column; gap: 40px;
}
.voice__head {
	display: flex; flex-direction: column; align-items: center;
	gap: 8px;
	text-align: center;
}
.voice__eyebrow {
	font-family: var(--font-numeric);
	font-weight: 800;
	font-size: 16px;
	color: var(--color-primary);
	letter-spacing: .04em;
	margin: 0;
}
.voice__title {
	font-family: var(--font-base);
	font-weight: 700;
	font-size: 40px; line-height: 1.4;
	color: var(--color-text);
	margin: 0;
}
.voice__body {
	display: flex; flex-direction: column;
	gap: 24px;
}
.voice__cards {
	display: grid;
	grid-template-columns: repeat(2, 1fr);
	gap: 23px;
}
.voice-card {
	background: var(--color-bg-mint-lightest);
	border: 1px solid var(--color-primary);
	border-radius: 10px;
	padding: 32px 24px;
	display: flex;
	flex-direction: column;
	gap: 8px;
}
.voice-card__stars {
	color: #f0b429;
	font-family: var(--font-numeric);
	font-weight: 800;
	font-size: 26px;
	line-height: 1.4;
	letter-spacing: .02em;
	margin: 0;
}
.voice-card__body {
	display: flex; flex-direction: column;
	gap: 14px;
}
.voice-card__text {
	font-size: 18px; font-weight: 700;
	line-height: 1.6;
	color: var(--color-primary);
	margin: 0;
}
.voice-card__meta {
	display: flex; align-items: center; gap: 10px;
	font-size: 14px; font-weight: 500;
	color: var(--color-text);
	line-height: 1.6;
}
.voice-card__avatar {
	flex-shrink: 0;
	width: 44px; height: 44px;
	border-radius: 50%;
	display: block;
}
.voice-card__avatar--placeholder {
	background: var(--color-accent);
}
.voice-card__meta-text { display: inline-block; }
.voice__placeholder {
	font-size: 16px; font-weight: 500;
	line-height: 1.6;
	color: var(--color-text);
	text-align: center;
	margin: 0;
}

/* ==========================================================================
   #11 コラム (Figma 540:3847, 1440×730, bg #E9F1EE)
   ========================================================================== */
.column {
	background: var(--color-bg-mint-lightest);
	padding: 80px 10px;
}
.column__container {
	max-width: 1000px; margin-inline: auto;
	display: flex; flex-direction: column; gap: 64px;
}
.column__head {
	display: flex; flex-direction: column; align-items: center;
	gap: 8px;
	text-align: center;
}
.column__eyebrow {
	font-family: var(--font-numeric);
	font-weight: 800;
	font-size: 16px;
	color: var(--color-primary);
	letter-spacing: .04em;
	margin: 0;
}
.column__title {
	font-family: var(--font-base);
	font-weight: 700;
	font-size: 40px; line-height: 1.4;
	color: var(--color-text);
	margin: 0;
}
.column__grid {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: 24px;
}
.column-card {
	background: transparent;
	display: flex;
	flex-direction: column;
	gap: 16px;
	color: var(--color-text);
	text-decoration: none;
	transition: transform .25s ease;
}
.column-card[href]:hover { transform: translateY(-4px); }
.column-card__thumb {
	aspect-ratio: 317 / 209;
	overflow: hidden;
	border-radius: 10px;
	background: #d9d9d9;
}
.column-card__thumb img { width: 100%; height: 100%; object-fit: cover; display: block; }
.column-card__placeholder {
	width: 100%; height: 100%;
	background: #d9d9d9;
}
.column-card__body {
	display: flex; flex-direction: column;
	gap: 32px;
}
.column-card__head {
	display: flex; flex-direction: column;
	gap: 6px;
}
.column-card__meta {
	display: flex; align-items: center; gap: 12px;
}
.column-card__date {
	font-size: 12px; font-weight: 500;
	color: var(--color-text);
	line-height: 1.4;
}
.column-card__cat {
	background: var(--color-primary);
	color: #fff;
	padding: 2px 12px;
	border-radius: 9999px;
	font-size: 12px; font-weight: 500;
	line-height: 1.4;
}
.column-card__title {
	font-size: 18px; font-weight: 500;
	line-height: 1.6;
	color: var(--color-text);
	margin: 0;
}
.column-card__supervisor {
	display: flex; align-items: center;
	gap: 6px;
}
.column-card__avatar {
	flex-shrink: 0;
	width: 38px; height: 38px;
	border-radius: 50%;
	background: #d9d9d9;
	overflow: hidden;
}
.column-card__avatar--has-image { background: transparent; }
.column-card__avatar img {
	width: 100%; height: 100%;
	object-fit: cover;
	display: block;
}
.column-card__supervisor-text {
	font-size: 14px; font-weight: 500;
	color: var(--color-text);
	line-height: 1.6;
}
.column__cta { display: flex; justify-content: center; }
.column__cta .btn-outline {
	display: inline-flex; align-items: center; justify-content: center;
	gap: 7px;
	background: transparent;
	color: var(--color-primary);
	border: 1px solid var(--color-primary);
	padding: 17px 18px;
	border-radius: 9999px;
	font-size: 14px;
	font-weight: 700;
	text-decoration: none;
	min-width: 300px;
	box-sizing: border-box;
	transition: background-color .25s ease, color .25s ease;
}
.column__cta .btn-outline:hover {
	background: var(--color-primary);
	color: #fff;
}
.column__cta .btn-outline:hover .column__btn-arrow { background: #fff; }
.column__cta .btn-outline:hover .column__btn-arrow::after { border-left-color: var(--color-primary); }
.column__btn-arrow {
	display: inline-block;
	width: 9px; height: 9px;
	border-radius: 50%;
	background: var(--color-primary);
	position: relative;
	transition: background-color .25s ease;
}
.column__btn-arrow::after {
	content: "";
	position: absolute;
	left: 3px; top: 50%;
	width: 0; height: 0;
	border-top: 2px solid transparent;
	border-bottom: 2px solid transparent;
	border-left: 3px solid #fff;
	transform: translateY(-50%);
	transition: border-left-color .25s ease;
}

/* ==========================================================================
   #12 CTA banner (Figma 488:8126, 1440×293, bg #40916c + 装飾)
   ========================================================================== */
.cta-banner {
	position: relative;
	width: 100%;
	background: var(--color-primary);
	padding: 80px 0;
	overflow: hidden;
	color: #fff;
}
/* 装飾4要素: Figma FV-bg (488:8128) 内の Vector / Group を SVG 化して個別配置
   1440px 中央コンテナで Figma 絶対座標を再現 */
.cta-banner__deco-wrap {
	position: absolute;
	top: 0; left: 50%;
	transform: translateX(-50%);
	width: 1440px; height: 100%;
	pointer-events: none;
	z-index: 0;
}
.cta-banner__deco {
	position: absolute;
	background-repeat: no-repeat;
	background-size: 100% 100%;
	pointer-events: none;
}
.cta-banner__deco--arc-tr {
	left: 985px; top: -91px;
	width: 527px; height: 294px;
	background-image: url('../../img/front/figma/cta-deco-arc-tr-488-8129.svg');
}
.cta-banner__deco--arc-bl {
	left: -203px; top: 98px;
	width: 552px; height: 286px;
	background-image: url('../../img/front/figma/cta-deco-arc-bl-488-8130.svg');
}
.cta-banner__deco--stairs {
	left: -35px; top: -5px;
	width: 140px; height: 133px;
	background-image: url('../../img/front/figma/cta-deco-stairs-488-8131.svg');
}
.cta-banner__deco--arc-br {
	left: 490px; top: 62px;
	width: 1079px; height: 790px;
	background-image: url('../../img/front/figma/cta-deco-arc-br-488-8149.svg');
}
.cta-banner__inner {
	position: relative; z-index: 1;
	max-width: 1000px; margin-inline: auto; padding-inline: 24px;
	display: flex; flex-direction: column; align-items: center;
	gap: 24px; text-align: center;
}
.cta-banner__title {
	display: block;
	font-family: var(--font-base);
	font-size: 32px;
	font-weight: 700;
	line-height: 1.5;
	color: #fff;
	letter-spacing: 0.04em;
	text-shadow: none;
	animation: none;
}

/* CTA専用ボタン (Figma 487:4790, 500×72) */
.cta-banner__btn {
	position: relative;
	display: inline-block;
	width: 500px; height: 72px;
	border-radius: 9999px;
	background: var(--color-accent);
	color: var(--color-text-warm);
	font-family: var(--font-base);
	font-weight: 700;
	text-decoration: none;
	box-shadow: var(--shadow-md);
	transition: transform .2s ease, box-shadow .25s ease, background .25s ease;
	cursor: pointer;
}
.cta-banner__btn:hover {
	background: var(--color-accent-warm);
	transform: translateY(-2px);
	box-shadow: 0 8px 18px rgba(61, 91, 98, .25);
}
/* 内側ハイライト (Figma GRADIENT_LINEAR opacity 0.55 + LAYER_BLUR 8) */
.cta-banner__btn-highlight {
	position: absolute;
	inset: 4px 6px;
	border-radius: 9999px;
	background: linear-gradient(to bottom, rgba(255,255,255,.55), rgba(255,255,255,0));
	filter: blur(8px);
	pointer-events: none;
	z-index: 0;
}
/* 内側 487×64 + 白1px枠 (Figma の二重枠) */
.cta-banner__btn-frame {
	position: absolute;
	inset: 4px 6px;
	border: 1px solid #fff;
	border-radius: 9999px;
	display: flex; align-items: center; justify-content: center;
	gap: 8px;
	z-index: 1;
}
.cta-banner__btn-icon {
	display: inline-flex; align-items: center; justify-content: center;
	width: 32px; height: 32px;
	transform: translateY(1px);
}
.cta-banner__btn-icon img {
	width: 28px; height: 22px;
	display: block;
}
.cta-banner__btn-label {
	font-size: 18px;
	line-height: 1.6;
	color: #494439;
	letter-spacing: 0.04em;
}
/* 右端の黒丸 + 黄三角 (Figma の Group 163103) */
.cta-banner__btn-arrow {
	position: absolute;
	right: 18px; top: 50%;
	width: 12px; height: 12px;
	margin-top: -6px;
	background: #494439;
	border-radius: 50%;
	pointer-events: none;
}
.cta-banner__btn-arrow::before {
	content: "";
	position: absolute;
	left: 50%; top: 50%;
	transform: translate(-30%, -50%);
	width: 0; height: 0;
	border-style: solid;
	border-width: 2.5px 0 2.5px 4px;
	border-color: transparent transparent transparent var(--color-accent);
}

/* ==========================================================================
   #13 運営について (Figma 490:5351, 1440×840, white + 罫線)
   ========================================================================== */
.company {
	background-color: #fff;
	background-image: url('../../img/front/figma/company-bgnote-490-5191@2x.webp');
	background-size: 1440px auto;
	background-position: center top;
	background-repeat: repeat;
	padding: 80px 10px;
}
.company__inner {
	max-width: 1000px; margin-inline: auto;
	display: flex; flex-direction: column; gap: 40px;
	align-items: center;
}
.company__head {
	display: flex; flex-direction: column; align-items: center; gap: 8px;
}
.company__eyebrow {
	font-family: var(--font-numeric);
	font-weight: 800;
	font-size: 16px;
	line-height: 1.4;
	color: var(--color-primary);
	letter-spacing: 0.06em;
}
.company__title {
	font-family: var(--font-base);
	font-weight: 700;
	font-size: 40px;
	line-height: 1.4;
	color: var(--color-text);
	letter-spacing: 0.04em;
	text-align: center;
}
.company__cols {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 24px;
	width: 100%;
}
.company-card {
	background: var(--color-bg-mint-lightest);
	border-radius: 10px;
	padding: 24px 24px 32px;
	display: flex; flex-direction: column; gap: 24px;
	align-items: center;
}
.company-card__title {
	font-family: var(--font-base);
	font-size: 22px;
	font-weight: 700;
	line-height: 1.8;
	color: var(--color-primary);
	text-align: center;
	margin: 0;
}
.company-list {
	width: 100%;
	margin: 0;
	display: flex; flex-direction: column;
}
.company-list__row {
	display: flex;
	gap: 10px;
	align-items: flex-start;
	padding: 20px 0;
	border-bottom: 1px solid #9caaa4;
}
.company-list__row--compact { padding: 16px 0; }
.company-list__label {
	flex: 0 0 120px;
	font-family: var(--font-base);
	font-size: 14px;
	font-weight: 700;
	line-height: 1.6;
	color: var(--color-text-warm);
	margin: 0;
}
.company-list__value {
	flex: 1;
	font-family: var(--font-base);
	font-size: 14px;
	font-weight: 500;
	line-height: 1.6;
	color: var(--color-text-warm);
	margin: 0;
}

/* 略歴・認定 (右カラムのみ) */
.company-card__profile {
	width: 100%;
	display: flex; flex-direction: column; gap: 16px;
}
.company-card__profile p {
	font-family: var(--font-base);
	font-size: 14px;
	font-weight: 500;
	line-height: 1.6;
	color: var(--color-text);
	margin: 0;
}
.company-cert {
	background: #fff;
	border-radius: 10px;
	padding: 16px 24px;
	display: flex; align-items: center; gap: 20px;
}
.company-cert__logo {
	flex: 0 0 80px;
	width: 80px; height: 80px;
	object-fit: contain;
	display: block;
}
.company-cert__body {
	display: flex; flex-direction: column; gap: 6px;
	flex: 1;
}
.company-cert__title {
	font-family: var(--font-base);
	font-size: 14px;
	font-weight: 500;
	line-height: 1.6;
	color: var(--color-primary);
	margin: 0;
}
.company-cert__desc {
	font-family: var(--font-base);
	font-size: 12px;
	font-weight: 500;
	line-height: 1.6;
	color: var(--color-text);
	margin: 0;
}

/* ==========================================================================
   #14 無料相談 / Contact (Figma 487:4833, 1440×1241, bg #E9F1EE, container 840px)
   ========================================================================== */
.contact {
	background: var(--color-bg-mint-lightest);
	padding: 80px 10px;
}
.contact__inner {
	max-width: 840px; margin-inline: auto;
	display: flex; flex-direction: column; gap: 64px;
	align-items: center;
}
.contact__head {
	display: flex; flex-direction: column; align-items: center; gap: 24px;
	width: 100%;
}
.contact__eyebrow {
	font-family: var(--font-numeric);
	font-weight: 800;
	font-size: 16px;
	line-height: 1.4;
	color: var(--color-primary);
	letter-spacing: 0.06em;
}
.contact__title {
	font-family: var(--font-base);
	font-weight: 700;
	font-size: 40px;
	line-height: 1.4;
	color: var(--color-text);
	letter-spacing: 0.04em;
	text-align: center;
	margin: 0;
}
.contact__lead {
	font-family: var(--font-base);
	font-size: 18px;
	font-weight: 500;
	line-height: 1.6;
	color: var(--color-text);
	text-align: center;
	margin: 0;
}
.contact__panel {
	background: #fff;
	border-radius: 10px;
	padding: 40px;
	width: 100%;
	box-sizing: border-box;
	min-width: 0;
	display: flex; flex-direction: column; gap: 32px;
	/* align-items は stretch（デフォルト）にして子フォームが panel 幅に収まるようにする。
	   center だと CF7 が生成する <input size="40"> の intrinsic min-content (約500px)
	   が cross-axis sizing を支配し、SP で panel をはみ出す。送信ボタンは
	   .contact__submit 側で `align-self: center` を指定しているため中央配置を維持する。 */
	align-items: stretch;
}
/* CF7 / fallback 共通フォームスタイル */
.contact__form,
.contact__panel .wpcf7-form {
	width: 100%;
	box-sizing: border-box;
	min-width: 0;
	display: flex; flex-direction: column; gap: 16px;
}
/* CF7 が <input> を <span class="wpcf7-form-control-wrap"> でラップするため、
   span が inline のままだと子 input の width:100% が span の文字幅に依存して
   機能せず、UA デフォルトの size 属性ベース幅 (例: size=40 → 約500px) が
   そのまま flex item の min-content として親を突き抜けてしまう。block 化 +
   width:100% + min-width:0 で確実に親幅へ収める。 */
.contact__panel .wpcf7-form-control-wrap {
	display: block;
	width: 100%;
	min-width: 0;
}
/* CF7 6.x が hidden input を fieldset.hidden-fields-container でラップして出力するため、
   デフォルト CSS 無効化 (wpcf7_load_css=false) の影響で fieldset の枠線が見えてしまう。
   送信に必要な input は内部に含まれているので非表示にする。 */
.contact__panel .wpcf7-form .hidden-fields-container {
	display: none;
}
.contact__field,
.contact__panel .wpcf7-form > p {
	display: flex; flex-direction: column; gap: 8px;
	margin: 0;
	width: 100%;
	box-sizing: border-box;
	min-width: 0;
}
.contact__label-row {
	display: flex; align-items: center; gap: 8px;
}
.contact__label,
.contact__panel .wpcf7-form label {
	font-family: var(--font-base);
	font-size: 16px;
	font-weight: 700;
	line-height: 1.6;
	color: var(--color-text);
	margin: 0;
}
.contact__badge {
	font-family: var(--font-base);
	font-size: 12px;
	font-weight: 700;
	line-height: 1.2;
	border-radius: 2px;
	padding: 3px 9px;
	display: inline-flex; align-items: center; justify-content: center;
}
.contact__badge--required {
	background: var(--color-primary);
	color: #fff;
}
.contact__badge--optional {
	background: transparent;
	color: var(--color-primary);
	border: 1px solid var(--color-primary);
}
.contact__input,
.contact__textarea,
.contact__panel .wpcf7-form input[type="text"],
.contact__panel .wpcf7-form input[type="email"],
.contact__panel .wpcf7-form input[type="tel"],
.contact__panel .wpcf7-form input[type="url"],
.contact__panel .wpcf7-form select,
.contact__panel .wpcf7-form textarea {
	width: 100%;
	background: #faf4da;
	border: 1px solid #9caaa4;
	border-radius: 4px;
	padding: 14px 16px;
	font-family: var(--font-base);
	font-size: 14px;
	font-weight: 500;
	line-height: 1.6;
	color: var(--color-text);
	transition: border-color .25s ease, background .25s ease;
	box-sizing: border-box;
}
.contact__input::placeholder,
.contact__textarea::placeholder,
.contact__panel .wpcf7-form input::placeholder,
.contact__panel .wpcf7-form textarea::placeholder {
	color: #9caaa4;
}
.contact__input:focus,
.contact__textarea:focus,
.contact__panel .wpcf7-form input:focus,
.contact__panel .wpcf7-form textarea:focus {
	border-color: var(--color-primary);
	background: #fff;
	outline: none;
}
.contact__textarea,
.contact__panel .wpcf7-form textarea {
	min-height: 140px;
	resize: vertical;
}

/* 送信ボタン (Figma 487:4855: 黄ピル + 白1px二重枠 + send-icon + テキスト) */
.contact__submit,
.contact__panel .wpcf7-form input[type="submit"],
.contact__panel .wpcf7-form button[type="submit"] {
	position: relative;
	display: inline-block;
	width: 500px; max-width: 100%; height: 72px;
	border: none;
	border-radius: 9999px;
	background: var(--color-accent);
	color: var(--color-text-warm);
	font-family: var(--font-base);
	font-weight: 700;
	cursor: pointer;
	box-shadow: var(--shadow-md);
	transition: transform .2s ease, box-shadow .25s ease, background .25s ease;
	margin-top: 16px;
	margin-inline: auto;
	align-self: center;
	padding: 0;
}
.contact__submit:hover,
.contact__panel .wpcf7-form input[type="submit"]:hover,
.contact__panel .wpcf7-form button[type="submit"]:hover {
	background: var(--color-accent-warm);
	transform: translateY(-2px);
	box-shadow: 0 8px 18px rgba(61, 91, 98, .25);
}
.contact__submit-highlight {
	position: absolute;
	inset: 4px 6px;
	border-radius: 9999px;
	background: linear-gradient(to bottom, rgba(255,255,255,.55), rgba(255,255,255,0));
	filter: blur(8px);
	pointer-events: none;
	z-index: 0;
}
.contact__submit-frame {
	position: absolute;
	inset: 4px 6px;
	border: 1px solid #fff;
	border-radius: 9999px;
	display: flex; align-items: center; justify-content: center;
	gap: 8px;
	z-index: 1;
}
.contact__submit-icon {
	display: inline-flex; align-items: center; justify-content: center;
	width: 24px; height: 24px;
}
.contact__submit-icon img {
	width: 20px; height: 20px;
	display: block;
}
.contact__submit-label {
	font-size: 18px;
	line-height: 1.6;
	color: #494439;
	letter-spacing: 0.04em;
}

/* プライバシーポリシー同意 (Figma指定外、追加実装) */
.contact__consent,
.contact__panel .wpcf7-acceptance {
	width: 100%;
	margin: 8px 0 0;
	text-align: center;
}
.contact__panel .wpcf7-acceptance .wpcf7-list-item {
	margin: 0;
	display: inline-block;
}
.contact__panel .wpcf7-acceptance label,
.contact__consent label {
	display: inline-flex;
	align-items: center;
	gap: 10px;
	cursor: pointer;
	font-family: var(--font-base);
	font-size: 14px;
	font-weight: 500;
	line-height: 1.6;
	color: var(--color-text);
}
.contact__panel .wpcf7-acceptance input[type="checkbox"],
.contact__consent input[type="checkbox"] {
	flex: 0 0 auto;
	width: 18px;
	height: 18px;
	margin: 0;
	accent-color: var(--color-primary);
	cursor: pointer;
}
.contact__privacy-link {
	color: var(--color-primary);
	text-decoration: underline;
	text-underline-offset: 3px;
	transition: color .2s ease;
}
.contact__privacy-link:hover,
.contact__privacy-link:focus-visible {
	color: var(--color-primary-dark);
}

.contact__form-help {
	font-size: 12px;
	color: var(--color-text-muted);
	text-align: center;
	margin-top: 8px;
}
.contact__form-help code {
	background: rgba(0,0,0,.05);
	padding: 1px 6px;
	border-radius: 3px;
	font-size: 11px;
}

.contact__note {
	font-family: var(--font-base);
	font-size: 14px;
	font-weight: 500;
	line-height: 1.6;
	color: var(--color-text);
	text-align: center;
	margin: 0;
}

/* ==========================================================================
   Mobile CTA (footer.php 内, 固定下部、SPのみ表示)
   立体ボタン (cta-banner__btn / hero__btn と同じ構造):
   黄ピル + 内側ハイライト(blur) + 白1px枠 + mail-icon + 右端の黒丸+黄三角
   ========================================================================== */
.mobile-cta {
	display: block;
	position: fixed;
	bottom: 0; left: 0; right: 0;
	width: 100%;
	max-width: 100vw;
	box-sizing: border-box;
	background: rgba(255, 255, 255, .96);
	backdrop-filter: blur(6px);
	-webkit-backdrop-filter: blur(6px);
	padding: 10px 32px;
	z-index: 95;
	box-shadow: 0 -4px 16px rgba(0, 0, 0, .08);
	opacity: 0;
	visibility: hidden;
	transform: translateY(100%);
	pointer-events: none;
	transition: opacity .25s ease, visibility .25s ease, transform .25s ease;
}
.mobile-cta.is-visible {
	opacity: 1;
	visibility: visible;
	transform: translateY(0);
	pointer-events: auto;
}
/* PC では非表示 */
@media (min-width: 901px) {
	.mobile-cta { display: none !important; }
}
.mobile-cta__btn {
	position: relative;
	display: block;
	width: 100%;
	max-width: 100%;
	box-sizing: border-box;
	height: 52px;
	border-radius: 9999px;
	background: var(--color-accent);
	color: var(--color-text-warm);
	font-family: var(--font-base);
	font-weight: 700;
	text-decoration: none;
	box-shadow: var(--shadow-md);
	transition: transform .2s ease, box-shadow .25s ease, background .25s ease;
	cursor: pointer;
}
.mobile-cta__btn:hover {
	background: var(--color-accent-warm);
	transform: translateY(-2px);
	box-shadow: 0 8px 18px rgba(61, 91, 98, .25);
}
.mobile-cta__btn-highlight {
	position: absolute;
	inset: 4px;
	border-radius: 9999px;
	background: linear-gradient(to bottom, rgba(255,255,255,.55), rgba(255,255,255,0));
	filter: blur(8px);
	pointer-events: none;
	z-index: 0;
}
.mobile-cta__btn-frame {
	position: absolute;
	inset: 4px;
	border: 1px solid #fff;
	border-radius: 9999px;
	display: flex; align-items: center; justify-content: center;
	gap: 8px;
	z-index: 1;
}
.mobile-cta__btn-icon {
	display: inline-flex; align-items: center; justify-content: center;
	width: 24px; height: 24px;
}
.mobile-cta__btn-icon img {
	width: 18px; height: 14px;
	display: block;
}
.mobile-cta__btn-label {
	font-size: 15px;
	line-height: 1.6;
	color: #494439;
	letter-spacing: 0.04em;
}
.mobile-cta__btn-arrow {
	position: absolute;
	right: 14px; top: 50%;
	width: 12px; height: 12px;
	margin-top: -6px;
	background: #494439;
	border-radius: 50%;
	pointer-events: none;
	z-index: 2;
}
.mobile-cta__btn-arrow::before {
	content: "";
	position: absolute;
	left: 50%; top: 50%;
	transform: translate(-30%, -50%);
	width: 0; height: 0;
	border-style: solid;
	border-width: 2.5px 0 2.5px 4px;
	border-color: transparent transparent transparent var(--color-accent);
}

/* ==========================================================================
   Mobile Nav (header.php 内, バーガー展開時)
   ========================================================================== */
.site-mobile-nav {
	display: none;
	position: fixed;
	top: var(--header-h); left: 0; right: 0; bottom: 0;
	width: 100%;
	max-width: 100vw;
	box-sizing: border-box;
	background: #fff;
	z-index: 99;
	padding: 32px 24px;
	overflow-y: auto;
}
body.nav-open .site-mobile-nav { display: block; }
.site-mobile-nav__list { display: flex; flex-direction: column; gap: 8px; }
.site-mobile-nav__link {
	display: block;
	padding: 16px 8px;
	font-size: 16px; font-weight: 700;
	color: var(--color-text);
	border-bottom: 1px solid var(--color-border-soft);
}
.site-mobile-nav__cta {
	position: relative;
	display: block;
	width: 100%;
	max-width: 400px;
	height: 64px;
	margin: 24px auto 0;
	border-radius: 9999px;
	background: var(--color-accent);
	color: var(--color-text-warm);
	font-family: var(--font-base);
	font-weight: 700;
	text-decoration: none;
	box-shadow: var(--shadow-md);
	transition: transform .2s ease, box-shadow .25s ease, background .25s ease;
	cursor: pointer;
}
.site-mobile-nav__cta:hover {
	background: var(--color-accent-warm);
	transform: translateY(-2px);
	box-shadow: 0 8px 18px rgba(61, 91, 98, .25);
}
.site-mobile-nav__cta-highlight {
	position: absolute;
	inset: 4px;
	border-radius: 9999px;
	background: linear-gradient(to bottom, rgba(255,255,255,.55), rgba(255,255,255,0));
	filter: blur(8px);
	pointer-events: none;
	z-index: 0;
}
.site-mobile-nav__cta-frame {
	position: absolute;
	inset: 4px;
	border: 1px solid #fff;
	border-radius: 9999px;
	display: flex; align-items: center; justify-content: center;
	gap: 8px;
	z-index: 1;
}
.site-mobile-nav__cta-icon {
	display: inline-flex; align-items: center; justify-content: center;
	width: 24px; height: 24px;
}
.site-mobile-nav__cta-icon img {
	width: 18px; height: 14px;
	display: block;
}
.site-mobile-nav__cta-label {
	font-size: 17px;
	line-height: 1.6;
	color: #494439;
	letter-spacing: 0.04em;
}
.site-mobile-nav__cta-arrow {
	position: absolute;
	right: 14px; top: 50%;
	width: 12px; height: 12px;
	margin-top: -6px;
	background: #494439;
	border-radius: 50%;
	pointer-events: none;
	z-index: 2;
}
.site-mobile-nav__cta-arrow::before {
	content: "";
	position: absolute;
	left: 50%; top: 50%;
	transform: translate(-30%, -50%);
	width: 0; height: 0;
	border-style: solid;
	border-width: 2.5px 0 2.5px 4px;
	border-color: transparent transparent transparent var(--color-accent);
}

/* ==========================================================================
   レスポンシブ
   ========================================================================== */
@media (max-width: 1024px) {
	.site-header__inner { padding: 16px 24px; max-width: 100%; }
	.site-nav__link { padding: 16px 4px; margin-inline: 10px; font-size: 15px; }
	.site-header__cta { min-width: 200px; padding: 14px 16px; font-size: 14px; }

	.site-footer { padding: 48px 32px; }
	.site-footer__container { gap: 32px; }

	.hero__inner { max-width: 95%; padding-inline: 16px; gap: 32px; }
	.hero__title-row { font-size: 44px; }
	.hero__text { width: auto; flex: 1; }
	.hero__illust { width: 420px; height: 340px; }
	.hero__title-maru::before { left: -18px; top: -12px; width: 116px; height: 87px; }

	.problems__inner { max-width: 95%; }
	.problems__body { padding: 0 16px; gap: 32px; }

	.about { padding: 64px 16px; }
	.about__inner { max-width: 95%; gap: 48px; }
	.about__cards { gap: 12px; }
	.about-card { padding: 28px 14px; }
	.about__pitch { padding: 0 16px; }
	.about__pitch-emphasis { font-size: 28px; }

	.strengths__inner { max-width: 95%; }
	.strength-card { padding: 28px 32px; gap: 32px; }
	.strength-card__illust,
	.strength-card__illust img { width: 220px; height: 146px; }

	.services__inner { max-width: 95%; }
	.services__grid { gap: 16px; }
	.service-card { padding: 28px 20px; }

	.pricing__inner { max-width: 95%; }
	.pricing__plans { gap: 12px; }
	.plan-card { padding: 28px 18px; }
	.plan-card.is-recommended { padding: 44px 18px; }

	.flow__title { font-size: 32px; }
	.flow__lead { font-size: 22px; }
	.flow__intro { font-size: 17px; }
	.flow__steps { gap: 20px; }
	.flow__steps::before { left: calc((100% - 20px * 3) / 8); right: calc((100% - 20px * 3) / 8); }
	.flow-step__label { font-size: 17px; }

	.cost-compare__title { font-size: 32px; gap: 12px; }
	.cost-compare__title-logo { height: 80px; }
	.cost-compare__desc { font-size: 16px; }
	.cost-compare__matrix { grid-template-columns: 132px 1fr; }
	.cost-compare__plans { gap: 8px; }
	.cost-compare__col--service .cost-compare__col-cell .cost-compare__price { font-size: 16px; }
	.cost-compare__col--hire .cost-compare__col-cell .cost-compare__price { font-size: 14px; }
	.cost-compare__rowlabel strong { font-size: 14px; }
	.cost-compare__rowlabel small { font-size: 11px; }

	/* PC帯で大きくしたカード説明文を 1024px帯では微調整 */
	.about-card__desc,
	.strength-card__desc { font-size: 15px; line-height: 1.7; }

	/* CTA frame の padding-right を arrow 縮小に合わせて緩める */
	.site-header__cta-frame { padding-right: 6px; }
	.hero__btn-frame { padding-right: 8px; }
}

@media (max-width: 900px) {
	/* 固定フッターCTAバー高さぶんを確保（CTAは900px以下で常時表示） */
	body { padding-bottom: 72px; }
	html,
	body,
	#body_wrap {
		max-width: 100%;
		overflow-x: hidden;
		overflow-x: clip;
	}
	/* SPでは装飾要素（::before/::after の背景画像）を確実にコンテンツの背面へ */
	.pricing::before,
	.pricing::after,
	.cost-compare::after,
	.cta-banner__deco-wrap,
	.hero__deco-wrap,
	.about__deco,
	.strengths::before,
	.strengths::after,
	.flow__deco,
	.voice__deco,
	.faq__deco,
	.column__deco {
		z-index: 0 !important;
		pointer-events: none !important;
	}
	.pricing__inner,
	.pricing__cta,
	.cost-compare__container,
	.cta-banner__inner,
	.hero__inner,
	.about__inner,
	.strengths__inner,
	.flow__container,
	.voice__container,
	.faq__container,
	.column__container,
	.company__inner,
	.contact__inner,
	.problems__inner,
	.problems__pitch {
		position: relative;
		z-index: 2;
	}
	/* SPでもヘッダー初期状態は透明（PC同様）。スクロール時に .is-scrolled で白半透明へ */
	.site-header {
		position: fixed !important;
		width: 100% !important;
		max-width: 100vw !important;
		overflow: hidden !important;
	}
	.site-header__inner {
		width: 100% !important;
		max-width: 100% !important;
		min-width: 0 !important;
		box-sizing: border-box !important;
		padding: 10px 16px !important;
	}
	.site-nav { display: none !important; }
	.site-header__cta { display: none !important; }
	.site-logo {
		max-width: calc(100% - 60px);
		overflow: hidden;
		flex: 0 1 auto;
	}
	.site-logo img {
		max-width: 100%;
		width: auto;
	}
	.site-burger {
		display: flex !important;
		flex-direction: column;
		justify-content: center;
		align-items: center;
		gap: 5px;
		width: 44px !important;
		height: 44px !important;
		background: transparent !important;
		border: 0 !important;
		border-radius: 0 !important;
		cursor: pointer;
		position: relative !important;
		right: auto !important;
		top: auto !important;
		transform: none !important;
		margin-left: auto;
		z-index: 102 !important;
		flex: 0 0 44px;
		padding: 0;
		box-shadow: none !important;
	}
	.site-burger span {
		display: block;
		width: 22px;
		height: 2.5px;
		background: var(--color-text) !important;
		border-radius: 2px;
		transition: transform .25s ease, opacity .25s ease;
	}
	body.nav-open .site-burger span:nth-child(1) { transform: translateY(7px) rotate(45deg); }
	body.nav-open .site-burger span:nth-child(2) { opacity: 0; }
	body.nav-open .site-burger span:nth-child(3) { transform: translateY(-7px) rotate(-45deg); }
	.site-header__cta { display: none; }

	.hero__fv { height: auto; padding: 104px 0 48px; }
	.hero__inner { flex-direction: column; padding: 0 20px; gap: 24px; align-items: center; }
	.hero__text { display: contents; }
	.hero__title { order: 1; align-items: center; gap: 10px; text-align: center; }
	.hero__title-row { font-size: 42px; text-align: center; }
	.hero__title-maru { margin-right: 8px; }
	.hero__title-maru::before { left: -14px; top: -10px; width: 110px; height: 82px; }
	.hero__sub { order: 2; justify-content: center; }
	.hero__sub-label, .hero__sub-badge { font-size: 15px; }
	.hero__illust { order: 3; width: 100%; max-width: 460px; height: 320px; margin-inline: auto; }
	.hero__btn { order: 4; align-self: center; width: 100%; max-width: 320px; height: 64px; }
	.hero__band { height: auto; padding: 12px 16px; }
	.hero__badges {
		flex-direction: column;
		align-items: flex-start;
		gap: 8px;
		width: max-content;
		max-width: 100%;
		margin-inline: auto;
	}
	/* SPでは緑帯バッジを本文より小さく */
	.hero__band .badge-check { font-size: 13px; gap: 6px; }
	.hero__band .badge-check__icon { width: 16px; height: 16px; }
	.hero__band .badge-check__icon::before {
		width: 7px; height: 4px;
		border-left-width: 1.5px; border-bottom-width: 1.5px;
	}

	.problems__body { grid-template-columns: 1fr; gap: 24px; padding: 0; }
	.problems__illust { display: flex; justify-content: center; }
	.problems__illust img { width: 220px; }
	.problems__list { max-width: 560px; margin-inline: auto; width: 100%; }
	.problems__pitch-text { font-size: 24px; line-height: 1.55; }
	.problems__pitch-line--first { display: block; }
	.problems__pitch-line--sp { display: block; }
	.problems__pitch-pc-inline { display: none; }
	.problems__pitch-after-logo {
		display: inline-block;
		position: relative;
		top: -4px;
	}
	.problems__pitch-logo { height: 44px; vertical-align: -10px; top: 0; }

	.about__cards { grid-template-columns: 1fr; gap: 40px; }
	.about-card { max-width: 480px; margin-inline: auto; width: 100%; }
	.about__intro p { font-size: 16px; }
	.about__pitch-line { font-size: 18px; line-height: 1.7; }
	.about__pitch-emphasis { font-size: 24px; }

	.strengths::before,
	.strengths::after { display: none; }
	.strength-card {
		flex-direction: column;
		gap: 20px;
		padding: 24px 20px;
		align-items: stretch;
	}
	.strength-card__illust { width: 100%; max-width: 320px; height: auto; margin-inline: auto; }
	.strength-card__illust img { width: 100%; height: auto; aspect-ratio: 260 / 173; }

	.services__grid { grid-template-columns: 1fr; gap: 16px; }
	.service-card { max-width: 480px; margin-inline: auto; width: 100%; }
	.services__intro { font-size: 16px; }

	.pricing__plans { grid-template-columns: 1fr; gap: 32px; padding-top: 40px; }
	.plan-card { max-width: 480px; margin-inline: auto; width: 100%; }
	.plan-card.is-recommended { margin-top: 0; padding: 32px 24px; }
	.pricing__btn { width: 100%; max-width: 400px; box-sizing: border-box; }

	.cost-compare { padding: 64px 16px; }
	.cost-compare__container { gap: 40px; }
	.cost-compare__title { font-size: 26px; gap: 8px; flex-direction: column; }
	.cost-compare__title-logo { height: 56px; }
	.cost-compare__desc { font-size: 14px; line-height: 1.8; text-align: center; }
	.cost-compare__desc br { display: none; }
	.cost-compare__matrix {
		grid-template-columns: 1fr;
		gap: 16px;
	}
	.cost-compare__rowlabels { display: none; }
	.cost-compare__plans {
		grid-template-columns: 1fr;
		gap: 16px;
		max-width: 480px;
		margin-inline: auto;
		width: 100%;
	}
	.cost-compare__plan {
		background: #fff;
		border-radius: var(--radius-lg);
		box-shadow: var(--shadow-soft);
		padding: 16px;
		gap: 8px;
		grid-template-columns: 1fr 1fr;
	}
	.cost-compare__col-cell {
		min-height: 0;
		padding: 12px 8px;
	}
	.cost-compare__col-cell::before {
		content: attr(data-row);
		display: block;
		font-size: 12px;
		font-weight: 700;
		color: var(--color-text-warm);
		margin-bottom: 4px;
		letter-spacing: .02em;
	}
	.cost-compare__col--service .cost-compare__col-head { font-size: 16px; min-height: 44px; padding: 10px 8px; }
	.cost-compare__col--hire .cost-compare__col-head { font-size: 15px; min-height: 40px; padding: 10px 8px; }
	.cost-compare__col--service .cost-compare__col-cell .cost-compare__price { font-size: 20px; }
	.cost-compare__col--hire .cost-compare__col-cell .cost-compare__price { font-size: 17px; }
	.cost-compare__price-sub {
		font-size: clamp(9px, 2.6vw, 11px);
		letter-spacing: -0.08em;
	}
	.cost-compare__notes { font-size: 14px; }

	.flow__steps { grid-template-columns: repeat(2, 1fr); gap: 32px 24px; }
	.flow__steps::before { display: none; }
	.flow__btn { width: 100%; max-width: 400px; box-sizing: border-box; }

	.faq__title { font-size: 32px; }
	.faq__list { gap: 16px; }
	.faq-item__question { padding: 20px 24px; gap: 16px; font-size: 17px; }
	.faq-item__q-icon, .faq-item__a-icon { width: 40px; height: 40px; font-size: 20px; }
	.faq-item__answer-divider { margin: 0 24px; }
	.faq-item__answer-row { padding: 16px 24px; gap: 12px; }
	.faq-item__answer-text { font-size: 15px; padding-top: 8px; }

	.voice__title { font-size: 32px; }
	.voice__cards { grid-template-columns: 1fr; gap: 16px; }
	.voice-card { padding: 24px 20px; }
	.voice-card__stars { font-size: 22px; }
	.voice-card__text { font-size: 17px; }
	.voice__placeholder { font-size: 15px; }

	.column__title { font-size: 32px; }
	.column__grid { grid-template-columns: 1fr; gap: 24px; max-width: 480px; margin-inline: auto; width: 100%; }
	.column-card__title { font-size: 17px; }
	.column__cta .btn-outline { min-width: 0; width: 100%; max-width: 320px; }

	.cta-banner { padding: 56px 0; }
	.cta-banner__title { font-size: 24px; line-height: 1.5; }
	.cta-banner__btn { width: 100%; max-width: 400px; height: 64px; box-sizing: border-box; }
	.cta-banner__btn-arrow { right: 14px; }

	.company__title { font-size: 32px; }
	.company__cols { grid-template-columns: 1fr; gap: 24px; }
	.company-card { padding: 24px 20px; }
	.company-list__label { flex: 0 0 100px; }

	.contact__inner { gap: 40px; }
	.contact__title { font-size: 32px; }
	.contact__lead { font-size: 17px; }
	.contact__panel { padding: 24px 20px; }
	.contact__submit { width: 100%; max-width: 400px; height: 64px; box-sizing: border-box; }
}

@media (max-width: 768px) {
	:root { --header-h: 72px; }
	.site-header { height: var(--header-h); }
	.site-logo {
		align-self: center;
		padding-bottom: 0;
		padding-top: 2px;
	}
	.site-logo img { height: 50px; }

	.site-footer { padding: 40px 20px; }
	.site-footer__top { flex-direction: column; align-items: center; text-align: center; gap: 32px; }
	.site-footer__brand { width: auto; align-items: center; }
	.site-footer__nav { flex-direction: column; align-items: center; height: auto; gap: 12px; }
	.site-footer__bottom { flex-direction: column-reverse; gap: 12px; text-align: center; }
	.site-footer__legal { justify-content: center; }

	.hero__title-row { font-size: 38px; }

	.problems__title,
	.about__title,
	.strengths__title,
	.services__title,
	.pricing__title,
	.cost-compare__title,
	.flow__title,
	.faq__title,
	.voice__title,
	.column__title,
	.company__title,
	.contact__title { font-size: 28px; }

	.problems__title { font-size: 28px; line-height: 1.4; }
	.problems__dots { gap: 24px; }
	.problems__title-emphasis::before {
		left: 0;
		top: -8px;
		transform: none;
		width: 100%;
		height: 6px;
		background-image: radial-gradient(circle, var(--color-accent) 3px, transparent 3.5px);
		background-size: calc(100% / 3) 6px;
	}
	.problems__polygon { margin-top: -41px; }
	.problems__pitch {
		width: 100%;
		margin-inline: 0;
		box-sizing: border-box;
	}
	.problems__pitch-text { font-size: 22px; line-height: 1.9; }
	.problems__pitch-logo { height: 44px; vertical-align: -10px; top: 0; }

	.about__title { font-size: 28px; line-height: 1.4; gap: 4px; }
	.about__intro p { font-size: 16px; line-height: 1.7; text-align: center; }
	.about__intro-br--pc { display: none; }
	.pricing__cloud-desc-detail { display: block; }
	.about-card__title,
	.about-card__effect { font-size: 17px; }
	.about__pitch-line { font-size: 17px; }
	.about__pitch-line--quotes .about__pitch-quote { display: block; }
	.about__pitch-emphasis { font-size: 24px; }
	.strengths__title-num-three { font-size: 36px; }
	.strengths__title-line--accent { gap: 4px; }
	.pricing__btn-label--pc { display: none; }
	.pricing__btn-label--sp { display: inline; }
	.pricing__notes,
	.cost-compare__notes {
		background: rgba(255, 255, 255, .85);
		padding: 16px;
		border-radius: 8px;
	}
	.cost-compare__matrix::before,
	.cost-compare__matrix::after { display: none; }

	.strengths { padding: 64px 16px; }
	.strengths__title { font-size: 28px; line-height: 1.4; }
	.strengths__title-num { font-size: 40px; }
	.strengths__title-num-burst { width: 84px; height: 64px; }
	.strength-card__heading { gap: 8px; flex-wrap: nowrap; }
	.strength-card__num { min-width: 40px; height: 36px; font-size: 22px; padding: 6px 4px; flex-shrink: 0; }
	.strength-card__title { font-size: 17px; line-height: 1.4; white-space: nowrap; letter-spacing: 0.02em; }

	.services { padding: 64px 16px; }
	.services__title { font-size: 28px; line-height: 1.4; }
	.services__intro { font-size: 16px; line-height: 1.7; }
	.service-card__name { font-size: 19px; }
	.services__softwares-title { font-size: 19px; }

	.pricing { padding: 64px 16px; gap: 32px; }
	.pricing__title { font-size: 28px; line-height: 1.4; }
	.pricing__sub-label { font-size: 24px; }
	.pricing__sub-desc { font-size: 16px; line-height: 1.7; }
	.pricing__cloud-name { font-size: 22px; }
	.pricing__cloud-num { font-size: 30px; }
	.pricing__cloud-unit,
	.pricing__cloud-tilde { font-size: 22px; }
	.plan-card__name { font-size: 22px; }
	.plan-card__tag { font-size: 17px; }
	.plan-card__price-num { font-size: 30px; }
	.plan-card__price-unit,
	.plan-card__price-tilde { font-size: 22px; }
	.pricing__btn-label { font-size: 17px; }

	/* SP（1列）では縦方向の点線で各ステップ番号円を中央で貫く */
	.flow__steps {
		grid-template-columns: 1fr;
		gap: 24px;
		max-width: 420px;
		margin-inline: auto;
		position: relative;
	}
	.flow__steps::before {
		display: block !important;
		content: "";
		position: absolute;
		left: 50%;
		top: 25px;
		bottom: 25px;
		width: 5px;
		height: auto;
		right: auto;
		transform: translateX(-50%);
		background-image: radial-gradient(circle, var(--color-primary) 2px, transparent 2.5px);
		background-size: 5px 14px;
		background-repeat: repeat-y;
		background-position: center 0;
		z-index: 0;
	}
	.flow-step {
		flex-direction: column;
		gap: 12px;
		align-items: center;
		text-align: center;
		position: relative;
		z-index: 1;
	}
	.flow-step__body {
		background: #fff;
		border-radius: 10px;
		padding: 16px;
		gap: 12px;
		box-shadow: var(--shadow-soft);
	}
	.flow-step__icon {
		width: 100%; max-width: 160px; height: 110px;
	}
	.flow-step__label {
		font-size: 16px;
	}
}

@media (max-width: 480px) {
	.hero__title-row { font-size: 34px; }
	.hero__title-maru::before { left: -12px; top: -8px; width: 90px; height: 67px; }
	.hero__illust { height: 260px; }
	.hero__band .badge-check { font-size: 12px; }
	.problems { padding: 48px 16px 0; }
	.problems__pitch {
		width: calc(100% + 32px);
		margin-inline: -16px;
		padding: 0 16px 48px;
		box-sizing: border-box;
	}
	.problems__pitch-text { font-size: 19px; line-height: 1.9; }
	.problems__pitch-logo { height: 38px; vertical-align: -10px; top: 0; }
	.problems__polygon { width: 220px; height: 56px; margin-top: -28px; }
	.problems__item { padding: 12px 16px; }
	.problems__text { font-size: 15px; }
	.problems__title-emphasis::before {
		top: -6px;
		height: 5px;
		background-image: radial-gradient(circle, var(--color-accent) 2.5px, transparent 3px);
		background-size: calc(100% / 3) 5px;
	}

	.about { padding: 48px 16px; }
	.about__title { font-size: 26px; }
	.about__intro p { font-size: 15px; }
	.about-card { padding: 24px 12px; }
	.about-card__step { width: 44px; height: 44px; font-size: 22px; top: -22px; left: 50%; transform: translateX(-50%); }
	.about__pitch-emphasis { font-size: 20px; }

	.strengths { padding: 48px 16px; }
	.strengths__title { font-size: 26px; }
	.strengths__title-num { font-size: 30px; }
	.strengths__title-num-three { font-size: 30px; }
	.strengths__title-num-burst { width: 60px; height: 46px; }
	.strength-card { padding: 20px 16px; }
	.strength-card__num { min-width: 36px; height: 32px; font-size: 20px; padding: 4px 4px; }
	.strength-card__title { font-size: 16px; }
	.strength-card__desc { font-size: 14px; }

	.services { padding: 48px 16px; }
	.services__title { font-size: 26px; }
	.service-card { padding: 24px 16px; }
	.service-card__name { font-size: 17px; line-height: 1.5; }
	.services__softwares { padding: 20px 16px; }
	.services__softwares-list { gap: 16px; flex-wrap: wrap; }
	.services__softwares-item { height: 80px; flex: 0 0 auto; }
	.services__softwares-item img { max-height: 72px; max-width: 180px; }
	.services__softwares-item img[alt="freee"] { max-height: 48px; max-width: 120px; }
	.services__softwares-item img[alt="マネーフォワード"],
	.services__softwares-item img[alt="弥生会計"] { max-height: 72px; max-width: 180px; }

	.pricing { padding: 48px 16px; }
	.pricing__title { font-size: 26px; }
	.pricing__sub-label { font-size: 20px; padding: 6px 0; }
	.pricing__icon { width: 52px; height: 52px; }
	.pricing__cloud { padding: 24px 16px; }
	.plan-card { padding: 24px 16px; }
	.plan-card.is-recommended { padding: 24px 16px; }
	.plan-card__name { font-size: 20px; }
	.plan-card__price-num,
	.pricing__cloud-num { font-size: 28px; }
	.plan-acc__head { font-size: 13px; }

	.cost-compare { padding: 48px 12px; }
	.cost-compare__title { font-size: 22px; }
	.cost-compare__title-logo { height: 48px; }
	.cost-compare__eyebrow { font-size: 14px; }
	.cost-compare__plan { padding: 12px; }
	.cost-compare__col--service .cost-compare__col-head,
	.cost-compare__col--hire .cost-compare__col-head { font-size: 14px; min-height: 40px; padding: 8px 4px; }
	.cost-compare__col-cell { padding: 10px 4px; }
	.cost-compare__col--service .cost-compare__col-cell .cost-compare__price { font-size: 18px; }
	.cost-compare__col--hire .cost-compare__col-cell .cost-compare__price { font-size: 15px; }
	.cost-compare__price-sub {
		font-size: clamp(8px, 2.55vw, 10px);
		letter-spacing: -0.1em;
	}
	.cost-compare__notes { font-size: 13px; }
}

/* ===== Motion policy: CTA buttons and pricing cards keep hover motion only ===== */
.site-header,
.site-nav__link,
.site-footer__nav a,
.site-footer__legal a,
.faq-item__icon::before,
.faq-item__icon::after,
.faq-item__answer,
.column-card,
.column__btn-arrow,
.column__btn-arrow::after,
.contact__panel .wpcf7-form input,
.contact__panel .wpcf7-form textarea,
.contact__privacy-link,
.mobile-cta,
.site-burger span {
	transition: none;
}
.site-nav__link:hover,
.site-footer__nav a:hover,
.site-footer__legal a:hover {
	color: inherit;
	opacity: 1;
}
.column-card[href]:hover {
	transform: none;
}
