html, body {
  width: 100%;
  overflow-x: hidden;
}

/* =============================================================
   カビ取りナビ - カスタムCSS
   クラス名はすべて .kabi- プレフィックス
   ============================================================= */

/* === SWELL レイアウト強制中央寄せ === */
.l-content,
.l-mainContent,
.l-mainContent__inner,
#content,
.post_content,
.home .entry-content {
	max-width: 720px;
	width: 100%;
	margin-left: auto;
	margin-right: auto;
}

.l-sidebar {
	display: none !important;
}

.l-header__inner {
	max-width: 720px;
	width: 100%;
	margin: 0 auto;
}

/* =============================================================
   FOUC（左寄せフラッシュ）防止
   - scrollbar-gutter でスクロールバー出現時のレイアウトシフトを防止
   - overflow-x: hidden で横スクロールによる幅揺れを防止
   - body text-align + .kabi-wrap text-align:left は念のため残置
   （本質的な FOUC 対策は front-page.php の wp_head インラインCSSで実施）
   ============================================================= */

html {
	scrollbar-gutter: stable;
	overflow-x: hidden;
}

body {
	text-align: center;
	overflow-x: hidden;
}

/* WP管理バー(32px) + サイトヘッダー(80px) 分の余白確保 */
body.admin-bar .l-content {
	padding-top: 112px; /* 32 + 80 */
}

body:not(.admin-bar) .l-content {
	padding-top: 80px;
}

/* .kabi-wrap 内は左揃えに戻す（body の text-align:center を継承させない） */
.kabi-wrap {
	text-align: left;
}

/* =============================================================
   SWELLレイアウト競合回避
   - サイドバー非表示
   - メインコンテンツ幅リセット
   - body の余白を .kabi-wrap 側で制御
   ============================================================= */

.l-sidebar,
.l-sidebarWrap {
	display: none !important;
}

/* 内側コンテナは親（480px）に対して100%幅、余分な padding を除去 */
.l-mainContent__inner {
	padding: 0 !important;
}

/* SWELLがコンテンツエリアに付ける padding を無効化 */
.l-main .l-article {
	padding: 0 !important;
}

/* SWELLデフォルトの post_content margin を除去（パンくず下の空白対策） */
.l-mainContent__inner > .post_content {
	margin: 0 !important;
}
.post_content > .kabi-wrap {
	margin-top: 0 !important;
	margin-bottom: 0 !important;
}

/* パンくず直後の空白を除去 */
.p-breadcrumb + .l-content,
.p-breadcrumb + #content {
	padding-top: 0 !important;
	margin-top: 0 !important;
}

/* フッターとコピーライトの間の隙間を除去 */
.l-content,
.l-mainContent,
.l-main {
	padding-bottom: 0 !important;
	margin-bottom: 0 !important;
}

/* SWELLタクソノミーアーカイブのタイトルバーを非表示（独自ヒーローで代替） */
.c-pageTitle,
.c-pageTitle__subTitle {
	display: none !important;
}

/* SWELLデフォルトの左右 padding を打ち消し（スマホ余白ずれ防止） */
body,
.l-content,
.l-mainContent,
.l-mainContent__inner,
.l-article,
.post_content {
	padding-left: 0 !important;
	padding-right: 0 !important;
}

/* .kabi-wrap の直下要素：文字が画面端にくっつかないよう左右 padding を確保
   個別要素に padding/margin の指定がある場合はそちらが上書きされる */
.kabi-wrap > * {
	padding-left: 16px;
	padding-right: 16px;
}

/* padding ではなく margin で水平位置を制御している要素・幅100%が必要な要素は除外 */
.kabi-hero,
.kabi-hero__quick,
.kabi-search-box,
.kabi-breadcrumb,
.kabi-section,
.kabi-category-hero,
.kabi-listing-info,
.kabi-company-card,
.kabi-detail-header,
.kabi-detail-map,
.kabi-detail-info-table,
.kabi-detail-section,
.kabi-detail-cta,
.kabi-area-links,
.kabi-area-meta,
.kabi-faq,
.kabi-category-intro,
.kabi-step-form,
.kabi-cta-banner,
.kabi-cta,
.kabi-footer,
.kabi-related-companies,
.kabi-related-areas,
.kabi-top-cities,
.kabi-adjacent-prefs {
	padding-left: revert;
	padding-right: revert;
}

/* SWELL のデフォルト見出しスタイルを .kabi-wrap 内でリセット */
.kabi-wrap h1::before,
.kabi-wrap h2::before,
.kabi-wrap h3::before {
	display: none;
}

.kabi-wrap h1,
.kabi-wrap h2,
.kabi-wrap h3,
.kabi-wrap h4,
.kabi-wrap h5,
.kabi-wrap h6 {
	border: none;
	background: none;
	padding: 0;
	margin: 0;
}

/* =============================================================
   カスタムプロパティ（デザイントークン）
   ============================================================= */

:root {
	--kabi-primary:       #1a6fbd;
	--kabi-primary-dark:  #1558a0;
	--kabi-primary-light: #e8f0fa;
	--kabi-accent:        #F59E0B;
	--kabi-accent-light:  #FEF3C7;
	--kabi-text:          #1A1A1A;
	--kabi-text-sub:      #6B7280;
	--kabi-bg:            #F9FAFB;
	--kabi-white:         #FFFFFF;
	--kabi-border:        #E5E7EB;
	--kabi-danger:        #EF4444;
	--kabi-star:          #F59E0B;
	--kabi-shadow:        0 1px 3px rgba(0, 0, 0, .08);
	--kabi-shadow-md:     0 4px 12px rgba(0, 0, 0, .1);
	--kabi-radius:        10px;
	--kabi-radius-sm:     6px;
}

/* =============================================================
   ラッパー（PCは480px中央寄せ）
   ============================================================= */

.kabi-wrap,
.kabi-wrap * {
	box-sizing: border-box;
}

.kabi-wrap {
	max-width: 1200px !important;
	width: 100%;
	margin: 0 auto;
	padding-bottom: 0;
	background: var(--kabi-bg);
	min-height: 100vh;
	font-family: "Hiragino Sans", "Hiragino Kaku Gothic ProN", "Noto Sans JP", sans-serif;
	font-size: 14px;
	line-height: 1.7;
	color: var(--kabi-text);
	box-shadow: 0 0 40px rgba(0, 0, 0, .06);
}

/* =============================================================
   セクション共通
   ============================================================= */

.kabi-section {
	padding: 3rem 16px;
}

.kabi-section__title {
	font-size: 1.5rem;
	font-weight: 800;
	margin-top: 10px;
	margin-bottom: 10px;
	display: flex;
	align-items: center;
	justify-content: center;
	gap: 8px;
	color: var(--color_main, var(--kabi-text));
	border: none;
	padding: 0 0 10px;
	text-align: center;
}

.kabi-section__title::before {
	content: '';
	display: inline-block;
	width: 4px;
	height: 22px;
	background: var(--kabi-primary);
	border-radius: 2px;
	flex-shrink: 0;
}

/* .kabi-wrap 内の全見出し: line-height を揃える */
.kabi-wrap h1,
.kabi-wrap h2,
.kabi-wrap h3,
.kabi-wrap h4,
.kabi-wrap h5,
.kabi-wrap h6 {
	line-height: 1.5;
}

/* =============================================================
   ヒーローセクション
   ============================================================= */

/* --- ヒーロー（v0 hero-section 移植）--- */

.kabi-hero {
	background: #000;
	color: #fff;
	padding: 48px 16px 56px;
	text-align: center;
	position: relative;
	overflow: hidden;
	width: 100vw;
	margin-left: calc(-50vw + 50%);
	max-width: none;
	min-height: 540px !important;
}

.kabi-hero__video {
	position: absolute;
	top: 50%;
	left: 50%;
	min-width: 100%;
	min-height: 100%;
	width: auto;
	height: auto;
	transform: translate(-50%, -50%);
	object-fit: cover;
	z-index: 0;
}

.kabi-hero__overlay {
	position: absolute;
	inset: 0;
	background: rgba(0, 0, 0, 0.45);
	z-index: 0;
	pointer-events: none;
}

.kabi-hero__inner {
	position: relative;
	z-index: 1;
	text-align: center;
	max-width: 600px;
	margin: 0 auto !important;
}

.kabi-hero__search-wrap {
	position: relative;
	z-index: 1;
	max-width: 800px;
	margin: 0 auto;
	padding: 0 20px;
}

.kabi-hero__badge,
.kabi-hero__lead,
.kabi-hero__title,
.kabi-hero__sub,
.kabi-hero__count {
	text-align: center;
}

.sp-br { display: none; }

@media (max-width: 768px) {
	.kabi-hero__badge,
	.kabi-hero__count {
		text-align: center;
	}
	.kabi-hero {
		min-height: 288px !important;
		padding-bottom: 80px !important;
	}
	.kabi-hero__inner {
		margin: 0 auto !important;
	}
	.kabi-hero__title {
		font-size: 2.2rem !important;
	}
	.kabi-hero__count-num {
		font-size: 2rem !important;
	}
	.kabi-hero__count {
		display: flex;
		align-items: center;
		gap: 8px;
	}
	.sp-br { display: block; }
}

@media (min-width: 769px) {
	.kabi-hero__badge { font-size: 0.96rem !important; }
	.kabi-hero__lead { font-size: 1.44rem !important; }
	.kabi-hero__title { font-size: 3.6rem !important; }
	.kabi-hero__sub { font-size: 1.2rem !important; }
	.kabi-hero__count-num { font-size: 3.2rem !important; }
	.kabi-hero__search-wrap { margin-top: 40px; }
}

.kabi-hero__badge {
	display: inline-block;
	background: transparent;
	color: #fff;
	font-size: 11px;
	font-weight: 700;
	padding: 4px 12px;
	border-radius: 20px;
	border: 1px solid rgba(255, 255, 255, .5);
	letter-spacing: .05em;
	margin-bottom: 12px;
}

.kabi-hero__lead {
	font-size: 15px;
	font-weight: 500;
	color: #fff;
	margin: 0 0 4px;
	text-shadow: 0 1px 3px rgba(0, 0, 0, 0.3);
}

.kabi-hero__title {
	font-size: 28px;
	font-weight: 800;
	line-height: 1.4;
	margin: 0 0 8px;
	color: #ffffff;
	text-shadow: 0 1px 3px rgba(0, 0, 0, 0.3);
}

@media (min-width: 768px) {
	.kabi-hero__title {
		font-size: 36px;
	}
}

.kabi-hero__accent {
	color: var(--color_main, var(--kabi-primary));
	background: #fff;
	padding: 0 6px;
	border-radius: 4px;
}

.kabi-hero__sub {
	font-size: 15px;
	font-weight: 500;
	opacity: 1;
	color: #ffffff;
	text-shadow: 0 1px 3px rgba(0, 0, 0, 0.3);
	margin: 0 0 16px;
}

.kabi-hero__count {
	display: inline-flex;
	align-items: center;
	gap: 8px;
	margin-bottom: 20px;
}

.kabi-hero__count-label {
	font-size: 13px;
	color: rgba(255, 255, 255, .8);
}

.kabi-hero__count-num {
	display: inline-block;
	background: #fff;
	color: #0d4a8a;
	font-size: 28px;
	font-weight: 800;
	padding: 4px 16px;
	border-radius: var(--kabi-radius);
	line-height: 1.3;
	box-shadow: 0 4px 12px rgba(0, 0, 0, .15);
	font-family: "Helvetica Neue", Arial, sans-serif;
}

/* Quick links (inside hero, below search) */
.kabi-hero__quick {
	display: flex;
	flex-wrap: wrap;
	justify-content: center;
	gap: 8px;
	margin-top: 16px;
}

.kabi-hero__quick-link {
	background: rgba(255, 255, 255, .20);
	border: 1px solid rgba(255, 255, 255, .30);
	color: #fff;
	font-size: 12px;
	font-weight: 600;
	padding: 5px 14px;
	border-radius: 20px;
	text-decoration: none;
	transition: background .2s;
}

.kabi-hero__quick-link:hover {
	background: rgba(255, 255, 255, .30);
	color: #fff;
}

/* =============================================================
   検索ボックス
   ============================================================= */

.kabi-search-box {
	background: var(--kabi-white);
	max-width: 800px;
	margin: 0 auto;
	padding: 16px;
	border-radius: 16px;
	box-shadow: 0 8px 32px rgba(0, 0, 0, 0.15);
	position: relative;
	z-index: 10;
	text-align: left;
}

.kabi-search-box__row {
	display: flex;
	flex-direction: column;
	gap: 8px;
}

@media (min-width: 480px) {
	.kabi-search-box__row {
		flex-direction: row;
		gap: 12px;
	}
}

.kabi-search-box__field {
	flex: 1;
}

.kabi-search-box__label {
	font-size: 11px;
	font-weight: 700;
	color: var(--kabi-text);
	display: block;
	margin-bottom: 4px;
}

.kabi-search-box__note {
	font-size: 11px;
	color: var(--kabi-text-sub);
	text-align: center;
	margin: 8px 0 0;
}

.kabi-search-box__select {
	width: 100%;
	padding: 12px 40px 12px 12px;
	border: 2px solid var(--kabi-border);
	border-radius: var(--kabi-radius-sm);
	font-size: 15px;
	font-family: inherit;
	color: var(--kabi-text);
	background-color: var(--kabi-white);
	background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%236B7280' stroke-width='2' fill='none'/%3E%3C/svg%3E");
	background-repeat: no-repeat;
	background-position: right 14px center;
	-webkit-appearance: none;
	-moz-appearance: none;
	appearance: none;
	margin-bottom: 12px;
	cursor: pointer;
}

.kabi-search-box__select:focus {
	outline: none;
	border-color: var(--kabi-primary);
}

.kabi-search-box__btn {
	max-width: 900px;
	margin: 0 auto;
	display: block;
	padding: 14px;
	border: none;
	border-radius: var(--kabi-radius-sm);
	background: var(--kabi-primary);
	color: #fff;
	font-size: 15px;
	font-weight: 700;
	font-family: inherit;
	cursor: pointer;
	transition: background .2s;
}

.kabi-search-box__btn:hover,
.kabi-search-box__btn:active {
	background: var(--kabi-primary-dark);
}

/* =============================================================
   NEWSセクション
   ============================================================= */

.kabi-news__item {
	display: flex;
	gap: 12px;
	padding: 14px 0;
	border-bottom: 1px solid var(--kabi-border);
	text-decoration: none;
	color: var(--kabi-text);
}

.kabi-news__item:last-child {
	border-bottom: none;
}

.kabi-news__item:hover .kabi-news__text {
	color: var(--kabi-primary);
}

.kabi-news__date {
	font-size: 11px;
	color: var(--kabi-text-sub);
	white-space: nowrap;
	padding-top: 2px;
	min-width: 66px;
}

.kabi-news__badge {
	display: inline-block;
	font-size: 10px;
	font-weight: 700;
	background: var(--kabi-danger);
	color: #fff;
	padding: 1px 6px;
	border-radius: 3px;
	margin-left: 4px;
	vertical-align: middle;
}

.kabi-news__text {
	font-size: 13px;
	line-height: 1.5;
	transition: color .2s;
}

/* =============================================================
   エリアから業者を探す（v0 popular-area-section 移植：地方ブロック形式）
   ============================================================= */

.kabi-region__list {
	display: flex;
	flex-direction: column;
	gap: 10px;
}

.kabi-region__block {
	border: 1px solid var(--kabi-border);
	border-radius: var(--kabi-radius);
	overflow: hidden;
}

.kabi-region__header {
	background: var(--kabi-bg);
	padding: 8px 14px;
	border-bottom: 1px solid var(--kabi-border);
}

.kabi-region__header h3 {
	font-size: 13px;
	font-weight: 700;
	color: var(--kabi-text);
	margin: 0;
}

.kabi-region__body {
	background: var(--kabi-white);
	padding: 10px 14px;
}

.kabi-region__links {
	list-style: none;
	margin: 0;
	padding: 0;
	display: flex;
	flex-wrap: wrap;
	gap: 4px;
}

.kabi-region__links li a {
	display: inline-block;
	font-size: 13px;
	color: #1a5a9e;
	text-decoration: none;
	padding: 4px 8px;
	border-radius: 4px;
	transition: background .2s, color .2s;
}

.kabi-region__links li a:hover {
	background: var(--kabi-primary-light);
	color: var(--kabi-primary-dark);
}

.kabi-region__links li span {
	display: inline-block;
	font-size: 13px;
	color: var(--kabi-text-sub);
	padding: 4px 8px;
}

.kabi-region__all {
	text-align: center;
	margin-top: 16px;
}

.kabi-region__all a {
	display: inline-block;
	font-size: 13px;
	font-weight: 600;
	color: var(--kabi-primary);
	border: 1px solid var(--kabi-primary);
	border-radius: 30px;
	padding: 8px 24px;
	text-decoration: none;
	transition: background .2s, color .2s;
}

.kabi-region__all a:hover {
	background: var(--kabi-primary);
	color: #fff;
}

/* =============================================================
   スポットの種類から業者を探す（アイコングリッド）
   ============================================================= */

.kabi-pest__grid {
	display: grid;
	grid-template-columns: repeat(4, 1fr);
	gap: 16px;
}

@media (max-width: 768px) {
	.kabi-pest__grid {
		grid-template-columns: repeat(2, 1fr);
	}
}

.kabi-pest__card {
	display: flex;
	flex-direction: column;
	align-items: center;
	gap: 8px;
	padding: 16px 8px;
	text-decoration: none;
	color: var(--kabi-text);
	transition: transform .2s;
}

.kabi-pest__card:hover {
	transform: translateY(-2px);
}


.kabi-pest__icon-circle {
	display: flex;
	align-items: center;
	justify-content: center;
	width: 64px;
	height: 64px;
	border-radius: 50%;
	background: rgba(var(--color_main_rgb, 107, 163, 214), 0.1);
	color: var(--color_main, var(--kabi-primary));
	font-size: 2.5rem;
	line-height: 1;
	transition: background .2s;
}

.kabi-pest__card:hover .kabi-pest__icon-circle {
	background: rgba(var(--color_main_rgb, 107, 163, 214), 0.2);
}

.kabi-pest__icon-circle img,
.kabi-pest__icon-circle i {
	width: 56px !important;
	height: 56px !important;
	object-fit: contain !important;
	filter: brightness(0) saturate(100%) invert(27%) sepia(51%) saturate(400%) hue-rotate(200deg) brightness(90%) contrast(90%) !important;
}

.kabi-pest__name {
	font-size: 12px;
	font-weight: 700;
	color: var(--kabi-text);
	text-align: center;
	border: 1px solid var(--kabi-border);
	border-radius: 20px;
	padding: 3px 10px;
	white-space: nowrap;
	transition: border-color .2s, color .2s;
}

.kabi-pest__card:hover .kabi-pest__name {
	border-color: var(--color_main, var(--kabi-primary));
	color: var(--color_main, var(--kabi-primary));
}

/* =============================================================
   都道府県エリアグリッド
   ============================================================= */

.kabi-area-region {
	font-size: 12px;
	font-weight: 700;
	color: var(--kabi-text-sub);
	margin: 12px 0 8px;
}

.kabi-area-grid {
	display: grid;
	grid-template-columns: repeat(4, 1fr);
	gap: 6px;
	margin-bottom: 4px;
}

.kabi-area-grid a,
.kabi-area-grid span {
	display: block;
	text-align: center;
	padding: 8px 4px;
	background: var(--kabi-white);
	border: 1px solid var(--kabi-border);
	border-radius: var(--kabi-radius-sm);
	font-size: 12px;
	text-decoration: none;
	color: var(--kabi-text);
	transition: background .2s, border-color .2s;
}

.kabi-area-grid a:hover,
.kabi-area-grid a:active {
	background: var(--kabi-primary-light);
	border-color: var(--kabi-primary);
	color: var(--kabi-primary-dark);
}

/* =============================================================
   サービス紹介
   ============================================================= */

/* section header (centered) */
.kabi-service__header {
	text-align: center;
	margin-bottom: 20px;
}

.kabi-service__badge {
	display: inline-block;
	background: rgba(46, 125, 50, .10);
	color: var(--kabi-primary);
	font-size: 0.95rem;
	font-weight: 700;
	padding: 4px 12px;
	border-radius: 20px;
	margin-top: 8px;
	margin-bottom: 8px;
}

.kabi-service__heading {
	font-size: 1.5rem;
	font-weight: 800;
	line-height: 1.5;
	color: var(--color_main, var(--kabi-text));
	text-align: center;
	padding-bottom: 10px;
}

/* 3-card grid */
.kabi-service.kabi-section {
	background: #e8f0fa;
}

.kabi-service__grid {
	display: grid;
	grid-template-columns: 1fr;
	gap: 16px;
}

@media (min-width: 640px) {
	.kabi-service__grid {
		grid-template-columns: repeat(3, 1fr);
	}
}

.kabi-service__card {
	background: #fff;
	border: 1px solid var(--kabi-border);
	border-radius: 0;
	padding: 24px 20px;
	display: flex;
	flex-direction: column;
	transition: transform 0.3s;
}

.kabi-service__card:hover {
	transform: translateY(-4px);
}

.kabi-service__text {
	flex: 1;
}

.kabi-service__icon {
	color: var(--color_main, var(--kabi-primary));
	font-size: 4rem;
	line-height: 1;
	text-align: center;
	margin-top: 16px;
	padding-top: 12px;
}

.kabi-service__highlight {
	color: var(--color_main, var(--kabi-primary));
}

.kabi-service__card h3 {
	font-size: 1.1rem;
	font-weight: 700;
	margin-top: 0;
	margin-bottom: 8px;
	color: var(--kabi-text);
	text-align: center;
}

.kabi-service__card p {
	font-size: 0.9rem;
	color: #666;
	line-height: 1.7;
	margin: 0;
	text-align: center;
}

/* =============================================================
   CTAバナー（cta-banner 移植）
   ============================================================= */

.kabi-cta__banner {
	background: linear-gradient(135deg, #1a6fbd 0%, #155a94 100%);
	border-radius: 16px;
	overflow: hidden;
	position: relative;
	padding: 32px 20px;
}

.kabi-cta__circle {
	position: absolute;
	border-radius: 50%;
	background: rgba(255, 255, 255, .10);
}

.kabi-cta__circle--tr {
	width: 180px;
	height: 180px;
	top: -50%;
	right: -10%;
}

.kabi-cta__circle--bl {
	width: 120px;
	height: 120px;
	bottom: -40%;
	left: -8%;
}

.kabi-cta__content {
	position: relative;
	z-index: 1;
}

.kabi-cta__text {
	text-align: center;
	margin-bottom: 20px;
}

.kabi-cta__badge {
	display: inline-block;
	background: rgba(255, 255, 255, .20);
	color: #fff;
	font-size: 11px;
	font-weight: 700;
	padding: 4px 12px;
	border-radius: 20px;
	margin-bottom: 10px;
}

.kabi-cta__text h2 {
	font-size: 20px;
	font-weight: 800;
	color: #fff;
	line-height: 1.4;
	margin: 0 0 8px;
}

.kabi-cta__text p {
	font-size: 13px;
	color: rgba(255, 255, 255, .9);
	line-height: 1.6;
	margin: 0 0 12px;
}

.kabi-cta__text strong {
	color: #fff;
}

.kabi-cta__badges {
	list-style: none;
	padding: 0;
	margin: 0;
	display: flex;
	flex-wrap: wrap;
	justify-content: center;
	gap: 6px;
}

.kabi-cta__badges li {
	display: inline-flex;
	align-items: center;
	gap: 4px;
	background: rgba(255, 255, 255, .20);
	color: #fff;
	font-size: 11px;
	font-weight: 600;
	padding: 4px 10px;
	border-radius: 20px;
}

.kabi-cta__actions {
	display: flex;
	flex-direction: row;
	gap: 16px;
	justify-content: center;
}

.kabi-cta__btn {
	display: block;
	text-align: center;
	max-width: 450px;
	flex: 1;
	padding: 12px 24px;
	border-radius: 12px;
	font-size: 14px;
	font-weight: 700;
	text-decoration: none;
	transition: opacity .2s;
}

.kabi-cta__btn--primary {
	background: #fff;
	color: #e65100;
	box-shadow: 0 4px 12px rgba(0, 0, 0, .12);
}

.kabi-cta__btn--outline {
	background: rgba(255, 255, 255, .20);
	color: #fff;
	border: 1px solid rgba(255, 255, 255, .40);
}

.kabi-cta__btn:hover {
	opacity: .9;
}

/* Stats bar */
.kabi-cta__stats {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: 10px;
	margin-top: 16px;
}

.kabi-cta__stat {
	background: var(--kabi-white);
	border: 1px solid var(--kabi-border);
	border-radius: var(--kabi-radius);
	padding: 14px 8px;
	text-align: center;
}

.kabi-cta__stat-value {
	font-size: 18px;
	font-weight: 800;
	color: var(--kabi-primary);
	margin: 0;
	font-family: "Helvetica Neue", Arial, sans-serif;
}

.kabi-cta__stat-label {
	font-size: 10px;
	color: var(--kabi-text-sub);
	margin: 4px 0 0;
}

/* =============================================================
   新着記事
   ============================================================= */

.kabi-article-card {
	display: flex;
	gap: 12px;
	background: var(--kabi-white);
	border-radius: var(--kabi-radius);
	padding: 12px;
	margin-bottom: 10px;
	box-shadow: var(--kabi-shadow);
	text-decoration: none;
	color: var(--kabi-text);
	transition: box-shadow .2s;
}

.kabi-article-card:hover {
	box-shadow: var(--kabi-shadow-md);
}

.kabi-article-card__thumb {
	width: 80px;
	height: 60px;
	border-radius: var(--kabi-radius-sm);
	object-fit: cover;
	flex-shrink: 0;
}

.kabi-article-card__thumb--no-img {
	background: #ddd;
}

.kabi-article-card__body {
	flex: 1;
	min-width: 0;
}

.kabi-article-card__body h4 {
	font-size: 13px;
	font-weight: 600;
	margin-top: 0;
	margin-bottom: 4px;
	line-height: 1.5;
	color: var(--kabi-text);
	/* 2行クランプ */
	display: -webkit-box;
	-webkit-line-clamp: 2;
	-webkit-box-orient: vertical;
	overflow: hidden;
}

.kabi-article-card__meta {
	font-size: 11px;
	color: var(--kabi-text-sub);
}

/* =============================================================
   星評価（functions.php render_stars() が出力するHTML）
   ============================================================= */

.kabi-stars {
	font-size: 14px;
	letter-spacing: 1px;
}

.kabi-stars__filled {
	color: var(--kabi-star);
}

.kabi-stars__empty {
	color: #D1D5DB;
}

/* =============================================================
   パンくずリスト（functions.php kabi_breadcrumb() が出力するHTML）
   ============================================================= */

.kabi-breadcrumb {
	padding: 12px 16px;
	font-size: 11px;
	color: var(--kabi-text-sub);
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	gap: 4px;
	background: var(--kabi-white);
	border-bottom: 1px solid var(--kabi-border);
}

.kabi-breadcrumb a {
	color: var(--kabi-primary);
	text-decoration: none;
}

.kabi-breadcrumb a:hover {
	text-decoration: underline;
}

.kabi-breadcrumb__sep {
	color: var(--kabi-text-sub);
}

.kabi-breadcrumb__item--current {
	color: var(--kabi-text-sub);
}

/* =============================================================
   業者カード（parts/company-card.php 用・taxonomy-city/single で使用）
   ============================================================= */

.kabi-company-card {
	background: var(--kabi-white);
	margin: 0 0 14px;
	border-radius: var(--kabi-radius);
	box-shadow: var(--kabi-shadow);
	overflow: hidden;
}

.kabi-company-list-wrap {
	position: relative;
	padding-top: 8px;
	max-width: 100% !important;
	padding-left: 16px;
	padding-right: 16px;
}

.kabi-score-tooltip {
	position: absolute;
	right: 16px;
	top: -15px;
	color: #888;
	font-size: 13px;
	cursor: help;
}

.kabi-score-tooltip:hover {
	color: var(--kabi-primary);
}

.kabi-score-tooltip__text {
	display: none;
	position: absolute;
	right: 0;
	top: 100%;
	margin-top: 6px;
	background: rgba(0, 0, 0, 0.5) !important;
	color: #fff;
	font-size: 12px;
	line-height: 1.5;
	padding: 8px 12px;
	border-radius: 6px;
	white-space: nowrap;
	z-index: 10;
}

.kabi-score-tooltip:hover .kabi-score-tooltip__text {
	display: block;
}

@media (max-width: 768px) {
	.kabi-score-tooltip__text {
		white-space: normal;
		width: 200px;
	}
}

.kabi-company-card__rank {
	display: inline-flex;
	align-items: center;
	gap: 4px;
	background: var(--kabi-accent);
	color: #fff;
	font-size: 11px;
	font-weight: 700;
	padding: 4px 10px;
	border-radius: 0 0 var(--kabi-radius-sm) 0;
}

.kabi-company-card__rank--lower {
	background: var(--kabi-text-sub);
}

.kabi-company-card__header {
	padding: 14px 16px 0;
}

.kabi-company-card__name {
	font-size: 30px;
	font-weight: 700;
	margin: 0 0 2px;
	color: var(--kabi-text);
}

.kabi-company-card__sub {
	display: block !important;
	color: #666;
	font-size: 13px;
}

.kabi-company-card__rating {
	display: flex;
	align-items: center;
	gap: 6px;
	margin-top: 8px;
}

.kabi-company-card__rating-num {
	font-size: 14px;
	font-weight: 700;
}

.kabi-company-card__review-count {
	font-size: 11px;
	color: var(--kabi-text-sub);
}

.kabi-company-card__body {
	padding: 12px 16px;
}

.kabi-company-card__meta {
	display: flex;
	flex-wrap: wrap;
	gap: 6px;
	margin-bottom: 10px;
}

.kabi-company-card__meta span {
	font-size: 11px;
	padding: 3px 8px;
	background: var(--kabi-primary-light);
	color: var(--kabi-primary-dark);
	border-radius: 3px;
}

.kabi-company-card__desc {
	font-size: 12px;
	color: var(--kabi-text-sub);
	line-height: 1.6;
	margin: 0;
}

.kabi-company-card__spots {
	display: flex;
	flex-wrap: wrap;
	gap: 6px;
	margin-top: 8px;
}

.kabi-company-card__spot-tag {
	font-size: 11px;
	padding: 3px 10px;
	background: #eef4fa;
	border: 1px solid #c8ddf0;
	border-radius: 20px;
	color: #1a6fbd;
	white-space: nowrap;
}

.kabi-company-card__tags {
	display: flex;
	flex-wrap: wrap;
	gap: 4px;
	margin-top: 10px;
}

.kabi-company-card__tags span {
	font-size: 10px;
	padding: 3px 8px;
	border: 1px solid var(--kabi-border);
	border-radius: 3px;
	color: var(--kabi-text-sub);
}

.kabi-company-card__actions {
	display: flex;
	gap: 8px;
	padding: 12px 16px;
	border-top: 1px solid var(--kabi-border);
}

/* =============================================================
   ボタン共通（業者カード内など）
   ============================================================= */

.kabi-btn-primary {
	flex: 1;
	padding: 12px;
	border: none;
	border-radius: var(--kabi-radius-sm);
	background: var(--kabi-primary);
	color: #fff;
	font-size: 13px;
	font-weight: 700;
	font-family: inherit;
	cursor: pointer;
	text-align: center;
	text-decoration: none;
	display: block;
	transition: background .2s;
}

.kabi-btn-primary:hover {
	background: var(--kabi-primary-dark);
	color: #fff;
}

.kabi-btn-outline {
	flex: 1;
	padding: 12px;
	border: 2px solid var(--kabi-primary);
	border-radius: var(--kabi-radius-sm);
	background: none;
	color: var(--kabi-primary);
	font-size: 13px;
	font-weight: 700;
	font-family: inherit;
	cursor: pointer;
	text-align: center;
	text-decoration: none;
	display: block;
	transition: background .2s, color .2s;
}

.kabi-btn-outline:hover {
	background: var(--kabi-primary-light);
}

/* =============================================================
   詳細ページ：業者ヘッダー
   ============================================================= */

.kabi-detail-header {
	background: var(--kabi-white);
	padding: 16px;
	border-bottom: 1px solid var(--kabi-border);
}

.kabi-detail-header__name {
	font-size: 17px;
	font-weight: 800;
	line-height: 1.5;
	margin-top: 0;
	margin-bottom: 10px;
	color: var(--kabi-text);
}

/* タクソノミーバッジ */
.kabi-detail-header__badges {
	display: flex;
	flex-wrap: wrap;
	gap: 6px;
	margin-bottom: 12px;
}

.kabi-detail-header__badge {
	font-size: 11px;
	padding: 4px 10px;
	border-radius: 20px;
	background: var(--kabi-primary-light);
	color: var(--kabi-primary-dark);
	font-weight: 600;
	text-decoration: none;
	transition: opacity .2s;
}

.kabi-detail-header__badge:hover {
	opacity: .8;
}

/* 評価ブロック共通 */
.kabi-detail-header__rating {
	display: flex;
	align-items: center;
	gap: 10px;
	margin-bottom: 10px;
}

.kabi-detail-header__score {
	font-size: 28px;
	font-weight: 800;
	color: var(--kabi-primary);
	line-height: 1;
}

.kabi-detail-header__score--site {
	color: var(--kabi-accent);
}

.kabi-detail-header__rating-detail {
	display: flex;
	flex-direction: column;
	gap: 2px;
}

.kabi-detail-header__rating-label {
	font-size: 11px;
	color: var(--kabi-text-sub);
}

.kabi-detail-header__no-review {
	font-size: 12px;
	color: var(--kabi-text-sub);
}

/* =============================================================
   詳細ページ：Googleマップ
   ============================================================= */

.kabi-detail-map {
	width: 100%;
	overflow: hidden;
	line-height: 0; /* iframe下の隙間を消す */
}

.kabi-detail-map iframe {
	width: 100%;
	height: 200px;
	display: block;
}

/* =============================================================
   詳細ページ：基本情報テーブル
   ============================================================= */

.kabi-detail-info-table {
	background: var(--kabi-white);
	margin: 16px;
	border-radius: var(--kabi-radius);
	box-shadow: var(--kabi-shadow);
	overflow: hidden;
}

.kabi-detail-info-row {
	display: flex;
	border-bottom: 1px solid var(--kabi-border);
}

.kabi-detail-info-row:last-child {
	border-bottom: none;
}

.kabi-detail-info-row--map {
	display: block;
	padding: 0;
	border-bottom: none;
}

.kabi-detail-info-row__value--full {
	width: 100%;
	padding: 8px 0 0;
}

.kabi-detail-info-row__label {
	width: 110px;
	flex-shrink: 0;
	padding: 12px;
	font-size: 12px;
	font-weight: 600;
	background: #F8FAFC;
	color: var(--kabi-text-sub);
}

.kabi-detail-info-row__label i {
	color: var(--kabi-primary, #1a6fbd);
	margin-right: 4px;
	width: 14px;
	text-align: center;
}

.kabi-detail-info-row__value {
	padding: 12px;
	font-size: 13px;
	flex: 1;
	line-height: 1.6;
	color: var(--kabi-text);
}

/* =============================================================
   詳細ページ：セクション共通
   ============================================================= */

.kabi-detail-section {
	background: var(--kabi-white);
	margin: 16px;
	padding: 20px 16px;
	border-radius: var(--kabi-radius);
	box-shadow: var(--kabi-shadow);
}

/* .kabi-detail-section h2 は .kabi-detail-section__h2 に統一済み */

/* =============================================================
   詳細ページ：口コミ一覧
   ============================================================= */

.kabi-detail-reviews__empty {
	font-size: 13px;
	color: var(--kabi-text-sub);
	text-align: center;
	padding: 16px 0;
	margin: 0;
}

/* =============================================================
   口コミカード（parts/review-card.php）
   ============================================================= */

.kabi-review-card {
	padding: 14px 0;
	border-bottom: 1px solid var(--kabi-border);
}

.kabi-review-card:last-child {
	border-bottom: none;
}

.kabi-review-card__label {
	font-size: 13px;
	font-weight: 700;
	color: #555;
	margin-bottom: 6px;
}

.kabi-review-card__label i {
	color: #1a6fbd;
	margin-right: 4px;
}

.kabi-review-card__quote {
	font-size: 13px;
	line-height: 1.7;
	color: var(--kabi-text);
	margin: 0 0 4px;
	padding: 0;
	border: none;
	font-style: normal;
}

.kabi-review-card__cite {
	font-size: 11px;
	color: var(--kabi-text-sub);
	font-style: normal;
}

/* =============================================================
   詳細ページ：h2セクション見出し（テーブル外）
   ============================================================= */

/* 青背景・白文字（基本情報/口コミ/対応箇所/料金） */
.kabi-detail-section__h2 {
	font-size: 15px !important;
	font-weight: 700 !important;
	line-height: 1.4 !important;
	margin: 24px 16px 0 !important;
	padding: 12px 16px !important;
	background: #1a6fbd !important;
	color: #fff !important;
	border-radius: 4px !important;
	border: none !important;
	border-top: none !important;
	border-bottom: none !important;
	position: relative !important;
	z-index: 1 !important;
	text-align: left !important;
	letter-spacing: normal !important;
}

/* SWELLの ::before 疑似要素を打ち消し */
.kabi-detail-section__h2::before,
.kabi-detail-section__h2::after {
	content: none !important;
	display: none !important;
	border: none !important;
}

/* セクションボックス内のh2はマージン調整 */
.kabi-detail-section .kabi-detail-section__h2 {
	margin: 0 0 14px !important;
}


/* =============================================================
   詳細ページ：情報訂正リンク
   ============================================================= */

.kabi-detail-info-correction {
	text-align: right;
	margin: 6px 16px 0;
	font-size: 11px;
}

.kabi-detail-info-correction a {
	color: #999;
	text-decoration: none;
}

.kabi-detail-info-correction a:hover {
	color: #666;
	text-decoration: underline;
}

/* =============================================================
   詳細ページ：Google口コミサマリー
   ============================================================= */

.kabi-review-google-summary {
	margin-bottom: 20px;
}

.kabi-review-google-summary__score {
	display: flex;
	align-items: center;
	gap: 10px;
	margin-bottom: 12px;
}

.kabi-review-google-summary__num {
	font-size: 32px;
	font-weight: 800;
	color: var(--kabi-text);
	line-height: 1;
}

.kabi-review-google-summary__detail {
	display: flex;
	flex-direction: column;
	gap: 2px;
}

.kabi-review-google-summary__count {
	font-size: 12px;
	color: var(--kabi-text-sub);
}

.kabi-review-google-summary__btn {
	display: inline-flex;
	align-items: center;
	gap: 6px;
	padding: 10px 20px;
	background: #fff;
	color: #4285F4;
	border: 2px solid #4285F4;
	border-radius: 30px;
	font-size: 13px;
	font-weight: 700;
	text-decoration: none;
	transition: background .2s, color .2s;
}

.kabi-review-google-summary__btn:hover {
	background: #4285F4;
	color: #fff;
}

/* =============================================================
   詳細ページ：口コミ投稿フォーム
   ============================================================= */

.kabi-review-list__heading,
.kabi-review-form__heading {
	font-size: 14px;
	font-weight: 700;
	color: var(--kabi-text);
	margin: 20px 0 10px;
	padding-top: 16px;
	border-top: 1px solid var(--kabi-border);
}

.kabi-review-form__form {
	display: flex;
	flex-direction: column;
	gap: 14px;
}

.kabi-review-form__field label {
	display: block;
	font-size: 13px;
	font-weight: 600;
	color: var(--kabi-text);
	margin-bottom: 4px;
}

.kabi-review-form__required {
	font-size: 11px;
	color: #e74c3c;
	font-weight: 400;
}

.kabi-review-form__field input[type="text"],
.kabi-review-form__field textarea {
	width: 100%;
	padding: 10px 12px;
	border: 1px solid var(--kabi-border);
	border-radius: var(--kabi-radius-sm);
	font-size: 14px;
	font-family: inherit;
	box-sizing: border-box;
	transition: border-color .2s;
}

.kabi-review-form__field input[type="text"]:focus,
.kabi-review-form__field textarea:focus {
	outline: none;
	border-color: var(--kabi-primary);
	box-shadow: 0 0 0 2px rgba(26, 111, 189, .15);
}

.kabi-review-form__stars {
	display: flex;
	gap: 4px;
}

.kabi-review-form__star-label {
	cursor: pointer;
}

.kabi-review-form__star-label input[type="radio"] {
	display: none;
}

.kabi-review-form__star-label i {
	font-size: 24px;
	color: #f5a623;
	transition: transform .1s;
}

.kabi-review-form__star-label i:hover {
	transform: scale(1.15);
}

.kabi-review-form__submit {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: 6px;
	padding: 12px 24px;
	background: var(--kabi-primary);
	color: #fff;
	border: none;
	border-radius: 30px;
	font-size: 14px;
	font-weight: 700;
	cursor: pointer;
	transition: opacity .2s;
}

.kabi-review-form__submit:hover {
	opacity: .9;
}

/* =============================================================
   詳細ページ：対応箇所・サービス内容
   ============================================================= */

.kabi-detail-service__badges {
	display: flex;
	flex-wrap: wrap;
	gap: 6px;
	margin-bottom: 12px;
}

.kabi-detail-service__type {
	font-size: 13px;
	color: var(--kabi-text-sub);
	margin-bottom: 12px;
}

.kabi-detail-price__note {
	font-size: 13px;
	color: var(--kabi-text-sub);
	line-height: 1.8;
}

/* =============================================================
   詳細ページ：関連業者見出し（h3）
   ============================================================= */

.kabi-related-companies__heading {
	font-size: 15px;
	font-weight: 700;
	margin-top: 0;
	margin-bottom: 12px;
	color: var(--kabi-text);
}

/* =============================================================
   詳細ページ：会社紹介文
   ============================================================= */

.kabi-detail-about__text {
	font-size: 13px;
	color: var(--kabi-text-sub);
	line-height: 1.8;
}

.kabi-detail-about__text p {
	margin-bottom: 10px;
}

.kabi-detail-about__text p:last-child {
	margin-bottom: 0;
}

/* =============================================================
   詳細ページ：CTAセクション
   ============================================================= */

.kabi-detail-cta {
	background: #1a6fbd;
	color: #fff;
	margin: 16px;
	padding: 24px 16px;
	border-radius: var(--kabi-radius);
	text-align: center;
}

.kabi-detail-cta h3 {
	font-size: 16px;
	font-weight: 700;
	margin-top: 0;
	margin-bottom: 6px;
	color: #fff;
}

.kabi-detail-cta p {
	font-size: 12px;
	opacity: .85;
	margin-bottom: 14px;
}

.kabi-detail-cta__phone {
	font-size: 24px;
	font-weight: 800;
	display: block;
	margin-bottom: 12px;
	text-decoration: none;
	color: #fff;
	letter-spacing: .05em;
}

.kabi-detail-cta__btn {
	display: inline-block;
	padding: 12px 28px;
	background: #fff;
	color: #1a6fbd;
	font-weight: 700;
	border-radius: 30px;
	text-decoration: none;
	font-size: 14px;
	transition: opacity .2s;
}

.kabi-detail-cta__btn:hover {
	opacity: .9;
	color: #1a6fbd;
}

/* =============================================================
   詳細ページ：会社情報
   ============================================================= */

.kabi-detail-company-info__list {
	font-size: 13px;
	line-height: 1.9;
	margin: 0;
}

.kabi-detail-company-info__row {
	display: flex;
	gap: 12px;
	border-bottom: 1px solid var(--kabi-border);
	padding: 6px 0;
}

.kabi-detail-company-info__row:last-child {
	border-bottom: none;
}

.kabi-detail-company-info__row dt {
	font-weight: 600;
	color: var(--kabi-text-sub);
	white-space: nowrap;
	min-width: 72px;
}

.kabi-detail-company-info__row dd {
	margin: 0;
	color: var(--kabi-text);
}

/* =============================================================
   近隣エリアリンク（parts/area-links.php）
   ============================================================= */

.kabi-area-links {
	background: var(--kabi-white);
	margin: 0 16px 16px;
	padding: 20px 16px;
	border-radius: var(--kabi-radius);
	box-shadow: var(--kabi-shadow);
}

.kabi-area-links__title {
	font-size: 15px;
	font-weight: 700;
	margin-top: 0;
	margin-bottom: 12px;
	color: var(--kabi-text);
	border: none;
	padding: 0;
}

.kabi-area-links__grid {
	display: grid;
	grid-template-columns: repeat(4, 1fr);
	gap: 6px;
}

.kabi-area-links__item {
	display: block;
	text-align: center;
	padding: 8px 4px;
	background: var(--kabi-white);
	border: 1px solid var(--kabi-border);
	border-radius: var(--kabi-radius-sm);
	font-size: 12px;
	text-decoration: none;
	color: var(--kabi-text);
	transition: background .2s, border-color .2s;
}

.kabi-area-links__item:hover,
.kabi-area-links__item:active {
	background: var(--kabi-primary-light);
	border-color: var(--kabi-primary);
	color: var(--kabi-primary-dark);
}

/* =============================================================
   ステップフォーム（parts/step-form.php）
   ============================================================= */

.kabi-step-form {
	background: var(--kabi-white);
	margin: 16px;
	border-radius: var(--kabi-radius);
	padding: 20px 16px;
	box-shadow: var(--kabi-shadow-md);
}

.kabi-step-form__title {
	font-size: 14px;
	font-weight: 700;
	text-align: center;
	margin-top: 0;
	margin-bottom: 4px;
	color: var(--kabi-text);
}

.kabi-step-form__sub {
	font-size: 12px;
	color: var(--kabi-text-sub);
	text-align: center;
	margin-bottom: 16px;
}

/* ドットインジケーター */
.kabi-step-dots {
	display: flex;
	justify-content: center;
	gap: 6px;
	margin-bottom: 16px;
}

.kabi-step-dot {
	width: 28px;
	height: 28px;
	border-radius: 50%;
	border: 2px solid var(--kabi-border);
	display: flex;
	align-items: center;
	justify-content: center;
	font-size: 11px;
	font-weight: 700;
	color: var(--kabi-text-sub);
	transition: background .2s, border-color .2s, color .2s;
}

.kabi-step-dot--active {
	background: var(--kabi-primary);
	color: #fff;
	border-color: var(--kabi-primary);
}

/* パネル */
.kabi-step-panel__question {
	text-align: center;
	font-size: 13px;
	font-weight: 600;
	margin-top: 0;
	margin-bottom: 12px;
	color: var(--kabi-text);
}

/* 選択肢グリッド */
.kabi-step-options {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 8px;
}

.kabi-step-form__option {
	padding: 12px 10px;
	border: 2px solid var(--kabi-border);
	border-radius: var(--kabi-radius-sm);
	background: var(--kabi-white);
	text-align: center;
	font-size: 12px;
	font-weight: 600;
	font-family: inherit;
	color: var(--kabi-text);
	cursor: pointer;
	transition: border-color .2s, background .2s;
}

.kabi-step-form__option:hover {
	border-color: var(--kabi-primary);
	background: var(--kabi-primary-light);
}

.kabi-step-form__option.selected {
	border-color: var(--kabi-primary);
	background: var(--kabi-primary-light);
	color: var(--kabi-primary-dark);
}

/* 連絡先フォーム */
.kabi-step-contact__group {
	margin-bottom: 12px;
}

.kabi-step-contact__label {
	display: block;
	font-size: 12px;
	font-weight: 600;
	color: var(--kabi-text-sub);
	margin-bottom: 5px;
}

.kabi-step-contact__required {
	display: inline-block;
	font-size: 10px;
	font-weight: 700;
	background: var(--kabi-danger);
	color: #fff;
	padding: 1px 5px;
	border-radius: 3px;
	margin-left: 4px;
	vertical-align: middle;
}

.kabi-step-contact__input,
.kabi-step-contact__textarea {
	width: 100%;
	padding: 10px 12px;
	border: 2px solid var(--kabi-border);
	border-radius: var(--kabi-radius-sm);
	font-size: 14px;
	font-family: inherit;
	color: var(--kabi-text);
	background: var(--kabi-white);
	transition: border-color .2s;
	box-sizing: border-box;
}

.kabi-step-contact__input:focus,
.kabi-step-contact__textarea:focus {
	outline: none;
	border-color: var(--kabi-primary);
}

.kabi-step-contact__textarea {
	resize: vertical;
	min-height: 90px;
}

.kabi-step-contact__submit {
	width: 100%;
	padding: 14px;
	border: none;
	border-radius: var(--kabi-radius-sm);
	background: var(--kabi-primary);
	color: #fff;
	font-size: 15px;
	font-weight: 700;
	font-family: inherit;
	cursor: pointer;
	transition: background .2s;
	margin-top: 4px;
}

.kabi-step-contact__submit:hover,
.kabi-step-contact__submit:active {
	background: var(--kabi-primary-dark);
}

/* 公式URLなしのとき「詳細を見る」を幅いっぱいに */
.kabi-btn-outline--full {
	flex: none;
	width: 100%;
}

/* 戻るボタン（JS が Step2〜4 に動的挿入） */
.kabi-step-back {
	display: inline-flex;
	align-items: center;
	gap: 4px;
	border: none;
	background: none;
	color: var(--kabi-text-sub);
	font-size: 12px;
	font-family: inherit;
	cursor: pointer;
	padding: 0;
	margin-bottom: 12px;
	transition: color .2s;
}

.kabi-step-back:hover {
	color: var(--kabi-primary);
}

/* =============================================================
   taxonomy-city.php：カテゴリーヒーロー
   ============================================================= */

.kabi-category-hero {
	background: #1a6fbd !important;
	color: #fff;
	padding: 24px 16px;
	text-align: center;
}

.kabi-category-hero__title {
	font-size: 17px;
	font-weight: 800;
	line-height: 1.5;
	margin-top: 0;
	margin-bottom: 6px;
	color: #fff;
}

.kabi-category-hero__sub {
	font-size: 12px;
	opacity: .8;
	margin: 0;
}

/* =============================================================
   taxonomy-city.php：件数バー
   ============================================================= */

.kabi-listing-info {
	padding: 12px 16px;
	font-size: 13px;
	color: var(--kabi-text-sub);
	display: flex;
	justify-content: space-between;
	align-items: center;
}

.kabi-listing-info__count strong {
	color: var(--kabi-text);
	font-size: 18px;
	font-weight: 700;
	margin: 0 2px;
}

.kabi-listing-info__sort {
	font-size: 12px;
}

/* =============================================================
   taxonomy-city.php：エリア紹介文
   ============================================================= */

.kabi-category-intro {
	background: var(--kabi-white);
	margin: 16px;
	padding: 20px 16px;
	border-radius: var(--kabi-radius);
	box-shadow: var(--kabi-shadow);
}

.kabi-category-intro__title {
	font-size: 15px;
	font-weight: 700;
	margin-top: 0;
	margin-bottom: 10px;
	color: var(--kabi-text);
}

.kabi-category-intro__body {
	font-size: 13px;
	color: var(--kabi-text-sub);
	line-height: 1.7;
	margin: 0;
}

/* =============================================================
   taxonomy-city.php：FAQ
   ============================================================= */

.kabi-faq {
	padding: 0 0 8px;
}

.kabi-faq__item {
	background: var(--kabi-white);
	margin: 0 16px 8px;
	padding: 16px;
	border-radius: var(--kabi-radius);
	box-shadow: var(--kabi-shadow);
}

.kabi-faq__q {
	font-size: 14px;
	font-weight: 700;
	margin-top: 0;
	margin-bottom: 8px;
	display: flex;
	gap: 8px;
	align-items: flex-start;
	color: var(--kabi-text);
}

.kabi-faq__q::before {
	content: 'Q';
	background: var(--kabi-primary);
	color: #fff;
	width: 22px;
	height: 22px;
	border-radius: 50%;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	font-size: 11px;
	font-weight: 800;
	flex-shrink: 0;
	margin-top: 1px;
}

.kabi-faq__a {
	font-size: 13px;
	color: var(--kabi-text-sub);
	line-height: 1.7;
	padding-left: 30px;
	margin: 0;
}

/* =============================================================
   taxonomy-city.php：エリア補助情報（助成金・価格帯）
   ============================================================= */

.kabi-area-meta {
	background: var(--kabi-accent-light);
	margin: 0 16px 16px;
	padding: 14px 16px;
	border-radius: var(--kabi-radius-sm);
	border-left: 3px solid var(--kabi-accent);
}

.kabi-area-meta__title {
	font-size: 12px;
	font-weight: 700;
	color: #92400E;
	margin-top: 0;
	margin-bottom: 6px;
}

.kabi-area-meta__body {
	font-size: 12px;
	color: #78350F;
	margin: 0;
	line-height: 1.6;
}

/* =============================================================
   共通：ロゴなし・マップなし時のプレースホルダー
   ============================================================= */

.kabi-map-placeholder {
	width: 100%;
	height: 200px;
	background: #E2E8F0;
	display: flex;
	align-items: center;
	justify-content: center;
	color: var(--kabi-text-sub);
	font-size: 13px;
}

/* =============================================================
   共通：ロゴ画像
   ============================================================= */

.kabi-company-logo {
	display: block;
	max-width: 160px;
	max-height: 60px;
	width: auto;
	height: auto;
	object-fit: contain;
	margin-bottom: 10px;
}

/* =============================================================
   共通：テキストリンク
   ============================================================= */

.kabi-text-link {
	color: var(--kabi-primary);
	text-decoration: none;
	font-size: inherit;
}

.kabi-text-link:hover {
	text-decoration: underline;
}

/* =============================================================
   共通：バッジ（サービスタグ・都道府県等）
   ============================================================= */

.kabi-badge {
	display: inline-block;
	font-size: 11px;
	padding: 3px 8px;
	border-radius: 3px;
	background: var(--kabi-primary-light);
	color: var(--kabi-primary-dark);
	font-weight: 600;
}

.kabi-badge--outline {
	background: transparent;
	border: 1px solid var(--kabi-border);
	color: var(--kabi-text-sub);
}

/* =============================================================
   共通：空状態メッセージ
   ============================================================= */

.kabi-empty {
	text-align: center;
	padding: 32px 16px;
	color: var(--kabi-text-sub);
	font-size: 13px;
}

/* =============================================================
   詳細ページ：電話番号リンク（CTAの外で使う場合）
   ============================================================= */

.kabi-tel-link {
	display: inline-flex;
	align-items: center;
	gap: 6px;
	font-size: 18px;
	font-weight: 800;
	color: var(--kabi-primary);
	text-decoration: none;
	letter-spacing: .03em;
}

.kabi-tel-link:hover {
	color: var(--kabi-primary-dark);
}

/* =============================================================
   レスポンシブ補足
   ============================================================= */

/* 375px 以下では文字を少し小さく */
@media (max-width: 374px) {
	.kabi-wrap {
		font-size: 13px;
	}

	.kabi-step-options {
		grid-template-columns: 1fr;
	}

	.kabi-area-links__grid,
	.kabi-area-grid {
		grid-template-columns: repeat(3, 1fr);
	}
}

/* =============================================================
   WPForms：フォームを左寄せ・幅100%に統一
   ============================================================= */

.wpforms-container,
.wpforms-form {
	text-align: left !important;
}

.wpforms-form .wpforms-field-label {
	text-align: left !important;
}

.wpforms-form .wpforms-field {
	text-align: left !important;
}

.wpforms-form .wpforms-field-checkbox ul,
.wpforms-form .wpforms-field-radio ul {
	text-align: left !important;
	padding-left: 0 !important;
	list-style: none !important;
}

.wpforms-form input[type="text"],
.wpforms-form input[type="email"],
.wpforms-form textarea {
	width: 100% !important;
}

/* ============================================================
   市区町村リンク（都道府県ページ）
   ============================================================ */
.kabi-city-links {
	margin-top: 24px;
}

.kabi-city-links__title {
	font-size: 1rem;
	font-weight: 700;
	margin-bottom: 12px;
	color: var(--kabi-text, #1a1a1a);
}

.kabi-city-links__grid {
	display: grid;
	grid-template-columns: repeat(4, 1fr);
	gap: 8px;
}

@media (max-width: 768px) {
	.kabi-city-links__grid {
		grid-template-columns: repeat(3, 1fr) !important;
	}
}

.kabi-city-links__item {
	display: flex;
	flex-direction: column;
	align-items: center;
	justify-content: center;
	gap: 2px;
	padding: 10px 6px;
	background: var(--kabi-white, #fff);
	border: 1px solid var(--kabi-border, #e5e7eb);
	border-radius: 8px;
	font-size: 0.8rem;
	font-weight: 600;
	color: var(--kabi-primary-dark, #1558a0);
	text-decoration: none;
	text-align: center;
	transition: background 0.15s, border-color 0.15s, box-shadow 0.15s;
	box-shadow: 0 1px 3px rgba(0,0,0,.06);
}

.kabi-city-links__item:hover {
	background: var(--kabi-primary-light, #e8f0fa);
	border-color: var(--kabi-primary, #1a6fbd);
	text-decoration: none;
	box-shadow: 0 2px 6px rgba(107, 163, 214, .2);
}

.kabi-city-links__count {
	font-size: 0.7rem;
	font-weight: 400;
	color: #666;
}

/* =============================================================
   カテゴリヒーロー（都道府県・市区町村・業者詳細共通）
   ============================================================= */

.kabi-category-hero {
	background: var(--kabi-primary, #1a6fbd);
	color: #fff;
	padding: 24px 16px 20px;
	margin-bottom: 0;
	width: 100vw;
	margin-left: calc(-50vw + 50%);
	max-width: none;
}

.kabi-category-hero .kabi-breadcrumb {
	margin-bottom: 12px;
	padding: 0;
}

.kabi-category-hero .kabi-breadcrumb,
.kabi-category-hero .kabi-breadcrumb a,
.kabi-category-hero .kabi-breadcrumb__sep {
	color: rgba(255, 255, 255, .8);
	font-size: 12px;
}

.kabi-category-hero .kabi-breadcrumb a:hover {
	color: #fff;
}

.kabi-category-hero__title {
	font-size: 1.4rem;
	font-weight: 800;
	margin: 0 0 8px;
	color: #fff;
	line-height: 1.4;
}

.kabi-category-hero__title {
	display: flex;
	align-items: center;
	justify-content: center;
	gap: 12px;
}

.kabi-category-hero__title i {
	margin-right: 0;
	opacity: .9;
}

.kabi-category-hero__title img {
	display: inline-block;
	vertical-align: middle;
	flex-shrink: 0;
	filter: brightness(0) invert(1);
}

.kabi-category-hero__count {
	font-size: 13px;
	opacity: .9;
	margin: 0;
}

.kabi-category-hero__desc {
	font-size: 13px;
	opacity: .9;
	margin: 4px 0 8px;
	line-height: 1.6;
}

.kabi-category-hero--company {
	margin-top: 0 !important;
	padding-bottom: 24px;
}

/* パンくず〜ヒーロー間の空白除去 */
.kabi-breadcrumb,
.p-breadcrumb,
.c-breadcrumb {
	margin-bottom: 0 !important;
}

/* エリアメタ情報（補助金・価格帯） */
.kabi-area-meta {
	display: flex;
	gap: 12px;
	padding: 12px 16px;
	background: var(--kabi-primary-light, #e8f0fa);
	border-bottom: 1px solid var(--kabi-border, #e5e7eb);
	flex-wrap: wrap;
}

.kabi-area-meta__item {
	display: flex;
	align-items: center;
	gap: 6px;
	font-size: 13px;
}

.kabi-area-meta__label {
	font-weight: 700;
	color: var(--kabi-primary-dark, #1558a0);
}

.kabi-area-meta__label i {
	margin-right: 2px;
}

.kabi-area-meta__value {
	color: var(--kabi-text, #1a1a1a);
}

/* =============================================================
   SWELLヘッダー オーバーライド（site-header 移植）
   ============================================================= */

.l-header,
.l-fixHeader {
	background: #ffffff !important;
	height: 80px !important;
	border-bottom: 1px solid #e5e7eb;
}

.l-header__inner {
	height: 80px !important;
	display: flex;
	align-items: center;
}

.c-headLogo__link {
	font-size: 1.5rem !important;
}

.l-header *,
.l-fixHeader *,
.l-header a,
.l-fixHeader a,
.c-headLogo__link,
.c-gnav .menu-item > a,
.c-gnav .menu-item .ttl {
	color: #1a1a1a !important;
}

.c-gnav .menu-item > a:hover {
	opacity: .7;
}

.l-header__bar {
	background: #f9fafb !important;
}

/* =============================================================
   SWELLフッター オーバーライド
   ============================================================= */

.l-footer {
	background: var(--kabi-primary-dark) !important;
	color: rgba(255, 255, 255, .7) !important;
	margin-top: 0 !important;
	padding-top: 0 !important;
	padding-bottom: 0 !important;
	margin-bottom: 0 !important;
}

/* SWELLフッター内の全要素の余白を除去 */
.l-footer > * {
	margin-top: 0 !important;
	padding-top: 0 !important;
}

/* .kabi-wrap 閉じタグ〜.l-footer 間の隙間を除去 */
.l-body,
.l-scrollBody {
	padding-bottom: 0 !important;
	margin-bottom: 0 !important;
}

/* .kabi-wrap 自体の下部余白を除去 */
.home .post_content,
.home .entry-content,
.home .l-article {
	padding-bottom: 0 !important;
	margin-bottom: 0 !important;
}

.kabi-city-links,
.kabi-detail-section {
	background: none !important;
	border-radius: 0 !important;
	box-shadow: none !important;
	border: none !important;
}

.l-footer,
.l-footer * {
	color: rgba(255, 255, 255, .7) !important;
}

.l-footer a:hover {
	color: #fff !important;
}

@media (max-width: 768px) {
	.kabi-cta-title {
		font-size: 1rem !important;
		white-space: nowrap;
		overflow: hidden;
		text-overflow: ellipsis;
	}

	/* 詳細ページ：スマホ全幅 */
	.kabi-detail-section,
	.kabi-detail-info-table,
	.kabi-detail-cta,
	.kabi-detail-reviews-section,
	.kabi-related-companies {
		margin-left: 0 !important;
		margin-right: 0 !important;
		padding-left: 12px !important;
		padding-right: 12px !important;
		width: 100% !important;
		box-sizing: border-box !important;
	}

	.kabi-detail-section__h2 {
		margin-left: 0 !important;
		margin-right: 0 !important;
	}
}

/* =============================================================
   カスタムフッター（site-footer 移植）
   ============================================================= */

.kabi-footer {
	background: #1a6fbd;
	color: rgba(255, 255, 255, .8);
	margin-top: 40px;
	position: relative;
	width: 100vw !important;
	max-width: none !important;
	margin-left: calc(-50vw + 50%) !important;
	margin-right: calc(-50vw + 50%) !important;
	padding-left: 0;
	padding-right: 0;
	box-sizing: border-box;
}

.kabi-footer__inner {
	max-width: 960px;
	width: 100%;
	margin: 0 auto;
	padding: 40px 20px 24px;
}

.kabi-footer__grid {
	display: grid;
	grid-template-columns: 1fr;
	gap: 28px;
	margin-bottom: 28px;
}

@media (min-width: 540px) {
	.kabi-footer__grid {
		grid-template-columns: repeat(3, 1fr);
	}
}

.kabi-footer__heading {
	font-size: 13px;
	font-weight: 700;
	color: #fff;
	margin: 0 0 12px;
	padding-bottom: 8px;
	border-bottom: 1px solid rgba(255, 255, 255, .2);
}

.kabi-footer__list {
	list-style: none;
	padding: 0;
	margin: 0;
}

.kabi-footer__list li {
	margin-bottom: 8px;
}

.kabi-footer__list a {
	font-size: 12px;
	color: rgba(255, 255, 255, .7);
	text-decoration: none;
	transition: color .2s;
}

.kabi-footer__list a:hover {
	color: #fff;
}

.kabi-footer__bottom {
	border-top: 1px solid rgba(255, 255, 255, .15);
	padding-top: 16px;
	text-align: center;
}

.kabi-footer__bottom p {
	margin: 0;
	font-size: 11px;
	color: rgba(255, 255, 255, .5);
}

/* =============================================================
   内部リンク強化: 関連業者セクション
   ============================================================= */

.kabi-related-companies {
	background: var(--kabi-white);
	margin: 0 16px 16px;
	padding: 20px 16px;
	border-radius: var(--kabi-radius);
	box-shadow: var(--kabi-shadow);
}

.kabi-related-companies h2 {
	font-size: 15px;
	font-weight: 700;
	margin-top: 0;
	margin-bottom: 12px;
	color: var(--kabi-text);
	border: none;
	padding: 0;
}

.kabi-related-companies__list {
	display: flex;
	flex-direction: column;
	gap: 8px;
}

.kabi-related-companies__item {
	display: flex;
	justify-content: space-between;
	align-items: center;
	padding: 10px 12px;
	background: var(--kabi-bg);
	border: 1px solid var(--kabi-border);
	border-radius: var(--kabi-radius-sm);
	text-decoration: none;
	color: var(--kabi-text);
	transition: background .2s, border-color .2s;
}

.kabi-related-companies__item:hover {
	background: var(--kabi-primary-light);
	border-color: var(--kabi-primary);
}

.kabi-related-companies__name {
	font-size: 13px;
	font-weight: 600;
	flex: 1;
	min-width: 0;
	overflow: hidden;
	text-overflow: ellipsis;
	white-space: nowrap;
}

.kabi-related-companies__rating {
	font-size: 12px;
	color: var(--kabi-text-light);
	white-space: nowrap;
	margin-left: 8px;
}

.kabi-related-companies__more {
	display: block;
	text-align: center;
	margin-top: 12px;
	font-size: 13px;
	color: var(--kabi-primary);
	text-decoration: none;
	font-weight: 600;
}

.kabi-related-companies__more:hover {
	text-decoration: underline;
}

/* =============================================================
   内部リンク強化: 近隣エリア（taxonomy-city.php）
   ============================================================= */

.kabi-related-areas__count {
	font-size: 11px;
	color: var(--kabi-text-light);
	margin-left: 4px;
}

.kabi-related-areas__more {
	display: block;
	text-align: center;
	margin-top: 12px;
	font-size: 13px;
	color: var(--kabi-primary);
	text-decoration: none;
	font-weight: 600;
}

.kabi-related-areas__more:hover {
	text-decoration: underline;
}

/* =============================================================
   内部リンク強化: 人気エリアランキング（taxonomy-prefecture.php）
   ============================================================= */

.kabi-top-cities {
	background: var(--kabi-white);
	margin: 0 16px 16px;
	padding: 20px 16px;
	border-radius: var(--kabi-radius);
	box-shadow: var(--kabi-shadow);
}

.kabi-top-cities h2 {
	font-size: 15px;
	font-weight: 700;
	margin-top: 0;
	margin-bottom: 12px;
	color: var(--kabi-text);
	border: none;
	padding: 0;
}

.kabi-top-cities__list {
	list-style: none;
	margin: 0;
	padding: 0;
	counter-reset: none;
}

.kabi-top-cities__item {
	margin: 0;
	padding: 0;
}

.kabi-top-cities__item a {
	display: flex;
	align-items: center;
	padding: 10px 12px;
	text-decoration: none;
	color: var(--kabi-text);
	border-bottom: 1px solid var(--kabi-border);
	transition: background .2s;
}

.kabi-top-cities__item:last-child a {
	border-bottom: none;
}

.kabi-top-cities__item a:hover {
	background: var(--kabi-primary-light);
}

.kabi-top-cities__rank {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 24px;
	height: 24px;
	border-radius: 50%;
	background: var(--kabi-primary);
	color: #fff;
	font-size: 12px;
	font-weight: 700;
	margin-right: 10px;
	flex-shrink: 0;
}

.kabi-top-cities__item:nth-child(n+4) .kabi-top-cities__rank {
	background: var(--kabi-border);
	color: var(--kabi-text-light);
}

.kabi-top-cities__name {
	flex: 1;
	font-size: 14px;
	font-weight: 600;
}

.kabi-top-cities__count {
	font-size: 12px;
	color: var(--kabi-text-light);
}

/* =============================================================
   内部リンク強化: 隣接都道府県（taxonomy-prefecture.php）
   ============================================================= */

.kabi-adjacent-prefs {
	background: var(--kabi-white);
	margin: 0 16px 16px;
	padding: 20px 16px;
	border-radius: var(--kabi-radius);
	box-shadow: var(--kabi-shadow);
}

.kabi-adjacent-prefs h2 {
	font-size: 15px;
	font-weight: 700;
	margin-top: 0;
	margin-bottom: 12px;
	color: var(--kabi-text);
	border: none;
	padding: 0;
}

.kabi-adjacent-prefs__list {
	display: flex;
	flex-wrap: wrap;
	gap: 8px;
}

.kabi-adjacent-prefs__item {
	display: inline-block;
	padding: 8px 16px;
	background: var(--kabi-bg);
	border: 1px solid var(--kabi-border);
	border-radius: var(--kabi-radius-sm);
	font-size: 13px;
	font-weight: 600;
	text-decoration: none;
	color: var(--kabi-text);
	transition: background .2s, border-color .2s;
}

.kabi-adjacent-prefs__item:hover {
	background: var(--kabi-primary-light);
	border-color: var(--kabi-primary);
	color: var(--kabi-primary-dark);
}

/* =============================================================
   エリア解説文（taxonomy-prefecture.php）
   ============================================================= */

.kabi-area-text {
	max-width: 800px;
	margin: 0 auto;
	padding: 20px;
	line-height: 1.8;
	color: #333;
	font-size: 14px;
}

.kabi-area-text__heading {
	font-size: 1.5rem;
	font-weight: 800;
	margin-top: 0;
	margin-bottom: 1rem;
	display: flex;
	align-items: center;
	gap: 8px;
}

.kabi-area-text__heading::before {
	content: '';
	display: inline-block;
	width: 4px;
	height: 22px;
	background: var(--kabi-primary);
	border-radius: 2px;
	flex-shrink: 0;
}

/* =============================================================
   スポット解説文（taxonomy-spot_type.php）
   ============================================================= */

.kabi-pest-desc {
	background: #fff;
	border-radius: 0;
	padding: 20px;
	margin-bottom: 20px;
	border: 1px solid #e0e0e0;
	line-height: 1.8;
	color: #333;
	font-size: 14px;
}

.kabi-pest-desc__heading {
	font-size: 1.2rem;
	font-weight: 700;
	margin-top: 0;
	margin-bottom: .8rem;
	color: var(--kabi-primary);
}

.kabi-pest-desc p {
	margin: 0;
}

/* =============================================================
   エリアフィルター（taxonomy-spot_type.php）
   ============================================================= */

.kabi-pest-filter {
	display: flex;
	align-items: center;
	gap: 12px;
	margin-bottom: 16px;
	flex-wrap: wrap;
}

.kabi-pest-filter__label {
	font-size: 14px;
	font-weight: 700;
	color: #333;
	white-space: nowrap;
}

.kabi-pest-filter__select {
	flex: 1;
	min-width: 160px;
	max-width: 260px;
	padding: 8px 12px;
	border: 1px solid #ddd;
	border-radius: 8px;
	font-size: 14px;
	background: #fff;
}

.kabi-pest-filter__count {
	font-size: 13px;
	color: #666;
	white-space: nowrap;
}

/* =============================================================
   スコア算出方法（taxonomy-spot_type.php）
   ============================================================= */

.kabi-score-info {
	margin-bottom: 20px;
}

.kabi-score-info__toggle {
	background: none;
	border: none;
	color: #666;
	font-size: 13px;
	cursor: pointer;
	padding: 4px 0;
	display: inline-flex;
	align-items: center;
	gap: 4px;
}

.kabi-score-info__toggle:hover {
	color: var(--kabi-primary);
}

.kabi-score-info__detail {
	background: #f8f9fa;
	border-radius: 8px;
	padding: 16px 20px;
	margin-top: 8px;
	font-size: 13px;
	line-height: 1.7;
	color: #555;
}

.kabi-score-info__detail ul {
	margin: 0 0 8px;
	padding-left: 20px;
}

.kabi-score-info__detail p {
	margin: 0;
}

/* =========================================================
   サービス種別バッジ
   ========================================================= */
.kabi-service-badge {
	display: inline-block;
	padding: 2px 10px;
	border-radius: 4px;
	font-size: .75rem;
	font-weight: 700;
	line-height: 1.6;
	vertical-align: middle;
}

.kabi-service-badge--specialist {
	background: #1a6fbd;
	color: #fff;
}

.kabi-service-badge--general {
	background: #e8e8e8;
	color: #555;
}

/* =========================================================
   セクション小見出し（専門業者 / 対応業者）
   ========================================================= */
.kabi-section__subtitle {
	display: flex;
	align-items: center;
	gap: 8px;
	font-size: 1.15rem;
	font-weight: 700;
	margin: 28px 0 12px;
	padding: 10px 16px;
	border-radius: 6px;
	line-height: 1.5;
}

.kabi-section__subtitle--specialist {
	background: linear-gradient(135deg, #e8f2fc 0%, #d6eaf8 100%);
	color: #1a6fbd;
}

.kabi-section__subtitle--unconfirmed {
	background: #f5f5f5;
	color: #444;
	border: 1px solid #d0d0d0;
}

.kabi-section__subtitle--general {
	background: #f0f4f8;
	color: #1a6fbd;
	border: 1px solid #d0dce8;
}

.kabi-section__subtitle-count {
	font-size: .85rem;
	font-weight: 400;
	margin-left: auto;
	opacity: .85;
}

.kabi-section__note {
	font-size: 12px;
	color: var(--kabi-text-sub);
	margin: 8px 0 0;
	padding: 0 4px;
}

/* =============================================================
   「さらに表示」ボタン
   ============================================================= */

.kabi-company-card-wrap--hidden {
	display: none;
}

.kabi-show-more-btn {
	display: block;
	width: 100%;
	margin: 16px 0 0;
	padding: 12px;
	background: #fff;
	color: #1a6fbd;
	font-size: 14px;
	font-weight: 700;
	border: 2px solid #1a6fbd;
	border-radius: 6px;
	cursor: pointer;
	text-align: center;
	transition: background .2s, color .2s;
}

.kabi-show-more-btn:hover {
	background: #1a6fbd;
	color: #fff;
}

/* =============================================================
   対応箇所コンテンツ（選び方・費用相場・FAQ）
   ============================================================= */

.kabi-spot-content {
	margin-top: 24px;
}

.kabi-spot-content__text {
	font-size: 14px;
	line-height: 1.8;
	color: var(--kabi-text);
	margin: 12px 0 0;
}

.kabi-faq-list {
	margin-top: 12px;
}

.kabi-faq-item {
	margin-bottom: 16px;
}

.kabi-faq-item__q {
	font-size: 14px;
	font-weight: 700;
	color: var(--kabi-text);
	display: flex;
	align-items: flex-start;
	gap: 8px;
	margin-bottom: 6px;
}

.kabi-faq-item__a {
	font-size: 14px;
	line-height: 1.7;
	color: var(--kabi-text);
	display: flex;
	align-items: flex-start;
	gap: 8px;
}

.kabi-faq-item__label {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	min-width: 24px;
	height: 24px;
	border-radius: 4px;
	font-size: 13px;
	font-weight: 700;
	color: #fff;
	background: #1a6fbd;
	flex-shrink: 0;
}

.kabi-faq-item__label--a {
	background: #e74c3c;
}

/* =========================================================
   対応箇所グリッド（front-page spot section）
   ========================================================= */
.kabi-spot {
	padding: 40px 0;
}

.kabi-spot__grid {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: 16px;
	margin-top: 20px;
}

@media (min-width: 600px) {
	.kabi-spot__grid {
		grid-template-columns: repeat(5, 1fr);
	}
}

.kabi-spot__card {
	display: flex;
	flex-direction: column;
	align-items: center;
	gap: 8px;
	padding: 16px 8px;
	border-radius: 12px;
	text-decoration: none;
	color: var(--kabi-text, #333);
	transition: background .2s, box-shadow .2s;
}

.kabi-spot__card:hover {
	background: #f0f6fc;
	box-shadow: 0 2px 8px rgba(26, 111, 189, .15);
}

.kabi-spot__icon-circle {
	display: flex;
	align-items: center;
	justify-content: center;
	width: 56px;
	height: 56px;
	border-radius: 50%;
	background: linear-gradient(135deg, #1a6fbd 0%, #2d8fd5 100%);
	color: #fff;
	font-size: 22px;
	flex-shrink: 0;
}

.kabi-spot__name {
	font-size: 12px;
	font-weight: 600;
	text-align: center;
	line-height: 1.4;
}

/* =========================================================
   絞り込みフィルター
   ========================================================= */
.kabi-filter {
	background: #f8fafc;
	border: 1px solid #e2e8f0;
	border-radius: 10px;
	padding: 16px 20px;
	margin: 20px 0 8px;
}

.kabi-filter__heading {
	font-size: 14px;
	font-weight: 700;
	color: #1a6fbd;
	margin: 0 0 12px;
}

.kabi-filter__group {
	margin-bottom: 10px;
}

.kabi-filter__group-label {
	display: block;
	font-size: 12px;
	font-weight: 600;
	color: #555;
	margin-bottom: 6px;
}

.kabi-filter__buttons {
	display: flex;
	flex-wrap: wrap;
	gap: 6px;
}

.kabi-filter__btn {
	font-size: 12px;
	padding: 5px 12px;
	border: 1px solid #c8ddf0;
	border-radius: 20px;
	background: #fff;
	color: #1a6fbd;
	cursor: pointer;
	transition: all .2s;
}

.kabi-filter__btn:hover {
	background: #eef4fa;
}

.kabi-filter__btn--active {
	background: #1a6fbd;
	color: #fff;
	border-color: #1a6fbd;
}

.kabi-filter__reset {
	display: inline-block;
	margin-top: 10px;
	font-size: 12px;
	padding: 4px 12px;
	border: 1px solid #ccc;
	border-radius: 4px;
	background: #fff;
	color: #666;
	cursor: pointer;
}

.kabi-filter__reset:hover {
	background: #f0f0f0;
}

.kabi-filter__count {
	font-size: 12px;
	color: #888;
	margin-left: 12px;
}


/* =========================================================
   固定ページ（policy等）コンテンツ幅
   ========================================================= */
body.page .l-content {
	max-width: 800px !important;
	margin-left: auto !important;
	margin-right: auto !important;
}
body.page .l-mainContent {
	width: 100% !important;
	max-width: 100% !important;
	flex: 1 1 100% !important;
}
