.x-card__scenario-summary-badges {
	width: 100%;
	display: flex;
	justify-content: flex-start;
	gap: 0.5em;
	position: relative;
	z-index: 2;
}
.x-card__scenario-summary-badges--outer {
	position: relative;
	top: -30px;
	left: 0;
	margin-bottom: -0.7em;
	margin-top: 0;
	/* カードの外側に重ねる */
	transform: translateY(1.1em);
	pointer-events: none;
	gap: 0;
}
.joho-feed__item {
	position: relative;
}
.x-card {
	position: relative;
	z-index: 1;
}
.x-card__scenario-tab-badge {
	display: inline-block;
	font-size: 0.93em;
	color: #fff;
	background: var(--color-blue);
	border-radius: 12px 12px 0 0;
	padding: 0.32em 1.3em 0.22em 1.3em;
	font-weight: 700;
	letter-spacing: 0.01em;
	box-shadow: 0 -2px 8px rgba(91,158,201,0.08);
	position: relative;
	top: 0;
	pointer-events: auto;
}
.x-card__summary-badge {
	display: inline-block;
	font-size: 0.93em;
	color: #fff;
	background: var(--color-primary);
	border-radius: 12px 12px 0 0;
	padding: 0.32em 1.3em 0.22em 1.3em;
	font-weight: 700;
	letter-spacing: 0.01em;
	box-shadow: 0 -2px 8px rgba(245,163,42,0.08);
	position: relative;
	top: 0;
	pointer-events: auto;
}
.x-card__scenario-tab-badge {
	display: inline-block;
	font-size: 0.93em;
	color: #fff;
	background: var(--color-blue);
	border-radius: 12px 12px 0 0;
	padding: 0.32em 1.3em 0.22em 1.3em;
	font-weight: 700;
	letter-spacing: 0.01em;
	box-shadow: 0 -2px 8px rgba(91,158,201,0.08);
	position: relative;
	top: 0.7em;
}
.x-card__summary-badge {
	display: inline-block;
	font-size: 0.93em;
	color: #fff;
	background: var(--color-primary);
	border-radius: 12px 12px 0 0;
	padding: 0.32em 1.3em 0.22em 1.3em;
	font-weight: 700;
	letter-spacing: 0.01em;
	box-shadow: 0 -2px 8px rgba(245,163,42,0.08);
	position: relative;
	top: 0.7em;
}
.x-card__scenario-tab-badge-area {
	width: 100%;
	display: flex;
	justify-content: flex-start;
	margin-bottom: -0.7em;
	margin-top: -1.2em;
	position: relative;
	z-index: 2;
}
.x-card__scenario-tab-badge {
	display: inline-block;
	font-size: 0.93em;
	color: #fff;
	background: var(--color-blue);
	border-radius: 12px 12px 0 0;
	padding: 0.32em 1.3em 0.22em 1.3em;
	font-weight: 700;
	letter-spacing: 0.01em;
	box-shadow: 0 -2px 8px rgba(91,158,201,0.08);
	position: relative;
	top: 0.7em;
}
.official-link-card.minimal {
	background: #f8fafc;
	border: 1.2px solid var(--color-primary-light);
	border-radius: 8px;
	box-shadow: none;
	padding: 0.7em 1em 0.7em 1em;
	min-width: 180px;
	max-width: 320px;
	flex: 1 1 180px;
	display: flex;
	flex-direction: column;
	gap: 0.2em;
	margin-bottom: 0.2em;
}
.official-link-card__title {
	font-size: 1.01em;
	font-weight: 700;
	color: var(--color-primary);
	text-decoration: underline;
	margin-bottom: 0.1em;
}
.official-link-card__note {
	font-size: 0.97em;
	color: var(--color-text-light);
	margin-top: 0.1em;
}
.x-card__scenario-type-badge {
	display: inline-block;
	font-size: 0.88em;
	color: #fff;
	background: var(--color-blue);
	border-radius: 8px;
	padding: 0.13em 0.8em 0.13em 0.7em;
	font-weight: 700;
	margin-bottom: 0.18em;
	margin-right: 0.5em;
	letter-spacing: 0.01em;
	vertical-align: middle;
}
.x-card__official-link-cards {
	display: flex;
	flex-wrap: wrap;
	gap: 1.1em 1.5em;
	margin-top: 0.5em;
}
.official-link-card {
	background: #fff;
	border: 1.5px solid var(--color-primary-light);
	border-radius: 12px;
	box-shadow: 0 2px 8px rgba(245,163,42,0.07);
	padding: 1em 1.1em 0.9em 1.1em;
	min-width: 220px;
	max-width: 320px;
	flex: 1 1 220px;
	display: flex;
	flex-direction: column;
	gap: 0.3em;
}
.official-link-card__head {
	display: flex;
	align-items: baseline;
	gap: 0.7em;
	margin-bottom: 0.2em;
}
.official-link-card__category {
	font-size: 0.92em;
	color: var(--color-primary);
	font-weight: 700;
	background: var(--color-primary-light);
	border-radius: 6px;
	padding: 0.1em 0.7em;
	margin-right: 0.2em;
}
.official-link-card__title {
	font-size: 1.05em;
	font-weight: 700;
	color: var(--color-text);
}
.official-link-card__label {
	font-size: 0.88em;
	color: var(--color-text-light);
	margin-right: 0.3em;
}
.official-link-card__value {
	font-size: 0.98em;
	color: var(--color-text);
}
.official-link-card__can-check,
.official-link-card__when,
.official-link-card__check-point,
.official-link-card__note {
	margin-bottom: 0.1em;
}
.official-link-card__action {
	margin-top: 0.5em;
	margin-bottom: 0.1em;
}
.official-link-card__btn {
	display: inline-block;
	background: var(--color-primary);
	color: #fff;
	font-size: 0.97em;
	font-weight: 700;
	border-radius: 8px;
	padding: 0.38em 1.2em;
	text-decoration: none;
	transition: background 0.18s;
}
.official-link-card__btn:hover {
	background: var(--color-primary-dark);
}
/* ============================
	 情報クイズカード拡張要素
============================ */
.x-card__summary-text {
	font-size: 1rem;
	color: var(--color-text-light);
	margin-bottom: 0.3em;
	font-weight: 500;
}
.x-card__scenario-type {
	font-size: 0.92rem;
	color: var(--color-blue);
	margin-bottom: 0.2em;
	font-weight: 500;
}
.x-card__official-links {
	margin-top: 0.7em;
	margin-bottom: 0.5em;
}
.x-card__official-links-title {
	font-size: 0.95rem;
	font-weight: 700;
	color: var(--color-primary);
	margin-bottom: 0.2em;
}
.x-card__official-links ul {
	padding-left: 1.2em;
}
.x-card__official-links li {
	font-size: 0.97rem;
	margin-bottom: 0.1em;
}
.x-card__official-links-desc {
	color: var(--color-text-light);
	font-size: 0.92em;
	margin-left: 0.3em;
}
.x-card__extra-point {
	margin-top: 0.6em;
	background: var(--color-primary-light);
	border-radius: 8px;
	padding: 0.5em 0.9em;
	font-size: 0.97rem;
}
.x-card__extra-point-title {
	font-weight: 700;
	color: var(--color-primary);
	margin-bottom: 0.1em;
}
.x-card__memory-line {
	margin-top: 0.7em;
	background: var(--color-blue-light);
	border-radius: 8px;
	padding: 0.5em 0.9em;
	font-size: 0.97rem;
}
.x-card__memory-line-title {
	font-weight: 700;
	color: var(--color-blue);
	margin-bottom: 0.1em;
}

/* 添付プレビュー（ダミー）は画像未登録時は非表示に */
.x-card__preview[aria-label="添付プレビュー（ダミー）"] {
	display: none !important;
}
/* ============================
	 ちょっと試してみる 吹き出し
============================ */
.joho-feed__balloon {
	display: inline-block;
	position: absolute;
	left: 0;
	top: -2.8rem;
	background: #fffbe7;
	color: #b56a00;
	font-size: 0.98rem;
	font-weight: 700;
	border-radius: 16px;
	padding: 0.35em 1.1em 0.35em 1.2em;
	box-shadow: 0 2px 8px rgba(245,163,42,0.10);
	border: 1.5px solid #ffe1a1;
	z-index: 2;
	margin-bottom: 0.2em;
	line-height: 1.5;
	letter-spacing: 0.01em;
}
.joho-feed-section {
	position: relative;
	margin-top: 2rem;
}
.joho-feed__balloon::before {
	content: "";
	position: absolute;
	left: 1.2em;
	top: 100%;
	width: 0;
	height: 0;
	border-left: 10px solid transparent;
	border-right: 10px solid transparent;
	border-top: 10px solid #fffbe7;
	filter: drop-shadow(0 1px 1px #ffe1a1);
}
/* ---- リンクカード用バッジ配置 ---- */
.link-card__badges {
	display: flex;
	flex-wrap: wrap;
	gap: 0.25em 0.5em;
	margin-top: 0.5em;
	margin-bottom: 0.5em;
	align-items: flex-start;
	position: relative;
	z-index: 1;
}
.link-card__head + .link-card__badges {
	margin-top: 0;
}

/* 地域検索テンプレートバッジ強調 */
.badge--local-template {
	background: #FFF3E0;
	color: #b56a00;
	font-weight: 900;
	letter-spacing: 0.04em;
	box-shadow: 0 1px 4px rgba(245,163,42,0.08);
}
/* ==============================================
   sonae-note / main.css
   モバイルファースト設計
   ============================================== */

/* ============================
   1. CSS カスタムプロパティ
   ============================ */
:root {
	/* カラーパレット */
	--color-primary:       #F5A32A;   /* ランタンのあかり */
	--color-primary-light: #FFF8EE;
	--color-primary-dark:  #E08F1A;

	--color-green:         #5BAD8F;   /* セージグリーン */
	--color-green-light:   #EDF7F2;

	--color-blue:          #5B9EC9;   /* やさしいブルー */
	--color-blue-light:    #EEF5FA;

	--color-alert:         #E05A4B;   /* 注意・地震 */
	--color-alert-light:   #FEF2F0;

	--color-warning:       #E89B30;   /* 警告・台風 */
	--color-warning-light: #FFF7E6;

	--color-info:          #5B9EC9;   /* 情報・停電 */
	--color-info-light:    #EEF5FA;

	/* 背景 */
	--color-bg:            #FFFDF7;   /* 温かみのある白 */
	--color-surface:       #FFFFFF;
	--color-gray-50:       #FAFAF7;
	--color-gray-100:      #F5F3EE;
	--color-gray-200:      #E8E3D8;
	--color-gray-300:      #CEC9BC;
	--color-gray-600:      #6B6557;
	--color-gray-800:      #3A3530;

	/* テキスト */
	--color-text:          #3A3530;
	--color-text-light:    #6B6557;
	--color-text-link:     #3A7BB5;

	/* ボーダー */
	--color-border:        #E8E3D8;

	/* タイポグラフィ */
	--font-base: 'Noto Sans JP', 'Hiragino Kaku Gothic ProN', 'Hiragino Sans', Meiryo, sans-serif;
	--font-size-xs:   0.75rem;    /* 12px */
	--font-size-sm:   0.875rem;   /* 14px */
	--font-size-base: 1rem;       /* 16px */
	--font-size-md:   1.0625rem;  /* 17px */
	--font-size-lg:   1.25rem;    /* 20px */
	--font-size-xl:   1.5rem;     /* 24px */
	--font-size-2xl:  1.75rem;    /* 28px */
	--font-size-3xl:  2rem;       /* 32px */
	--line-height-tight:  1.4;
	--line-height-base:   1.8;
	--line-height-loose:  2.0;

	/* スペーシング */
	--spacing-1:  0.25rem;
	--spacing-2:  0.5rem;
	--spacing-3:  0.75rem;
	--spacing-4:  1rem;
	--spacing-5:  1.25rem;
	--spacing-6:  1.5rem;
	--spacing-8:  2rem;
	--spacing-10: 2.5rem;
	--spacing-12: 3rem;
	--spacing-16: 4rem;

	/* レイアウト */
	--container-max:      680px;
	--container-padding:  var(--spacing-5);
	--border-radius-sm:   6px;
	--border-radius-base: 12px;
	--border-radius-lg:   16px;
	--border-radius-full: 9999px;

	/* シャドウ */
	--shadow-sm:   0 1px 3px rgba(60,50,40,.08);
	--shadow-base: 0 2px 8px rgba(60,50,40,.10);
	--shadow-md:   0 4px 16px rgba(60,50,40,.12);
	--shadow-lg:   0 8px 32px rgba(60,50,40,.16);

	/* ボトムナビ高さ（余白確保用） */
	--bottom-nav-height: 64px;

	/* トランジション */
	--transition: 0.2s ease;
}


/* ============================
   2. リセット & ベース
   ============================ */
*,
*::before,
*::after {
	box-sizing: border-box;
	margin: 0;
	padding: 0;
}

html {
	font-size: 16px;
	-webkit-text-size-adjust: 100%;
	scroll-behavior: smooth;
}

body {
	font-family: var(--font-base);
	font-size: var(--font-size-base);
	color: var(--color-text);
	background-color: var(--color-bg);
	line-height: var(--line-height-base);
	-webkit-font-smoothing: antialiased;
}

a {
	color: var(--color-text-link);
	text-decoration: none;
}
a:hover {
	text-decoration: underline;
}

img,
svg {
	max-width: 100%;
	height: auto;
	vertical-align: middle;
}

ul,
ol {
	list-style: none;
}

button {
	font-family: var(--font-base);
	cursor: pointer;
	border: none;
	background: none;
	padding: 0;
}

/* サイト全体ラッパー */
.site-wrapper {
	min-height: 100vh;
	display: flex;
	flex-direction: column;
	padding-bottom: calc(var(--bottom-nav-height) + env(safe-area-inset-bottom, 0px));
}

.site-content {
	flex: 1;
}


/* ============================
   3. コンテナ
   ============================ */
.container {
	max-width: var(--container-max);
	margin-inline: auto;
	padding-inline: var(--container-padding);
}


/* ============================
   4. 画像プレースホルダー
   ============================ */
.img-placeholder {
	display: flex;
	align-items: center;
	justify-content: center;
	background-color: var(--color-gray-100);
	border: 2px dashed var(--color-gray-300);
	border-radius: var(--border-radius-sm);
	color: var(--color-gray-600);
	font-size: var(--font-size-xs);
	text-align: center;
	line-height: var(--line-height-tight);
}

.img-placeholder::before {
	content: "📷 画像準備中";
	white-space: nowrap;
}

/* ワイド横長（16:9 相当） */
.img-placeholder--wide {
	width: 100%;
	aspect-ratio: 16 / 7;
}

/* 正方形 */
.img-placeholder--square {
	width: 100%;
	aspect-ratio: 1;
}

/* 横長カード（4:3） */
.img-placeholder--landscape {
	width: 100%;
	aspect-ratio: 4 / 3;
}

/* アイコンサイズ */
.img-placeholder--icon {
	width: 48px;
	height: 48px;
	flex-shrink: 0;
	border-radius: var(--border-radius-base);
	font-size: 8px;
}
.img-placeholder--icon::before {
	content: "📷";
	font-size: 1.25rem;
}

/* アバター（円形） */
.img-placeholder--avatar {
	width: 40px;
	height: 40px;
	border-radius: var(--border-radius-full);
	flex-shrink: 0;
}
.img-placeholder--avatar::before {
	content: "👤";
	font-size: 1.25rem;
}


/* ============================
   5. マスコット
   ============================ */
.mascot {
	display: inline-block;
	line-height: 0;
}

/* ============================
   マスコット吹き出し・コメント
   ============================ */
.mascot__comment {
  margin-top: 8px;
  padding: 6px 14px;
  background: var(--color-primary-light);
  color: var(--color-text);
  border-radius: 16px;
  font-size: 0.98rem;
  line-height: 1.7;
  display: inline-block;
  max-width: 90%;
  box-shadow: 0 1px 4px rgba(245,163,42,0.07);
}

.mascot__img {
	border-radius: 0;
	object-fit: contain;
	width: 100%;
	height: 100%;
	display: block;
}

/* サイズ別フットプリント。mascot.php の $sizes と一致させること */
.mascot--small  .mascot__img,
.mascot--small  .mascot__placeholder { width: 60px;  height: 60px; }
.mascot--medium .mascot__img,
.mascot--medium .mascot__placeholder { width: 120px; height: 120px; }
.mascot--large  .mascot__img,
.mascot--large  .mascot__placeholder { width: 160px; height: 160px; }
.mascot--hero   .mascot__img,
.mascot--hero   .mascot__placeholder { width: 200px; height: 200px; }
.mascot--modal  .mascot__img,
.mascot--modal  .mascot__placeholder { width: 110px; height: 110px; }

/* 画像未設定時のソフトプレースホルダー（テキスト表示はしない） */
/* プレースホルダーは丸型のまま */
.mascot__placeholder {
	border-radius: var(--border-radius-full);
	display: block;
	background-color: var(--color-primary-light);
}

.mascot__placeholder::before {
	content: none;
}

.mascot--akari .mascot__placeholder {
	background-color: #FFF4E0;
}

.mascot--nono .mascot__placeholder {
	background-color: #F0F4FF;
}


/* ============================
   6. ヘッダー
   ============================ */
.site-header {
	background-color: var(--color-surface);
	border-bottom: 1px solid var(--color-border);
	position: sticky;
	top: 0;
	z-index: 100;
}

.site-header__inner {
	display: flex;
	align-items: center;
	justify-content: space-between;
	padding: var(--spacing-3) var(--container-padding);
	max-width: var(--container-max);
	margin-inline: auto;
	gap: var(--spacing-3);
}

.site-header__logo {
	flex-shrink: 0;
}

.site-header__name-link {
	text-decoration: none;
}

.site-header__name {
	font-size: var(--font-size-lg);
	font-weight: 700;
	color: var(--color-text);
	letter-spacing: -0.02em;
}

/* ハンバーガーボタン */
.site-header__nav-toggle {
	display: flex;
	align-items: center;
	justify-content: center;
	width: 44px;
	height: 44px;
	background: none;
	border: none;
	border-radius: var(--border-radius-sm);
	cursor: pointer;
	color: var(--color-text);
	-webkit-tap-highlight-color: transparent;
	transition: background-color var(--transition);
	flex-shrink: 0;
}
.site-header__nav-toggle:hover {
	background-color: var(--color-gray-100);
}

.site-header__hamburger,
.site-header__hamburger::before,
.site-header__hamburger::after {
	display: block;
	width: 22px;
	height: 2px;
	background-color: var(--color-text);
	border-radius: 2px;
	transition: transform 0.25s ease, opacity 0.25s ease;
}
.site-header__hamburger {
	position: relative;
}
.site-header__hamburger::before,
.site-header__hamburger::after {
	content: '';
	position: absolute;
	left: 0;
}
.site-header__hamburger::before { top: -7px; }
.site-header__hamburger::after  { top:  7px; }

/* ハンバーガー → ✕ アニメーション */
.is-nav-open .site-header__hamburger {
	background-color: transparent;
}
.is-nav-open .site-header__hamburger::before {
	transform: translateY(7px) rotate(45deg);
}
.is-nav-open .site-header__hamburger::after {
	transform: translateY(-7px) rotate(-45deg);
}


/* ============================
   6b. ドロワーナビゲーション
   ============================ */

/* オーバーレイ */
.site-nav-overlay {
	position: fixed;
	inset: 0;
	z-index: 290;
	background-color: rgba(58,53,48,.55);
	opacity: 0;
	visibility: hidden;
	transition: opacity 0.3s ease, visibility 0.3s ease;
}
.site-nav-overlay.is-open {
	opacity: 1;
	visibility: visible;
}

/* ドロワー本体 */
.site-nav-drawer {
	position: fixed;
	top: 0;
	right: 0;
	z-index: 300;
	width: min(320px, 90vw);
	height: 100dvh;
	background-color: var(--color-surface);
	box-shadow: var(--shadow-lg);
	display: flex;
	flex-direction: column;
	transform: translateX(100%);
	transition: transform 0.3s cubic-bezier(.4,0,.2,1);
	overflow: hidden;
}
.site-nav-drawer.is-open {
	transform: translateX(0);
}

/* ドロワーヘッダー */
.site-nav-drawer__header {
	display: flex;
	align-items: center;
	justify-content: space-between;
	padding: var(--spacing-4) var(--spacing-5);
	border-bottom: 1px solid var(--color-border);
	min-height: 56px;
	background-color: var(--color-primary-light);
}
.site-nav-drawer__title {
	font-size: var(--font-size-sm);
	font-weight: 700;
	color: var(--color-text);
	letter-spacing: .05em;
}
.site-nav-drawer__close {
	width: 36px;
	height: 36px;
	display: flex;
	align-items: center;
	justify-content: center;
	background: none;
	border: none;
	cursor: pointer;
	color: var(--color-text-light);
	font-size: var(--font-size-base);
	border-radius: var(--border-radius-full);
	transition: background-color var(--transition);
	-webkit-tap-highlight-color: transparent;
}
.site-nav-drawer__close:hover {
	background-color: var(--color-gray-100);
}

/* ドロワー本文（スクロール可能） */
.site-nav-drawer__body {
	overflow-y: auto;
	flex: 1;
	padding: var(--spacing-3) 0 calc(var(--spacing-4) + env(safe-area-inset-bottom));
	-webkit-overflow-scrolling: touch;
}

/* ナビリスト */
.site-nav-drawer__list {
	list-style: none;
	padding: 0;
	margin: 0;
}

/* WordPressメニューのul対応 */
.site-nav-drawer__list > li > a,
.site-nav-drawer__link {
	display: flex;
	align-items: center;
	gap: var(--spacing-3);
	padding: var(--spacing-4) var(--spacing-5);
	color: var(--color-text);
	text-decoration: none;
	font-size: var(--font-size-base);
	font-weight: 500;
	transition: background-color var(--transition), color var(--transition);
	border-left: 3px solid transparent;
}
.site-nav-drawer__list > li > a:hover,
.site-nav-drawer__link:hover {
	background-color: var(--color-primary-light);
	color: var(--color-primary-dark);
	border-left-color: var(--color-primary);
	text-decoration: none;
}
.site-nav-drawer__list > li > a.current-menu-item,
.site-nav-drawer__link.current-menu-item {
	background-color: var(--color-primary-light);
	color: var(--color-primary-dark);
	border-left-color: var(--color-primary);
	font-weight: 700;
}

.site-nav-drawer__icon {
	font-size: 1.25rem;
	line-height: 1;
	width: 28px;
	text-align: center;
	flex-shrink: 0;
}

/* グループラベル（仕切り） */
.site-nav-drawer__item--divider {
	padding: var(--spacing-4) var(--spacing-5) var(--spacing-1);
	margin-top: var(--spacing-2);
	border-top: 1px solid var(--color-border);
}
.site-nav-drawer__group-label {
	font-size: var(--font-size-xs);
	color: var(--color-text-light);
	font-weight: 700;
	letter-spacing: .08em;
	text-transform: uppercase;
}

/* WordPressメニュー サブメニュー */
.site-nav-drawer__list .sub-menu {
	border-left: 3px solid var(--color-primary-light);
	margin-left: var(--spacing-10);
}
.site-nav-drawer__list .sub-menu a {
	padding: var(--spacing-3) var(--spacing-4);
	font-size: var(--font-size-sm);
	color: var(--color-text-light);
}

/* ============================
   7. ボトムナビゲーション
   ============================ */
.bottom-nav {
	position: fixed;
	bottom: 0;
	left: 0;
	right: 0;
	z-index: 200;
	background-color: var(--color-surface);
	border-top: 1px solid var(--color-border);
	min-height: var(--bottom-nav-height);
	padding-bottom: env(safe-area-inset-bottom, 0px);
	box-shadow: 0 -2px 12px rgba(60,50,40,.08);
}

.bottom-nav__list {
	display: flex;
	height: 100%;
	max-width: var(--container-max);
	margin-inline: auto;
}

.bottom-nav__item {
	flex: 1;
}

.bottom-nav__link {
	display: flex;
	flex-direction: column;
	align-items: center;
	justify-content: center;
	gap: 3px;
	height: 100%;
	color: var(--color-gray-600);
	text-decoration: none;
	font-size: var(--font-size-xs);
	line-height: 1;
	padding: var(--spacing-2) var(--spacing-1);
	transition: color var(--transition);
	-webkit-tap-highlight-color: transparent;
}

.bottom-nav__link.is-active,
.bottom-nav__link:hover {
	color: var(--color-primary);
}

.bottom-nav__icon {
	font-size: 1.375rem;
	display: block;
	line-height: 1;
}

.bottom-nav__label {
	display: block;
	white-space: nowrap;
}


/* ============================
   8. フッター
   ============================ */
.site-footer {
	background-color: var(--color-gray-100);
	border-top: 1px solid var(--color-border);
	padding: var(--spacing-8) 0 var(--spacing-6);
}

.site-footer__inner {
	display: flex;
	flex-direction: column;
	gap: var(--spacing-4);
}

.site-footer__name a {
	font-weight: 700;
	color: var(--color-text);
	font-size: var(--font-size-md);
}

.site-footer__nav ul {
	display: flex;
	flex-wrap: wrap;
	gap: var(--spacing-4);
}

.site-footer__nav a {
	font-size: var(--font-size-sm);
	color: var(--color-text-light);
}

.site-footer__note {
	font-size: var(--font-size-xs);
	color: var(--color-text-light);
	line-height: var(--line-height-base);
}

.site-footer__copy {
	color: var(--color-gray-600);
	font-size: var(--font-size-xs);
}


/* ============================
   9. セクション共通
   ============================ */
.section {
	padding: var(--spacing-10) 0;
}

.section--gray {
	background-color: var(--color-gray-50);
}

.section--primary-light {
	background-color: var(--color-primary-light);
}

.section__title {
	font-size: var(--font-size-xl);
	font-weight: 700;
	margin-bottom: var(--spacing-2);
	letter-spacing: -0.02em;
}

.section__desc {
	font-size: var(--font-size-sm);
	color: var(--color-text-light);
	margin-bottom: var(--spacing-5);
}

.section__more {
	margin-top: var(--spacing-6);
	text-align: center;
}


/* ============================
   10. ボタン
   ============================ */
.btn {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: var(--spacing-2);
	padding: var(--spacing-3) var(--spacing-6);
	border-radius: var(--border-radius-full);
	font-size: var(--font-size-base);
	font-weight: 700;
	text-decoration: none;
	transition: all var(--transition);
	-webkit-tap-highlight-color: transparent;
	white-space: nowrap;
	border: 2px solid transparent;
}

.btn--primary {
	background-color: var(--color-primary);
	color: #fff;
	border-color: var(--color-primary);
}
.btn--primary:hover {
	background-color: var(--color-primary-dark);
	border-color: var(--color-primary-dark);
	text-decoration: none;
	color: #fff;
}

.btn--secondary {
	/* 後方互換: 旧secondary（緑塗り）。新規実装では .btn--green を使用 */
	background-color: var(--color-green);
	color: #fff;
	border-color: var(--color-green);
}
.btn--secondary:hover {
	background-color: #4a9b7e;
	border-color: #4a9b7e;
	text-decoration: none;
	color: #fff;
}

/* 安心/確認系（公式情報・状況別など）。primary と並ぶ第二CTA */
.btn--green {
	background-color: var(--color-green);
	color: #fff;
	border-color: var(--color-green);
}
.btn--green:hover {
	background-color: #4a9b7e;
	border-color: #4a9b7e;
	text-decoration: none;
	color: #fff;
}

/* 戻る/補助導線。白背景＋枠線 */
.btn--outline {
	background-color: var(--color-surface);
	color: var(--color-text);
	border-color: var(--color-gray-300);
}
.btn--outline:hover {
	background-color: var(--color-gray-50);
	border-color: var(--color-gray-600);
	text-decoration: none;
	color: var(--color-text);
}

.btn--ghost {
	background-color: transparent;
	color: var(--color-text);
	border-color: var(--color-border);
}
.btn--ghost:hover {
	border-color: var(--color-gray-300);
	text-decoration: none;
	background-color: var(--color-gray-50);
}

.btn--large {
	padding: var(--spacing-4) var(--spacing-8);
	font-size: var(--font-size-md);
	width: 100%;
}

/* Phase 27: 小型ボタン（pending UIなど） */
.btn--xs {
	padding: 0.35rem 0.7rem;
	font-size: var(--font-size-xs);
	min-width: 0;
	white-space: nowrap;
}

/* モバイル横幅いっぱいに広げるユーティリティ */
.btn--block {
	display: flex;
	width: 100%;
}

/* ============================
   10b. カードリンク（カード全体タップ可）
   ============================ */
.card-link {
	display: block;
	position: relative;
	background-color: var(--color-surface);
	border: 1px solid var(--color-border);
	border-radius: var(--border-radius-base);
	padding: var(--spacing-5);
	text-decoration: none;
	color: var(--color-text);
	transition: transform var(--transition), box-shadow var(--transition), border-color var(--transition);
	-webkit-tap-highlight-color: transparent;
	min-height: 44px;
}
.card-link:hover {
	transform: translateY(-2px);
	box-shadow: var(--shadow-md);
	border-color: var(--color-gray-300);
	text-decoration: none;
	color: var(--color-text);
}
.card-link:focus-visible {
	outline: 3px solid var(--color-primary);
	outline-offset: 2px;
}
.card-link__title {
	font-weight: 700;
	font-size: var(--font-size-md);
	line-height: var(--line-height-tight);
	margin-bottom: var(--spacing-2);
}
.card-link__desc {
	font-size: var(--font-size-sm);
	color: var(--color-text-light);
	line-height: 1.6;
	margin-bottom: var(--spacing-3);
}
.card-link__cta {
	display: inline-flex;
	align-items: center;
	gap: var(--spacing-1);
	font-size: var(--font-size-sm);
	font-weight: 700;
	color: var(--color-primary-dark);
}
.card-link__cta::after {
	content: "";
	display: inline-block;
	width: 6px;
	height: 6px;
	border-top: 2px solid currentColor;
	border-right: 2px solid currentColor;
	transform: rotate(45deg);
	margin-left: var(--spacing-1);
}

.link-more {
	color: var(--color-text-link);
	font-size: var(--font-size-sm);
	font-weight: 500;
}
.link-more:hover {
	text-decoration: underline;
}

.link-back {
	color: var(--color-text-light);
	font-size: var(--font-size-sm);
	display: inline-flex;
	align-items: center;
	gap: var(--spacing-1);
}

.link-text {
	color: var(--color-text-light);
	font-size: var(--font-size-sm);
	text-decoration: underline;
	cursor: pointer;
	background: none;
	border: none;
	padding: 0;
	font-family: var(--font-base);
}


/* ============================
   11. バッジ
   ============================ */
.badge {
	display: inline-flex;
	align-items: center;
	padding: 2px var(--spacing-2);
	border-radius: var(--border-radius-full);
	font-size: var(--font-size-xs);
	font-weight: 700;
	white-space: nowrap;
}

.badge--easy {
	background-color: var(--color-green-light);
	color: #2e7d57;
}

.badge--medium {
	background-color: #FFF3E0;
	color: #b56a00;
}

.badge--hard {
	background-color: #FFF0EE;
	color: #c0392b;
}

/* 状況バッジ（タスクカードに JS で動的注入） */
.badge--situation {
	background-color: var(--color-info-light);
	color: var(--color-info);
	margin-left: var(--spacing-1);
}
.badge--situation-typhoon,
.badge--situation-rain {
	background-color: var(--color-warning-light);
	color: var(--color-warning);
}
.badge--situation-earthquake {
	background-color: var(--color-alert-light);
	color: var(--color-alert);
}
.badge--situation-blackout,
.badge--situation-water_cut {
	background-color: var(--color-info-light);
	color: var(--color-info);
}
.badge--situation-heat {
	background-color: #FFF3E0;
	color: #b56a00;
}


/* ============================
   12. ページヒーロー
   ============================ */
.page-hero {
	background-color: var(--color-primary-light);
	padding: var(--spacing-8) 0 var(--spacing-6);
	border-bottom: 1px solid var(--color-border);
}

.page-hero--guide,
.page-hero--guide-single {
	background-color: var(--color-green-light);
}

.page-hero--shindan {
	background: linear-gradient(135deg, #FFF8EE 0%, #EEF5FA 100%);
}

.page-hero--memo,
.page-hero--memo-single {
	background-color: var(--color-blue-light);
}

.page-hero--links {
	background-color: var(--color-green-light);
}

.page-hero--joho {
	background-color: #F0EFF7;
}

.page-hero--contact {
	background-color: var(--color-gray-50);
}

.page-hero--about {
	background-color: var(--color-primary-light);
}

.page-hero--error {
	background-color: var(--color-gray-100);
}

.page-hero__cat {
	font-size: var(--font-size-xs);
	color: var(--color-text-light);
	margin-bottom: var(--spacing-1);
	font-weight: 500;
}

.page-hero__title {
	font-size: var(--font-size-2xl);
	font-weight: 700;
	line-height: var(--line-height-tight);
	letter-spacing: -0.03em;
	margin-bottom: var(--spacing-2);
}

.page-hero__sub {
	font-size: var(--font-size-sm);
	color: var(--color-text-light);
}

.page-hero__date {
	font-size: var(--font-size-xs);
	color: var(--color-text-light);
	margin-bottom: var(--spacing-2);
}


/* ============================
   13. ページ本文
   ============================ */
.page-body {
	padding-top: var(--spacing-6);
}

.page-body--narrow {
	max-width: 560px;
	margin-inline: auto;
}

.page-body h2 {
	font-size: var(--font-size-xl);
	font-weight: 700;
	margin-top: var(--spacing-8);
	margin-bottom: var(--spacing-4);
	letter-spacing: -0.02em;
}

.page-body h3 {
	font-size: var(--font-size-lg);
	font-weight: 700;
	margin-top: var(--spacing-6);
	margin-bottom: var(--spacing-3);
}

.page-body p {
	margin-bottom: var(--spacing-4);
	line-height: var(--line-height-base);
}

.page-body ul,
.page-body ol {
	margin-bottom: var(--spacing-4);
	list-style: disc;
}

.page-body ol {
	list-style: decimal;
}

.page-body li {
	margin-bottom: var(--spacing-2);
	line-height: var(--line-height-base);
}

.page-body strong {
	font-weight: 700;
}


/* ============================
   14. ヒーロー（TOP）
   ============================ */
.hero {
	padding: var(--spacing-10) 0;
	background: linear-gradient(160deg, var(--color-primary-light) 0%, #FFFDF7 60%);
}

.hero__inner {
	display: flex;
	flex-direction: column;
	gap: var(--spacing-6);
	align-items: center;
	text-align: center;
}

.hero__title {
	font-size: var(--font-size-2xl);
	font-weight: 700;
	line-height: var(--line-height-tight);
	letter-spacing: -0.03em;
	margin-bottom: var(--spacing-4);
}

.hero__title strong {
	color: var(--color-primary-dark);
}

.hero__desc {
	font-size: var(--font-size-sm);
	color: var(--color-text-light);
	margin-bottom: var(--spacing-6);
	line-height: var(--line-height-base);
}

.hero__mascot {
	margin-bottom: var(--spacing-2);
}


/* ============================
   15. 状況別ガイドカード（TOP）
   ============================ */
.guide-cards {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: var(--spacing-3);
}

.guide-card {
	display: flex;
	flex-direction: column;
	align-items: center;
	gap: var(--spacing-2);
	padding: var(--spacing-3) var(--spacing-2);
	background-color: var(--color-surface);
	border: 1px solid var(--color-border);
	border-radius: var(--border-radius-base);
	text-decoration: none;
	color: var(--color-text);
	text-align: center;
	transition: all var(--transition);
	box-shadow: var(--shadow-sm);
}

.guide-card:hover {
	border-color: var(--color-primary);
	box-shadow: var(--shadow-base);
	text-decoration: none;
}

.guide-card__title {
	font-size: var(--font-size-xs);
	font-weight: 700;
	line-height: var(--line-height-tight);
}


/* ============================
   16. アイテムカード（まず揃えるもの）
   ============================ */
.item-cards {
	display: flex;
	flex-direction: column;
	gap: var(--spacing-3);
}

.item-card {
	display: flex;
	align-items: center;
	gap: var(--spacing-4);
	background-color: var(--color-surface);
	border: 1px solid var(--color-border);
	border-radius: var(--border-radius-base);
	padding: var(--spacing-4);
	box-shadow: var(--shadow-sm);
}

.item-card__icon {
	font-size: 2rem;
	flex-shrink: 0;
	width: 48px;
	text-align: center;
}

.item-card__title {
	font-size: var(--font-size-base);
	font-weight: 700;
	margin-bottom: 2px;
}

.item-card__desc {
	font-size: var(--font-size-xs);
	color: var(--color-text-light);
}


/* ============================
   17. タスクリスト
   ============================ */
.task-list {
	display: flex;
	flex-direction: column;
	gap: var(--spacing-3);
}

.task-list__item {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: var(--spacing-3);
	background-color: var(--color-surface);
	border: 1px solid var(--color-border);
	border-radius: var(--border-radius-base);
	padding: var(--spacing-4);
	box-shadow: var(--shadow-sm);
}

.task-list__item.is-done {
	background-color: var(--color-green-light);
	border-color: var(--color-green);
	opacity: 0.7;
}

/* 次タスク強調アニメーション */
@keyframes highlight-pulse {
	0%   { box-shadow: 0 0 0 0 rgba(245, 163, 42, 0.5); }
	50%  { box-shadow: 0 0 0 6px rgba(245, 163, 42, 0.2); }
	100% { box-shadow: 0 0 0 0 rgba(245, 163, 42, 0); }
}

.task-list__item.is-highlighted {
	animation: highlight-pulse 0.8s ease 2;
	border-color: var(--color-primary);
}

.task-list__body {
	display: flex;
	flex-direction: column;
	gap: var(--spacing-1);
	flex: 1;
	min-width: 0;
}

.task-list__title {
	font-size: var(--font-size-base);
	font-weight: 500;
	line-height: var(--line-height-tight);
}

.task-list__note {
	font-size: var(--font-size-xs);
	color: var(--color-text-light);
	line-height: var(--line-height-base);
}

/* できたボタン／アクションエリア */
.task-list__actions {
	display: flex;
	flex-direction: column;
	gap: var(--spacing-2);
	flex-shrink: 0;
}

.dekita-btn {
	flex-shrink: 0;
	background-color: var(--color-primary);
	color: #fff;
	border-radius: var(--border-radius-full);
	padding: var(--spacing-2) var(--spacing-4);
	font-size: var(--font-size-sm);
	font-weight: 700;
	transition: all var(--transition);
	border: 2px solid transparent;
	min-width: 72px;
	min-height: 44px;
	text-align: center;
}

.dekita-btn:hover {
	background-color: var(--color-primary-dark);
}

.dekita-btn.is-done {
	background-color: var(--color-green);
	cursor: default;
}

/* もうある場合も：できた！ボタンの上に置く補足ラベル（ボタンではない） */
.already-hint {
	display: inline-block;
	position: relative;
	align-self: start;
	margin-bottom: 8px;
	background-color: var(--color-surface);
	border: 1px solid var(--color-border);
	border-radius: 8px;
	padding: 3px 10px;
	font-size: 0.7rem;
	color: var(--color-text-light);
	line-height: 1.4;
	white-space: nowrap;
	pointer-events: none;
}

/* 下向き三角でできた！ボタンを指す */
.already-hint::before {
	content: '';
	position: absolute;
	bottom: -7px;
	right: 18px;
	border-width: 7px 5px 0;
	border-style: solid;
	border-color: var(--color-border) transparent transparent;
}
.already-hint::after {
	content: '';
	position: absolute;
	bottom: -5px;
	right: 19px;
	border-width: 6px 4px 0;
	border-style: solid;
	border-color: var(--color-surface) transparent transparent;
}

/* タスクが完了済みのときは補足は薄める */
.task-list__item.is-done .already-hint {
	opacity: 0.4;
}

/* タスクフィルター */
.task-filter {
	display: flex;
	flex-wrap: wrap;
	gap: var(--spacing-2);
	margin-bottom: var(--spacing-5);
}

.task-filter__btn {
	padding: var(--spacing-2) var(--spacing-4);
	border-radius: var(--border-radius-full);
	border: 1px solid var(--color-border);
	font-size: var(--font-size-sm);
	font-weight: 500;
	color: var(--color-text-light);
	background-color: var(--color-surface);
	transition: all var(--transition);
}

.task-filter__btn.is-active,
.task-filter__btn:hover {
	border-color: var(--color-primary);
	color: var(--color-primary-dark);
	background-color: var(--color-primary-light);
}


/* ============================
   18. できたモーダル
   ============================ */
.dekita-modal {
	position: fixed;
	inset: 0;
	z-index: 500;
	display: flex;
	align-items: flex-end;
	justify-content: center;
}

.dekita-modal[aria-hidden="true"] {
	display: none;
}

.dekita-modal__overlay {
	position: absolute;
	inset: 0;
	background-color: rgba(60,50,40,.5);
	cursor: pointer;
}

.dekita-modal__content {
	position: relative;
	background-color: var(--color-surface);
	border-radius: var(--border-radius-lg) var(--border-radius-lg) 0 0;
	padding: var(--spacing-8) var(--spacing-6) calc(var(--spacing-8) + var(--bottom-nav-height));
	width: 100%;
	max-width: var(--container-max);
	max-width: 100vw;
	max-height: 100vh;
	overflow: auto;
	text-align: center;
	animation: slideUp 0.3s ease;
}

@keyframes slideUp {
	from { transform: translateY(100%); }
	to   { transform: translateY(0); }
}

.dekita-modal__close {
	position: absolute;
	top: var(--spacing-4);
	right: var(--spacing-4);
	font-size: var(--font-size-lg);
	color: var(--color-gray-600);
	width: 36px;
	height: 36px;
	display: flex;
	align-items: center;
	justify-content: center;
}

.dekita-modal__mascot {
	margin-bottom: var(--spacing-4);
	display: flex;
	justify-content: center;
}

.dekita-modal__heading {
	font-size: var(--font-size-xl);
	font-weight: 700;
	margin-bottom: var(--spacing-2);
	color: var(--color-primary-dark);
}

.dekita-modal__task-title {
	display: inline-block;
	font-size: var(--font-size-base);
	font-weight: 700;
	color: var(--color-text);
	background-color: var(--color-primary-light);
	padding: var(--spacing-1) var(--spacing-3);
	border-radius: var(--border-radius-full);
	margin-bottom: var(--spacing-3);
	max-width: 100%;
	overflow-wrap: anywhere;
}

.dekita-modal__message {
	font-size: var(--font-size-md);
	font-weight: 500;
	margin-bottom: var(--spacing-3);
	color: var(--color-text);
}

.dekita-modal__sub {
	font-size: var(--font-size-sm);
	color: var(--color-text-light);
	margin-bottom: var(--spacing-6);
	line-height: var(--line-height-base);
}

/* ▼ Phase9: 累計カウントチップ + マイルストーン強調 */
.dekita-modal__count {
	display: inline-block;
	font-size: var(--font-size-sm);
	color: var(--color-primary-dark);
	background-color: var(--color-primary-light);
	padding: var(--spacing-1) var(--spacing-3);
	border-radius: var(--border-radius-full);
	margin: 0 0 var(--spacing-4);
	font-weight: 700;
}
.dekita-modal__count strong {
	font-size: var(--font-size-md);
	margin: 0 2px;
}
.dekita-modal__sub.is-milestone {
	color: var(--color-primary-dark);
	font-weight: 700;
	font-size: var(--font-size-base);
	background-color: #fff8e1;
	border-radius: var(--border-radius-base);
	padding: var(--spacing-3);
}

/* ============================================================
   Phase 28: レベルアップお祝いブロック（dekita-modal 内）
   ============================================================ */
.dekita-modal__levelup {
	margin: var(--spacing-3) 0 var(--spacing-5);
	padding: var(--spacing-4);
	background: linear-gradient(135deg, #fff8e1, #ffe9b3);
	border: 2px solid var(--color-primary, #f5a32a);
	border-radius: var(--border-radius-lg, 12px);
	text-align: center;
	animation: dekitaLevelupPop 0.5s ease-out;
}
.dekita-modal__levelup[hidden] { display: none; }
.dekita-modal__levelup-eyebrow {
	font-size: var(--font-size-xs);
	font-weight: 700;
	color: var(--color-primary-dark, #d27a00);
	letter-spacing: 0.08em;
	margin: 0 0 var(--spacing-1);
}
.dekita-modal__levelup-num {
	font-size: 1.5rem;
	font-weight: 800;
	color: var(--color-text);
	margin: 0 0 var(--spacing-1);
	line-height: 1.2;
}
.dekita-modal__levelup-num span {
	color: var(--color-primary-dark, #d27a00);
	font-size: 1.7em;
	margin: 0 0.1em;
}
.dekita-modal__levelup-title {
	font-size: var(--font-size-base);
	font-weight: 700;
	color: var(--color-text);
	margin: 0 0 var(--spacing-2);
}
.dekita-modal__levelup-msg {
	font-size: var(--font-size-sm);
	color: var(--color-text);
	margin: 0;
	line-height: 1.5;
}
@keyframes dekitaLevelupPop {
	0%   { transform: scale(0.85); opacity: 0; }
	60%  { transform: scale(1.04); opacity: 1; }
	100% { transform: scale(1); opacity: 1; }
}
.dekita-modal--levelup .dekita-modal__mascot {
	animation: dekitaLevelupBounce 0.6s ease-out;
}
@keyframes dekitaLevelupBounce {
	0%   { transform: translateY(0); }
	30%  { transform: translateY(-12px); }
	60%  { transform: translateY(0); }
	80%  { transform: translateY(-4px); }
	100% { transform: translateY(0); }
}

.dekita-modal__actions {
	display: flex;
	flex-direction: column;
	gap: var(--spacing-3);
	margin-bottom: var(--spacing-6);
}


/* ============================
   19. SNSシェア
   ============================ */
.share-block {
	padding-top: var(--spacing-4);
	border-top: 1px solid var(--color-border);
}

.share-block__label {
	font-size: var(--font-size-xs);
	color: var(--color-text-light);
	margin-bottom: var(--spacing-3);
}

.share-block__buttons {
	display: flex;
	justify-content: center;
	gap: var(--spacing-3);
	margin-bottom: var(--spacing-3);
}

.share-btn {
	display: inline-flex;
	align-items: center;
	gap: var(--spacing-2);
	padding: var(--spacing-2) var(--spacing-5);
	border-radius: var(--border-radius-full);
	font-size: var(--font-size-sm);
	font-weight: 700;
	text-decoration: none;
	transition: opacity var(--transition);
}
.share-btn:hover {
	opacity: 0.85;
	text-decoration: none;
}

.share-btn--x {
	background-color: #000;
	color: #fff;
}

.share-block__note {
	font-size: var(--font-size-xs);
	color: var(--color-text-light);
	line-height: var(--line-height-base);
}


/* ============================
   20. 今日のそなえバナー
   ============================ */
.kyou-no-sonae {
	padding: var(--spacing-5) 0;
}

/* バナー全体の色味（モード別） */
.kyou-no-sonae--normal {
	--kyou-accent: var(--color-primary);
	--kyou-accent-dark: var(--color-primary-dark);
	--kyou-accent-soft: var(--color-primary-light);
}
.kyou-no-sonae--warning {
	--kyou-accent: var(--color-warning);
	--kyou-accent-dark: var(--color-warning);
	--kyou-accent-soft: var(--color-warning-light);
}
.kyou-no-sonae--alert {
	--kyou-accent: var(--color-alert);
	--kyou-accent-dark: var(--color-alert);
	--kyou-accent-soft: var(--color-alert-light);
}
.kyou-no-sonae--info {
	--kyou-accent: var(--color-blue, #3a86b8);
	--kyou-accent-dark: var(--color-info, #2c6e9b);
	--kyou-accent-soft: var(--color-blue-light, #e8f2f8);
}

/* カード本体：左にアクセントバー、内容を構造化 */
.kyou-no-sonae__card {
	display: grid;
	grid-template-columns: auto 1fr;
	gap: var(--spacing-4);
	background-color: var(--color-surface, #fff);
	border: 1px solid rgba(0, 0, 0, 0.06);
	border-left: 4px solid var(--kyou-accent);
	border-radius: var(--border-radius-lg, 12px);
	padding: var(--spacing-5);
	box-shadow: 0 2px 6px rgba(0, 0, 0, 0.04);
}

/* 旧クラスの後方互換（テンプレ更新後は使用されないが、念のため） */
.kyou-no-sonae__inner {
	display: flex;
	align-items: flex-start;
	gap: var(--spacing-3);
}
.kyou-no-sonae__icon {
	display: none;
}

/* モード別アイコン円 */
.kyou-no-sonae__visual {
	display: flex;
	align-items: flex-start;
	justify-content: center;
}
.kyou-no-sonae__icon-circle {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 48px;
	height: 48px;
	border-radius: 50%;
	background-color: var(--kyou-accent-soft);
	color: var(--kyou-accent-dark);
	flex-shrink: 0;
}
.kyou-no-sonae__svg {
	display: block;
}

/* 本文カラム */
.kyou-no-sonae__body {
	min-width: 0;
}

/* eyebrow（バッジ＋ラベル） */
.kyou-no-sonae__eyebrow {
	display: flex;
	align-items: center;
	flex-wrap: wrap;
	gap: var(--spacing-2);
	margin: 0 0 var(--spacing-2);
	font-size: var(--font-size-xs);
	color: var(--color-text-light);
	letter-spacing: 0.04em;
}
.kyou-no-sonae__eyebrow-label {
	font-weight: 600;
}
.kyou-no-sonae__badge {
	display: inline-flex;
	align-items: center;
	font-size: 0.72rem;
	font-weight: 700;
	padding: 2px 8px;
	border-radius: var(--border-radius-full, 999px);
	letter-spacing: 0.05em;
	line-height: 1.4;
}
.kyou-no-sonae__badge--urgent {
	color: #fff;
	background-color: var(--color-alert, #c0392b);
}
.kyou-no-sonae__badge--attention {
	color: #7a5300;
	background-color: rgba(255, 178, 60, 0.22);
}

/* タイトル */
.kyou-no-sonae__title {
	font-size: var(--font-size-lg, 1.15rem);
	font-weight: 700;
	margin: 0 0 var(--spacing-2);
	line-height: 1.45;
	color: var(--color-text);
}

/* 本文 */
.kyou-no-sonae__text {
	font-size: var(--font-size-sm);
	margin: 0 0 var(--spacing-3);
	line-height: var(--line-height-base, 1.7);
	color: var(--color-text);
}

/* CTA + 注意書きをひとまとまりに */
.kyou-no-sonae__actions {
	display: flex;
	align-items: center;
	flex-wrap: wrap;
	gap: var(--spacing-2) var(--spacing-4);
	margin-bottom: 0;
}

/* CTA：塗りボタンに昇格して直感性を上げる */
.kyou-no-sonae__btn {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: var(--spacing-2);
	padding: var(--spacing-3) var(--spacing-5);
	border-radius: var(--border-radius-full, 999px);
	font-size: var(--font-size-sm);
	font-weight: 700;
	background-color: var(--kyou-accent-dark);
	color: #fff;
	border: 2px solid var(--kyou-accent-dark);
	text-decoration: none;
	transition: all var(--transition, 0.2s ease);
	min-height: 44px;
	line-height: 1.2;
}
.kyou-no-sonae__btn:hover,
.kyou-no-sonae__btn:focus-visible {
	background-color: #fff;
	color: var(--kyou-accent-dark);
	text-decoration: none;
	box-shadow: 0 2px 6px rgba(0, 0, 0, 0.1);
}
.kyou-no-sonae__btn-arrow {
	display: inline-flex;
	align-items: center;
	transition: transform var(--transition, 0.2s ease);
}
.kyou-no-sonae__btn:hover .kyou-no-sonae__btn-arrow {
	transform: translateX(2px);
}

.kyou-no-sonae__note {
	font-size: var(--font-size-xs);
	color: var(--color-text-light);
	margin: 0;
	line-height: 1.5;
}

/* 関連公式情報セクション（区切り線で明確に分ける） */
.kyou-no-sonae__related {
	margin-top: var(--spacing-4);
	padding-top: var(--spacing-3);
	border-top: 1px dashed rgba(0, 0, 0, 0.12);
}
.kyou-no-sonae__related-heading {
	margin: 0 0 var(--spacing-2);
	font-size: var(--font-size-xs);
	font-weight: 600;
	color: var(--color-text-light);
	letter-spacing: 0.03em;
}
.kyou-no-sonae__links {
	list-style: none;
	margin: 0;
	padding: 0;
	display: flex;
	flex-wrap: wrap;
	gap: var(--spacing-2) var(--spacing-3);
}
.kyou-no-sonae__link-item {
	display: inline-flex;
}
.kyou-no-sonae__link {
	display: inline-flex;
	align-items: center;
	gap: 4px;
	padding: 4px 10px;
	border-radius: var(--border-radius-full, 999px);
	background-color: var(--kyou-accent-soft);
	color: var(--kyou-accent-dark);
	font-size: 0.85rem;
	font-weight: 600;
	text-decoration: none;
	transition: background-color var(--transition, 0.2s ease);
}
.kyou-no-sonae__link:hover,
.kyou-no-sonae__link:focus-visible {
	background-color: var(--kyou-accent);
	color: #fff;
	text-decoration: none;
}
.kyou-no-sonae__link-ext {
	display: inline-flex;
	opacity: 0.85;
}

/* 旧 is-external CSS は塗りボタンに変わったため簡略化 */
.kyou-no-sonae__btn.is-external::after {
	content: none;
}

/* 優先度別の補助スタイル（カード自体を変化させる） */
.kyou-no-sonae--priority-attention .kyou-no-sonae__card {
	background-color: rgba(255, 245, 220, 0.5);
}
.kyou-no-sonae--priority-urgent .kyou-no-sonae__card {
	border-left-width: 6px;
	background-color: rgba(255, 235, 232, 0.6);
	box-shadow: 0 4px 12px rgba(220, 60, 60, 0.12);
}

/* レスポンシブ：狭幅ではアイコンを上に積む */
@media (max-width: 480px) {
	.kyou-no-sonae__card {
		grid-template-columns: 1fr;
		gap: var(--spacing-3);
		padding: var(--spacing-4);
	}
	.kyou-no-sonae__visual {
		justify-content: flex-start;
	}
	.kyou-no-sonae__icon-circle {
		width: 40px;
		height: 40px;
	}
	.kyou-no-sonae__btn {
		width: 100%;
	}
}

/* スクリーンリーダーのみに読ませるテキスト */
.screen-reader-text {
	border: 0;
	clip: rect(1px, 1px, 1px, 1px);
	-webkit-clip-path: inset(50%);
	clip-path: inset(50%);
	height: 1px;
	margin: -1px;
	overflow: hidden;
	padding: 0;
	position: absolute !important;
	width: 1px;
	word-wrap: normal !important;
}


/* ============================
   21. 今日やること（パーツ）
   ============================ */

/* ---- さりげないヒント（task-hint） ---- */
.task-hint {
	margin-top: var(--spacing-10);
	padding-top: var(--spacing-5);
	border-top: 1px dashed var(--color-gray-200);
}

.task-hint__label {
	font-size: var(--font-size-xs);
	color: var(--color-gray-600);
	font-weight: 700;
	letter-spacing: .06em;
	margin-bottom: var(--spacing-3);
}

ul.task-hint__list {
	display: flex;
	flex-direction: column;
	gap: var(--spacing-2);
	list-style: none;
}

.task-hint__check {
	display: flex;
	align-items: center;
	gap: var(--spacing-3);
	width: 100%;
	text-align: left;
	padding: var(--spacing-3) var(--spacing-4);
	background-color: var(--color-gray-50);
	border: 1px solid var(--color-gray-200);
	border-radius: var(--border-radius-base);
	font-size: var(--font-size-sm);
	color: var(--color-text);
	cursor: pointer;
	transition: background-color var(--transition), border-color var(--transition), color var(--transition);
	font-family: var(--font-base);
	line-height: var(--line-height-tight);
}

.task-hint__check:hover {
	background-color: var(--color-primary-light);
	border-color: var(--color-primary);
	color: var(--color-primary-dark);
}

.task-hint__check.is-done {
	background-color: var(--color-green-light);
	border-color: var(--color-green);
	color: #2e7d57;
	cursor: default;
	opacity: 0.75;
}

.task-hint__check-icon {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 20px;
	height: 20px;
	border: 1.5px solid var(--color-gray-300);
	border-radius: 50%;
	flex-shrink: 0;
	font-size: 10px;
	transition: all var(--transition);
	color: transparent;
}

.task-hint__check:hover .task-hint__check-icon {
	border-color: var(--color-primary);
}

.task-hint__check.is-done .task-hint__check-icon {
	border-color: var(--color-green);
	background-color: var(--color-green);
	color: #fff;
}

.task-hint__check-text {
	flex: 1;
}

/* Phase O-2: ボタン内に時間・難易度のチップを並べる */
.task-hint__meta {
	display: inline-flex;
	flex-wrap: wrap;
	gap: 4px;
	margin-left: auto;
	flex-shrink: 0;
}
.task-hint__chip {
	display: inline-flex;
	align-items: center;
	font-size: 0.7rem;
	font-weight: 600;
	padding: 1px 7px;
	border-radius: 999px;
	line-height: 1.4;
	background-color: rgba(0, 0, 0, 0.05);
	color: var(--color-text-light);
}
.task-hint__chip--time::before {
	content: "⏱\00a0";
	opacity: 0.7;
}
.task-hint__chip--diff-easy   { background-color: rgba(85, 170, 95, 0.12);  color: #2e7036; }
.task-hint__chip--diff-medium { background-color: rgba(220, 160, 50, 0.14); color: #8a5a00; }
.task-hint__chip--diff-hard   { background-color: rgba(200, 80, 80, 0.12);  color: #a14040; }

/* ---- 旧 today-task-block（front-page.php 等で引き続き使用） ---- */
.today-task-block {
	margin-top: var(--spacing-10);
	padding: var(--spacing-6);
	background-color: var(--color-primary-light);
	border-radius: var(--border-radius-lg);
	border: 1px solid rgba(245,163,42,.3);
}

.today-task-block__header {
	display: flex;
	align-items: center;
	gap: var(--spacing-2);
	margin-bottom: var(--spacing-4);
}

.today-task-block__icon {
	font-size: 1.25rem;
}

.today-task-block__title {
	font-size: var(--font-size-lg);
	font-weight: 700;
}

.today-task-block__footer {
	margin-top: var(--spacing-4);
	text-align: right;
}

.today-task-block__empty {
	color: var(--color-text-light);
	font-size: var(--font-size-sm);
}


/* ============================
   22. 診断ページ
   ============================ */
.shindan-wrapper {
	padding-top: var(--spacing-6);
	padding-bottom: var(--spacing-10);
}

.shindan-intro {
	display: flex;
	align-items: flex-start;
	gap: var(--spacing-4);
	margin-bottom: var(--spacing-6);
	padding: var(--spacing-4);
	background-color: var(--color-primary-light);
	border-radius: var(--border-radius-base);
}

.shindan-intro__mascot {
	flex-shrink: 0;
}

.shindan-intro__text {
	font-size: var(--font-size-sm);
	line-height: var(--line-height-base);
}

.shindan-intro__text p {
	margin: 0 0 var(--spacing-2);
}

.shindan-intro__text p:last-child {
	margin-bottom: 0;
}

.shindan-progress {
	height: 6px;
	background-color: var(--color-gray-200);
	border-radius: var(--border-radius-full);
	overflow: hidden;
	margin-bottom: var(--spacing-2);
}

.shindan-progress__bar {
	height: 100%;
	background-color: var(--color-primary);
	border-radius: var(--border-radius-full);
	transition: width 0.3s ease;
}

.shindan-progress__label {
	font-size: var(--font-size-xs);
	color: var(--color-text-light);
	text-align: right;
	margin-bottom: var(--spacing-5);
}

.shindan-question {
	display: none;
}

.shindan-question.is-active {
	display: block;
}

.shindan-question__text {
	font-size: var(--font-size-lg);
	font-weight: 700;
	line-height: var(--line-height-tight);
	margin-bottom: var(--spacing-6);
	padding: var(--spacing-5);
	background-color: var(--color-surface);
	border-radius: var(--border-radius-base);
	border: 1px solid var(--color-border);
}

.shindan-question__num {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 28px;
	height: 28px;
	background-color: var(--color-primary);
	color: #fff;
	border-radius: var(--border-radius-full);
	font-size: var(--font-size-sm);
	font-weight: 700;
	margin-right: var(--spacing-2);
	flex-shrink: 0;
}

.shindan-question__choices {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: var(--spacing-3);
}

/* 「よく分からない」は下段に幅全体 */
.shindan-choice--unknown {
	grid-column: 1 / -1;
	background-color: var(--color-gray-50);
	color: var(--color-text-light);
	font-size: var(--font-size-base);
	padding: var(--spacing-4);
}

.shindan-choice--unknown:hover,
.shindan-choice--unknown:focus {
	background-color: var(--color-gray-100);
	color: var(--color-text);
	border-color: var(--color-gray-300);
}

.shindan-choice {
	min-height: 56px;
	padding: var(--spacing-5);
	border-radius: var(--border-radius-base);
	border: 2px solid var(--color-border);
	font-size: var(--font-size-lg);
	font-weight: 700;
	background-color: var(--color-surface);
	color: var(--color-text);
	transition: all var(--transition);
}

/* はい：緑 / いいえ：グレー — ビジュアルで一瞬で判断できる */
.shindan-choice--yes {
	border-color: var(--color-green);
	color: var(--color-green);
}

.shindan-choice--yes:hover,
.shindan-choice--yes:focus {
	background-color: var(--color-green);
	color: #fff;
}

.shindan-choice--no {
	color: var(--color-text-light);
}

.shindan-choice--no:hover,
.shindan-choice--no:focus {
	border-color: var(--color-border);
	background-color: var(--color-bg);
	color: var(--color-text);
}

/* ヒント折りたたみ */
.shindan-question__hint-wrap {
	margin-top: var(--spacing-2);
}

.shindan-question__hint-toggle {
	font-size: var(--font-size-sm);
	color: var(--color-text-light);
	cursor: pointer;
	list-style: none;
	display: inline-flex;
	align-items: center;
	gap: var(--spacing-1);
}

.shindan-question__hint-toggle::before {
	content: '▶';
	font-size: 0.6em;
	transition: transform 0.15s ease;
}

details[open] .shindan-question__hint-toggle::before {
	transform: rotate(90deg);
}

.shindan-question__hint-wrap .shindan-question__hint {
	margin-top: var(--spacing-2);
	padding: var(--spacing-3) var(--spacing-4);
	background-color: var(--color-bg);
	border-radius: var(--border-radius-base);
	font-size: var(--font-size-sm);
	color: var(--color-text-light);
	line-height: var(--line-height-base);
}

/* 「いいえ」マイクロフィードバック */
.shindan-micro {
	position: absolute;
	left: 50%;
	top: 50%;
	transform: translate(-50%, -50%);
	background-color: rgba(58, 53, 48, 0.88);
	color: #fff;
	padding: var(--spacing-3) var(--spacing-5);
	border-radius: var(--border-radius-full);
	font-size: var(--font-size-sm);
	font-weight: 600;
	pointer-events: none;
	opacity: 0;
	transition: opacity 0.2s ease;
	white-space: nowrap;
	z-index: 10;
}

.shindan-micro.is-visible {
	opacity: 1;
}

.shindan-question {
	position: relative;
}

.shindan-skip {
	text-align: center;
	margin-top: var(--spacing-6);
}

.shindan-result {
	text-align: center;
	padding-top: var(--spacing-4);
}

.shindan-result__mascot {
	display: flex;
	justify-content: center;
	margin-bottom: var(--spacing-4);
}

.shindan-result__level {
	display: inline-block;
	font-size: var(--font-size-sm);
	font-weight: 700;
	background-color: var(--color-primary);
	color: #fff;
	padding: var(--spacing-1) var(--spacing-4);
	border-radius: var(--border-radius-full);
	margin-bottom: var(--spacing-3);
}

.shindan-result__title {
	font-size: var(--font-size-xl);
	font-weight: 700;
	margin-bottom: var(--spacing-3);
}

/* 残り感テキスト → レベル称号表示 */
.shindan-result__remain {
	font-size: var(--font-size-base);
	font-weight: 700;
	color: var(--color-primary-dark);
	margin-bottom: var(--spacing-3);
}

.shindan-result__desc {
	font-size: var(--font-size-sm);
	color: var(--color-text-light);
	margin-bottom: var(--spacing-2);
	line-height: var(--line-height-base);
	text-align: left;
}

/* 診断結果ヘッダー（レベル表示部分）*/
.shindan-result__head {
	text-align: center;
	margin-bottom: var(--spacing-6);
}

.shindan-result__lead {
	font-size: var(--font-size-sm);
	color: var(--color-text-light);
	margin-bottom: var(--spacing-2);
}

.shindan-result__intro {
	font-size: var(--font-size-sm);
	color: var(--color-text);
	line-height: var(--line-height-base);
	margin-top: var(--spacing-3);
}

/* Phase 26: 再診断時のやさしい注記 */
.shindan-result__redo-notice {
	margin-top: var(--spacing-3);
	padding: var(--spacing-2) var(--spacing-3);
	background-color: var(--color-bg-soft, #fff7ee);
	border-left: 3px solid var(--color-primary, #f5a32a);
	border-radius: var(--border-radius-base);
	font-size: var(--font-size-xs);
	color: var(--color-text);
	line-height: 1.5;
	text-align: left;
}
.shindan-result__redo-notice[hidden] { display: none; }
.shindan-result__next {
	margin-top: var(--spacing-4);
	padding: var(--spacing-3) var(--spacing-4);
	background-color: var(--color-gray-50);
	border-radius: var(--border-radius-base);
	text-align: left;
}

.shindan-result__next-toggle {
	font-size: var(--font-size-sm);
	font-weight: 700;
	color: var(--color-text);
	cursor: pointer;
	list-style: none;
	display: inline-flex;
	align-items: center;
	gap: var(--spacing-2);
}

.shindan-result__next-toggle::before {
	content: '▶';
	font-size: 0.6em;
	transition: transform 0.15s ease;
}

details[open] > .shindan-result__next-toggle::before {
	transform: rotate(90deg);
}

/* 結果タスクリスト（チェックリスト風）*/
.shindan-result__tasks-title {
	font-size: var(--font-size-md);
	font-weight: 700;
	margin-bottom: var(--spacing-3);
	text-align: left;
}

.result-task-item {
	display: flex;
	align-items: flex-start;
	gap: var(--spacing-3);
	padding: var(--spacing-3);
	background-color: var(--color-surface);
	border-radius: var(--border-radius-base);
	margin-bottom: var(--spacing-2);
	text-align: left;
}

.result-task-item:last-child {
	margin-bottom: 0;
}

.result-task-item__mark {
	flex-shrink: 0;
	font-size: var(--font-size-lg);
	color: var(--color-primary);
	line-height: 1;
}

.result-task-item__text {
	font-size: var(--font-size-base);
	font-weight: 700;
	line-height: var(--line-height-tight);
}

.result-task-item--empty {
	display: block;
	font-weight: 400;
	color: var(--color-text-light);
	text-align: left;
}

/* 結果タスク：最初の1件を大きく */
.result-task-featured {
	background-color: var(--color-primary-light);
	border: 2px solid var(--color-primary);
	border-radius: var(--border-radius-base);
	padding: var(--spacing-4);
	margin-bottom: var(--spacing-2);
	text-align: left;
}

.result-task-featured__label {
	display: inline-block;
	font-size: var(--font-size-xs, 0.75rem);
	font-weight: 700;
	color: var(--color-primary-dark);
	background-color: var(--color-primary);
	color: #fff;
	padding: 2px var(--spacing-2);
	border-radius: var(--border-radius-full);
	margin-bottom: var(--spacing-2);
}

.result-task-featured__title {
	font-size: var(--font-size-base);
	font-weight: 700;
	margin: 0;
}

.result-task-more {
	font-size: var(--font-size-sm);
	color: var(--color-text-light);
	text-align: right;
	margin-top: var(--spacing-1);
}

.shindan-result__tasks {
	text-align: left;
	background-color: var(--color-primary-light);
	border-radius: var(--border-radius-base);
	padding: var(--spacing-5);
	margin-bottom: var(--spacing-6);
}

.shindan-result__tasks h3 {
	font-size: var(--font-size-base);
	font-weight: 700;
	margin-bottom: var(--spacing-3);
}

.shindan-result__actions {
	display: flex;
	flex-direction: column;
	gap: var(--spacing-3);
	margin-bottom: var(--spacing-6);
}


/* ============================
   22b. 今日やること（kyou-intro / 診断後フィードバック）
   ============================ */
.kyou-intro {
	display: flex;
	align-items: flex-start;
	gap: var(--spacing-4);
	padding: var(--spacing-4);
	background-color: var(--color-gray-50);
	border-radius: var(--border-radius-base);
	margin-bottom: var(--spacing-6);
	font-size: var(--font-size-sm);
	line-height: var(--line-height-base);
}

.kyou-intro__mascot {
	flex-shrink: 0;
}

.kyou-intro__body,
.kyou-intro p {
	margin: 0;
}

.kyou-intro__from-shindan {
	background-color: var(--color-primary-light);
	border-left: 4px solid var(--color-primary);
	padding: var(--spacing-3) var(--spacing-4);
	border-radius: var(--border-radius-sm);
	margin: 0;
}


/* ============================
   23. 状況別ガイド一覧
   ============================ */
.guide-list-grid {
	display: flex;
	flex-direction: column;
	gap: var(--spacing-3);
	padding: var(--spacing-6) 0;
}

.guide-list-card {
	display: flex;
	gap: var(--spacing-4);
	background-color: var(--color-surface);
	border: 1px solid var(--color-border);
	border-radius: var(--border-radius-base);
	overflow: hidden;
	text-decoration: none;
	color: var(--color-text);
	box-shadow: var(--shadow-sm);
	transition: all var(--transition);
}

.guide-list-card:hover {
	box-shadow: var(--shadow-base);
	border-color: var(--color-green);
	text-decoration: none;
}

.guide-list-card__thumb {
	width: 100px;
	flex-shrink: 0;
	border-radius: 0;
}

.guide-list-card__body {
	padding: var(--spacing-4);
	flex: 1;
}

.guide-list-card__title {
	font-size: var(--font-size-md);
	font-weight: 700;
	margin-bottom: var(--spacing-2);
}

.guide-list-card__desc {
	font-size: var(--font-size-xs);
	color: var(--color-text-light);
	line-height: var(--line-height-base);
}

.guide-note {
	margin-top: var(--spacing-6);
	padding: var(--spacing-4);
	background-color: var(--color-gray-50);
	border-radius: var(--border-radius-base);
	font-size: var(--font-size-sm);
	color: var(--color-text-light);
	line-height: var(--line-height-base);
}


/* ============================
   24. 状況別ガイド詳細
   ============================ */
.guide-body {
	padding-top: var(--spacing-6);
	padding-bottom: var(--spacing-10);
}

.guide-section {
	margin-bottom: var(--spacing-8);
}

.guide-section--urgent {
	background-color: var(--color-alert-light);
	border-left: 4px solid var(--color-alert);
	border-radius: 0 var(--border-radius-base) var(--border-radius-base) 0;
	padding: var(--spacing-5);
}

.guide-section--info {
	background-color: var(--color-blue-light);
	border-left: 4px solid var(--color-blue);
	border-radius: 0 var(--border-radius-base) var(--border-radius-base) 0;
	padding: var(--spacing-5);
}

.guide-section--official {
	background-color: var(--color-green-light);
	border-left: 4px solid var(--color-green);
	border-radius: 0 var(--border-radius-base) var(--border-radius-base) 0;
	padding: var(--spacing-5);
}

.guide-section__title {
	display: flex;
	align-items: center;
	gap: var(--spacing-2);
	font-size: var(--font-size-lg);
	font-weight: 700;
	margin-bottom: var(--spacing-4);
}

.guide-section__num {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 28px;
	height: 28px;
	background-color: var(--color-primary);
	color: #fff;
	border-radius: var(--border-radius-full);
	font-size: var(--font-size-sm);
	font-weight: 700;
	flex-shrink: 0;
}

.guide-section__link {
	margin-top: var(--spacing-3);
}

.guide-back,
.memo-back {
	margin-top: var(--spacing-8);
}


/* ============================
   25. 公式リンクカード
   ============================ */
.links-section {
	margin-bottom: var(--spacing-8);
}

.links-section__title {
	display: flex;
	align-items: center;
	gap: var(--spacing-2);
	font-size: var(--font-size-xl);
	font-weight: 700;
	margin-bottom: var(--spacing-4);
	padding-bottom: var(--spacing-3);
	border-bottom: 2px solid var(--color-border);
}

.link-cards {
	display: flex;
	flex-direction: column;
	gap: var(--spacing-3);
}

.link-card {
	background-color: var(--color-surface);
	border: 1px solid var(--color-border);
	border-radius: var(--border-radius-base);
	padding: var(--spacing-4);
	box-shadow: var(--shadow-sm);
}

.link-card--bookmark {
	border-color: var(--color-primary);
	background-color: var(--color-primary-light);
}

.link-card__bookmark-badge {
	display: inline-block;
	font-size: var(--font-size-xs);
	font-weight: 700;
	color: var(--color-primary-dark);
	margin-bottom: var(--spacing-2);
}

.link-card__title {
	font-size: var(--font-size-md);
	font-weight: 700;
	margin-bottom: var(--spacing-3);
}

.link-card__can-check,
.link-card__when {
	font-size: var(--font-size-sm);
	margin-bottom: var(--spacing-2);
	line-height: var(--line-height-base);
}

.link-card__region {
	font-size: var(--font-size-xs);
	color: var(--color-text-light);
	margin-bottom: var(--spacing-3);
}

.link-card__btn {
	display: inline-flex;
	align-items: center;
	gap: var(--spacing-1);
	background-color: var(--color-primary);
	color: #fff;
	padding: var(--spacing-2) var(--spacing-4);
	border-radius: var(--border-radius-full);
	font-size: var(--font-size-sm);
	font-weight: 700;
	text-decoration: none;
	transition: background-color var(--transition);
}
.link-card__btn:hover {
	background-color: var(--color-primary-dark);
	text-decoration: none;
	color: #fff;
}

p.link-card__note {
	font-size: var(--font-size-xs);
	color: var(--color-text-light);
	margin-bottom: 0;
	margin-top: var(--spacing-2);
}

.links-notice {
	margin-top: var(--spacing-8);
	padding: var(--spacing-5);
	background-color: var(--color-gray-50);
	border-radius: var(--border-radius-base);
	font-size: var(--font-size-sm);
	line-height: var(--line-height-base);
	color: var(--color-text-light);
}

.links-intro {
	margin-bottom: var(--spacing-6);
	font-size: var(--font-size-sm);
	line-height: var(--line-height-base);
}

/* ▼ Phase5: 公式リンク集 ─ 追加スタイル */
.links-intro__lead {
	background-color: var(--color-primary-light);
	border-radius: var(--border-radius-base);
	padding: var(--spacing-4) var(--spacing-5);
	margin: 0 0 var(--spacing-3);
	font-size: var(--font-size-base);
	color: var(--color-text);
}

.links-intro__howto {
	background-color: var(--color-surface);
	border: 1px solid var(--color-border);
	border-radius: var(--border-radius-base);
	padding: var(--spacing-3) var(--spacing-4);
	font-size: var(--font-size-sm);
}
.links-intro__howto > summary {
	cursor: pointer;
	font-weight: 700;
	color: var(--color-text-light);
	list-style: none;
}
.links-intro__howto > summary::-webkit-details-marker { display: none; }
.links-intro__howto > summary::before {
	content: '\25B6';
	display: inline-block;
	font-size: var(--font-size-xs);
	margin-right: var(--spacing-2);
	transition: transform var(--transition);
}
.links-intro__howto[open] > summary::before { transform: rotate(90deg); }
.links-intro__howto ul {
	list-style: none;
	margin: var(--spacing-3) 0 0;
	padding: 0;
	display: flex;
	flex-direction: column;
	gap: var(--spacing-2);
	color: var(--color-text);
}

/* セクション補足（こんな時に） */
.links-section__sub,
.links-section__when {
	font-size: var(--font-size-sm);
	color: var(--color-text-light);
	margin: calc(var(--spacing-4) * -1 + var(--spacing-1)) 0 var(--spacing-4);
	line-height: var(--line-height-base);
}

/* ⭐ まずこれだけブックマーク セクション */
.links-section--picks {
	background-color: #FFFBF2;
	border: 1px solid var(--color-primary);
	border-radius: var(--border-radius-lg);
	padding: var(--spacing-5);
	margin-bottom: var(--spacing-8);
}
.links-section__title--picks {
	border-bottom: none;
	color: var(--color-primary-dark);
	padding-bottom: 0;
	margin-bottom: var(--spacing-2);
}

/* link-card 内のラベル（確認できること / こんな時に） */
.link-card__label {
	display: inline-block;
	font-size: var(--font-size-xs);
	font-weight: 700;
	color: var(--color-text-light);
	background-color: var(--color-gray-50);
	padding: 1px var(--spacing-2);
	border-radius: var(--border-radius-sm);
	margin-right: var(--spacing-1);
	margin-bottom: 2px;
}


/* ============================
   26. 情報の見方ページ
   ============================ */
.joho-intro {
	margin-bottom: var(--spacing-6);
	padding: var(--spacing-5);
	background-color: var(--color-gray-50);
	border-radius: var(--border-radius-base);
	font-size: var(--font-size-sm);
	line-height: var(--line-height-base);
}

.joho-section {
	margin-bottom: var(--spacing-8);
}

.joho-section__title {
	font-size: var(--font-size-xl);
	font-weight: 700;
	margin-bottom: var(--spacing-4);
	padding-bottom: var(--spacing-3);
	border-bottom: 2px solid var(--color-border);
}

#joho-feed-title {
	margin-top: calc(var(--spacing-8) + 50px);
}

/* ▼ Phase6: 追加 */
.joho-intro__lead {
	margin: 0;
	font-size: var(--font-size-base);
	color: var(--color-text);
	line-height: var(--line-height-base);
}

.joho-section__sub {
	font-size: var(--font-size-sm);
	color: var(--color-text-light);
	margin: calc(var(--spacing-4) * -1 + var(--spacing-1)) 0 var(--spacing-4);
	line-height: var(--line-height-base);
}

/* いざという時の3ステップ */
.joho-section--steps {
	background-color: var(--color-primary-light);
	border-radius: var(--border-radius-lg);
	padding: var(--spacing-5);
}
.joho-section--steps .joho-section__title {
	border-bottom-color: var(--color-primary);
	color: var(--color-primary-dark);
}

.joho-steps {
	list-style: none;
	margin: 0;
	padding: 0;
	display: flex;
	flex-direction: column;
	gap: var(--spacing-4);
}

.joho-steps__item {
	display: flex;
	gap: var(--spacing-3);
	background-color: var(--color-surface);
	border-radius: var(--border-radius-base);
	padding: var(--spacing-4);
	box-shadow: var(--shadow-sm);
}

.joho-steps__num {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	flex-shrink: 0;
	width: 32px;
	height: 32px;
	background-color: var(--color-primary);
	color: #fff;
	border-radius: var(--border-radius-full);
	font-weight: 700;
	font-size: var(--font-size-base);
}

.joho-steps__body { flex: 1; }

.joho-steps__title {
	font-weight: 700;
	margin: 0 0 var(--spacing-1);
	font-size: var(--font-size-base);
	color: var(--color-text);
}

.joho-steps__text {
	margin: 0;
	font-size: var(--font-size-sm);
	color: var(--color-text);
	line-height: var(--line-height-base);
}

.joho-steps__chips {
	display: inline-flex;
	gap: var(--spacing-1);
	margin-left: var(--spacing-1);
}
.joho-steps__chips > span {
	display: inline-block;
	font-size: var(--font-size-xs);
	font-weight: 700;
	color: var(--color-primary-dark);
	background-color: var(--color-primary-light);
	padding: 1px var(--spacing-2);
	border-radius: var(--border-radius-full);
}

/* シンプルな覚え方ボックス */
.remember-box--single {
	text-align: center;
	padding: var(--spacing-5);
	background-color: var(--color-primary-light);
	border-radius: var(--border-radius-base);
	border: 1px solid var(--color-primary);
}
.remember-box__lead {
	font-size: var(--font-size-xl);
	color: var(--color-primary-dark);
	margin: 0 0 var(--spacing-2);
}
.remember-box__sub {
	font-size: var(--font-size-sm);
	color: var(--color-text);
	margin: 0;
}

.joho-remember-more {
	margin-top: var(--spacing-3);
	background-color: var(--color-surface);
	border: 1px solid var(--color-border);
	border-radius: var(--border-radius-base);
	padding: var(--spacing-3) var(--spacing-4);
	font-size: var(--font-size-sm);
}
.joho-remember-more > summary {
	cursor: pointer;
	font-weight: 700;
	color: var(--color-text-light);
	list-style: none;
}
.joho-remember-more > summary::-webkit-details-marker { display: none; }
.joho-remember-more > summary::before {
	content: '\25B6';
	display: inline-block;
	font-size: var(--font-size-xs);
	margin-right: var(--spacing-2);
	transition: transform var(--transition);
}
.joho-remember-more[open] > summary::before { transform: rotate(90deg); }
.joho-remember-more .remember-list {
	margin-top: var(--spacing-3);
}

.check-list {
	display: flex;
	flex-direction: column;
	gap: var(--spacing-4);
}

.check-list__item {
	display: flex;
	gap: var(--spacing-4);
	align-items: flex-start;
}

.check-list__icon {
	font-size: 1.5rem;
	flex-shrink: 0;
	width: 32px;
	text-align: center;
}

.check-list__item strong {
	display: block;
	font-weight: 700;
	margin-bottom: var(--spacing-1);
}

.check-list__item p {
	font-size: var(--font-size-sm);
	color: var(--color-text-light);
	line-height: var(--line-height-base);
}

/* ミニクイズ */
.mini-quiz {
	margin-bottom: var(--spacing-8);
	background-color: var(--color-surface);
	border: 1px solid var(--color-border);
	border-radius: var(--border-radius-base);
	overflow: hidden;
	box-shadow: var(--shadow-sm);
}

.mini-quiz__post {
	padding: var(--spacing-4);
	background-color: var(--color-gray-50);
	border-bottom: 1px solid var(--color-border);
}

.mini-quiz__post-header {
	display: flex;
	align-items: center;
	gap: var(--spacing-2);
	margin-bottom: var(--spacing-3);
}

.mini-quiz__post-name {
	font-size: var(--font-size-sm);
	font-weight: 700;
}

.mini-quiz__post-time {
	font-size: var(--font-size-xs);
	color: var(--color-text-light);
}

.mini-quiz__post-text {
	font-size: var(--font-size-sm);
	line-height: var(--line-height-base);
}

.mini-quiz__question {
	font-size: var(--font-size-base);
	font-weight: 700;
	padding: var(--spacing-4) var(--spacing-4) var(--spacing-3);
}

.mini-quiz__choices {
	display: flex;
	flex-direction: column;
	gap: var(--spacing-2);
	padding: 0 var(--spacing-4) var(--spacing-4);
}

.mini-quiz__choice {
	padding: var(--spacing-3) var(--spacing-4);
	border: 2px solid var(--color-border);
	border-radius: var(--border-radius-base);
	font-size: var(--font-size-sm);
	text-align: left;
	background-color: var(--color-surface);
	color: var(--color-text);
	transition: all var(--transition);
	font-family: var(--font-base);
}

.mini-quiz__choice:hover {
	border-color: var(--color-primary);
	background-color: var(--color-primary-light);
}

.mini-quiz__choice.is-correct {
	border-color: var(--color-green);
	background-color: var(--color-green-light);
	color: #2e7d57;
}

.mini-quiz__choice.is-wrong {
	border-color: var(--color-gray-300);
	background-color: var(--color-gray-50);
	color: var(--color-text-light);
}

.mini-quiz__answer {
	padding: var(--spacing-4);
	background-color: var(--color-green-light);
	border-top: 1px solid var(--color-green);
}

.mini-quiz__answer-text {
	font-size: var(--font-size-sm);
	line-height: var(--line-height-base);
	margin-bottom: var(--spacing-3);
}

.mini-quiz__answer-point {
	font-size: var(--font-size-sm);
	font-weight: 500;
	color: #2e7d57;
}

.remember-box {
	padding: var(--spacing-5);
	background-color: #FFFEF0;
	border: 1px solid #E8C84A;
	border-radius: var(--border-radius-base);
}

.remember-list {
	display: flex;
	flex-direction: column;
	gap: var(--spacing-3);
}

.remember-list li {
	font-size: var(--font-size-sm);
	padding-left: var(--spacing-4);
	position: relative;
	line-height: var(--line-height-base);
}

.remember-list li::before {
	content: "✓";
	position: absolute;
	left: 0;
	color: var(--color-primary-dark);
	font-weight: 700;
}

.joho-links {
	margin-top: var(--spacing-8);
}


/* ============================
   27. そなえメモカード（旧）
   → 新ルールは末尾の「Phase 22」ブロックで定義。ここでは無効化のみ。
   ============================ */
.memo-cards {
	display: flex;
	flex-direction: column;
	gap: var(--spacing-3);
}

.memo-card__date {
	font-size: var(--font-size-xs);
	color: var(--color-gray-300);
}

.memo-featured__title,
.memo-all__title {
	font-size: var(--font-size-xl);
	font-weight: 700;
	margin-bottom: var(--spacing-4);
	padding-bottom: var(--spacing-3);
	border-bottom: 2px solid var(--color-border);
}

.memo-list {
	display: flex;
	flex-direction: column;
}

.memo-list__item {
	border-bottom: 1px solid var(--color-border);
}

.memo-list__link {
	display: flex;
	align-items: baseline;
	justify-content: space-between;
	gap: var(--spacing-3);
	padding: var(--spacing-4) 0;
	text-decoration: none;
	color: var(--color-text);
}

.memo-list__link:hover .memo-list__title {
	text-decoration: underline;
}

.memo-list__title {
	font-size: var(--font-size-base);
	font-weight: 500;
}

.memo-list__date {
	font-size: var(--font-size-xs);
	color: var(--color-text-light);
	flex-shrink: 0;
}


/* ============================
   28. まず揃えるもの
   ============================ */
.sonaeru-item {
	margin-bottom: var(--spacing-10);
	padding-bottom: var(--spacing-8);
	border-bottom: 1px solid var(--color-border);
}

.sonaeru-item:last-child {
	border-bottom: none;
}

.sonaeru-item__header {
	display: flex;
	align-items: baseline;
	flex-wrap: wrap;
	gap: var(--spacing-2) var(--spacing-3);
	margin-bottom: var(--spacing-4);
}

.sonaeru-item__icon {
	font-size: 2rem;
}

.sonaeru-item__title {
	font-size: var(--font-size-xl);
	font-weight: 700;
}

.sonaeru-item__target {
	font-size: var(--font-size-sm);
	color: var(--color-text-light);
	background-color: var(--color-gray-100);
	padding: 2px var(--spacing-3);
	border-radius: var(--border-radius-full);
}

.sonaeru-item__img {
	margin-bottom: var(--spacing-5);
}

.sonaeru-item__body > p {
	margin-bottom: var(--spacing-4);
	font-size: var(--font-size-sm);
	line-height: var(--line-height-base);
}

.sonaeru-item__tips,
.sonaeru-item__where {
	background-color: var(--color-gray-50);
	border-radius: var(--border-radius-base);
	padding: var(--spacing-4);
	margin-bottom: var(--spacing-4);
}

.sonaeru-item__tips h3,
.sonaeru-item__where h3 {
	font-size: var(--font-size-sm);
	font-weight: 700;
	margin-bottom: var(--spacing-2);
	color: var(--color-text-light);
}

.sonaeru-item__tips ul {
	list-style: disc;
	padding-left: var(--spacing-5);
}

.sonaeru-item__tips li {
	font-size: var(--font-size-sm);
	margin-bottom: var(--spacing-1);
	line-height: var(--line-height-base);
}

/* ▼ Phase7: 進捗カード + 持ってるトグル */
.intro-text--soft {
	background-color: var(--color-primary-light);
	border-radius: var(--border-radius-base);
	padding: var(--spacing-5);
	font-size: var(--font-size-sm);
	line-height: var(--line-height-base);
	margin-bottom: var(--spacing-5);
}

.sonaeru-pick {
	background-color: var(--color-surface);
	border: 2px solid var(--color-primary);
	border-radius: var(--border-radius-lg);
	padding: var(--spacing-5);
	margin-bottom: var(--spacing-8);
	box-shadow: var(--shadow-sm);
	transition: background-color var(--transition);
}
.sonaeru-pick.is-complete {
	background-color: var(--color-primary-light);
}

.sonaeru-pick__head {
	display: flex;
	flex-wrap: wrap;
	justify-content: space-between;
	align-items: baseline;
	gap: var(--spacing-2);
	margin-bottom: var(--spacing-4);
	padding-bottom: var(--spacing-3);
	border-bottom: 1px dashed var(--color-border);
}

.sonaeru-pick__title {
	font-size: var(--font-size-lg);
	font-weight: 700;
	color: var(--color-primary-dark);
	margin: 0;
}

.sonaeru-pick__count {
	font-size: var(--font-size-sm);
	color: var(--color-text-light);
	margin: 0;
}
.sonaeru-pick__count strong {
	font-size: var(--font-size-xl);
	color: var(--color-primary-dark);
	margin: 0 2px;
}

.sonaeru-pick__list {
	list-style: none;
	margin: 0 0 var(--spacing-3);
	padding: 0;
	display: flex;
	flex-direction: column;
	gap: var(--spacing-2);
	counter-reset: pick;
}

.sonaeru-pick__list a {
	display: flex;
	align-items: center;
	gap: var(--spacing-3);
	padding: var(--spacing-3);
	background-color: var(--color-gray-50);
	border-radius: var(--border-radius-base);
	color: var(--color-text);
	font-weight: 700;
	text-decoration: none;
	transition: background-color var(--transition);
}
.sonaeru-pick__list a:hover {
	background-color: var(--color-primary-light);
}
.sonaeru-pick__list a small {
	font-weight: 400;
	font-size: var(--font-size-xs);
	color: var(--color-text-light);
	margin-left: auto;
	text-align: right;
}
.sonaeru-pick__name { flex-shrink: 0; }
.sonaeru-pick__check {
	display: none;
	flex-shrink: 0;
	width: 24px; height: 24px;
	align-items: center;
	justify-content: center;
	background-color: var(--color-primary);
	color: #fff;
	border-radius: var(--border-radius-full);
	font-size: var(--font-size-sm);
	font-weight: 700;
	margin-left: var(--spacing-2);
}
.sonaeru-pick__list li.is-have a {
	background-color: #e8f5e9;
	color: var(--color-text-light);
}
.sonaeru-pick__list li.is-have .sonaeru-pick__rank {
	background-color: var(--color-text-light);
}
.sonaeru-pick__list li.is-have .sonaeru-pick__name {
	text-decoration: line-through;
	text-decoration-color: var(--color-text-light);
	text-decoration-thickness: 2px;
}
.sonaeru-pick__list li.is-have .sonaeru-pick__check {
	display: inline-flex;
}
.sonaeru-pick__list li.is-have small {
	display: none;
}

.sonaeru-pick__rank {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	flex-shrink: 0;
	width: 28px; height: 28px;
	background-color: var(--color-primary);
	color: #fff;
	border-radius: var(--border-radius-full);
	font-weight: 700;
	font-size: var(--font-size-sm);
}

.sonaeru-pick__hint {
	font-size: var(--font-size-xs);
	color: var(--color-text-light);
	margin: 0;
}

/* 持ってるトグル */
.sonaeru-have {
	margin-left: auto;
	display: inline-flex;
	align-items: center;
	gap: var(--spacing-1);
	padding: 4px var(--spacing-3);
	font-size: var(--font-size-xs);
	font-weight: 700;
	border: 1px solid var(--color-border);
	background-color: var(--color-surface);
	color: var(--color-text-light);
	border-radius: var(--border-radius-full);
	cursor: pointer;
	transition: all var(--transition);
}
.sonaeru-have:hover {
	border-color: var(--color-primary);
	color: var(--color-primary-dark);
}
.sonaeru-have__on { display: none; }
.sonaeru-have__off { display: inline; }
.sonaeru-have.is-on {
	background-color: var(--color-primary);
	border-color: var(--color-primary);
	color: #fff;
}
.sonaeru-have.is-on .sonaeru-have__on { display: inline; }
.sonaeru-have.is-on .sonaeru-have__off { display: none; }

.sonaeru-item.is-have .sonaeru-item__title {
	color: var(--color-primary-dark);
}

/* front-page sonaeru-list の順位バッジ */
.sonaeru-list__rank {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 22px; height: 22px;
	background-color: var(--color-primary);
	color: #fff;
	border-radius: var(--border-radius-full);
	font-size: var(--font-size-xs);
	font-weight: 700;
	margin-right: var(--spacing-2);
}

.hint-box {
	background-color: var(--color-blue-light);
	border-radius: var(--border-radius-base);
	padding: var(--spacing-5);
	margin-bottom: var(--spacing-8);
}

.hint-box__title {
	font-size: var(--font-size-lg);
	font-weight: 700;
	margin-bottom: var(--spacing-4);
}

.hint-box__img {
	margin-bottom: var(--spacing-4);
}

.hint-box p,
.hint-box ul {
	font-size: var(--font-size-sm);
	margin-bottom: var(--spacing-3);
	line-height: var(--line-height-base);
}

.hint-box ul {
	list-style: disc;
	padding-left: var(--spacing-5);
}

.link-memo {
	font-size: var(--font-size-sm);
}


/* ============================
   29. このサイトについて (Phase 23 で page-about.php を全面再設計し、本セクションの旧スタイルは Phase 24 で削除されました。新スタイルは .about-hero / .about-usage / .about-concept / .about-position / .about-notice / .about-cta を参照。)
   ============================ */


/* ============================
   30. TOPページ：このサイトについて (Phase 24 で未使用のため削除)
   ============================ */


/* ============================
   31. フォーム（ご意見）
   ============================ */
.contact-notice--urgent {
	background-color: #FFF5F5;
	border: 1px solid #FFCDD2;
	border-left: 4px solid var(--color-alert);
	border-radius: 0 var(--border-radius-base) var(--border-radius-base) 0;
	padding: var(--spacing-5);
	margin-bottom: var(--spacing-6);
	font-size: var(--font-size-sm);
	line-height: var(--line-height-base);
}

.contact-notice--urgent strong {
	font-weight: 700;
}

.contact-intro {
	font-size: var(--font-size-sm);
	margin-bottom: var(--spacing-6);
	line-height: var(--line-height-base);
	color: var(--color-text-light);
}

.contact-form {
	display: flex;
	flex-direction: column;
	gap: var(--spacing-6);
}

.form-group {
	display: flex;
	flex-direction: column;
	gap: var(--spacing-2);
}

.form-label {
	font-size: var(--font-size-sm);
	font-weight: 700;
	display: flex;
	align-items: center;
	gap: var(--spacing-2);
}

.form-required {
	font-size: var(--font-size-xs);
	background-color: var(--color-alert);
	color: #fff;
	padding: 1px var(--spacing-2);
	border-radius: var(--border-radius-full);
}

.form-optional {
	font-size: var(--font-size-xs);
	color: var(--color-text-light);
}

.form-radio-group {
	display: flex;
	flex-direction: column;
	gap: var(--spacing-2);
}

.form-radio {
	display: flex;
	align-items: center;
	gap: var(--spacing-2);
	font-size: var(--font-size-sm);
	cursor: pointer;
}

.form-input,
.form-textarea {
	width: 100%;
	padding: var(--spacing-3) var(--spacing-4);
	border: 1px solid var(--color-border);
	border-radius: var(--border-radius-base);
	font-size: var(--font-size-base);
	font-family: var(--font-base);
	color: var(--color-text);
	background-color: var(--color-surface);
	transition: border-color var(--transition);
}

.form-input:focus,
.form-textarea:focus {
	outline: none;
	border-color: var(--color-primary);
	box-shadow: 0 0 0 3px rgba(245,163,42,.2);
}

.form-textarea {
	resize: vertical;
	min-height: 120px;
}

.form-note {
	font-size: var(--font-size-xs);
	color: var(--color-text-light);
}

.form-submit {
	padding-top: var(--spacing-2);
}

.form-privacy-note {
	font-size: var(--font-size-xs);
	color: var(--color-text-light);
	margin-top: var(--spacing-3);
}

.contact-plugin-note {
	margin-top: var(--spacing-4);
	font-size: var(--font-size-xs);
	color: var(--color-text-light);
	padding: var(--spacing-3);
	background-color: var(--color-gray-100);
	border-radius: var(--border-radius-sm);
}


/* ============================
   32. 404ページ
   ============================ */
.error-body {
	padding: var(--spacing-8) 0;
	text-align: center;
}

.error-mascot {
	display: flex;
	justify-content: center;
	margin-bottom: var(--spacing-5);
}

.error-body p {
	color: var(--color-text-light);
	margin-bottom: var(--spacing-6);
	line-height: var(--line-height-base);
}

.error-links {
	display: flex;
	flex-direction: column;
	gap: var(--spacing-3);
	align-items: center;
}

.error-links a {
	color: var(--color-text-link);
	font-size: var(--font-size-sm);
}


/* ============================
   33. ペジネーション
   ============================ */
.pagination {
	padding: var(--spacing-6) 0;
	text-align: center;
}

.pagination .page-numbers {
	display: inline-flex;
	gap: var(--spacing-2);
}

.pagination .page-numbers li a,
.pagination .page-numbers li span {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	min-width: 40px;
	height: 40px;
	padding: 0 var(--spacing-2);
	border: 1px solid var(--color-border);
	border-radius: var(--border-radius-sm);
	font-size: var(--font-size-sm);
	color: var(--color-text);
	text-decoration: none;
}

.pagination .page-numbers li span.current {
	background-color: var(--color-primary);
	border-color: var(--color-primary);
	color: #fff;
}


/* ============================
   34. レスポンシブ（タブレット～）
   ============================ */
@media (min-width: 640px) {
	:root {
		--container-padding: 2rem;
	}

	.hero__inner {
		flex-direction: row;
		text-align: left;
	}

	.hero__text {
		flex: 1;
	}

	.hero__mascot {
		order: 2;
		flex-shrink: 0;
	}

	.btn--large {
		width: auto;
	}

	.guide-cards {
		grid-template-columns: repeat(5, 1fr);
	}

	.memo-card--featured {
		grid-template-columns: 160px 1fr;
	}

	.shindan-result__actions,
	.dekita-modal__actions {
		flex-direction: row;
		justify-content: center;
	}

	.item-cards {
		display: grid;
		grid-template-columns: 1fr 1fr;
	}

	.contact-form {
		gap: var(--spacing-8);
	}

	.form-radio-group {
		flex-direction: row;
		flex-wrap: wrap;
		gap: var(--spacing-4);
	}
}

@media (min-width: 768px) {
	.guide-list-grid {
		display: grid;
		grid-template-columns: 1fr 1fr;
		gap: var(--spacing-4);
	}

	.guide-list-card {
		flex-direction: column;
	}

	.guide-list-card__thumb {
		width: 100%;
		aspect-ratio: 4 / 3;
	}

	.link-cards {
		display: grid;
		grid-template-columns: 1fr 1fr;
		gap: var(--spacing-4);
	}
}


/* ============================
   35. ヒーロー追加スタイル
   ============================ */
.hero__eyebrow {
	display: inline-block;
	font-size: var(--font-size-xs);
	font-weight: 700;
	color: var(--color-primary-dark);
	background-color: rgba(245,163,42,.15);
	padding: 3px var(--spacing-3);
	border-radius: var(--border-radius-full);
	letter-spacing: .05em;
	margin-bottom: var(--spacing-3);
}

.hero__actions {
	display: flex;
	flex-direction: column;
	gap: var(--spacing-3);
}

@media (min-width: 480px) {
	.hero__actions {
		flex-direction: row;
		flex-wrap: wrap;
	}
}

.btn--outline {
	background-color: transparent;
	color: var(--color-text);
	border-color: var(--color-border);
	font-weight: 700;
}
.btn--outline:hover {
	background-color: var(--color-gray-50);
	border-color: var(--color-gray-300);
	text-decoration: none;
	color: var(--color-text);
}

.btn-text {
	display: inline-flex;
	align-items: center;
	gap: var(--spacing-1);
	color: var(--color-text-link);
	font-size: var(--font-size-sm);
	font-weight: 500;
	text-decoration: none;
}
.btn-text:hover {
	text-decoration: underline;
}


/* ============================
   36. このサイトでできること（フィーチャーカード）
   ============================ */
.feature-cards {
	display: flex;
	flex-direction: column;
	gap: var(--spacing-4);
}

.feature-card {
	background-color: var(--color-surface);
	border: 1px solid var(--color-border);
	border-radius: var(--border-radius-lg);
	padding: var(--spacing-5);
	box-shadow: var(--shadow-sm);
}

.feature-card__icon {
	font-size: 2rem;
	margin-bottom: var(--spacing-3);
	line-height: 1;
}

.feature-card__title {
	font-size: var(--font-size-md);
	font-weight: 700;
	margin-bottom: var(--spacing-2);
}

.feature-card__desc {
	font-size: var(--font-size-sm);
	color: var(--color-text-light);
	line-height: var(--line-height-base);
	margin-bottom: var(--spacing-3);
}

.feature-card__link {
	font-size: var(--font-size-sm);
	font-weight: 700;
	color: var(--color-text-link);
}
.feature-card__link:hover {
	text-decoration: underline;
}

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


/* ============================
   36b. 状態別 次の一歩ピッカー（TOP）
   ============================ */
.section--next-step {
	background-color: var(--color-primary-light);
}

.next-step-picker {
	display: flex;
	flex-direction: column;
	gap: var(--spacing-4);
	list-style: none;
	margin: 0;
	padding: 0;
}

.next-step-picker__item {
	margin: 0;
}

.next-step-card {
	display: flex;
	align-items: stretch;
	gap: var(--spacing-4);
	background-color: var(--color-surface);
	border: 1px solid var(--color-border);
	border-left: 6px solid var(--color-primary);
	border-radius: var(--border-radius-lg);
	padding: var(--spacing-5);
	box-shadow: var(--shadow-sm);
	color: var(--color-text);
	text-decoration: none;
	transition: transform var(--transition), box-shadow var(--transition), border-color var(--transition);
	min-height: 96px;
}

.next-step-card:hover,
.next-step-card:focus-visible {
	text-decoration: none;
	box-shadow: var(--shadow-md);
	transform: translateY(-2px);
}

.next-step-card--shindan { border-left-color: var(--color-primary); }
.next-step-card--guide   { border-left-color: var(--color-warning); }
.next-step-card--kyou    { border-left-color: var(--color-green); }

.next-step-card__num {
	flex-shrink: 0;
	width: 36px;
	height: 36px;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	border-radius: var(--border-radius-full);
	background-color: var(--color-primary-light);
	color: var(--color-primary-dark);
	font-weight: 700;
	font-size: var(--font-size-md);
	line-height: 1;
}

.next-step-card--guide .next-step-card__num { background-color: var(--color-warning-light); color: var(--color-warning); }
.next-step-card--kyou  .next-step-card__num { background-color: var(--color-green-light);   color: var(--color-green); }

.next-step-card__body {
	flex: 1;
	min-width: 0;
	display: flex;
	flex-direction: column;
}

.next-step-card__title {
	font-size: var(--font-size-md);
	font-weight: 700;
	margin: 0 0 var(--spacing-1);
	line-height: var(--line-height-tight);
}

.next-step-card__desc {
	font-size: var(--font-size-sm);
	color: var(--color-text-light);
	line-height: var(--line-height-base);
	margin: 0 0 var(--spacing-2);
}

.next-step-card__cta {
	display: inline-flex;
	align-items: center;
	gap: 4px;
	align-self: flex-end;
	margin-top: auto;
	color: var(--color-primary-dark);
	font-size: var(--font-size-sm);
	font-weight: 700;
	white-space: nowrap;
}
.next-step-card__cta::after {
	content: "→";
	font-size: 14px;
	transition: transform var(--transition);
}
.next-step-card:hover .next-step-card__cta {
	color: var(--color-primary);
}
.next-step-card:hover .next-step-card__cta::after {
	transform: translateX(2px);
}

@media (min-width: 640px) {
	.next-step-card {
		min-height: 120px;
	}
}


/* ============================
   37. アイテムカード追加スタイル
   ============================ */
.item-card__note {
	font-size: var(--font-size-xs);
	color: var(--color-gray-600);
	margin-top: 2px;
}


/* ============================
   38. タスクリスト追加スタイル
   ============================ */
.task-list__meta {
	display: flex;
	gap: var(--spacing-3);
	font-size: var(--font-size-xs);
	color: var(--color-text-light);
}


/* ============================
   39. ガイドカード（レベル別カラー）
   ============================ */
.guide-card__icon {
	font-size: 2rem;
	line-height: 1;
	width: 48px;
	text-align: center;
}

.guide-card__level {
	font-size: var(--font-size-xs);
	align-self: flex-end;
}

.guide-card--level-danger {
	border-color: rgba(224,90,75,.3);
	background-color: #FFF9F8;
}
.guide-card--level-danger:hover {
	border-color: var(--color-alert);
}

.guide-card--level-watch {
	border-color: rgba(232,155,48,.3);
	background-color: #FFFCF7;
}
.guide-card--level-watch:hover {
	border-color: var(--color-warning);
}

.guide-card--level-recovery {
	border-color: rgba(91,158,201,.3);
	background-color: #F5FAFE;
}
.guide-card--level-recovery:hover {
	border-color: var(--color-blue);
}


/* ============================
   40. ガイド一覧カード（改善版）
   ============================ */
.guide-list-intro-block {
	margin-bottom: var(--spacing-5);
}

.guide-list-intro {
	font-size: var(--font-size-sm);
	line-height: var(--line-height-base);
	margin-bottom: var(--spacing-3);
}

.guide-list-note {
	font-size: var(--font-size-xs);
	color: var(--color-text-light);
	padding: var(--spacing-3) var(--spacing-4);
	background-color: var(--color-gray-50);
	border-radius: var(--border-radius-sm);
	line-height: var(--line-height-base);
}

.guide-list-card {
	display: flex;
	gap: var(--spacing-3);
	align-items: center;
	background-color: var(--color-surface);
	border: 1px solid var(--color-border);
	border-radius: var(--border-radius-base);
	padding: var(--spacing-4);
	text-decoration: none;
	color: var(--color-text);
	box-shadow: var(--shadow-sm);
	transition: all var(--transition);
}

.guide-list-card:hover {
	box-shadow: var(--shadow-base);
	border-color: var(--color-green);
	text-decoration: none;
	transform: translateY(-1px);
}

.guide-list-card__icon {
	font-size: 2.25rem;
	width: 52px;
	text-align: center;
	flex-shrink: 0;
	line-height: 1;
}

.guide-list-card__body {
	flex: 1;
	min-width: 0;
}

.guide-list-card__title {
	font-size: var(--font-size-md);
	font-weight: 700;
	margin-top: var(--spacing-1);
	margin-bottom: var(--spacing-1);
	line-height: var(--line-height-tight);
}

.guide-list-card__desc {
	font-size: var(--font-size-xs);
	color: var(--color-text-light);
	line-height: var(--line-height-base);
}

.guide-list-card__arrow {
	color: var(--color-gray-300);
	flex-shrink: 0;
	font-size: var(--font-size-lg);
}


/* ============================
   41. レベルバッジ（ガイド用）
   ============================ */
.guide-level-badge {
	display: inline-block;
	font-size: var(--font-size-xs);
	font-weight: 700;
	padding: 2px var(--spacing-2);
	border-radius: var(--border-radius-full);
	line-height: 1.6;
}

.level--normal {
	background-color: var(--color-green-light);
	color: #2e7d57;
}

.level--watch {
	background-color: #FFF3E0;
	color: #8a5200;
}

.level--danger {
	background-color: #FEF2F0;
	color: #c0392b;
}

.level--recovery {
	background-color: var(--color-blue-light);
	color: #1a5a85;
}


/* ============================
   42. ガイド詳細ページ
   ============================ */

/* ヒーロー */
.guide-hero-meta {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	gap: var(--spacing-2);
	margin-bottom: var(--spacing-3);
}

.guide-cat-badge {
	display: inline-block;
	font-size: var(--font-size-xs);
	color: var(--color-text-light);
	background-color: var(--color-gray-100);
	padding: 2px var(--spacing-3);
	border-radius: var(--border-radius-full);
}

.guide-hero-icon {
	display: inline-block;
	margin-right: var(--spacing-2);
	font-size: 1.2em;
}

/* ヒーロー レベル別背景 */
.page-hero--danger {
	background-color: var(--color-alert-light);
	border-bottom: 3px solid var(--color-alert);
}

.page-hero--watch {
	background-color: var(--color-warning-light);
	border-bottom: 3px solid var(--color-warning);
}

.page-hero--recovery {
	background-color: var(--color-blue-light);
	border-bottom: 3px solid var(--color-blue);
}

/* 目次 */
.guide-toc {
	margin-top: var(--spacing-5);
	padding: var(--spacing-4);
	background-color: rgba(255,255,255,.7);
	border-radius: var(--border-radius-base);
	border: 1px solid var(--color-border);
}

.guide-toc__list {
	display: flex;
	flex-direction: column;
	gap: var(--spacing-2);
	counter-reset: none;
	list-style: none;
}

.guide-toc__list li {
	counter-increment: none;
}

.guide-toc__list a {
	font-size: var(--font-size-sm);
	font-weight: 500;
	color: var(--color-text-link);
	text-decoration: none;
}

.guide-toc__list a:hover {
	text-decoration: underline;
}

/* ① まず確認すること */
.guide-checklist {
	display: flex;
	flex-direction: column;
	gap: var(--spacing-3);
}

.guide-checklist__item {
	display: flex;
	gap: var(--spacing-3);
	align-items: flex-start;
}

.guide-checklist__icon {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 24px;
	height: 24px;
	background-color: var(--color-alert);
	color: #fff;
	border-radius: var(--border-radius-full);
	font-size: var(--font-size-xs);
	font-weight: 700;
	flex-shrink: 0;
	margin-top: 2px;
}

.guide-checklist__body {
	flex: 1;
}

.guide-checklist__text {
	font-size: var(--font-size-base);
	font-weight: 500;
	line-height: var(--line-height-tight);
	display: block;
}

.guide-checklist__note {
	font-size: var(--font-size-xs);
	color: var(--color-text-light);
	display: block;
	margin-top: 2px;
}

/* ① 最優先項目（🔴マーク付き） */
.guide-checklist__item--high {
	background-color: #FFF7F5;
	border-left: 4px solid var(--color-alert);
	padding: var(--spacing-3);
	border-radius: var(--border-radius-sm);
}

.guide-checklist__priority {
	display: inline-block;
	font-size: var(--font-size-xs);
	font-weight: 700;
	color: var(--color-alert);
	margin-bottom: 2px;
}

/* ① セクション内ヒント */
.guide-section__hint {
	font-size: var(--font-size-sm);
	color: var(--color-text-light);
	background-color: var(--color-primary-light);
	padding: var(--spacing-2) var(--spacing-3);
	border-radius: var(--border-radius-sm);
	margin-bottom: var(--spacing-3);
}

/* ② アクション */
.guide-actions {
	display: flex;
	flex-direction: column;
	gap: var(--spacing-3);
	list-style: none;
}

.guide-action {
	background-color: var(--color-surface);
	border: 1px solid var(--color-border);
	border-radius: var(--border-radius-base);
	padding: var(--spacing-4);
	box-shadow: var(--shadow-sm);
}

.guide-action--high {
	border-left: 4px solid var(--color-alert);
	background-color: #FFFCFC;
}

.guide-action__header {
	display: flex;
	align-items: flex-start;
	flex-wrap: wrap;
	gap: var(--spacing-2);
	margin-bottom: var(--spacing-2);
}

.guide-action__num {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 24px;
	height: 24px;
	background-color: var(--color-primary);
	color: #fff;
	border-radius: var(--border-radius-full);
	font-size: var(--font-size-xs);
	font-weight: 700;
	flex-shrink: 0;
}

.guide-action__step {
	font-size: var(--font-size-base);
	font-weight: 700;
	flex: 1;
	line-height: var(--line-height-tight);
}

.guide-action__priority {
	font-size: var(--font-size-xs);
	font-weight: 700;
	padding: 2px var(--spacing-2);
	border-radius: var(--border-radius-full);
	flex-shrink: 0;
}

.guide-action__priority--high {
	background-color: #FEF2F0;
	color: #c0392b;
}

.guide-action__priority--medium {
	background-color: #FFF3E0;
	color: #8a5200;
}

.guide-action__priority--low {
	background-color: var(--color-gray-100);
	color: var(--color-text-light);
}

.guide-action__detail {
	font-size: var(--font-size-sm);
	color: var(--color-text-light);
	line-height: var(--line-height-base);
	margin-top: var(--spacing-1);
}

/* ③ 一人暮らしで困ること */
.guide-section--solo {
	background-color: #FFFEF6;
	border-left: 4px solid var(--color-warning);
	border-radius: 0 var(--border-radius-base) var(--border-radius-base) 0;
	padding: var(--spacing-5);
}

.guide-trouble-list {
	display: flex;
	flex-direction: column;
	gap: var(--spacing-4);
}

.guide-trouble-item {
	padding-bottom: var(--spacing-4);
	border-bottom: 1px solid var(--color-border);
}
.guide-trouble-item:last-child {
	border-bottom: none;
	padding-bottom: 0;
}

.guide-trouble-item__title {
	font-size: var(--font-size-base);
	font-weight: 700;
	margin-bottom: var(--spacing-2);
	display: flex;
	align-items: center;
	gap: var(--spacing-1);
}

.guide-trouble-item__solution {
	font-size: var(--font-size-sm);
	color: var(--color-text);
	line-height: var(--line-height-base);
}

/* 吹き出し */
.guide-callout {
	padding: var(--spacing-4) var(--spacing-5);
	border-radius: var(--border-radius-base);
	font-size: var(--font-size-sm);
	line-height: var(--line-height-base);
}

.guide-callout--info {
	background-color: var(--color-blue-light);
	border-left: 3px solid var(--color-blue);
}

/* ④ 公式リンク */
.guide-official-list {
	display: flex;
	flex-direction: column;
	gap: var(--spacing-2);
	margin-bottom: var(--spacing-4);
}

.guide-official-link {
	display: flex;
	align-items: center;
	gap: var(--spacing-3);
	padding: var(--spacing-3) var(--spacing-4);
	background-color: var(--color-surface);
	border: 1px solid var(--color-border);
	border-radius: var(--border-radius-base);
	text-decoration: none;
	color: var(--color-text);
	font-size: var(--font-size-sm);
	transition: all var(--transition);
}

.guide-official-link:hover {
	border-color: var(--color-green);
	background-color: var(--color-green-light);
	text-decoration: none;
}

.guide-official-link__icon {
	flex-shrink: 0;
}

.guide-official-link__label {
	flex: 1;
	font-weight: 500;
}

.guide-official-link__ext {
	font-size: var(--font-size-xs);
	color: var(--color-text-light);
}

/* セクション内「もっと見る」 */
.guide-section__more {
	margin-top: var(--spacing-3);
}

.guide-section__empty {
	font-size: var(--font-size-sm);
	color: var(--color-text-light);
}

/* エディターコンテンツ（追記欄） */
.guide-editor-content {
	margin-top: var(--spacing-6);
	padding-top: var(--spacing-6);
	border-top: 1px solid var(--color-border);
}

/* ナビゲーション */
.guide-post-nav {
	margin-top: var(--spacing-10);
	padding-top: var(--spacing-6);
	border-top: 1px solid var(--color-border);
}


/* ============================
   43. そなえメモ詳細ページ
   ============================ */
.memo-cat-badge {
	display: inline-block;
	font-size: var(--font-size-xs);
	color: var(--color-text-light);
	background-color: var(--color-gray-100);
	padding: 2px var(--spacing-3);
	border-radius: var(--border-radius-full);
	margin-bottom: var(--spacing-2);
}

/* メタバー */
.memo-meta-bar {
	display: flex;
	flex-wrap: wrap;
	gap: var(--spacing-2);
	margin-top: var(--spacing-4);
}

.memo-meta-item {
	display: inline-flex;
	align-items: center;
	gap: var(--spacing-1);
	font-size: var(--font-size-xs);
	padding: 4px var(--spacing-3);
	border-radius: var(--border-radius-full);
	background-color: rgba(255,255,255,.8);
	border: 1px solid var(--color-border);
	color: var(--color-text);
}

.memo-meta-item__icon {
	font-size: .875rem;
}

.memo-meta-item--diff.diff--easy {
	background-color: var(--color-green-light);
	border-color: var(--color-green);
	color: #2e7d57;
}

.memo-meta-item--diff.diff--medium {
	background-color: #FFF3E0;
	border-color: #E89B30;
	color: #8a5200;
}

.memo-meta-item--diff.diff--hard {
	background-color: #FEF2F0;
	border-color: var(--color-alert);
	color: #c0392b;
}

/* まとめ */
.memo-summary {
	background-color: var(--color-primary-light);
	border: 1px solid rgba(245,163,42,.3);
	border-radius: var(--border-radius-base);
	padding: var(--spacing-5);
	margin-bottom: var(--spacing-6);
}

.memo-summary__label {
	font-size: var(--font-size-sm);
	font-weight: 700;
	color: var(--color-primary-dark);
	margin-bottom: var(--spacing-3);
}

.memo-summary__list {
	display: flex;
	flex-direction: column;
	gap: var(--spacing-2);
	list-style: none;
}

.memo-summary__list li {
	font-size: var(--font-size-sm);
	line-height: var(--line-height-base);
	padding-left: var(--spacing-4);
	position: relative;
}

.memo-summary__list li::before {
	content: "・";
	position: absolute;
	left: 0;
	color: var(--color-primary-dark);
	font-weight: 700;
}

/* セクション */
.memo-section {
	margin-bottom: var(--spacing-8);
}

.memo-section__title {
	font-size: var(--font-size-lg);
	font-weight: 700;
	margin-bottom: var(--spacing-4);
	padding-bottom: var(--spacing-2);
	border-bottom: 2px solid var(--color-border);
}

/* 手順 */
.memo-steps {
	display: flex;
	flex-direction: column;
	gap: var(--spacing-4);
	list-style: none;
}

.memo-step {
	background-color: var(--color-surface);
	border: 1px solid var(--color-border);
	border-radius: var(--border-radius-base);
	padding: var(--spacing-4);
	box-shadow: var(--shadow-sm);
}

.memo-step__header {
	display: flex;
	align-items: flex-start;
	gap: var(--spacing-3);
	margin-bottom: var(--spacing-2);
}

.memo-step__num {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 28px;
	height: 28px;
	background-color: var(--color-blue);
	color: #fff;
	border-radius: var(--border-radius-full);
	font-size: var(--font-size-sm);
	font-weight: 700;
	flex-shrink: 0;
}

.memo-step__title {
	font-size: var(--font-size-base);
	font-weight: 700;
	line-height: var(--line-height-tight);
	flex: 1;
}

.memo-step__body {
	font-size: var(--font-size-sm);
	line-height: var(--line-height-base);
	color: var(--color-text);
	margin-left: calc(28px + var(--spacing-3));
	margin-bottom: var(--spacing-2);
}

.memo-step__tip {
	font-size: var(--font-size-xs);
	color: var(--color-text-light);
	background-color: #FFFEF0;
	border-radius: var(--border-radius-sm);
	padding: var(--spacing-2) var(--spacing-3);
	margin-left: calc(28px + var(--spacing-3));
}

/* 用意するもの テーブル */
.memo-items-wrap {
	overflow-x: auto;
	-webkit-overflow-scrolling: touch;
}

.memo-items-table {
	width: 100%;
	border-collapse: collapse;
	font-size: var(--font-size-sm);
}

.memo-items-table th {
	background-color: var(--color-gray-100);
	font-weight: 700;
	text-align: left;
	padding: var(--spacing-2) var(--spacing-3);
	border-bottom: 2px solid var(--color-border);
	white-space: nowrap;
}

.memo-items-table td {
	padding: var(--spacing-3);
	border-bottom: 1px solid var(--color-border);
	line-height: var(--line-height-tight);
	vertical-align: top;
}

.memo-items-table tr:last-child td {
	border-bottom: none;
}

.memo-items-table__name {
	font-weight: 500;
}

.memo-items-table__qty,
.memo-items-table__note {
	color: var(--color-text-light);
}

/* アドバイス */
.memo-advice {
	display: flex;
	gap: var(--spacing-3);
	align-items: flex-start;
	background-color: var(--color-green-light);
	border: 1px solid rgba(91,173,143,.3);
	border-radius: var(--border-radius-base);
	padding: var(--spacing-5);
	margin-bottom: var(--spacing-6);
}

.memo-advice__icon {
	font-size: 1.5rem;
	flex-shrink: 0;
	line-height: 1;
}

.memo-advice__body {
	font-size: var(--font-size-sm);
	line-height: var(--line-height-base);
	color: var(--color-text);
}

/* 関連ガイド */
.memo-related-guide-list,
.memo-related-link-list {
	display: flex;
	flex-direction: column;
	gap: var(--spacing-2);
}

.memo-related-guide-link,
.memo-related-link-item-a {
	display: flex;
	align-items: center;
	gap: var(--spacing-3);
	padding: var(--spacing-3) var(--spacing-4);
	background-color: var(--color-surface);
	border: 1px solid var(--color-border);
	border-radius: var(--border-radius-base);
	text-decoration: none;
	color: var(--color-text);
	font-size: var(--font-size-sm);
	font-weight: 500;
	transition: all var(--transition);
}

.memo-related-guide-link:hover {
	border-color: var(--color-green);
	background-color: var(--color-green-light);
	text-decoration: none;
}

.memo-related-guide-link__icon {
	font-size: 1.5rem;
	flex-shrink: 0;
}

.memo-related-guide-link__title {
	flex: 1;
}

.memo-related-guide-link__arrow {
	color: var(--color-text-light);
	flex-shrink: 0;
}

/* ナビゲーション */
.memo-post-nav {
	margin-top: var(--spacing-10);
	padding-top: var(--spacing-6);
	border-top: 1px solid var(--color-border);
}

/* 関連ガイドセクション */
.memo-related-guides,
.memo-related-links {
	padding: var(--spacing-5);
	background-color: var(--color-gray-50);
	border-radius: var(--border-radius-base);
	border: 1px solid var(--color-border);
}

/* メモカード 難易度アイコン */
.memo-card__diff {
	display: inline-block;
	margin-bottom: var(--spacing-1);
}

.memo-card__meta {
	font-size: var(--font-size-xs);
	color: var(--color-text-light);
	margin-bottom: var(--spacing-2);
}


/* ================================================
   44. 状況選択セレクター（ガイド一覧ページ）
   ================================================ */

.situation-selector {
margin-bottom: var(--spacing-8);
}

.situation-selector__label {
font-size: var(--font-size-lg);
font-weight: var(--font-weight-bold);
text-align: center;
margin-bottom: var(--spacing-4);
color: var(--color-text);
}

.situation-selector__hint {
font-size: var(--font-size-sm);
text-align: center;
color: var(--color-text-light);
margin: calc(var(--spacing-4) * -1 + var(--spacing-1)) 0 var(--spacing-4);
}

.guide-list-intro {
background-color: var(--color-primary-light);
border-radius: var(--border-radius-base);
padding: var(--spacing-4) var(--spacing-5);
margin-bottom: var(--spacing-6);
text-align: center;
}

.guide-list-intro__text {
font-size: var(--font-size-base);
line-height: var(--line-height-base);
color: var(--color-text);
margin: 0;
}

.guide-level-legend {
background-color: var(--color-surface);
border: 1px solid var(--color-border);
border-radius: var(--border-radius-base);
padding: var(--spacing-3) var(--spacing-4);
margin-bottom: var(--spacing-6);
font-size: var(--font-size-sm);
}

.guide-level-legend__summary {
cursor: pointer;
font-weight: 700;
color: var(--color-text-light);
list-style: none;
}
.guide-level-legend__summary::-webkit-details-marker { display: none; }
.guide-level-legend__summary::before {
content: '\25B6';
display: inline-block;
font-size: var(--font-size-xs);
margin-right: var(--spacing-2);
transition: transform var(--transition);
}
.guide-level-legend[open] .guide-level-legend__summary::before {
transform: rotate(90deg);
}

.guide-level-legend__list {
list-style: none;
margin: var(--spacing-3) 0 0;
padding: 0;
display: flex;
flex-direction: column;
gap: var(--spacing-2);
}
.guide-level-legend__list li {
display: flex;
align-items: center;
gap: var(--spacing-2);
flex-wrap: wrap;
font-size: var(--font-size-sm);
color: var(--color-text-light);
}

/* ガイド詳細 目次見出し */
.guide-toc__heading {
font-size: var(--font-size-sm);
font-weight: 700;
color: var(--color-text-light);
margin: 0 0 var(--spacing-2);
}

.situation-selector__grid {
display: grid;
grid-template-columns: repeat(3, 1fr);
gap: var(--spacing-3);
margin-bottom: var(--spacing-3);
}

@media (min-width: 480px) {
.situation-selector__grid {
grid-template-columns: repeat(3, 1fr);
}
}

@media (min-width: 640px) {
.situation-selector__grid {
grid-template-columns: repeat(6, 1fr);
}
}

.situation-btn {
display: flex;
flex-direction: column;
align-items: center;
gap: var(--spacing-1);
padding: var(--spacing-3) var(--spacing-2);
background-color: var(--color-bg);
border: 2px solid var(--color-border);
border-radius: var(--border-radius-base);
cursor: pointer;
transition: border-color 0.2s, background-color 0.2s, transform 0.1s;
text-align: center;
width: 100%;
}

.situation-btn:hover {
border-color: var(--color-primary);
background-color: var(--color-primary-light);
}

.situation-btn.is-active {
border-color: var(--color-primary);
background-color: var(--color-primary-light);
box-shadow: 0 0 0 1px var(--color-primary);
}

.situation-btn__icon {
font-size: 2rem;
line-height: 1;
}

.situation-btn__label {
font-size: var(--font-size-sm);
font-weight: var(--font-weight-bold);
color: var(--color-text);
}

.situation-btn__desc {
font-size: var(--font-size-xs);
color: var(--color-text-light);
display: none;
}

@media (min-width: 480px) {
.situation-btn__desc {
display: block;
}
}

/* 「すべて表示」ボタン */
.situation-btn--all {
display: block;
width: 100%;
padding: var(--spacing-2) var(--spacing-4);
background: none;
border: 1px dashed var(--color-border);
border-radius: var(--border-radius-base);
color: var(--color-text-light);
font-size: var(--font-size-sm);
cursor: pointer;
transition: border-color 0.2s, color 0.2s;
}

.situation-btn--all:hover,
.situation-btn--all.is-active {
border-color: var(--color-primary);
color: var(--color-primary-dark);
}

/* ガイドグリッド */
.guide-list-grid {
display: flex;
flex-direction: column;
gap: var(--spacing-3);
}

/* 件数ラベル */
.guide-list-count {
font-size: var(--font-size-sm);
color: var(--color-text-light);
margin-bottom: var(--spacing-2);
}

/* 該当なし */
.guide-list-empty {
padding: var(--spacing-8) var(--spacing-4);
text-align: center;
color: var(--color-text-light);
}

.guide-list-empty p {
margin-bottom: var(--spacing-4);
}

/* 非表示（JSで切り替え） */
.guide-list-card.is-hidden {
display: none;
}

/* ================================================
   45. メモフィルタータブ
   ================================================ */

.memo-filter {
display: flex;
gap: var(--spacing-2);
overflow-x: auto;
-webkit-overflow-scrolling: touch;
scrollbar-width: none;
padding-bottom: var(--spacing-2);
margin-bottom: var(--spacing-6);
border-bottom: 1px solid var(--color-border);
}

.memo-filter::-webkit-scrollbar {
display: none;
}

.memo-filter__btn {
flex-shrink: 0;
padding: var(--spacing-2) var(--spacing-4);
background: none;
border: 1px solid var(--color-border);
border-radius: 999px;
font-size: var(--font-size-sm);
color: var(--color-text-light);
cursor: pointer;
transition: background-color 0.2s, border-color 0.2s, color 0.2s;
white-space: nowrap;
}

.memo-filter__btn:hover {
border-color: var(--color-primary);
color: var(--color-primary-dark);
}

.memo-filter__btn.is-active {
background-color: var(--color-primary);
border-color: var(--color-primary);
color: #fff;
font-weight: var(--font-weight-bold);
}

/* メモカードグリッド */
.memo-card-grid {
display: grid;
grid-template-columns: 1fr;
gap: var(--spacing-4);
margin-bottom: var(--spacing-8);
}

@media (min-width: 480px) {
.memo-card-grid {
grid-template-columns: repeat(2, 1fr);
}
}

/* メモカード */
.memo-card {
display: flex;
flex-direction: column;
background-color: var(--color-bg);
border: 1px solid var(--color-border);
border-radius: var(--border-radius-lg);
overflow: hidden;
text-decoration: none;
color: var(--color-text);
transition: box-shadow 0.2s, transform 0.1s;
}

.memo-card:hover {
box-shadow: var(--shadow-md);
transform: translateY(-2px);
}

/* featured カードのサムネ */
.memo-card--featured .memo-card__thumb {
width: 100%;
aspect-ratio: 16 / 9;
overflow: hidden;
background-color: var(--color-border);
}

.memo-card--featured .memo-card__thumb img {
width: 100%;
height: 100%;
object-fit: cover;
}

.memo-card__thumb--placeholder {
background: linear-gradient(135deg, var(--color-primary-light) 0%, var(--color-border) 100%);
}

.memo-card__body {
padding: var(--spacing-4);
flex: 1;
}

.memo-card__title {
font-size: var(--font-size-base);
font-weight: var(--font-weight-bold);
color: var(--color-text);
margin-bottom: var(--spacing-2);
line-height: var(--line-height-snug);
}

.memo-card__excerpt {
font-size: var(--font-size-sm);
color: var(--color-text-light);
line-height: var(--line-height-normal);
margin-bottom: var(--spacing-3);
}

.memo-card__meta {
display: flex;
flex-wrap: wrap;
gap: var(--spacing-1);
}

/* メモチップ */
.memo-chip {
display: inline-block;
padding: 2px var(--spacing-2);
border-radius: 999px;
font-size: var(--font-size-xs);
font-weight: var(--font-weight-medium);
white-space: nowrap;
}

.memo-chip--diff {
background-color: var(--color-gray-100);
color: var(--color-text);
}

.memo-chip--diff.diff--easy {
background-color: var(--color-green-light);
color: var(--color-green);
}

.memo-chip--diff.diff--medium {
background-color: #FFF3CD;
color: #856404;
}

.memo-chip--diff.diff--hard {
background-color: #FFE5E5;
color: #B00020;
}

.memo-chip--time {
background-color: var(--color-primary-light);
color: var(--color-primary-dark);
}

.memo-chip--cost {
background-color: var(--color-green-light);
color: var(--color-green);
}

/* 非表示（JSで切り替え） */
.memo-card.is-hidden {
display: none;
}

.memo-empty {
padding: var(--spacing-8) 0;
text-align: center;
color: var(--color-text-light);
}

.memo-section-title {
font-size: var(--font-size-lg);
font-weight: var(--font-weight-bold);
color: var(--color-text);
margin-bottom: var(--spacing-4);
padding-bottom: var(--spacing-2);
border-bottom: 2px solid var(--color-primary);
}

/* ▼ Phase8: 追加 */
.memo-section-sub {
	font-size: var(--font-size-sm);
	color: var(--color-text-light);
	margin: calc(var(--spacing-4) * -1) 0 var(--spacing-4);
	line-height: var(--line-height-base);
}

.memo-intro {
	margin-bottom: var(--spacing-6);
}

.memo-post-nav {
	display: flex;
	flex-wrap: wrap;
	justify-content: space-between;
	gap: var(--spacing-3);
	margin-top: var(--spacing-8);
}
.memo-post-nav .btn {
	flex: 1 1 auto;
	min-width: 200px;
	text-align: center;
}

/* ================================================
   46. 診断質問：画像・ヒント
   ================================================ */

.shindan-question__image {
margin-bottom: var(--spacing-4);
border-radius: var(--border-radius-base);
overflow: hidden;
border: 1px solid var(--color-border);
background-color: var(--color-gray-50);
}

.shindan-question__image img {
display: block;
width: 100%;
height: auto;
max-height: 280px;
object-fit: cover;
}

.shindan-question__hint {
font-size: var(--font-size-sm);
color: var(--color-text-light);
font-style: italic;
margin-top: var(--spacing-2);
margin-bottom: var(--spacing-2);
padding: var(--spacing-2) var(--spacing-3);
background-color: var(--color-primary-light);
border-left: 3px solid var(--color-primary);
border-radius: 0 var(--border-radius-sm) var(--border-radius-sm) 0;
}


/* ================================================
   47. ガイド詳細：アイキャッチ画像
   ================================================ */

.guide-eyecatch {
margin-bottom: var(--spacing-6);
border-radius: var(--border-radius-lg);
overflow: hidden;
}

.guide-eyecatch__img {
display: block;
width: 100%;
height: auto;
max-height: 360px;
object-fit: cover;
}

/* ================================================
   48. ガイド詳細：関連そなえメモカード
   ================================================ */

.guide-related-memos {
margin-top: var(--spacing-10);
margin-bottom: var(--spacing-8);
padding: var(--spacing-6);
background-color: var(--color-primary-light);
border-radius: var(--border-radius-lg);
border: 1px solid rgba(245, 163, 42, 0.25);
}

.guide-section__title--memos {
border-bottom-color: var(--color-primary);
}

.guide-section__title-icon {
margin-right: var(--spacing-1);
}

.guide-related-memos__lead {
font-size: var(--font-size-sm);
color: var(--color-text-light);
margin-bottom: var(--spacing-4);
}

.guide-related-memos__grid {
display: grid;
grid-template-columns: 1fr;
gap: var(--spacing-3);
margin-bottom: var(--spacing-4);
}

@media (min-width: 480px) {
.guide-related-memos__grid {
grid-template-columns: repeat(2, 1fr);
}
}

.guide-memo-card {
display: flex;
align-items: stretch;
background-color: var(--color-bg);
border: 1px solid var(--color-border);
border-radius: var(--border-radius-base);
text-decoration: none;
color: var(--color-text);
overflow: hidden;
transition: box-shadow 0.2s, transform 0.1s;
}

.guide-memo-card:hover {
box-shadow: var(--shadow-md);
transform: translateY(-2px);
}

.guide-memo-card__thumb {
flex-shrink: 0;
width: 72px;
min-height: 72px;
overflow: hidden;
background-color: var(--color-border);
}

.guide-memo-card__thumb img {
width: 100%;
height: 100%;
object-fit: cover;
}

.guide-memo-card__thumb--placeholder {
display: flex;
align-items: center;
justify-content: center;
background: linear-gradient(135deg, var(--color-primary-light) 0%, var(--color-border) 100%);
font-size: 1.5rem;
}

.guide-memo-card__body {
flex: 1;
padding: var(--spacing-3);
display: flex;
flex-direction: column;
gap: var(--spacing-1);
}

.guide-memo-card__title {
font-size: var(--font-size-sm);
font-weight: var(--font-weight-bold);
color: var(--color-text);
line-height: var(--line-height-snug);
margin: 0;
}

.guide-memo-card__excerpt {
font-size: var(--font-size-xs);
color: var(--color-text-light);
line-height: var(--line-height-normal);
margin: 0;
}

.guide-memo-card__meta {
display: flex;
flex-wrap: wrap;
gap: 4px;
}

.guide-memo-card__arrow {
display: flex;
align-items: center;
padding-right: var(--spacing-2);
color: var(--color-primary);
font-size: var(--font-size-lg);
flex-shrink: 0;
}

.guide-related-memos__more {
text-align: center;
margin-top: var(--spacing-4);
}
.guide-memo-all-btn {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: 8px;
	padding: 12px var(--spacing-5);
	background-color: var(--color-primary);
	color: #fff;
	border-radius: var(--border-radius-full);
	font-size: var(--font-size-base);
	font-weight: 700;
	text-decoration: none;
	transition: background-color var(--transition), transform var(--transition), box-shadow var(--transition);
	box-shadow: 0 2px 6px rgba(245,163,42,0.25);
}
.guide-memo-all-btn:hover,
.guide-memo-all-btn:focus {
	background-color: var(--color-primary-dark);
	color: #fff;
	transform: translateY(-1px);
	box-shadow: 0 4px 10px rgba(245,163,42,0.35);
}
.guide-memo-all-btn__icon { font-size: 18px; }
.guide-memo-all-btn__arrow { font-size: 16px; transition: transform var(--transition); }
.guide-memo-all-btn:hover .guide-memo-all-btn__arrow { transform: translateX(3px); }

/* ================================================
   49. クイズ「答えを見る」トグルボタン
   ================================================ */

.mini-quiz__toggle {
display: flex;
align-items: center;
gap: var(--spacing-2);
margin-top: var(--spacing-3);
padding: var(--spacing-2) var(--spacing-4);
background: none;
border: 1px solid var(--color-border);
border-radius: var(--border-radius-base);
font-size: var(--font-size-sm);
color: var(--color-primary-dark);
cursor: pointer;
transition: background-color 0.2s, border-color 0.2s;
width: 100%;
justify-content: center;
}

.mini-quiz__toggle:hover {
background-color: var(--color-primary-light);
border-color: var(--color-primary);
}

.mini-quiz__toggle[aria-expanded="true"] {
background-color: var(--color-primary-light);
border-color: var(--color-primary);
}

.mini-quiz__toggle-icon {
font-size: var(--font-size-xs);
transition: transform 0.2s;
}

/* 回答エリアのアニメーション */
.mini-quiz__answer {
margin-top: var(--spacing-4);
padding: var(--spacing-4);
background-color: var(--color-green-light);
border-left: 3px solid var(--color-green);
border-radius: 0 var(--border-radius-base) var(--border-radius-base) 0;
}

.mini-quiz__answer[hidden] {
display: none;
}


/* ============================================================
   Section 50: お知らせセクション（TOPページ）
   ============================================================ */

.section--news {
background-color: var(--color-bg);
}

.news-list {
list-style: none;
padding: 0;
margin: 0 0 var(--spacing-6);
border-top: 1px solid var(--color-border);
}

.news-item {
border-bottom: 1px solid var(--color-border);
}

.news-item__link {
display: flex;
align-items: baseline;
flex-wrap: wrap;
gap: var(--spacing-2) var(--spacing-3);
padding: var(--spacing-4) var(--spacing-2);
text-decoration: none;
color: var(--color-text);
transition: background-color 0.15s;
}

.news-item__link:hover {
background-color: var(--color-primary-light);
}

.news-item__date {
font-size: var(--font-size-xs);
color: #888;
white-space: nowrap;
flex-shrink: 0;
}

.news-item__cat {
font-size: var(--font-size-xs);
padding: 2px 8px;
border-radius: 9999px;
background-color: var(--color-primary-light);
color: var(--color-primary-dark);
flex-shrink: 0;
}

.news-item__title {
font-size: var(--font-size-sm);
flex: 1;
min-width: 0;
}


/* ============================================================
   Section 51: タスク ステップグループ
   ============================================================ */

.task-step-groups {
display: flex;
flex-direction: column;
gap: var(--spacing-6);
}

.task-step-group {
border: 1px solid var(--color-border);
border-radius: var(--border-radius-lg);
overflow: hidden;
}

.task-step-group__header {
display: flex;
align-items: center;
gap: var(--spacing-3);
padding: var(--spacing-3) var(--spacing-4);
background-color: var(--color-primary-light);
border-bottom: 1px solid var(--color-border);
}

.task-step-badge {
display: flex;
align-items: center;
justify-content: center;
width: 36px;
height: 36px;
font-size: 1.25rem;
flex-shrink: 0;
}

.task-step-badge--1 { background-color: #E8F5E9; border-radius: 50%; }
.task-step-badge--2 { background-color: #E3F2FD; border-radius: 50%; }
.task-step-badge--3 { background-color: #E8F5E9; border-radius: 50%; }
.task-step-badge--4 { background-color: #FFF3E0; border-radius: 50%; }

.task-step-group__label {
font-size: var(--font-size-sm);
font-weight: 700;
color: var(--color-text);
margin: 0;
line-height: 1.4;
}

.task-step-group__sub {
font-size: var(--font-size-xs);
color: #888;
margin: 0;
}

.task-step-group .task-list {
padding: var(--spacing-2) var(--spacing-3);
margin: 0;
}

/* ============================================================
   Lv.別タスクグループ（診断から来た場合）
   ============================================================ */
.kyou-level-group {
border: 1px solid var(--color-border);
border-radius: var(--border-radius-lg);
overflow: hidden;
margin-bottom: var(--spacing-4);
}

.kyou-level-group__header {
display: flex;
align-items: center;
gap: var(--spacing-3);
padding: var(--spacing-3) var(--spacing-4);
background: linear-gradient(135deg, #2a2320, #3d3530);
}

.kyou-level-group__badge {
display: inline-flex;
align-items: center;
justify-content: center;
background-color: var(--color-primary);
color: #fff;
font-size: var(--font-size-sm);
font-weight: 700;
padding: 2px 12px;
border-radius: var(--border-radius-full);
flex-shrink: 0;
white-space: nowrap;
}

.kyou-level-group__title {
font-size: var(--font-size-sm);
font-weight: 700;
color: #fff;
margin: 0;
}

.kyou-level-group .task-list {
padding: var(--spacing-2) var(--spacing-3);
margin: 0;
}


/* ============================================================
   Section 52: 診断結果画像
   ============================================================ */

.shindan-result__image {
text-align: center;
margin-bottom: var(--spacing-4);
}

.shindan-result__img {
max-width: 200px;
width: 100%;
height: auto;
border-radius: var(--border-radius-base);
}


/* ============================================================
   Section 53: WYSIWYGコンテンツ（メモ本文）
   ============================================================ */

/* 目次 */
.memo-toc {
background-color: var(--color-primary-light);
border: 1px solid rgba(245,163,42,.3);
border-radius: var(--border-radius-base);
padding: var(--spacing-4) var(--spacing-5);
margin-bottom: var(--spacing-6);
}

.memo-toc__label {
font-size: var(--font-size-sm);
font-weight: 700;
color: var(--color-primary-dark);
margin-bottom: var(--spacing-3);
padding-bottom: var(--spacing-2);
border-bottom: 1px solid rgba(245,163,42,.3);
}

.memo-toc__list {
list-style: none;
padding: 0;
margin: 0;
counter-reset: toc-h2;
display: flex;
flex-direction: column;
gap: var(--spacing-3);
}

.memo-toc__item--h2 {
counter-increment: toc-h2;
}

.memo-toc__link--h2 {
display: flex;
align-items: center;
gap: var(--spacing-2);
font-size: var(--font-size-sm);
font-weight: 700;
color: var(--color-text);
text-decoration: none;
line-height: 1.5;
}

.memo-toc__link--h2::before {
content: counter(toc-h2);
display: inline-flex;
align-items: center;
justify-content: center;
min-width: 1.4rem;
height: 1.4rem;
background-color: var(--color-primary);
color: #fff;
font-size: 0.7rem;
font-weight: 700;
border-radius: 50%;
flex-shrink: 0;
}

.memo-toc__link--h2:hover {
color: var(--color-primary-dark);
}

.memo-toc__sublist {
list-style: none;
padding: 0;
margin: var(--spacing-2) 0 0 2rem;
display: flex;
flex-direction: column;
gap: var(--spacing-1);
}

.memo-toc__link--h3 {
display: flex;
align-items: center;
gap: var(--spacing-2);
font-size: var(--font-size-xs);
color: #6b6460;
text-decoration: none;
line-height: 1.5;
}

.memo-toc__link--h3::before {
content: "";
display: inline-block;
width: 6px;
height: 6px;
border-radius: 50%;
background-color: var(--color-primary);
opacity: 0.7;
flex-shrink: 0;
}

.memo-toc__link--h3:hover {
color: var(--color-primary-dark);
}

/* そなえメモ本文エリア */
.memo-body-content {
margin-top: var(--spacing-6);
}

.wysiwyg-content h1 {
font-size: var(--font-size-xl);
font-weight: 700;
margin: var(--spacing-8) 0 var(--spacing-4);
color: var(--color-text);
padding-bottom: var(--spacing-2);
border-bottom: 2px solid var(--color-primary);
}

.wysiwyg-content h1:first-child {
margin-top: 0;
}

.wysiwyg-content h2 {
font-size: var(--font-size-lg);
font-weight: 700;
margin: var(--spacing-8) 0 var(--spacing-3);
color: var(--color-text);
padding: var(--spacing-2) var(--spacing-3);
border-left: 4px solid var(--color-primary);
background-color: var(--color-primary-light);
border-radius: 0 4px 4px 0;
}

.wysiwyg-content h2:first-child {
margin-top: 0;
}

.wysiwyg-content h3 {
font-size: var(--font-size-base);
font-weight: 700;
margin: var(--spacing-6) 0 var(--spacing-2);
color: var(--color-text);
padding-left: var(--spacing-5);
position: relative;
border: none;
}

.wysiwyg-content h3::before {
content: "";
position: absolute;
left: 0;
top: 50%;
transform: translateY(-50%);
width: 8px;
height: 8px;
background-color: var(--color-primary);
border-radius: 50%;
}

.wysiwyg-content p {
font-size: var(--font-size-sm);
line-height: 1.8;
margin-bottom: var(--spacing-3);
color: var(--color-text);
}

.wysiwyg-content ul,
.wysiwyg-content ol {
padding-left: 1.5rem;
margin-bottom: var(--spacing-4);
}

.wysiwyg-content ul {
list-style: disc;
}

.wysiwyg-content ul ul {
list-style: circle;
}

.wysiwyg-content ol {
list-style: decimal;
}

.wysiwyg-content li {
font-size: var(--font-size-sm);
line-height: 1.8;
margin-bottom: var(--spacing-1);
}

.wysiwyg-content strong {
color: var(--color-primary-dark);
}

/* 引用ブロック */
.wysiwyg-content blockquote {
margin: var(--spacing-6) 0;
padding: var(--spacing-4) var(--spacing-5);
background-color: var(--color-primary-light);
border-left: 4px solid var(--color-primary);
border-radius: 0 var(--border-radius-base) var(--border-radius-base) 0;
font-style: italic;
color: #5A5248;
}

.wysiwyg-content blockquote p {
margin-bottom: var(--spacing-2);
font-size: var(--font-size-sm);
line-height: 1.8;
}

.wysiwyg-content blockquote p:last-child {
margin-bottom: 0;
}

/* リンク */
.wysiwyg-content a {
color: var(--color-blue);
text-decoration: underline;
text-underline-offset: 2px;
}

.wysiwyg-content a:hover {
opacity: 0.8;
}

/* 外部リンクアイコン */
.wysiwyg-content a[target="_blank"]::after {
content: "\00a0\2197";
font-size: 0.7em;
vertical-align: super;
text-decoration: none;
display: inline-block;
opacity: 0.7;
}

/* 本文内画像 */
.wysiwyg-content img {
max-width: 100%;
width: 100%;
height: auto;
border-radius: var(--border-radius-base);
margin: var(--spacing-4) 0;
display: block;
}

/* 左右寄せ画像は幅を auto に戻す */
.wysiwyg-content .alignleft img,
.wysiwyg-content .alignright img {
width: auto;
max-width: 50%;
}

.wysiwyg-content .alignleft {
float: left;
margin: var(--spacing-2) var(--spacing-4) var(--spacing-4) 0;
}

.wysiwyg-content .alignright {
float: right;
margin: var(--spacing-2) 0 var(--spacing-4) var(--spacing-4);
}

.wysiwyg-content .aligncenter {
margin-left: auto;
margin-right: auto;
}

.wysiwyg-content .wp-caption {
max-width: 100%;
}

.wysiwyg-content .wp-caption-text {
font-size: var(--font-size-xs);
color: #888;
text-align: center;
margin-top: var(--spacing-1);
}

/* WYSIWYGテーブル */
.wysiwyg-content table {
width: 100%;
border-collapse: collapse;
margin-bottom: var(--spacing-6);
font-size: var(--font-size-sm);
}

.wysiwyg-content th,
.wysiwyg-content td {
padding: var(--spacing-2) var(--spacing-3);
border: 1px solid var(--color-border);
text-align: left;
line-height: 1.6;
}

.wysiwyg-content th,
.wysiwyg-content thead td {
background-color: var(--color-primary) !important;
font-weight: 700;
color: #fff !important;
}

.wysiwyg-content tr:nth-child(even) td {
background-color: #FAFAFA;
}

/* ============================
   Phase 7: タッチ/UX改善
   ============================ */

/* タスクリスト最小タップターゲット */
.task-list__item {
	min-height: 56px;
}

.dekita-btn {
	min-height: 44px;
	min-width: 80px;
}

.page-id-18 .dekita-btn {
	width: 100%;
}

/* 今日やること：おすすめブロック */
.task-list__item--featured {
	background-color: var(--color-primary-light);
	border-color: var(--color-primary);
}

.task-list--recommended .task-list__item {
	border-left: 3px solid var(--color-primary);
}

/* 診断選択肢：フルwidth・最小高さ56px */
.shindan-choices {
	display: flex;
	flex-direction: column;
	gap: var(--spacing-3);
}

.shindan-choice {
	width: 100%;
	min-height: 56px;
	display: flex;
	align-items: center;
	justify-content: center;
	cursor: pointer;
}

/* 診断質問のスライドアニメーション */
.shindan-question {
	transition: opacity 0.2s ease, transform 0.2s ease;
}

.shindan-question[hidden] {
	display: none;
}

.shindan-question.is-active {
	animation: slideInQuestion 0.25s ease forwards;
}

@keyframes slideInQuestion {
	from {
		opacity: 0;
		transform: translateX(12px);
	}
	to {
		opacity: 1;
		transform: translateX(0);
	}
}

/* ガイドカード 緊急度色分け強化 */
.guide-card--level-danger {
	border-color: rgba(224,90,75,.5);
	background-color: #FFF2F0;
	border-width: 2px;
}

.guide-card--level-danger:hover {
	border-color: var(--color-alert);
	background-color: #FFE8E5;
}

.guide-card--level-watch {
	border-color: rgba(232,155,48,.5);
	background-color: #FFFAF0;
	border-width: 2px;
}

.guide-card--level-watch:hover {
	border-color: var(--color-warning, #E89B30);
	background-color: #FFF5E0;
}

/* ガイド一覧カード 緊急度色分け強化 */
.guide-list-card--level-danger {
	border-left: 4px solid var(--color-alert);
}

.guide-list-card--level-watch {
	border-left: 4px solid #E89B30;
}

/* 今日やること おすすめセクション */
.kyou-recommended {
	margin-bottom: var(--spacing-6);
}

/* ============================================================
   Phase 27: できているかも？（仮完了候補） セクション
   ============================================================ */
.kyou-pending {
	background: var(--color-bg-soft, #fff7ee);
	border: 1px solid var(--color-primary-light, #ffd9a3);
	border-radius: var(--border-radius-lg, 12px);
	padding: var(--spacing-4);
	margin-bottom: var(--spacing-6);
}
.kyou-pending[hidden] { display: none; }
.kyou-pending__groups {
	display: flex;
	flex-direction: column;
	gap: var(--spacing-4);
	margin-top: var(--spacing-3);
}
.kyou-pending__group {
	background: #fff;
	border-radius: var(--border-radius-base);
	padding: var(--spacing-3);
	border: 1px solid var(--color-border-light, #f0e3d0);
}
.kyou-pending__group-head {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	justify-content: space-between;
	gap: var(--spacing-2);
	margin-bottom: var(--spacing-2);
}
.kyou-pending__group-title {
	font-size: var(--font-size-base);
	font-weight: 700;
	color: var(--color-text);
	margin: 0;
}
.kyou-pending__group-bulk {
	display: flex;
	gap: var(--spacing-2);
	flex-wrap: wrap;
}
.kyou-pending__list {
	list-style: none;
	margin: 0;
	padding: 0;
	display: flex;
	flex-direction: column;
	gap: var(--spacing-2);
}
.kyou-pending__item {
	display: flex;
	flex-direction: column;
	gap: var(--spacing-2);
	padding: var(--spacing-2) var(--spacing-3);
	background: var(--color-bg, #fff);
	border-radius: var(--border-radius-base);
	border: 1px solid var(--color-border-light, #f0e3d0);
}
.kyou-pending__title {
	margin: 0;
	font-size: var(--font-size-sm);
	color: var(--color-text);
	line-height: 1.4;
}
.kyou-pending__actions {
	display: flex;
	gap: var(--spacing-2);
	flex-wrap: wrap;
}
.kyou-pending__actions .btn {
	min-width: 0;
	flex: 1 1 auto;
}
@media (min-width: 600px) {
	.kyou-pending__item {
		flex-direction: row;
		align-items: center;
		justify-content: space-between;
	}
	.kyou-pending__actions {
		flex: 0 0 auto;
	}
	.kyou-pending__actions .btn { flex: 0 0 auto; }
}

/* 再訪ユーザー進捗バナー */
.kyou-progress-banner {
	background: linear-gradient(135deg, var(--color-primary-light), #fff8ee);
	border: 1px solid var(--color-primary);
	border-radius: var(--border-radius-base);
	padding: var(--spacing-3) var(--spacing-4);
	margin-bottom: var(--spacing-4);
	display: flex;
	flex-direction: column;
	gap: var(--spacing-1);
}

.kyou-progress-banner[hidden] {
	display: none !important;
}

.kyou-progress-banner__text {
	font-size: var(--font-size-base);
	font-weight: 700;
	color: var(--color-primary-dark);
}

.kyou-progress-banner__sub {
	font-size: var(--font-size-sm);
	color: var(--color-text-light);
}

.kyou-recommended__title {
	font-size: var(--font-size-lg);
	font-weight: 700;
	color: var(--color-text);
	margin-bottom: var(--spacing-3);
	padding-bottom: var(--spacing-2);
	border-bottom: 2px solid var(--color-primary);
}

.kyou-recommended__level {
	font-size: var(--font-size-sm);
	font-weight: normal;
	color: var(--color-text-light);
}

.kyou-recommended__empty {
	color: var(--color-text-light);
	font-size: var(--font-size-sm);
}

/* 今日やること アコーディオン */
.kyou-all-tasks {
	margin-top: var(--spacing-6);
}

.kyou-all-tasks__toggle {
	width: 100%;
	padding: var(--spacing-4);
	background-color: var(--color-surface);
	border: 1px solid var(--color-border);
	border-radius: var(--border-radius-base);
	font-size: var(--font-size-sm);
	font-weight: 600;
	color: var(--color-text);
	cursor: pointer;
	text-align: center;
	transition: all var(--transition);
}

.kyou-all-tasks__toggle:hover {
	background-color: var(--color-primary-light);
	border-color: var(--color-primary);
}

/* TOPページ 特大タスク */
.task-featured {
	display: flex;
	align-items: flex-start;
	justify-content: space-between;
	gap: var(--spacing-4);
	background-color: var(--color-primary-light);
	border: 2px solid var(--color-primary);
	border-radius: var(--border-radius-lg);
	padding: var(--spacing-5);
	margin-bottom: var(--spacing-4);
}

.task-featured__body {
	display: flex;
	flex-direction: column;
	gap: var(--spacing-2);
	flex: 1;
}

.task-featured__title {
	font-size: var(--font-size-lg);
	font-weight: 700;
	line-height: var(--line-height-tight);
}

.task-featured__note {
	font-size: var(--font-size-sm);
	color: var(--color-text-light);
}

.task-list--sub {
	margin-top: var(--spacing-2);
}

/* TOPページ まず揃えるもの リスト */
.sonaeru-list {
	list-style: none;
	margin: var(--spacing-5) 0;
	display: flex;
	flex-direction: column;
	gap: var(--spacing-3);
}

.sonaeru-list__item {
	padding: var(--spacing-3) var(--spacing-4);
	background-color: var(--color-surface);
	border-radius: var(--border-radius-base);
	border: 1px solid var(--color-border);
	font-size: var(--font-size-base);
	line-height: var(--line-height-base);
}

/* ガイド詳細 マスコットブロック */
.guide-mascot-block {
	display: flex;
	align-items: center;
	gap: var(--spacing-4);
	background-color: var(--color-primary-light);
	border-radius: var(--border-radius-base);
	padding: var(--spacing-4);
	margin-bottom: var(--spacing-5);
}

.guide-mascot-block__msg {
	font-size: var(--font-size-sm);
	color: var(--color-text);
	line-height: var(--line-height-base);
}

/* ガイド詳細 マスコットブロック レベル別カラー */
.guide-mascot-block--danger {
	background-color: #FFF0EE;
	border-left: 4px solid var(--color-alert);
}
.guide-mascot-block--watch {
	background-color: #FFF7E6;
	border-left: 4px solid #b56a00;
}
.guide-mascot-block--recovery {
	background-color: var(--color-blue-light, #EEF5FA);
	border-left: 4px solid #2E6BA8;
}
.guide-mascot-block--normal {
	background-color: var(--color-primary-light);
	border-left: 4px solid var(--color-primary);
}

/* ガイドチェックリスト チェックボタン */
.guide-checklist__item {
	cursor: pointer;
	transition: background-color var(--transition);
}

.guide-checklist__item.is-checked {
	opacity: 0.6;
}

.guide-checklist__item.is-checked .guide-checklist__icon {
	background-color: var(--color-green);
	color: #fff;
}

.guide-checklist__check-btn {
	background: none;
	border: none;
	padding: 0;
	cursor: pointer;
	flex-shrink: 0;
}

/* kyouのレコメンド見出しLv表示 */
.kyou-recommended__level {
	margin-left: var(--spacing-2);
}

/* ============================
   リセットボタン
   ============================ */
.kyou-reset {
	text-align: center;
	margin-top: var(--spacing-6);
	margin-bottom: var(--spacing-6);
	padding-top: var(--spacing-4);
	border-top: 1px solid var(--color-border);
}

.kyou-reset__btn {
	background: none;
	border: 1px solid var(--color-border);
	border-radius: var(--border-radius-base);
	font-size: var(--font-size-sm);
	color: var(--color-text-light);
	cursor: pointer;
	padding: var(--spacing-2) var(--spacing-5);
	transition: color var(--transition), border-color var(--transition), background-color var(--transition);
}

.kyou-reset__btn:hover {
	color: var(--color-alert);
	border-color: var(--color-alert);
	background-color: rgba(224, 90, 75, 0.05);
}

/* ============================
   リセット確認モーダル
   ============================ */
.reset-modal {
	position: fixed;
	inset: 0;
	z-index: 600;
	display: flex;
	align-items: center;
	justify-content: center;
	padding: var(--spacing-4);
}

.reset-modal[aria-hidden="true"] {
	display: none;
}

.reset-modal__overlay {
	position: absolute;
	inset: 0;
	background-color: rgba(60, 50, 40, 0.5);
	cursor: pointer;
}

.reset-modal__content {
	position: relative;
	background-color: var(--color-surface);
	border-radius: var(--border-radius-lg);
	padding: var(--spacing-8) var(--spacing-6);
	width: 100%;
	max-width: 420px;
	text-align: center;
	animation: slideUp 0.3s ease;
	z-index: 1;
}

.reset-modal__close {
	position: absolute;
	top: var(--spacing-4);
	right: var(--spacing-4);
	font-size: var(--font-size-lg);
	color: var(--color-text-light);
	width: 36px;
	height: 36px;
	display: flex;
	align-items: center;
	justify-content: center;
	background: none;
	border: none;
	cursor: pointer;
}

.reset-modal__mascot {
	margin-bottom: var(--spacing-4);
	display: flex;
	justify-content: center;
}

.reset-modal__title {
	font-size: var(--font-size-lg);
	font-weight: 700;
	margin-bottom: var(--spacing-4);
}

.reset-modal__desc {
	font-size: var(--font-size-sm);
	color: var(--color-text-light);
	text-align: left;
	margin-bottom: var(--spacing-6);
	line-height: var(--line-height-base);
}

.reset-modal__desc ul {
	list-style: disc !important;
	padding-left: 1.5rem;
	margin: var(--spacing-2) 0;
}

.reset-modal__desc li {
	margin-bottom: var(--spacing-1);
}

.reset-modal__note {
	margin-top: var(--spacing-3);
	font-size: var(--font-size-xs, 0.75rem);
	color: var(--color-text-light);
}

.reset-modal__actions {
	display: flex;
	flex-direction: column;
	gap: var(--spacing-3);
}

/* アラートボタン */
.btn--alert {
	background-color: var(--color-alert);
	color: #fff;
	border-color: var(--color-alert);
}

.btn--alert:hover {
	background-color: #c94a3c;
	border-color: #c94a3c;
	color: #fff;
	text-decoration: none;
}

/* ============================
   RPG レベルカード
   ============================ */
.sonae-level-card {
	background: linear-gradient(135deg, #2a2320 0%, #3d3530 100%);
	border-radius: var(--border-radius-lg);
	padding: var(--spacing-4) var(--spacing-5);
	margin-bottom: var(--spacing-6);
	color: #fff;
	position: relative;
	overflow: hidden;
}

/* 背景の装飾グロー */
.sonae-level-card::before {
	content: '';
	position: absolute;
	top: -40px;
	right: -40px;
	width: 140px;
	height: 140px;
	background: radial-gradient(circle, rgba(245, 163, 42, 0.18) 0%, transparent 70%);
	pointer-events: none;
}

.sonae-level-card__main {
	display: flex;
	align-items: center;
	gap: var(--spacing-4);
	margin-bottom: var(--spacing-4);
}

/* Lv. バッジ */
.sonae-level-card__lv-badge {
	background: var(--color-primary);
	border-radius: 12px;
	padding: var(--spacing-2) var(--spacing-3);
	display: flex;
	align-items: baseline;
	gap: 2px;
	flex-shrink: 0;
	box-shadow: 0 2px 14px rgba(245, 163, 42, 0.45);
}

.sonae-level-card__lv-label {
	font-size: 0.6rem;
	font-weight: 700;
	color: rgba(255, 255, 255, 0.85);
	letter-spacing: 0.05em;
}

.sonae-level-card__lv-num {
	font-size: 2.4rem;
	font-weight: 900;
	color: #fff;
	line-height: 1;
}

/* タイトル・件数 */
.sonae-level-card__info {
	flex: 1;
	min-width: 0;
}

.sonae-level-card__title {
	font-size: var(--font-size-base);
	font-weight: 700;
	color: #fff;
	margin-bottom: var(--spacing-1);
}

.sonae-level-card__count {
	font-size: var(--font-size-sm);
	color: rgba(255, 255, 255, 0.65);
}

.sonae-level-card__count span {
	color: var(--color-primary);
	font-weight: 700;
	font-size: var(--font-size-base);
}

/* XP バー */
.sonae-level-card__bar-track {
	height: 10px;
	background: rgba(255, 255, 255, 0.12);
	border-radius: 5px;
	overflow: hidden;
	margin-bottom: var(--spacing-2);
}

.sonae-level-card__bar-fill {
	height: 100%;
	background: linear-gradient(90deg, var(--color-primary) 0%, #ffd166 100%);
	border-radius: 5px;
	width: 0%;
	transition: width 1s cubic-bezier(0.4, 0, 0.2, 1);
	position: relative;
}

/* バーの先端ハイライト */
.sonae-level-card__bar-fill::after {
	content: '';
	position: absolute;
	top: 0;
	right: 0;
	width: 24px;
	height: 100%;
	background: rgba(255, 255, 255, 0.35);
	border-radius: 0 5px 5px 0;
}

.sonae-level-card__next {
	font-size: var(--font-size-xs, 0.75rem);
	color: rgba(255, 255, 255, 0.55);
	text-align: right;
}

/* Phase O-2: レベルメッセージ（穏やかな励まし） */
.sonae-level-card__message {
	margin: 6px 0 10px;
	font-size: 0.88rem;
	line-height: 1.6;
	color: rgba(255, 255, 255, 0.92);
}

/* Phase O-2: つぎにおすすめ（柔らかい提案） */
.sonae-level-card__suggestion {
	display: flex;
	align-items: flex-start;
	gap: 8px;
	margin: 10px 0 0;
	padding: 8px 12px;
	background: rgba(255, 255, 255, 0.12);
	border-radius: 8px;
	font-size: 0.85rem;
	line-height: 1.55;
	color: rgba(255, 255, 255, 0.95);
}
.sonae-level-card__suggestion-label {
	flex-shrink: 0;
	font-size: 0.72rem;
	font-weight: 700;
	padding: 2px 8px;
	background: rgba(255, 255, 255, 0.22);
	border-radius: 999px;
	letter-spacing: 0.04em;
	margin-top: 1px;
}
.sonae-level-card__suggestion-text {
	flex: 1 1 auto;
	min-width: 0;
}


/* ============================================================
   Phase 14: TOP（front-page.php）専用 — 状況グリッド / 5基本 /
   今日の小さな一歩 / お知らせトグル / 使い方ステップ
   ============================================================ */

/* ---- ヒーロー：CTA を縦積み→横並び ---- */
.hero__actions {
	display: flex;
	flex-direction: column;
	gap: var(--spacing-3);
	width: 100%;
}
@media (min-width: 600px) {
	.hero__actions {
		flex-direction: row;
		flex-wrap: wrap;
	}
	.hero__actions .btn--block {
		flex: 1 1 auto;
		min-width: 0;
	}
}

/* ---- 状況グリッド（ユーザー状態名カード） ---- */
.situation-grid {
	display: grid;
	grid-template-columns: 1fr;
	gap: var(--spacing-3);
	margin-bottom: var(--spacing-6);
}
@media (min-width: 480px) {
	.situation-grid {
		grid-template-columns: repeat(2, 1fr);
	}
}

.situation-card {
	height: 100%;
	display: flex;
	flex-direction: column;
	gap: var(--spacing-2);
}
.situation-card__label {
	font-size: var(--font-size-md);
	font-weight: 700;
	line-height: var(--line-height-tight);
	color: var(--color-text);
	margin: 0;
}
.situation-card__sub {
	font-size: var(--font-size-sm);
	color: var(--color-text-light);
	line-height: 1.6;
	margin: 0;
	flex: 1;
}
.situation-card .card-link__cta {
	margin-top: var(--spacing-2);
}


/* ---- 5基本グリッド（最初にそろえる基本の5つ） ---- */
.five-grid {
	display: grid;
	grid-template-columns: repeat(5, 1fr);
	gap: var(--spacing-2);
	margin: var(--spacing-5) 0;
}

.five-grid__item {
	background-color: var(--color-surface);
	border: 1px solid var(--color-border);
	border-radius: var(--border-radius-base);
	padding: var(--spacing-3) var(--spacing-2);
	text-align: center;
	display: flex;
	flex-direction: column;
	align-items: center;
	gap: var(--spacing-1);
}

.five-grid__icon {
	display: block;
	width: 36px;
	height: 36px;
	border-radius: var(--border-radius-full);
	background-color: var(--color-primary-light);
	margin-bottom: var(--spacing-1);
	position: relative;
}
.five-grid__item--water   .five-grid__icon { background-color: #E3F0FA; }
.five-grid__item--food    .five-grid__icon { background-color: #FFF1E0; }
.five-grid__item--light   .five-grid__icon { background-color: #FFF8E0; }
.five-grid__item--battery .five-grid__icon { background-color: #E6F4EE; }
.five-grid__item--toilet  .five-grid__icon { background-color: #F0EBFA; }

/* アイコン中央の小さな丸（雰囲気付け、絵文字は使わない） */
.five-grid__icon::after {
	content: '';
	position: absolute;
	top: 50%;
	left: 50%;
	width: 14px;
	height: 14px;
	border-radius: 50%;
	transform: translate(-50%, -50%);
	background-color: rgba(0, 0, 0, 0.12);
}

.five-grid__name {
	font-size: var(--font-size-sm);
	font-weight: 700;
	margin: 0;
	line-height: 1.3;
}

.five-grid__sub {
	font-size: var(--font-size-xs);
	color: var(--color-text-light);
	margin: 0;
	line-height: 1.3;
}

@media (max-width: 380px) {
	.five-grid {
		gap: 4px;
	}
	.five-grid__item {
		padding: var(--spacing-2) 4px;
	}
	.five-grid__icon {
		width: 28px;
		height: 28px;
	}
}


/* ---- 今日の小さな一歩（タスクプレビュー） ---- */
.today-step-list {
	display: flex;
	flex-direction: column;
	gap: var(--spacing-3);
	margin-bottom: var(--spacing-6);
}

.today-step-item {
	background-color: var(--color-surface);
	border: 1px solid var(--color-border);
	border-radius: var(--border-radius-base);
	padding: var(--spacing-4);
}
.today-step-item.is-done {
	background-color: var(--color-gray-50);
	border-color: var(--color-gray-200);
	opacity: 0.85;
}

.today-step-item__head {
	display: flex;
	align-items: flex-start;
	justify-content: space-between;
	gap: var(--spacing-3);
}

.today-step-item__main {
	flex: 1;
	display: flex;
	flex-direction: column;
	gap: var(--spacing-2);
	min-width: 0;
}

.today-step-item__title {
	font-size: var(--font-size-md);
	font-weight: 700;
	line-height: var(--line-height-tight);
	margin: 0;
}

.today-step-item__meta {
	display: flex;
	flex-wrap: wrap;
	gap: var(--spacing-2);
	margin: 0;
	padding: 0;
	list-style: none;
}
.today-step-item__meta li {
	font-size: var(--font-size-xs);
	color: var(--color-text-light);
	background-color: var(--color-gray-100);
	padding: 2px var(--spacing-2);
	border-radius: var(--border-radius-full);
}

.today-step-item__details {
	margin-top: var(--spacing-3);
	padding-top: var(--spacing-3);
	border-top: 1px dashed var(--color-border);
}
.today-step-item__details summary {
	list-style: none;
	cursor: pointer;
	font-size: var(--font-size-sm);
	font-weight: 500;
	color: var(--color-primary-dark);
	display: inline-flex;
	align-items: center;
	gap: var(--spacing-1);
}
.today-step-item__details summary::-webkit-details-marker { display: none; }
.today-step-item__details summary::after {
	content: '';
	display: inline-block;
	width: 6px;
	height: 6px;
	border-right: 2px solid currentColor;
	border-bottom: 2px solid currentColor;
	transform: rotate(45deg);
	margin-left: var(--spacing-1);
	transition: transform var(--transition);
}
.today-step-item__details[open] summary::after {
	transform: rotate(-135deg);
}
.today-step-item__detail {
	margin: var(--spacing-3) 0 0;
	font-size: var(--font-size-sm);
	color: var(--color-text-light);
	line-height: 1.7;
}


/* ---- もう少し知りたいときは（メモグリッド） ---- */
.top-memo-grid {
	display: grid;
	grid-template-columns: 1fr;
	gap: var(--spacing-3);
}
@media (min-width: 480px) {
	.top-memo-grid {
		grid-template-columns: repeat(2, 1fr);
	}
}
.top-memo-card {
	height: 100%;
	display: flex;
	flex-direction: column;
}
.top-memo-card .card-link__desc {
	flex: 1;
}


/* ---- お知らせ：トグル展開 ---- */
.news-toggle-list {
	display: flex;
	flex-direction: column;
	gap: var(--spacing-2);
	margin: 0;
	padding: 0;
	list-style: none;
}

.news-toggle {
	background-color: var(--color-surface);
	border: 1px solid var(--color-border);
	border-radius: var(--border-radius-base);
	overflow: hidden;
}

.news-toggle__summary {
	display: flex;
	align-items: center;
	gap: var(--spacing-3);
	padding: var(--spacing-3) var(--spacing-4);
	cursor: pointer;
	list-style: none;
	min-height: 44px;
	flex-wrap: wrap;
}
.news-toggle__summary::-webkit-details-marker { display: none; }
.news-toggle__summary:hover {
	background-color: var(--color-gray-50);
}

.news-toggle__date {
	font-size: var(--font-size-xs);
	color: var(--color-text-light);
	flex-shrink: 0;
	font-variant-numeric: tabular-nums;
}

.news-toggle__cat {
	font-size: var(--font-size-xs);
	padding: 2px var(--spacing-2);
	border-radius: var(--border-radius-full);
	background-color: var(--color-primary-light);
	color: var(--color-primary-dark);
	font-weight: 700;
	flex-shrink: 0;
}

.news-toggle__title {
	font-weight: 500;
	flex: 1;
	font-size: var(--font-size-sm);
	min-width: 0;
}

.news-toggle__chevron {
	display: inline-block;
	width: 8px;
	height: 8px;
	border-right: 2px solid var(--color-text-light);
	border-bottom: 2px solid var(--color-text-light);
	transform: rotate(45deg);
	transition: transform var(--transition);
	flex-shrink: 0;
}
.news-toggle[open] .news-toggle__chevron {
	transform: rotate(-135deg);
}

.news-toggle__body {
	padding: var(--spacing-4);
	border-top: 1px dashed var(--color-border);
	font-size: var(--font-size-sm);
	line-height: 1.8;
	color: var(--color-text);
}
.news-toggle__body > p { margin-bottom: var(--spacing-3); }
.news-toggle__body > p:last-child { margin-bottom: 0; }
.news-toggle__more {
	margin-top: var(--spacing-3) !important;
	padding-top: var(--spacing-3);
	border-top: 1px dashed var(--color-border);
	font-size: var(--font-size-sm);
}


/* ---- 使い方ステップ ---- */
.howto-block {
	background-color: var(--color-surface);
	border: 1px solid var(--color-border);
	border-radius: var(--border-radius-lg);
	padding: var(--spacing-5);
}

.howto-block__head {
	display: flex;
	align-items: flex-start;
	gap: var(--spacing-4);
	margin-bottom: var(--spacing-5);
}
.howto-block__head .section__title,
.howto-block__head .section__desc {
	margin-bottom: var(--spacing-2);
	text-align: left;
}
.howto-block__mascot {
	flex-shrink: 0;
}

.howto-steps {
	display: flex;
	flex-direction: column;
	gap: var(--spacing-3);
	margin: 0;
	padding: 0;
	list-style: none;
}

.howto-steps__item {
	display: flex;
	align-items: flex-start;
	gap: var(--spacing-3);
	padding: var(--spacing-4);
	background-color: var(--color-primary-light);
	border-radius: var(--border-radius-base);
}

.howto-steps__num {
	flex-shrink: 0;
	width: 32px;
	height: 32px;
	border-radius: var(--border-radius-full);
	background-color: var(--color-primary);
	color: #fff;
	display: flex;
	align-items: center;
	justify-content: center;
	font-weight: 700;
	font-size: var(--font-size-sm);
}

.howto-steps__text {
	font-size: var(--font-size-sm);
	line-height: 1.7;
	flex: 1;
}
.howto-steps__text strong {
	display: inline-block;
	font-size: var(--font-size-base);
	margin-bottom: var(--spacing-1);
}

.howto-block__note {
	margin-top: var(--spacing-5);
	padding: var(--spacing-3) var(--spacing-4);
	background-color: var(--color-gray-50);
	border-radius: var(--border-radius-base);
	font-size: var(--font-size-xs);
	color: var(--color-text-light);
	line-height: 1.7;
}

.howto-block__actions {
	margin-top: var(--spacing-5);
	text-align: center;
}
.howto-block__actions .btn {
	max-width: 100%;
	white-space: normal;
	line-height: 1.4;
}

@media (max-width: 480px) {
	.howto-block { padding: var(--spacing-4); }
	.howto-block__head { flex-direction: column; gap: var(--spacing-3); }
	.howto-block__actions .btn {
		display: flex;
		width: 100%;
		justify-content: center;
		padding: 12px 16px;
	}
}


/* ============================================================
   Phase 14b: ビジュアル強化 — アイコン / カード装飾 / 背景塗り分け
   ============================================================ */

/* ---- アイコン共通 ---- */
.icon {
	display: inline-block;
	vertical-align: middle;
	flex-shrink: 0;
}

/* ---- セクション見出しに視覚アンカー ---- */
.section__title--icon {
	display: inline-flex;
	align-items: center;
	gap: var(--spacing-2);
	width: 100%;
	justify-content: center;
}
.section__title-icon {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 36px;
	height: 36px;
	border-radius: var(--border-radius-full);
	background-color: var(--color-primary-light);
	color: var(--color-primary-dark);
}

/* セクション見出し直下に短い色付きバー */
.section__title:not(.section__title--plain)::after {
	content: '';
	display: block;
	width: 40px;
	height: 4px;
	border-radius: 2px;
	background-color: var(--color-primary);
	margin: var(--spacing-2) auto 0;
}

/* ---- ヒーロー：背景に空 ---- */
.hero--front {
	position: relative;
	background: linear-gradient(180deg, #EAF4FB 0%, #FFFAF0 100%);
	overflow: hidden;
}
.hero__bg {
	position: absolute;
	inset: 0;
	pointer-events: none;
	z-index: 0;
}
.hero__bg-sun {
	position: absolute;
	top: 16px;
	right: 24px;
	color: #F5C24A;
	opacity: 0.7;
}
.hero__bg-cloud {
	position: absolute;
	color: #fff;
	opacity: 0.85;
}
.hero__bg-cloud--1 { top: 60px; left: 8%; }
.hero__bg-cloud--2 { top: 110px; right: 18%; }
.hero--front .container,
.hero--front .hero__inner {
	position: relative;
	z-index: 1;
}

@media (max-width: 600px) {
	.hero__bg-sun     { width: 64px; height: 64px; top: 8px; right: 8px; }
	.hero__bg-sun svg { width: 64px; height: 64px; }
	.hero__bg-cloud--1 { top: 40px; left: 4%; }
	.hero__bg-cloud--1 svg { width: 56px; height: 56px; }
	.hero__bg-cloud--2 { top: 80px; right: 8%; }
	.hero__bg-cloud--2 svg { width: 40px; height: 40px; }
}

/* ---- 3択カード（next-step）：アイコン円とカラーアクセント ---- */
.next-step-card {
	position: relative;
	overflow: hidden;
}
.next-step-card__icon {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 56px;
	height: 56px;
	border-radius: var(--border-radius-full);
	flex-shrink: 0;
	margin-bottom: var(--spacing-2);
}
.next-step-card--shindan .next-step-card__icon {
	background-color: var(--color-primary-light);
	color: var(--color-primary-dark);
}
.next-step-card--guide .next-step-card__icon {
	background-color: #EEF5FA;
	color: var(--color-info);
}
.next-step-card--kyou .next-step-card__icon {
	background-color: #E6F4EE;
	color: #2E8B57;
}

/* カード上端に色帯 */
.next-step-card::before {
	content: '';
	position: absolute;
	top: 0;
	left: 0;
	right: 0;
	height: 4px;
	background-color: var(--color-primary);
}
.next-step-card--guide::before  { background-color: var(--color-info); }
.next-step-card--kyou::before   { background-color: #2E8B57; }


/* ---- 状況カードを「アイコン+ラベル+矢印」横並びに刷新 ---- */
.situation-card {
	display: flex !important;
	flex-direction: row !important;
	align-items: center;
	gap: var(--spacing-3);
	padding: var(--spacing-4);
	position: relative;
}
.situation-card__icon {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 52px;
	height: 52px;
	border-radius: var(--border-radius-full);
	flex-shrink: 0;
	background-color: var(--color-gray-100);
	color: var(--color-text);
}
.situation-card__body {
	flex: 1;
	min-width: 0;
	display: flex;
	flex-direction: column;
	gap: 2px;
}
.situation-card__label {
	font-size: var(--font-size-md);
	font-weight: 700;
	margin: 0;
	line-height: 1.4;
}
.situation-card__sub {
	font-size: var(--font-size-xs);
	color: var(--color-text-light);
	margin: 0;
	line-height: 1.5;
	flex: 0;
}
.situation-card__arrow {
	flex-shrink: 0;
	color: var(--color-text-light);
	transition: transform var(--transition);
}
.situation-card:hover .situation-card__arrow {
	transform: translateX(4px);
	color: var(--color-primary-dark);
}
/* 状況別カラー */
.situation-card--earthquake .situation-card__icon { background-color: var(--color-alert-light);   color: var(--color-alert); }
.situation-card--typhoon    .situation-card__icon { background-color: var(--color-info-light);    color: var(--color-info); }
.situation-card--rain       .situation-card__icon { background-color: #E3F0FA;                    color: #3A88B8; }
.situation-card--blackout   .situation-card__icon { background-color: var(--color-warning-light); color: var(--color-warning); }
.situation-card--water_cut  .situation-card__icon { background-color: #E0F2EF;                    color: #2A8C7C; }
.situation-card--normal     .situation-card__icon { background-color: var(--color-primary-light); color: var(--color-primary-dark); }


/* ---- 5基本グリッド：SVGアイコン用に上書き ---- */
.five-grid__icon {
	width: 48px !important;
	height: 48px !important;
	background-color: var(--color-surface) !important;
	border: 2px solid var(--color-primary-light);
	display: inline-flex !important;
	align-items: center;
	justify-content: center;
	color: var(--color-text);
	margin-bottom: var(--spacing-1);
}
.five-grid__icon::after { display: none !important; }

.five-grid__item--water   .five-grid__icon { border-color: #C7E1F2; color: #3A88B8; background-color: #F4FAFD !important; }
.five-grid__item--food    .five-grid__icon { border-color: #FAD8AE; color: #C97A1F; background-color: #FFF8F0 !important; }
.five-grid__item--light   .five-grid__icon { border-color: #FAE6A0; color: #B89018; background-color: #FFFCEF !important; }
.five-grid__item--battery .five-grid__icon { border-color: #BFE3D2; color: #2A8C5C; background-color: #F1FAF5 !important; }
.five-grid__item--toilet  .five-grid__icon { border-color: #DACBF2; color: #6B4FA8; background-color: #F8F4FE !important; }

@media (max-width: 380px) {
	.five-grid__icon {
		width: 36px !important;
		height: 36px !important;
	}
	.five-grid__icon svg { width: 22px; height: 22px; }
}


/* ---- 今日の小さな一歩：1件目をフィーチャー化 ---- */
.today-step-item--featured {
	background: linear-gradient(180deg, var(--color-primary-light) 0%, #FFFFFF 60%);
	border: 2px solid var(--color-primary);
	box-shadow: 0 4px 12px rgba(245, 163, 42, 0.12);
	padding: var(--spacing-5);
}
.today-step-item__featured-head {
	display: flex;
	align-items: center;
	gap: var(--spacing-3);
	margin-bottom: var(--spacing-3);
	padding-bottom: var(--spacing-3);
	border-bottom: 1px dashed var(--color-primary);
}
.today-step-item__mascot {
	flex-shrink: 0;
}
.today-step-item__lead {
	font-size: var(--font-size-md);
	font-weight: 700;
	color: var(--color-primary-dark);
	margin: 0;
	line-height: 1.4;
}
.today-step-item--featured .today-step-item__title {
	font-size: var(--font-size-lg);
}

/* できた！ボタンにチェックアイコン */
.dekita-btn .dekita-btn__icon {
	margin-right: 4px;
	vertical-align: -2px;
}


/* ---- メモカード：アイコン + 左アクセントバー ---- */
.top-memo-card {
	display: flex !important;
	flex-direction: row !important;
	align-items: flex-start;
	gap: var(--spacing-3);
	padding-left: calc(var(--spacing-4) + 4px);
	position: relative;
}
.top-memo-card::before {
	content: '';
	position: absolute;
	top: 0;
	bottom: 0;
	left: 0;
	width: 4px;
	background-color: var(--color-primary);
	border-top-left-radius: var(--border-radius-base);
	border-bottom-left-radius: var(--border-radius-base);
}
.top-memo-card__icon {
	flex-shrink: 0;
	width: 36px;
	height: 36px;
	border-radius: var(--border-radius-full);
	background-color: var(--color-primary-light);
	color: var(--color-primary-dark);
	display: inline-flex;
	align-items: center;
	justify-content: center;
}
.top-memo-card__body {
	flex: 1;
	min-width: 0;
	display: flex;
	flex-direction: column;
}


/* ---- お知らせカテゴリ色分け ---- */
.news-toggle__cat--update { background-color: var(--color-info-light);    color: var(--color-info); }
.news-toggle__cat--new    { background-color: #E6F4EE;                    color: #2A8C5C; }
.news-toggle__cat--tips   { background-color: var(--color-warning-light); color: var(--color-warning); }
.news-toggle__cat--notice { background-color: var(--color-gray-100);      color: var(--color-gray-600); }


/* ---- カード共通：影＋ホバー浮き上がり ---- */
.card-link,
.next-step-card,
.today-step-item,
.howto-block {
	box-shadow: 0 1px 2px rgba(58, 53, 48, 0.04);
	transition: transform var(--transition), box-shadow var(--transition), border-color var(--transition);
}
.card-link:hover,
.next-step-card:hover {
	transform: translateY(-2px);
	box-shadow: 0 6px 16px rgba(58, 53, 48, 0.10);
}


/* ---- セクション背景バリエーション ---- */
.section--peach { background-color: #FFF4ED; }
.section--lavender { background-color: #F6F2FA; }
.section--beige { background-color: #FAF6EC; }


/* ---- 使い方ステップ：ステッパー風（横線で番号を繋ぐ） ---- */
@media (min-width: 720px) {
	.howto-steps {
		flex-direction: row;
		gap: 0;
		position: relative;
	}
	.howto-steps::before {
		content: '';
		position: absolute;
		top: 36px;
		left: 8%;
		right: 8%;
		height: 2px;
		background-color: var(--color-primary-light);
		z-index: 0;
	}
	.howto-steps__item {
		flex: 1;
		flex-direction: column;
		align-items: center;
		text-align: center;
		background-color: transparent;
		padding: var(--spacing-3) var(--spacing-2);
		position: relative;
		z-index: 1;
	}
	.howto-steps__num {
		width: 48px;
		height: 48px;
		font-size: var(--font-size-md);
		box-shadow: 0 0 0 4px var(--color-surface);
	}
}


/* ============================================================
   Phase 15: 診断ページ（page-shindan.php）視覚再設計
   ============================================================ */

/* ---- 進捗：カウンタを大きく見せる ---- */
.shindan-progress-wrap {
	margin: var(--spacing-5) 0 var(--spacing-4);
	display: flex;
	flex-direction: column;
	align-items: center;
	gap: var(--spacing-2);
}

.shindan-progress__counter {
	font-size: var(--font-size-lg);
	font-weight: 700;
	font-variant-numeric: tabular-nums;
	color: var(--color-text);
	margin: 0;
	line-height: 1;
}
.shindan-progress__current {
	font-size: 2rem;
	color: var(--color-primary-dark);
}
.shindan-progress__sep {
	margin: 0 4px;
	color: var(--color-text-light);
	font-weight: 400;
}
.shindan-progress__total {
	color: var(--color-text-light);
	font-weight: 400;
}

/* 上書き：既存 .shindan-progress を新ラッパー内で幅100% */
.shindan-progress-wrap .shindan-progress {
	width: 100%;
	max-width: 360px;
}

/* ---- 質問カード：中央配置・大きめ・カード化 ---- */
.shindan-question {
	background-color: var(--color-surface);
	border: 1px solid var(--color-border);
	border-radius: var(--border-radius-lg);
	padding: var(--spacing-5);
	box-shadow: 0 2px 8px rgba(58, 53, 48, 0.05);
	text-align: center;
}

.shindan-question__text {
	font-size: var(--font-size-lg);
	font-weight: 700;
	line-height: 1.5;
	margin: 0 0 var(--spacing-3);
	color: var(--color-text);
	display: block;
	min-height: auto;
	padding-left: 0;
}
/* 旧 .shindan-question__num（左肩番号バッジ）は廃止 */
.shindan-question__num { display: none !important; }

/* ---- ヒント：選択肢の上に配置（見つけやすく） ---- */
.shindan-question__hint-wrap {
	margin: 0 auto var(--spacing-4);
	max-width: 360px;
	background-color: var(--color-primary-light);
	border-radius: var(--border-radius-base);
	padding: 0;
	border: 1px solid #FFE0B0;
}

.shindan-question__hint-toggle {
	display: inline-flex;
	align-items: center;
	gap: var(--spacing-1);
	padding: var(--spacing-2) var(--spacing-3);
	cursor: pointer;
	font-size: var(--font-size-sm);
	font-weight: 700;
	color: var(--color-primary-dark);
	list-style: none;
	width: 100%;
	justify-content: center;
}
.shindan-question__hint-toggle::-webkit-details-marker { display: none; }
/* 旧 ::before は使わずアイコンSVGを使用するため非表示化 */
.shindan-question__hint-toggle::before { content: none !important; }

.shindan-question__hint-icon {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	color: var(--color-warning);
}

.shindan-question__hint-wrap .shindan-question__hint {
	padding: 0 var(--spacing-3) var(--spacing-3);
	margin: 0;
	font-size: var(--font-size-sm);
	color: var(--color-text);
	line-height: 1.7;
	text-align: left;
}

/* ---- 選択肢：はい/いいえを大きく、よく分からないを補助 ---- */
.shindan-question__choices {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: var(--spacing-3);
	margin-bottom: var(--spacing-3);
}

.shindan-choice {
	min-height: 64px;
	font-size: var(--font-size-md);
	font-weight: 700;
	border-radius: var(--border-radius-base);
	border: 2px solid;
	padding: var(--spacing-3);
	cursor: pointer;
	transition: all var(--transition);
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: var(--spacing-2);
	background-color: var(--color-surface);
}

.shindan-choice__icon {
	display: inline-flex;
	align-items: center;
	justify-content: center;
}

.shindan-choice--yes {
	color: #2A8C5C;
	border-color: #2A8C5C;
	background-color: #F1FAF5;
}
.shindan-choice--yes:hover,
.shindan-choice--yes:focus {
	background-color: #2A8C5C;
	color: #fff;
}

.shindan-choice--no {
	color: var(--color-text);
	border-color: var(--color-gray-300);
}
.shindan-choice--no:hover,
.shindan-choice--no:focus {
	background-color: var(--color-text);
	color: #fff;
	border-color: var(--color-text);
}

/* よく分からない：選択肢2つの下に小さなテキストボタン */
.shindan-choice--unknown {
	display: block;
	width: 100%;
	max-width: 280px;
	margin: 0 auto;
	min-height: 36px;
	font-size: var(--font-size-sm);
	font-weight: 500;
	background: transparent;
	border: 1px dashed var(--color-gray-300);
	color: var(--color-text-light);
	padding: var(--spacing-2);
}
.shindan-choice--unknown:hover,
.shindan-choice--unknown:focus {
	background-color: var(--color-gray-50);
	color: var(--color-text);
	border-style: solid;
}

/* ---- ナビ（戻る） ---- */
.shindan-nav {
	margin-top: var(--spacing-4);
	display: flex;
	justify-content: center;
}
.shindan-nav__back {
	background: transparent;
	border: none;
	color: var(--color-text-light);
	font-size: var(--font-size-sm);
	cursor: pointer;
	padding: var(--spacing-2) var(--spacing-3);
	border-radius: var(--border-radius-base);
	transition: all var(--transition);
}
.shindan-nav__back:hover,
.shindan-nav__back:focus {
	color: var(--color-primary-dark);
	background-color: var(--color-primary-light);
}

/* ---- 結果カード：1枚ビジュアルに統一・中央配置 ---- */
.shindan-result__card {
	background-color: var(--color-surface);
	border: 1px solid var(--color-border);
	border-radius: var(--border-radius-lg);
	padding: var(--spacing-6) var(--spacing-5);
	text-align: center;
	box-shadow: 0 4px 16px rgba(58, 53, 48, 0.06);
	margin-bottom: var(--spacing-5);
}

.shindan-result__visual {
	margin-bottom: var(--spacing-4);
	min-height: 160px;
	display: flex;
	align-items: center;
	justify-content: center;
}
.shindan-result__image:empty { display: none; }
.shindan-result__image img {
	max-width: 200px;
	height: auto;
}

.shindan-result__lead {
	font-size: var(--font-size-sm);
	color: var(--color-text-light);
	margin: 0 0 var(--spacing-1);
}

.shindan-result__level {
	font-size: 3rem;
	font-weight: 800;
	line-height: 1;
	color: var(--color-primary-dark);
	margin: 0;
	letter-spacing: -0.02em;
}

.shindan-result__remain {
	font-size: var(--font-size-sm);
	color: var(--color-primary);
	font-weight: 700;
	margin: var(--spacing-1) 0 var(--spacing-3);
}

.shindan-result__title {
	font-size: var(--font-size-xl);
	font-weight: 700;
	line-height: 1.4;
	margin: 0 0 var(--spacing-3);
	color: var(--color-text);
}

.shindan-result__intro {
	font-size: var(--font-size-base);
	color: var(--color-text);
	line-height: 1.8;
	margin: 0;
	max-width: 480px;
	margin-left: auto;
	margin-right: auto;
}

/* 旧 .shindan-result__head/desc/next レイアウトは新カードに置換 */
.shindan-result__head,
.shindan-result__next { display: none !important; }
.shindan-result__desc { display: none !important; }


/* ---- 今日のおすすめ：リンクカード化 ---- */
.shindan-result__tasks {
	background-color: var(--color-surface);
	border: 1px solid var(--color-border);
	border-radius: var(--border-radius-lg);
	padding: var(--spacing-5);
	margin-bottom: var(--spacing-5);
}

.shindan-result__tasks-title {
	font-size: var(--font-size-md);
	font-weight: 700;
	margin: 0 0 var(--spacing-4);
	display: flex;
	align-items: center;
	gap: var(--spacing-2);
	color: var(--color-text);
}
.shindan-result__tasks-icon {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 32px;
	height: 32px;
	border-radius: var(--border-radius-full);
	background-color: var(--color-primary-light);
	color: var(--color-primary-dark);
	flex-shrink: 0;
}

/* ---- 次にできそうなこと（旧: shindan-result__tasks / shindan-result__nextlevel を統合） ---- */
.shindan-result__nextcan {
	background: linear-gradient(135deg, #FFF8EE 0%, #FFFBF3 100%);
	border: 1px solid #FFE0B0;
	border-radius: var(--border-radius-lg);
	padding: var(--spacing-5);
	margin-bottom: var(--spacing-5);
}
.nextcan__head {
	display: flex;
	align-items: center;
	gap: var(--spacing-2);
	margin-bottom: var(--spacing-2);
}
.nextcan__icon {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 32px;
	height: 32px;
	border-radius: var(--border-radius-full);
	background-color: var(--color-primary);
	color: #fff;
	flex-shrink: 0;
}
.nextcan__title {
	margin: 0;
	font-size: var(--font-size-md);
	font-weight: 700;
	color: var(--color-text);
}
.nextcan__lead {
	margin: 0 0 var(--spacing-4);
	font-size: var(--font-size-sm);
	color: var(--color-text);
	line-height: 1.7;
}

.nextcan-list {
	list-style: none;
	margin: 0;
	padding: 0;
	display: flex;
	flex-direction: column;
	gap: var(--spacing-2);
}
.nextcan-item {
	display: flex;
	align-items: center;
	gap: var(--spacing-3);
	padding: var(--spacing-3);
	background-color: #fff;
	border: 1px solid #FFE0B0;
	border-radius: var(--border-radius-base);
	font-size: var(--font-size-base);
	line-height: 1.5;
	color: var(--color-text);
}
.nextcan-item__text {
	flex: 1;
	font-weight: 500;
	min-width: 0;
}
.nextcan-item--empty {
	color: var(--color-text-light);
	font-size: var(--font-size-sm);
	font-style: italic;
}
.nextcan-more {
	font-size: var(--font-size-sm);
	color: var(--color-text-light);
	padding: var(--spacing-2) 0 0;
	text-align: center;
	list-style: none;
}

/* チェック + ペン アニメーション
   - .is-animating が付与されたときだけ実行（IntersectionObserver でスクロール時に発火）
   - drawCheck: 1.4s、penMove: 1.4s でゆっくり描画
   - 各項目の遅延は --anim-delay (1.4s × index) で順番に */
.result-task-check {
	position: relative;
	width: 28px;
	height: 28px;
	flex-shrink: 0;
	display: inline-block;
}
.result-task-check__line {
	width: 100%;
	height: 100%;
	overflow: visible;
	display: block;
}
.result-task-check__path {
	fill: none;
	stroke: var(--color-primary);
	stroke-width: 3;
	stroke-linecap: round;
	stroke-linejoin: round;
	stroke-dasharray: 30;
	stroke-dashoffset: 30;
}
.result-task-check__pen {
	position: absolute;
	top: 0;
	left: 0;
	width: 16px;
	height: 16px;
	font-size: 16px;
	line-height: 1;
	pointer-events: none;
	offset-path: path('M5 13 L10 18 L19 7');
	offset-rotate: 0deg;
	offset-anchor: 0% 100%;
	offset-distance: 0%;
	opacity: 0;
	transform: scale(1.1);
}
.shindan-result__nextcan.is-animating .result-task-check__path {
	animation: drawCheck 1.4s ease-out forwards;
	animation-delay: var(--anim-delay, 0s);
}
.shindan-result__nextcan.is-animating .result-task-check__pen {
	animation: penMove 1.4s ease-out forwards, penFade 0.4s ease-out forwards;
	animation-delay: var(--anim-delay, 0s), calc(var(--anim-delay, 0s) + 1.4s);
}
@keyframes drawCheck {
	0%   { stroke-dashoffset: 30; }
	100% { stroke-dashoffset: 0; }
}
@keyframes penMove {
	0%   { offset-distance: 0%;   opacity: 1; }
	100% { offset-distance: 100%; opacity: 1; }
}
@keyframes penFade {
	0%   { opacity: 1; }
	100% { opacity: 0; }
}
/* offset-path 非対応ブラウザ：ペンを非表示にしてチェックのみ表示 */
@supports not (offset-path: path('M0 0 L1 1')) {
	.result-task-check__pen { display: none; }
}
@media (prefers-reduced-motion: reduce) {
	.result-task-check__path {
		stroke-dashoffset: 0;
		animation: none;
	}
	.result-task-check__pen { display: none; }
}

/* 旧: result-task-list / shindan-result__tasks / shindan-result__nextlevel を非表示
   (Phase 24 で完全削除予定) */
.shindan-result__tasks { display: none !important; }
.shindan-result__nextlevel { display: none !important; }

/* ---- share-btn は <button> でも使うのでリセット追加 ---- */
.share-btn {
	border: none;
	cursor: pointer;
	font-family: inherit;
}
.share-block__note strong {
	color: var(--color-text);
}


/* ---- アクション群 ---- */
.shindan-result__actions {
	display: flex;
	flex-direction: column;
	gap: var(--spacing-3);
	margin-bottom: var(--spacing-5);
	max-width: 360px;
	margin-left: auto;
	margin-right: auto;
}


/* ---- レスポンシブ調整 ---- */
@media (max-width: 480px) {
	.shindan-question {
		padding: var(--spacing-4);
	}
	.shindan-question__text {
		font-size: var(--font-size-md);
	}
	.shindan-result__card {
		padding: var(--spacing-5) var(--spacing-4);
	}
	.shindan-result__level {
		font-size: 2.5rem;
	}
	.shindan-result__title {
		font-size: var(--font-size-lg);
	}
	.shindan-result__tasks {
		padding: var(--spacing-4);
	}
}


/* ============================================================
   Phase 16: まず揃えるもの（page-sonaeru.php）視覚再設計
   ============================================================ */

/* ---- 5基本のカラーパレット ---- */
:root {
	--sonaeru-water:   #5B9EC9; /* 青：水 */
	--sonaeru-toilet:  #9B7AB8; /* 紫：トイレ */
	--sonaeru-battery: #2A8C5C; /* 緑：バッテリー */
	--sonaeru-light:   #E89B30; /* 橙：ライト */
	--sonaeru-food:    #E05A4B; /* 赤：食料 */
}

/* ---- ① 進捗ビジュアル ---- */
.sonaeru-summary {
	background: linear-gradient(135deg, #FFF8EE 0%, #FFFBF3 100%);
	border: 1px solid #FFE0B0;
	border-radius: var(--border-radius-lg);
	padding: var(--spacing-5);
	margin-bottom: var(--spacing-6);
	text-align: center;
}
.sonaeru-summary__lead {
	font-size: var(--font-size-sm);
	color: var(--color-text-light);
	margin: 0 0 var(--spacing-1);
}
.sonaeru-summary__counter {
	display: inline-flex;
	align-items: baseline;
	gap: var(--spacing-2);
	margin-bottom: var(--spacing-4);
}
.sonaeru-summary__num {
	font-size: 1.25rem;
	color: var(--color-text);
	font-weight: 700;
	font-variant-numeric: tabular-nums;
}
.sonaeru-summary__num strong {
	font-size: 2.5rem;
	color: var(--color-primary-dark);
	font-weight: 800;
	line-height: 1;
}
.sonaeru-summary__label {
	font-size: var(--font-size-sm);
	color: var(--color-text-light);
}
.sonaeru-summary__icons {
	list-style: none;
	margin: 0 0 var(--spacing-3);
	padding: 0;
	display: flex;
	justify-content: center;
	gap: var(--spacing-3);
	flex-wrap: wrap;
}
.sonaeru-summary__icon {
	position: relative;
	width: 56px;
	height: 56px;
	border-radius: var(--border-radius-full);
	background-color: #fff;
	border: 2px solid var(--color-border);
	color: var(--color-gray-300);
	display: inline-flex;
	align-items: center;
	justify-content: center;
	transition: all var(--transition);
}
.sonaeru-summary__svg {
	display: inline-flex;
	align-items: center;
	justify-content: center;
}
.sonaeru-summary__check {
	position: absolute;
	top: -4px;
	right: -4px;
	width: 22px;
	height: 22px;
	border-radius: var(--border-radius-full);
	background-color: var(--color-primary);
	color: #fff;
	display: none;
	align-items: center;
	justify-content: center;
	box-shadow: 0 0 0 2px #fff;
}
/* 持っているとき（JSが [data-have-summary] 内の対応 [data-pick-key].is-have を見て切替） */
.sonaeru-summary__icon[data-summary-key="water"]   { /* base */ }
[data-pick-key="water"].is-have   ~ /* siblings: 直接連動できないため JS では未操作。CSS用の代替 */ * { /* no-op */ }

/* JSがアイコンに .is-on を付与しないため、優先順リストの状態を擬似的にこちらに反映する仕掛け：
   実装は initSonaeruHave 側で .sonaeru-summary__icon にも .is-on を付ける形に拡張済みでない場合、
   下記スタイルは [data-have-target] ボタンの aria-pressed を CSS の :has で参照する。 */
body:has(.js-sonaeru-have[data-have-target="water"][aria-pressed="true"])   .sonaeru-summary__icon[data-summary-key="water"]   { background-color: var(--sonaeru-water);   border-color: var(--sonaeru-water);   color: #fff; }
body:has(.js-sonaeru-have[data-have-target="toilet"][aria-pressed="true"])  .sonaeru-summary__icon[data-summary-key="toilet"]  { background-color: var(--sonaeru-toilet);  border-color: var(--sonaeru-toilet);  color: #fff; }
body:has(.js-sonaeru-have[data-have-target="battery"][aria-pressed="true"]) .sonaeru-summary__icon[data-summary-key="battery"] { background-color: var(--sonaeru-battery); border-color: var(--sonaeru-battery); color: #fff; }
body:has(.js-sonaeru-have[data-have-target="light"][aria-pressed="true"])   .sonaeru-summary__icon[data-summary-key="light"]   { background-color: var(--sonaeru-light);   border-color: var(--sonaeru-light);   color: #fff; }
body:has(.js-sonaeru-have[data-have-target="food"][aria-pressed="true"])    .sonaeru-summary__icon[data-summary-key="food"]    { background-color: var(--sonaeru-food);    border-color: var(--sonaeru-food);    color: #fff; }
body:has(.js-sonaeru-have[data-have-target="water"][aria-pressed="true"])   .sonaeru-summary__icon[data-summary-key="water"]   .sonaeru-summary__check,
body:has(.js-sonaeru-have[data-have-target="toilet"][aria-pressed="true"])  .sonaeru-summary__icon[data-summary-key="toilet"]  .sonaeru-summary__check,
body:has(.js-sonaeru-have[data-have-target="battery"][aria-pressed="true"]) .sonaeru-summary__icon[data-summary-key="battery"] .sonaeru-summary__check,
body:has(.js-sonaeru-have[data-have-target="light"][aria-pressed="true"])   .sonaeru-summary__icon[data-summary-key="light"]   .sonaeru-summary__check,
body:has(.js-sonaeru-have[data-have-target="food"][aria-pressed="true"])    .sonaeru-summary__icon[data-summary-key="food"]    .sonaeru-summary__check {
	display: inline-flex;
}

.sonaeru-summary__hint {
	font-size: var(--font-size-xs);
	color: var(--color-text-light);
	margin: 0;
}

/* 完了状態：ぐるっと装飾 */
.sonaeru-summary.is-complete {
	background: linear-gradient(135deg, #E8F5E9 0%, #F1FAF5 100%);
	border-color: var(--sonaeru-battery);
}
.sonaeru-summary.is-complete .sonaeru-summary__num strong {
	color: var(--sonaeru-battery);
}

/* ---- ② 優先順リスト ---- */
.sonaeru-pick {
	background-color: var(--color-surface);
	border: 1px solid var(--color-border);
	border-radius: var(--border-radius-lg);
	padding: var(--spacing-5);
	margin-bottom: var(--spacing-6);
}
.sonaeru-pick__list {
	list-style: none !important;
	margin: 0;
	padding: 0 !important;
	display: flex;
	flex-direction: column;
	gap: var(--spacing-2);
	counter-reset: none;
}
.sonaeru-pick__item {
	margin: 0;
	padding: 0;
	list-style: none;
}
.sonaeru-pick__link {
	display: flex;
	align-items: center;
	gap: var(--spacing-3);
	padding: var(--spacing-3);
	background-color: var(--color-surface);
	border: 2px solid var(--color-border);
	border-radius: var(--border-radius-base);
	color: var(--color-text);
	text-decoration: none;
	transition: all var(--transition);
	min-height: 64px;
}
.sonaeru-pick__link:hover,
.sonaeru-pick__link:focus {
	transform: translateX(2px);
	text-decoration: none;
	color: var(--color-text);
}
/* アイテム別カラー（左ボーダー＋ホバー時に背景） */
.sonaeru-pick__item--water   .sonaeru-pick__link { border-left-color: var(--sonaeru-water);   border-left-width: 4px; }
.sonaeru-pick__item--toilet  .sonaeru-pick__link { border-left-color: var(--sonaeru-toilet);  border-left-width: 4px; }
.sonaeru-pick__item--battery .sonaeru-pick__link { border-left-color: var(--sonaeru-battery); border-left-width: 4px; }
.sonaeru-pick__item--light   .sonaeru-pick__link { border-left-color: var(--sonaeru-light);   border-left-width: 4px; }
.sonaeru-pick__item--food    .sonaeru-pick__link { border-left-color: var(--sonaeru-food);    border-left-width: 4px; }
.sonaeru-pick__item--water   .sonaeru-pick__link:hover { background-color: rgba(91, 158, 201, 0.06); border-color: var(--sonaeru-water); }
.sonaeru-pick__item--toilet  .sonaeru-pick__link:hover { background-color: rgba(155, 122, 184, 0.06); border-color: var(--sonaeru-toilet); }
.sonaeru-pick__item--battery .sonaeru-pick__link:hover { background-color: rgba(42, 140, 92, 0.06);   border-color: var(--sonaeru-battery); }
.sonaeru-pick__item--light   .sonaeru-pick__link:hover { background-color: rgba(232, 155, 48, 0.06);  border-color: var(--sonaeru-light); }
.sonaeru-pick__item--food    .sonaeru-pick__link:hover { background-color: rgba(224, 90, 75, 0.06);   border-color: var(--sonaeru-food); }

.sonaeru-pick__rank {
	flex-shrink: 0;
	font-size: var(--font-size-sm);
	font-weight: 800;
	color: var(--color-text-light);
	min-width: 18px;
	text-align: center;
	font-variant-numeric: tabular-nums;
}
.sonaeru-pick__icon {
	flex-shrink: 0;
	width: 36px;
	height: 36px;
	border-radius: var(--border-radius-full);
	display: inline-flex;
	align-items: center;
	justify-content: center;
	color: #fff;
}
.sonaeru-pick__item--water   .sonaeru-pick__icon { background-color: var(--sonaeru-water); }
.sonaeru-pick__item--toilet  .sonaeru-pick__icon { background-color: var(--sonaeru-toilet); }
.sonaeru-pick__item--battery .sonaeru-pick__icon { background-color: var(--sonaeru-battery); }
.sonaeru-pick__item--light   .sonaeru-pick__icon { background-color: var(--sonaeru-light); }
.sonaeru-pick__item--food    .sonaeru-pick__icon { background-color: var(--sonaeru-food); }

.sonaeru-pick__body {
	flex: 1;
	display: flex;
	flex-direction: column;
	min-width: 0;
}
.sonaeru-pick__name {
	font-weight: 700;
	font-size: var(--font-size-base);
	line-height: 1.3;
}
.sonaeru-pick__sub {
	font-size: var(--font-size-xs);
	color: var(--color-text-light);
	line-height: 1.4;
	margin-top: 2px;
}
.sonaeru-pick__check {
	flex-shrink: 0;
	width: 24px;
	height: 24px;
	border-radius: var(--border-radius-full);
	background-color: var(--color-primary);
	color: #fff;
	display: none;
	align-items: center;
	justify-content: center;
}
.sonaeru-pick__item.is-have .sonaeru-pick__check {
	display: inline-flex;
}
.sonaeru-pick__item.is-have .sonaeru-pick__name {
	color: var(--color-text-light);
	text-decoration: line-through;
	text-decoration-color: var(--color-gray-300);
}
.sonaeru-pick__arrow {
	flex-shrink: 0;
	color: var(--color-text-light);
	font-size: var(--font-size-md);
	transition: transform var(--transition);
}
.sonaeru-pick__link:hover .sonaeru-pick__arrow {
	transform: translateX(4px);
	color: var(--color-primary);
}

/* ---- ③ 5つのアイテム詳細 ---- */
.sonaeru-section {
	display: flex;
	flex-direction: column;
	gap: var(--spacing-5);
	margin-bottom: var(--spacing-6);
}

.sonaeru-item {
	background-color: var(--color-surface);
	border: 1px solid var(--color-border);
	border-left: 4px solid var(--color-border);
	border-radius: var(--border-radius-lg);
	padding: var(--spacing-5);
	box-shadow: 0 2px 8px rgba(58, 53, 48, 0.04);
	transition: all var(--transition);
	scroll-margin-top: 80px;
}
.sonaeru-item--water   { border-left-color: var(--sonaeru-water); }
.sonaeru-item--toilet  { border-left-color: var(--sonaeru-toilet); }
.sonaeru-item--battery { border-left-color: var(--sonaeru-battery); }
.sonaeru-item--light   { border-left-color: var(--sonaeru-light); }
.sonaeru-item--food    { border-left-color: var(--sonaeru-food); }

/* 持っている状態：背景を淡く */
.sonaeru-item.is-have {
	background-color: #F7FBF8;
}

.sonaeru-item__header {
	display: flex;
	align-items: center;
	gap: var(--spacing-3);
	margin-bottom: var(--spacing-3);
}
.sonaeru-item__visual {
	flex-shrink: 0;
	width: 64px;
	height: 64px;
	border-radius: var(--border-radius-full);
	display: inline-flex;
	align-items: center;
	justify-content: center;
	color: #fff;
}
.sonaeru-item--water   .sonaeru-item__visual { background-color: var(--sonaeru-water); }
.sonaeru-item--toilet  .sonaeru-item__visual { background-color: var(--sonaeru-toilet); }
.sonaeru-item--battery .sonaeru-item__visual { background-color: var(--sonaeru-battery); }
.sonaeru-item--light   .sonaeru-item__visual { background-color: var(--sonaeru-light); }
.sonaeru-item--food    .sonaeru-item__visual { background-color: var(--sonaeru-food); }

.sonaeru-item__heading {
	flex: 1;
	min-width: 0;
}
.sonaeru-item__title {
	margin: 0;
	font-size: var(--font-size-lg);
	font-weight: 700;
	line-height: 1.3;
	color: var(--color-text);
}
.sonaeru-item__target {
	margin: var(--spacing-1) 0 0;
	font-size: var(--font-size-xs);
	color: var(--color-text-light);
	background-color: var(--color-gray-50);
	padding: 2px var(--spacing-2);
	border-radius: var(--border-radius-base);
	display: inline-block;
}

/* 持ってるトグル */
.sonaeru-have {
	width: 100%;
	min-height: 56px;
	border-radius: var(--border-radius-base);
	background-color: var(--color-surface);
	border: 2px solid var(--color-gray-300);
	color: var(--color-text);
	font-size: var(--font-size-md);
	font-weight: 700;
	cursor: pointer;
	transition: all var(--transition);
	font-family: inherit;
	margin-bottom: var(--spacing-3);
	display: flex;
	align-items: center;
	justify-content: center;
}
.sonaeru-have__off,
.sonaeru-have__on {
	display: inline-flex;
	align-items: center;
	gap: var(--spacing-2);
}
.sonaeru-have__on { display: none; }
.sonaeru-have__icon {
	display: inline-flex;
	align-items: center;
	justify-content: center;
}
.sonaeru-have:hover {
	border-color: var(--color-primary);
	background-color: var(--color-primary-light);
}
.sonaeru-have.is-on,
.sonaeru-have[aria-pressed="true"] {
	background-color: var(--sonaeru-battery);
	border-color: var(--sonaeru-battery);
	color: #fff;
}
.sonaeru-have.is-on .sonaeru-have__off,
.sonaeru-have[aria-pressed="true"] .sonaeru-have__off { display: none; }
.sonaeru-have.is-on .sonaeru-have__on,
.sonaeru-have[aria-pressed="true"] .sonaeru-have__on { display: inline-flex; }

.sonaeru-item__lead {
	margin: 0 0 var(--spacing-3);
	font-size: var(--font-size-base);
	line-height: 1.7;
	color: var(--color-text);
}

/* 詳細アコーディオン */
.sonaeru-item__details {
	border-top: 1px dashed var(--color-border);
	padding-top: var(--spacing-3);
}
.sonaeru-item__details-toggle {
	display: flex;
	align-items: center;
	justify-content: space-between;
	cursor: pointer;
	padding: var(--spacing-2) 0;
	font-size: var(--font-size-sm);
	font-weight: 700;
	color: var(--color-primary-dark);
	list-style: none;
	gap: var(--spacing-2);
}
.sonaeru-item__details-toggle::-webkit-details-marker { display: none; }
.sonaeru-item__details-toggle:hover {
	color: var(--color-primary);
}
.sonaeru-item__details-mark {
	transition: transform var(--transition);
	font-size: var(--font-size-xs);
	color: var(--color-text-light);
}
.sonaeru-item__details[open] .sonaeru-item__details-mark {
	transform: rotate(180deg);
}

.sonaeru-item__sub {
	margin: var(--spacing-3) 0 var(--spacing-2);
	font-size: var(--font-size-sm);
	font-weight: 700;
	color: var(--color-text);
}
.sonaeru-item__tips ul {
	margin: 0;
	padding-left: var(--spacing-5);
	font-size: var(--font-size-sm);
	color: var(--color-text);
	line-height: 1.7;
}
.sonaeru-item__tips li {
	margin-bottom: var(--spacing-1);
}
.sonaeru-item__where p {
	margin: 0;
	font-size: var(--font-size-sm);
	line-height: 1.7;
	color: var(--color-text);
}
.sonaeru-item__memo-link {
	margin: var(--spacing-3) 0 0;
	font-size: var(--font-size-sm);
	text-align: right;
}

/* 「これが無いと、こう困ります」ボックス */
.sonaeru-item__trouble {
	margin: var(--spacing-3) 0;
	padding: var(--spacing-3);
	background-color: #FFF5F2;
	border: 1px solid #FAD4CC;
	border-left: 4px solid var(--color-alert);
	border-radius: var(--border-radius-base);
}
.sonaeru-item__trouble-title {
	margin: 0 0 var(--spacing-1);
	font-size: var(--font-size-sm);
	font-weight: 700;
	color: var(--color-alert);
	display: flex;
	align-items: center;
	gap: var(--spacing-1);
}
.sonaeru-item__trouble-icon {
	display: inline-flex;
	align-items: center;
	justify-content: center;
}
.sonaeru-item__trouble p {
	margin: 0;
	font-size: var(--font-size-sm);
	line-height: 1.7;
	color: var(--color-text);
}

/* メモへの導線：カード型ボタン */
.memo-card-link {
	display: flex;
	align-items: center;
	gap: var(--spacing-3);
	padding: var(--spacing-3) var(--spacing-4);
	margin-top: var(--spacing-4);
	background-color: var(--color-surface);
	border: 2px solid var(--color-primary-light);
	border-radius: var(--border-radius-base);
	color: var(--color-text);
	text-decoration: none;
	transition: all var(--transition);
	min-height: 60px;
}
.memo-card-link:hover,
.memo-card-link:focus {
	background-color: var(--color-primary-light);
	border-color: var(--color-primary);
	transform: translateY(-1px);
	text-decoration: none;
	color: var(--color-text);
	box-shadow: 0 4px 12px rgba(245, 163, 42, 0.15);
}
.memo-card-link__icon {
	flex-shrink: 0;
	width: 36px;
	height: 36px;
	border-radius: var(--border-radius-full);
	background-color: var(--color-primary);
	color: #fff;
	display: inline-flex;
	align-items: center;
	justify-content: center;
}
.memo-card-link__body {
	flex: 1;
	display: flex;
	flex-direction: column;
	min-width: 0;
}
.memo-card-link__label {
	font-size: var(--font-size-xs);
	color: var(--color-primary-dark);
	font-weight: 700;
	letter-spacing: 0.05em;
	margin-bottom: 2px;
}
.memo-card-link__title {
	font-size: var(--font-size-base);
	font-weight: 700;
	color: var(--color-text);
	line-height: 1.4;
}
.memo-card-link__arrow {
	flex-shrink: 0;
	color: var(--color-primary);
	font-size: var(--font-size-md);
	font-weight: 700;
	transition: transform var(--transition);
}
.memo-card-link:hover .memo-card-link__arrow {
	transform: translateX(4px);
}

/* 旧 sonaeru-item__memo-link は新カードに置換のため非表示 */
.sonaeru-item__memo-link { display: none; }

/* 防災セットを買うなら */
.sonaeset-check {
	margin-top: var(--spacing-8);
	padding: var(--spacing-5);
	background-color: var(--color-surface);
	border: 1px solid var(--color-border);
	border-radius: var(--border-radius-lg);
}
.sonaeset-check__lead {
	margin: 0 0 var(--spacing-4);
	font-size: var(--font-size-sm);
	line-height: 1.7;
	color: var(--color-text);
}
.sonaeset-check__box {
	padding: var(--spacing-4);
	background-color: #FFF8EE;
	border-left: 4px solid var(--color-primary);
	border-radius: var(--border-radius-base);
	margin-bottom: var(--spacing-4);
}
.sonaeset-check__subtitle {
	margin: 0 0 var(--spacing-2);
	font-size: var(--font-size-base);
	font-weight: 700;
	color: var(--color-primary-dark);
}
.sonaeset-check__list {
	margin: 0;
	padding-left: var(--spacing-5);
	list-style: disc;
}
.sonaeset-check__list li {
	margin-bottom: var(--spacing-1);
	font-size: var(--font-size-sm);
	line-height: 1.7;
}
.sonaeset-check__cta {
	display: flex;
	flex-direction: column;
	gap: var(--spacing-3);
}
.sonaeset-check__cta .btn {
	align-self: flex-start;
}

/* 閲覧のみユーザー向け導線 */
.sonaeru-readonly-cta {
	margin-top: var(--spacing-8);
	margin-bottom: var(--spacing-5);
	padding: var(--spacing-5);
	background: linear-gradient(135deg, var(--color-primary-light) 0%, #FFF8EE 100%);
	border-radius: var(--border-radius-lg);
	text-align: center;
}
.sonaeru-readonly-cta__lead {
	margin: 0 0 var(--spacing-4);
	font-size: var(--font-size-base);
	line-height: 1.7;
	color: var(--color-text);
}

/* ---- 旧スタイルとの整合（廃止フィールド非表示） ---- */
.sonaeru-pick__head,
.sonaeru-pick__count,
.sonaeru-pick__hint { display: none; }
.sonaeru-item__img { display: none; }

/* :has() 非対応ブラウザ向け追加：JSで .sonaeru-summary__icon に .is-on を付ける運用にしてもよいが、
   :has() が広く対応している現時点ではこの実装で十分（Safari 15.4+/Chrome 105+/Firefox 121+）。 */
@supports not selector(:has(*)) {
	.sonaeru-summary__icon { background-color: var(--color-primary-light); }
}

/* ---- レスポンシブ ---- */
@media (max-width: 480px) {
	.sonaeru-summary { padding: var(--spacing-4); }
	.sonaeru-summary__icons { gap: var(--spacing-2); }
	.sonaeru-summary__icon { width: 48px; height: 48px; }
	.sonaeru-summary__num strong { font-size: 2rem; }
	.sonaeru-pick { padding: var(--spacing-4); }
	.sonaeru-pick__rank { min-width: 16px; font-size: var(--font-size-xs); }
	.sonaeru-pick__icon { width: 32px; height: 32px; }
	.sonaeru-pick__name { font-size: var(--font-size-sm); }
	.sonaeru-item { padding: var(--spacing-4); }
	.sonaeru-item__visual { width: 52px; height: 52px; }
	.sonaeru-item__title { font-size: var(--font-size-md); }
}

/* ============================================================
   Phase 17: page-kyou.php 行動ハブ再設計
   ============================================================ */

/* 共通：セクション見出し */
.kyou-recommended .section-head,
.kyou-explore .section-head,
.kyou-more .section-head {
	margin-bottom: var(--spacing-4);
}
.section-head__title {
	display: flex;
	align-items: center;
	gap: var(--spacing-2);
	margin: 0 0 var(--spacing-1);
	font-size: var(--font-size-lg);
	font-weight: 700;
	color: var(--color-text);
}
.section-head__icon {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 32px;
	height: 32px;
	border-radius: var(--border-radius-full);
	background-color: var(--color-primary-light);
	color: var(--color-primary-dark);
	flex-shrink: 0;
}
.section-head__sub {
	margin: 0;
	font-size: var(--font-size-sm);
	line-height: 1.7;
	color: var(--color-text-light);
}

/* 診断結果から来た時のリードカード */
.kyou-from-shindan {
	margin: var(--spacing-4) 0;
	padding: var(--spacing-3) var(--spacing-4);
	background-color: var(--color-primary-light);
	border-left: 4px solid var(--color-primary);
	border-radius: var(--border-radius-base);
}
.kyou-from-shindan p {
	margin: 0;
	font-size: var(--font-size-sm);
	line-height: 1.7;
	color: var(--color-text);
}

/* タスクカード（コンパクト） */
.task-card {
	display: grid;
	grid-template-columns: 1fr auto;
	grid-template-areas:
		"head action"
		"details details";
	gap: var(--spacing-3);
	align-items: start;
}
.task-card__head { grid-area: head; min-width: 0; }
.task-card__action {
	grid-area: action;
	display: flex;
	flex-direction: column;
	align-items: flex-end;
	gap: var(--spacing-1);
}
.task-card__details { grid-area: details; }

.task-card__title {
	margin: 0 0 var(--spacing-1);
	font-size: var(--font-size-base);
	font-weight: 700;
	color: var(--color-text);
	line-height: 1.4;
}
.task-card__desc {
	margin: 0 0 var(--spacing-2);
	font-size: var(--font-size-sm);
	line-height: 1.6;
	color: var(--color-text-light);
}

/* メタ情報チップ（横並び） */
.task-card__chips {
	list-style: none;
	margin: 0;
	padding: 0;
	display: flex;
	flex-wrap: wrap;
	gap: var(--spacing-1);
}
.task-chip {
	display: inline-flex;
	align-items: center;
	gap: 4px;
	padding: 2px 8px;
	font-size: var(--font-size-xs);
	font-weight: 600;
	border-radius: var(--border-radius-full);
	background-color: var(--color-bg);
	color: var(--color-text-light);
	border: 1px solid var(--color-border);
	line-height: 1.5;
}
.task-chip__icon {
	display: inline-flex;
	align-items: center;
	justify-content: center;
}
.task-chip--time {
	background-color: #EFF6FB;
	color: #2C6B91;
	border-color: #C6DEEE;
}
.task-chip--cost {
	background-color: #FFF8EE;
	color: var(--color-primary-dark);
	border-color: #F4D9A8;
}
.task-chip--sit {
	background-color: #F4F0F8;
	color: #6E4F8C;
	border-color: #DCCFE6;
}
.task-chip--diff-easy {
	background-color: #EBF5EE;
	color: #2A8C5C;
	border-color: #C7E2D1;
}
.task-chip--diff-medium {
	background-color: #FFF5E6;
	color: #B96B14;
	border-color: #F0CE9C;
}
.task-chip--diff-hard {
	background-color: #FBEEEC;
	color: #A24033;
	border-color: #EBC2BC;
}

/* タスク詳細（折りたたみ） */
.task-card__details {
	margin-top: var(--spacing-2);
	border-top: 1px dashed var(--color-border);
	padding-top: var(--spacing-2);
}
.task-card__details > summary {
	list-style: none;
	cursor: pointer;
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: var(--spacing-2);
	padding: var(--spacing-1) 0;
	font-size: var(--font-size-sm);
	color: var(--color-primary-dark);
	font-weight: 600;
}
.task-card__details > summary::-webkit-details-marker { display: none; }
.task-card__details[open] .task-card__details-mark { transform: rotate(180deg); }
.task-card__details-mark {
	transition: transform var(--transition);
	font-size: 10px;
}
.task-card__details-body {
	margin-top: var(--spacing-2);
	padding: var(--spacing-3);
	background-color: var(--color-bg);
	border-radius: var(--border-radius-base);
	font-size: var(--font-size-sm);
	line-height: 1.7;
	color: var(--color-text);
}
.task-card__details-body p { margin: 0 0 var(--spacing-2); }
.task-card__details-body p:last-child { margin-bottom: 0; }

/* 既存 .task-list__item ベースを上書き：内側に新カードを置くため余白調整 */
.task-list__item .task-card {
	width: 100%;
}

/* 「ほかのタスクを探す」セクション */
.kyou-explore {
	margin-top: var(--spacing-8);
}

/* フィルターブロック（説明付き） */
.task-filter-block {
	margin: var(--spacing-4) 0;
	padding: var(--spacing-3) var(--spacing-4);
	background-color: var(--color-surface);
	border: 1px solid var(--color-border);
	border-radius: var(--border-radius-base);
}
.task-filter-block__title {
	margin: 0 0 4px;
	font-size: var(--font-size-base);
	font-weight: 700;
	color: var(--color-text);
}
.task-filter-block__desc {
	margin: 0 0 var(--spacing-2);
	font-size: var(--font-size-sm);
	color: var(--color-text-light);
	line-height: 1.6;
}

/* Lv. ブロック（アコーディオン） */
.kyou-level-block {
	margin-bottom: var(--spacing-3);
	background-color: var(--color-surface);
	border: 1px solid var(--color-border);
	border-radius: var(--border-radius-lg);
	overflow: hidden;
}
.kyou-level-block--current {
	border-color: var(--color-primary);
	box-shadow: 0 2px 8px rgba(245, 163, 42, 0.12);
}
.kyou-level-block__summary {
	list-style: none;
	cursor: pointer;
	display: flex;
	align-items: center;
	gap: var(--spacing-3);
	padding: var(--spacing-3) var(--spacing-4);
	background-color: var(--color-surface);
	transition: background-color var(--transition);
}
.kyou-level-block__summary::-webkit-details-marker { display: none; }
.kyou-level-block__summary:hover {
	background-color: var(--color-bg);
}
.kyou-level-block[open] .kyou-level-block__summary {
	border-bottom: 1px solid var(--color-border);
}
.kyou-level-block[open] .kyou-level-block__mark {
	transform: rotate(180deg);
}
.kyou-level-block__badge {
	flex-shrink: 0;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	min-width: 48px;
	padding: 4px 10px;
	background-color: var(--color-primary);
	color: #fff;
	font-weight: 700;
	font-size: var(--font-size-sm);
	border-radius: var(--border-radius-full);
}
.kyou-level-block--past .kyou-level-block__badge {
	background-color: #2A8C5C;
}
.kyou-level-block--next .kyou-level-block__badge,
.kyou-level-block--future .kyou-level-block__badge {
	background-color: var(--color-text-light);
}
.kyou-level-block__heading {
	flex: 1;
	display: flex;
	flex-direction: column;
	min-width: 0;
}
.kyou-level-block__title {
	font-size: var(--font-size-base);
	font-weight: 700;
	color: var(--color-text);
}
.kyou-level-block__status {
	font-size: var(--font-size-xs);
	color: var(--color-text-light);
}
.kyou-level-block--current .kyou-level-block__status {
	color: var(--color-primary-dark);
	font-weight: 600;
}
.kyou-level-block__mark {
	transition: transform var(--transition);
	color: var(--color-text-light);
	font-size: 12px;
}
.kyou-level-block .task-step-group {
	padding: var(--spacing-3) var(--spacing-4);
	border-top: 1px solid var(--color-border);
}
.kyou-level-block .task-step-group:first-of-type {
	border-top: none;
}
.kyou-level-block .task-step-group__header {
	margin-bottom: var(--spacing-2);
}
.kyou-level-block .task-step-group__label {
	margin: 0;
	font-size: var(--font-size-sm);
	font-weight: 700;
	color: var(--color-primary-dark);
}
.kyou-level-block .task-step-group__sub {
	margin: 0;
	font-size: var(--font-size-xs);
	color: var(--color-text-light);
}

/* 「もっと知りたい」カードCTA */
.kyou-more {
	margin-top: var(--spacing-8);
}
.kyou-more__cards {
	display: grid;
	grid-template-columns: 1fr;
	gap: var(--spacing-3);
	margin-bottom: var(--spacing-4);
}
@media (min-width: 720px) {
	.kyou-more__cards { grid-template-columns: 1fr 1fr; }
}
.more-card {
	display: flex;
	align-items: flex-start;
	gap: var(--spacing-3);
	padding: var(--spacing-4);
	background-color: var(--color-surface);
	border: 2px solid var(--color-primary-light);
	border-radius: var(--border-radius-lg);
	color: var(--color-text);
	text-decoration: none;
	transition: all var(--transition);
}
.more-card:hover,
.more-card:focus {
	background-color: var(--color-primary-light);
	border-color: var(--color-primary);
	transform: translateY(-2px);
	box-shadow: 0 4px 12px rgba(245, 163, 42, 0.15);
	text-decoration: none;
	color: var(--color-text);
}
.more-card__icon {
	flex-shrink: 0;
	width: 44px;
	height: 44px;
	border-radius: var(--border-radius-full);
	background-color: var(--color-primary);
	color: #fff;
	display: inline-flex;
	align-items: center;
	justify-content: center;
}
.more-card__body {
	flex: 1;
	display: flex;
	flex-direction: column;
	gap: 4px;
	min-width: 0;
}
.more-card__label {
	font-size: var(--font-size-xs);
	color: var(--color-primary-dark);
	font-weight: 700;
	letter-spacing: 0.05em;
}
.more-card__title {
	font-size: var(--font-size-base);
	font-weight: 700;
	color: var(--color-text);
}
.more-card__desc {
	font-size: var(--font-size-sm);
	color: var(--color-text-light);
	line-height: 1.6;
}
.more-card__arrow {
	flex-shrink: 0;
	color: var(--color-primary);
	font-size: var(--font-size-md);
	font-weight: 700;
	align-self: center;
}

/* 旧 .kyou-progress-banner / .kyou-recommended__title などは新マークアップで非使用。
   念のため非表示しておく（既存DOMには無いが、副作用回避）。 */
.kyou-progress-banner { display: none; }
.kyou-intro { display: none; }

/* レスポンシブ */
@media (max-width: 480px) {
	.task-card {
		grid-template-columns: 1fr;
		grid-template-areas:
			"head"
			"action"
			"details";
	}
	.task-card__action {
		flex-direction: column;
		justify-content: space-between;
		align-items: center;
	}
	.kyou-level-block__summary { padding: var(--spacing-2) var(--spacing-3); gap: var(--spacing-2); }
	.kyou-level-block .task-step-group { padding: var(--spacing-2) var(--spacing-3); }
	.more-card { padding: var(--spacing-3); }
}

/* ============================================================
   Phase 17.1: タスク詳細トグルの構造化ブロック
   ============================================================ */
.task-detail-block {
	margin-bottom: var(--spacing-3);
}
.task-detail-block:last-child {
	margin-bottom: 0;
}
.task-detail-block__title {
	margin: 0 0 var(--spacing-1);
	font-size: var(--font-size-sm);
	font-weight: 700;
	color: var(--color-primary-dark);
	display: flex;
	align-items: center;
	gap: 6px;
}
.task-detail-block__title::before {
	content: "";
	display: inline-block;
	width: 4px;
	height: 14px;
	background-color: var(--color-primary);
	border-radius: 2px;
}
.task-detail-block__text {
	margin: 0;
	font-size: var(--font-size-sm);
	line-height: 1.7;
	color: var(--color-text);
}
.task-detail-block__steps {
	margin: 0;
	padding-left: 1.4em;
	font-size: var(--font-size-sm);
	line-height: 1.7;
	color: var(--color-text);
}
.task-detail-block__steps li {
	margin-bottom: 4px;
}
.task-detail-block__meta {
	list-style: none;
	margin: 0;
	padding: 0;
	display: flex;
	flex-wrap: wrap;
	gap: var(--spacing-2);
	font-size: var(--font-size-sm);
}
.task-detail-block__meta li {
	display: flex;
	align-items: center;
	gap: 6px;
	padding: 2px 10px;
	background-color: #fff;
	border: 1px solid var(--color-border);
	border-radius: var(--border-radius-base);
	color: var(--color-text);
}
.task-detail-block__meta-label {
	font-size: var(--font-size-xs);
	color: var(--color-text-light);
	font-weight: 600;
}
.task-detail-block__figure {
	margin: 0;
}
.task-detail-block__figure img {
	max-width: 100%;
	height: auto;
	border-radius: var(--border-radius-base);
	border: 1px solid var(--color-border);
	display: block;
}
.task-detail-block__figure figcaption {
	margin-top: 4px;
	font-size: var(--font-size-xs);
	color: var(--color-text-light);
}
ul.task-detail-block__related {
	list-style: none;
	margin: 0;
	padding: 0;
	display: flex;
	flex-direction: column;
	gap: 6px;
}
.task-detail-block__related a {
	display: flex;
	align-items: center;
	gap: var(--spacing-2);
	padding: 8px 12px;
	background-color: #fff;
	border: 1px solid var(--color-border);
	border-radius: var(--border-radius-base);
	color: var(--color-text);
	text-decoration: none;
	font-size: var(--font-size-sm);
	transition: all var(--transition);
}
.task-detail-block__related a:hover,
.task-detail-block__related a:focus {
	border-color: var(--color-primary);
	background-color: var(--color-primary-light);
	color: var(--color-text);
}
.task-detail-block__related-tag {
	flex-shrink: 0;
	font-size: var(--font-size-xs);
	font-weight: 700;
	color: #fff;
	background-color: var(--color-primary);
	padding: 2px 8px;
	border-radius: var(--border-radius-full);
	letter-spacing: 0.05em;
}
.task-detail-block__related-tag--memo {
	background-color: #6E4F8C;
}
.task-detail-block__related-tag--link {
	background-color: #2c6e9b;
}

/* Phase O-2: チェックリスト表示（タスク詳細トグル内） */
.task-detail-block__checklist {
	list-style: none;
	margin: 0;
	padding: 0;
	display: flex;
	flex-direction: column;
	gap: 6px;
}
.task-detail-block__checklist li {
	display: flex;
	align-items: flex-start;
	gap: 8px;
	padding: 6px 10px;
	background-color: rgba(0, 0, 0, 0.025);
	border-left: 3px solid var(--color-green, #5aa05a);
	border-radius: 4px;
	font-size: 0.9rem;
	line-height: 1.5;
}
.task-detail-block__checklist-mark {
	flex-shrink: 0;
	color: var(--color-green, #5aa05a);
	font-weight: 700;
	margin-top: 1px;
}

/* ============================================================
   Phase 18: 状況別ガイド一覧 再設計
   ============================================================ */

/* 状況選択（ユーザー状態カード） */
.situation-selector {
	margin: var(--spacing-4) 0 var(--spacing-6);
	padding: var(--spacing-4);
	background-color: var(--color-surface);
	border: 1px solid var(--color-border);
	border-radius: var(--border-radius-lg);
}
.situation-selector__label {
	margin: 0 0 var(--spacing-3);
	font-size: var(--font-size-md);
	font-weight: 700;
	color: var(--color-text);
}
.situation-selector__grid {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: var(--spacing-2);
	margin-bottom: var(--spacing-3);
}
@media (min-width: 720px) {
	.situation-selector__grid { grid-template-columns: 1fr 1fr 1fr; }
}
.situation-btn {
	display: flex;
	flex-direction: column;
	align-items: center;
	justify-content: center;
	gap: var(--spacing-2);
	width: 100%;
	padding: var(--spacing-3) var(--spacing-4);
	background-color: #fff;
	border: 2px solid var(--color-border);
	border-radius: var(--border-radius-base);
	cursor: pointer;
	text-align: center;
	transition: all var(--transition);
	color: var(--color-text);
}
.situation-btn:hover,
.situation-btn:focus {
	border-color: var(--color-primary);
	background-color: var(--color-primary-light);
}
.situation-btn.is-active,
.situation-btn[aria-pressed="true"] {
	border-color: var(--color-primary);
	background-color: var(--color-primary-light);
	box-shadow: 0 2px 6px rgba(245, 163, 42, 0.15);
}
.situation-btn__icon {
	flex-shrink: 0;
	font-size: 28px;
	line-height: 1;
	width: 44px;
	height: 44px;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	background-color: var(--color-bg);
	border-radius: var(--border-radius-full);
}
.situation-btn__body {
	display: flex;
	flex-direction: column;
	align-items: center;
	gap: 2px;
	min-width: 0;
}
.situation-btn__label {
	font-size: var(--font-size-base);
	font-weight: 700;
	color: var(--color-text);
	line-height: 1.4;
}
.situation-btn__desc {
	font-size: var(--font-size-sm);
	color: var(--color-text-light);
	line-height: 1.5;
}
.situation-btn--all {
	display: block;
	width: 100%;
	padding: 10px var(--spacing-4);
	background-color: transparent;
	border: 1px dashed var(--color-border);
	border-radius: var(--border-radius-base);
	color: var(--color-text-light);
	font-size: var(--font-size-sm);
	font-weight: 600;
	cursor: pointer;
	transition: all var(--transition);
}
.situation-btn--all:hover,
.situation-btn--all:focus,
.situation-btn--all.is-active,
.situation-btn--all[aria-pressed="true"] {
	border-color: var(--color-primary);
	background-color: var(--color-primary-light);
	color: var(--color-primary-dark);
}

/* 凡例（やわらかいバッジ表現） */
.guide-level-legend {
	margin: 0 0 var(--spacing-4);
	padding: 0 var(--spacing-2);
}
.guide-level-legend__summary {
	cursor: pointer;
	font-size: var(--font-size-sm);
	color: var(--color-text-light);
	padding: 8px 0;
	list-style: none;
}
.guide-level-legend__summary::-webkit-details-marker { display: none; }
.guide-level-legend__summary::before { content: "▶ "; font-size: 10px; color: var(--color-text-light); margin-right: 4px; }
.guide-level-legend[open] .guide-level-legend__summary::before { content: "▼ "; }
.guide-level-legend__list {
	list-style: none;
	margin: var(--spacing-2) 0 0;
	padding: var(--spacing-3);
	background-color: var(--color-bg);
	border-radius: var(--border-radius-base);
	display: flex;
	flex-direction: column;
	gap: var(--spacing-2);
}
.guide-level-legend__list li {
	display: flex;
	align-items: center;
	gap: var(--spacing-2);
	font-size: var(--font-size-sm);
	color: var(--color-text);
}

/* やわらかいレベルバッジ（絵文字無し・トーン別） */
.guide-level-badge {
	display: inline-flex;
	align-items: center;
	gap: 5px;
	padding: 3px 10px 3px 8px;
	font-size: var(--font-size-xs);
	font-weight: 700;
	border-radius: var(--border-radius-full);
	border: 1px solid transparent;
	letter-spacing: 0.02em;
	white-space: nowrap;
	line-height: 1.4;
}
.guide-level-badge__icon {
	width: 14px;
	height: 14px;
	flex-shrink: 0;
	color: inherit;
	stroke-width: 2;
}
.guide-level-badge__text {
	display: inline-block;
}
.guide-level-badge--urgent {
	background-color: #FBEEEC;
	color: #A24033;
	border-color: #EBC2BC;
}
.guide-level-badge--watch {
	background-color: #FFF8EE;
	color: #B96B14;
	border-color: #F4D9A8;
}
.guide-level-badge--recovery {
	background-color: #EFF6FB;
	color: #2C6B91;
	border-color: #C6DEEE;
}
.guide-level-badge--normal {
	background-color: #EBF5EE;
	color: #2A8C5C;
	border-color: #C7E2D1;
}

/* 件数 */
.guide-list-count {
	margin: var(--spacing-3) 0;
	font-size: var(--font-size-sm);
	color: var(--color-text-light);
}

/* ガイドグリッド */
.guide-list-grid {
	display: grid;
	grid-template-columns: 1fr;
	gap: var(--spacing-3);
}
@media (min-width: 720px) {
	.guide-list-grid { grid-template-columns: 1fr 1fr; }
}

/* 構造化されたガイドカード（Phase 18） */
.guide-list-grid .guide-list-card {
	display: block;
	background-color: var(--color-surface);
	border: 1px solid var(--color-border);
	border-radius: var(--border-radius-lg);
	overflow: hidden;
	padding: 0;
	transition: all var(--transition);
}
.guide-list-grid .guide-list-card:hover,
.guide-list-grid .guide-list-card:focus-within {
	transform: translateY(-2px);
	box-shadow: 0 4px 12px rgba(0, 0, 0, 0.08);
	border-color: var(--color-primary);
}
.guide-list-grid .guide-list-card.is-hidden {
	display: none;
}
.guide-list-card--tone-urgent { border-top: 4px solid #C9534A; }
.guide-list-card--tone-watch { border-top: 4px solid var(--color-primary); }
.guide-list-card--tone-recovery { border-top: 4px solid #4584AE; }
.guide-list-card--tone-normal { border-top: 4px solid #4FA877; }

.guide-list-card__inner {
	display: flex;
	flex-direction: column;
	align-items: stretch;
	padding: var(--spacing-4);
	color: var(--color-text);
	text-decoration: none;
}
.guide-list-card__inner:hover,
.guide-list-card__inner:focus {
	text-decoration: none;
	color: var(--color-text);
}
.guide-list-card__head {
	display: flex;
	align-items: flex-start;
	gap: var(--spacing-3);
	margin-bottom: var(--spacing-3);
}
.guide-list-card__icon {
	flex-shrink: 0;
	width: 44px;
	height: 44px;
	border-radius: var(--border-radius-full);
	background-color: var(--color-bg);
	display: inline-flex;
	align-items: center;
	justify-content: center;
	font-size: 24px;
	line-height: 1;
}
.guide-list-card__labels {
	display: flex;
	flex-wrap: wrap;
	gap: 6px;
	align-items: center;
	flex: 1;
}
.guide-list-card__sit-label {
	font-size: var(--font-size-xs);
	font-weight: 600;
	color: var(--color-text-light);
	background-color: var(--color-bg);
	padding: 3px 8px;
	border-radius: var(--border-radius-full);
}
h2.guide-list-card__title {
	margin: 0 0 var(--spacing-2);
	font-weight: 700;
	color: var(--color-text);
	line-height: 1.4;
}
.guide-list-card__summary {
	margin-bottom: var(--spacing-3);
}
.guide-list-card__summary-label {
	margin: 0 0 4px;
	font-size: var(--font-size-xs);
	font-weight: 700;
	color: var(--color-primary-dark);
	letter-spacing: 0.04em;
}
.guide-list-card__summary-text {
	margin: 0;
	font-size: var(--font-size-sm);
	color: var(--color-text);
	line-height: 1.6;
}
.guide-list-card__first-check {
	display: flex;
	align-items: flex-start;
	gap: var(--spacing-2);
	padding: 8px var(--spacing-3);
	margin-bottom: var(--spacing-3);
	background-color: var(--color-bg);
	border-left: 3px solid var(--color-primary);
	border-radius: 0 var(--border-radius-base) var(--border-radius-base) 0;
}
.guide-list-card__first-check-tag {
	flex-shrink: 0;
	font-size: var(--font-size-xs);
	font-weight: 700;
	color: var(--color-primary-dark);
	background-color: #fff;
	padding: 2px 8px;
	border-radius: var(--border-radius-full);
	border: 1px solid var(--color-primary-light);
	white-space: nowrap;
}
.guide-list-card__first-check-text {
	font-size: var(--font-size-sm);
	color: var(--color-text);
	line-height: 1.5;
}
.guide-list-card__cta {
	align-self: flex-end;
	margin-top: auto;
	display: inline-flex;
	align-items: center;
	gap: 6px;
	padding: 8px 16px;
	background-color: var(--color-primary);
	color: #fff;
	border-radius: var(--border-radius-full);
	font-size: var(--font-size-sm);
	font-weight: 700;
	transition: background-color var(--transition);
}
.guide-list-card__inner:hover .guide-list-card__cta,
.guide-list-card__inner:focus .guide-list-card__cta {
	background-color: var(--color-primary-dark);
}
.guide-list-card__cta-arrow {
	font-size: 14px;
	transition: transform var(--transition);
}
.guide-list-card__inner:hover .guide-list-card__cta-arrow {
	transform: translateX(3px);
}

/* 旧マークアップ（.guide-list-card__body / __desc / __arrow など）の影響回避：
   新しい .guide-list-card__inner 配下では古いスタイルを上書きせず、
   そのまま動作するようにしている。 */

/* レスポンシブ */
@media (max-width: 480px) {
	.situation-btn { padding: var(--spacing-2) var(--spacing-3); gap: var(--spacing-2); }
	.situation-btn__icon { width: 36px; height: 36px; font-size: 22px; }
	.situation-btn__label { font-size: var(--font-size-sm); }
	.situation-btn__desc { font-size: var(--font-size-xs); }
	.guide-list-card__inner { padding: var(--spacing-3); }
	.guide-list-card__title { font-size: var(--font-size-base); }
}


/* ============================================================
   Phase 19: ガイド詳細ページ 再設計
   ============================================================ */

/* ヒーロー上の状況ラベル */
.guide-hero-sit {
	display: inline-flex;
	align-items: center;
	font-size: var(--font-size-xs);
	font-weight: 600;
	color: var(--color-text-light);
	background-color: rgba(255,255,255,0.7);
	padding: 3px 10px;
	border-radius: var(--border-radius-full);
	margin-left: 4px;
}

/* このガイドの使い方 */
.guide-howto {
	margin: var(--spacing-5) 0 var(--spacing-4);
	padding: var(--spacing-4);
	background-color: var(--color-surface);
	border: 1px solid var(--color-border);
	border-radius: var(--border-radius-lg);
	border-left: 4px solid var(--color-primary);
}
.guide-howto--danger {
	border-left-color: #C9534A;
	background-color: #FBF6F5;
}
.guide-howto--watch  { border-left-color: var(--color-primary); }
.guide-howto--recovery { border-left-color: #4584AE; }
.guide-howto--normal { border-left-color: #4FA877; }
.guide-howto__inner {
	display: flex;
	gap: var(--spacing-4);
	align-items: flex-start;
}
.guide-howto__mascot {
	flex-shrink: 0;
	width: 64px;
}
.guide-howto__mascot img,
.guide-howto__mascot svg { width: 100%; height: auto; display: block; }
.guide-howto--danger .guide-howto__mascot { display: none; }
.guide-howto__body { flex: 1; min-width: 0; }
.guide-howto__label {
	margin: 0 0 6px;
	font-size: var(--font-size-xs);
	font-weight: 700;
	color: var(--color-primary-dark);
	letter-spacing: 0.04em;
}
.guide-howto__msg {
	margin: 0;
	font-size: var(--font-size-md);
	font-weight: 700;
	color: var(--color-text);
	line-height: 1.6;
}
.guide-howto__sub {
	margin: 6px 0 0;
	font-size: var(--font-size-sm);
	color: var(--color-text-light);
	line-height: 1.6;
}

/* セクションリード */
.guide-section__lead {
	margin: 0 0 var(--spacing-3);
	font-size: var(--font-size-sm);
	color: var(--color-text-light);
	line-height: 1.6;
}

/* ① まず確認すること - チェックカード */
.guide-check-card {
	background-color: var(--color-surface);
	border: 1px solid var(--color-border);
	border-radius: var(--border-radius-lg);
	padding: var(--spacing-4);
	border-top: 4px solid var(--color-primary);
}
.guide-check-card__hint {
	margin: 0 0 var(--spacing-3);
	font-size: var(--font-size-sm);
	color: var(--color-text);
	line-height: 1.6;
}
.guide-check-card__hint-tag {
	display: inline-block;
	font-size: var(--font-size-xs);
	font-weight: 700;
	color: var(--color-primary-dark);
	background-color: var(--color-primary-light);
	padding: 2px 8px;
	border-radius: var(--border-radius-full);
	margin-right: 4px;
}
.guide-checklist__priority {
	display: inline-block;
	font-size: var(--font-size-xs);
	font-weight: 700;
	color: var(--color-primary-dark);
	background-color: var(--color-primary-light);
	padding: 2px 8px;
	border-radius: var(--border-radius-full);
	margin-right: 6px;
	vertical-align: middle;
}

/* ② 行動カード */
.guide-action-cards {
	list-style: none;
	margin: 0;
	padding: 0;
	display: flex;
	flex-direction: column;
	gap: var(--spacing-3);
	counter-reset: action;
}
.guide-action-card {
	display: flex;
	gap: var(--spacing-3);
	align-items: stretch;
	background-color: var(--color-surface);
	border: 1px solid var(--color-border);
	border-radius: var(--border-radius-lg);
	padding: var(--spacing-3) var(--spacing-4);
	transition: all var(--transition);
}
.guide-action-card--high {
	border-left: 4px solid var(--color-primary);
	background-color: #FFFBF3;
}
.guide-action-card.is-done {
	background-color: #F4F8F2;
	border-color: #C7E2D1;
	opacity: 0.85;
}
.guide-action-card__main {
	flex: 1;
	min-width: 0;
}
.guide-action-card__head {
	display: flex;
	align-items: center;
	gap: 8px;
	margin-bottom: 6px;
}
.guide-action-card__num {
	flex-shrink: 0;
	width: 28px;
	height: 28px;
	border-radius: var(--border-radius-full);
	background-color: var(--color-primary);
	color: #fff;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	font-size: var(--font-size-sm);
	font-weight: 700;
	line-height: 1;
}
.guide-action-card__priority {
	display: inline-block;
	font-size: var(--font-size-xs);
	font-weight: 700;
	color: var(--color-primary-dark);
	background-color: var(--color-primary-light);
	padding: 2px 8px;
	border-radius: var(--border-radius-full);
}
.guide-action-card__step {
	margin: 0;
	font-size: var(--font-size-base);
	font-weight: 700;
	color: var(--color-text);
	line-height: 1.5;
}
.guide-action-card__detail {
	margin: 4px 0 0;
	font-size: var(--font-size-sm);
	color: var(--color-text-light);
	line-height: 1.6;
}
.guide-action-card.is-done .guide-action-card__step {
	text-decoration: line-through;
	color: var(--color-text-light);
}
.guide-action-card__done {
	flex-shrink: 0;
	display: inline-flex;
	flex-direction: column;
	align-items: center;
	justify-content: center;
	gap: 4px;
	min-width: 72px;
	padding: 8px 12px;
	background-color: #fff;
	border: 2px solid var(--color-primary);
	color: var(--color-primary-dark);
	border-radius: var(--border-radius-base);
	font-size: var(--font-size-xs);
	font-weight: 700;
	cursor: pointer;
	transition: all var(--transition);
}
.guide-action-card__done:hover,
.guide-action-card__done:focus {
	background-color: var(--color-primary-light);
}
.guide-action-card__done-icon {
	font-size: 18px;
	line-height: 1;
}
.guide-action-card.is-done .guide-action-card__done {
	background-color: #2A8C5C;
	border-color: #2A8C5C;
	color: #fff;
}

/* ③ 困りごと→対処カード */
.guide-trouble-cards {
	display: flex;
	flex-direction: column;
	gap: var(--spacing-3);
}
.guide-trouble-card {
	background-color: var(--color-surface);
	border: 1px solid var(--color-border);
	border-radius: var(--border-radius-lg);
	overflow: hidden;
}
.guide-trouble-card__row {
	display: flex;
	gap: var(--spacing-3);
	align-items: flex-start;
	padding: var(--spacing-3) var(--spacing-4);
}
.guide-trouble-card__row--problem {
	background-color: #FFF8EE;
	border-bottom: 1px dashed var(--color-border);
}
.guide-trouble-card__row--solution {
	background-color: #fff;
}
.guide-trouble-card__tag {
	flex-shrink: 0;
	display: inline-block;
	font-size: var(--font-size-xs);
	font-weight: 700;
	padding: 3px 10px;
	border-radius: var(--border-radius-full);
	white-space: nowrap;
}
.guide-trouble-card__tag--problem {
	color: #B96B14;
	background-color: #FFE9C9;
}
.guide-trouble-card__tag--solution {
	color: #2A8C5C;
	background-color: #D5ECDD;
}
.guide-trouble-card__text {
	margin: 0;
	font-size: var(--font-size-base);
	line-height: 1.6;
	color: var(--color-text);
	flex: 1;
}

/* ④ 公式情報カード */
.guide-official-cards {
	list-style: none;
	margin: 0;
	padding: 0;
	display: grid;
	grid-template-columns: 1fr;
	gap: var(--spacing-3);
}
@media (min-width: 720px) {
	.guide-official-cards { grid-template-columns: 1fr 1fr; }
}
.guide-official-card {
	background-color: var(--color-surface);
	border: 1px solid var(--color-border);
	border-radius: var(--border-radius-lg);
	padding: var(--spacing-4);
	display: flex;
	flex-direction: column;
	gap: var(--spacing-3);
	border-top: 4px solid #4584AE;
}
.guide-official-card__name {
	margin: 0;
	font-size: var(--font-size-md);
	font-weight: 700;
	color: var(--color-text);
}
.guide-official-card__meta {
	margin: 0;
	display: flex;
	flex-direction: column;
	gap: var(--spacing-2);
}
.guide-official-card__row {
	display: flex;
	gap: var(--spacing-2);
	align-items: flex-start;
	font-size: var(--font-size-sm);
	line-height: 1.6;
}
.guide-official-card__dt {
	flex-shrink: 0;
	font-weight: 700;
	color: #2C6B91;
	background-color: #EFF6FB;
	padding: 1px 8px;
	border-radius: var(--border-radius-full);
	font-size: var(--font-size-xs);
	white-space: nowrap;
	margin-top: 2px;
}
.guide-official-card__dd {
	margin: 0;
	color: var(--color-text);
}
.guide-official-card__btn {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: 6px;
	padding: 10px var(--spacing-4);
	background-color: var(--color-primary);
	color: #fff;
	border-radius: var(--border-radius-full);
	font-size: var(--font-size-sm);
	font-weight: 700;
	text-decoration: none;
	transition: background-color var(--transition);
	margin-top: auto;
	align-self: flex-end;
}
.guide-official-card__btn:hover,
.guide-official-card__btn:focus {
	background-color: var(--color-primary-dark);
	color: #fff;
}
.guide-official-card__btn-ext { font-size: 13px; }

/* 関連メモ v2 */
.guide-related-memos--v2 .guide-related-memos__grid--v2 {
	display: grid;
	grid-template-columns: 1fr;
	gap: var(--spacing-3);
}
@media (min-width: 720px) {
	.guide-related-memos--v2 .guide-related-memos__grid--v2 {
		grid-template-columns: 1fr 1fr;
	}
}
.guide-memo-card--v2 {
	background-color: var(--color-surface);
	border: 1px solid var(--color-border);
	border-radius: var(--border-radius-lg);
	overflow: hidden;
	transition: all var(--transition);
	display: block;
	height: auto;
}
.guide-memo-card--v2:hover,
.guide-memo-card--v2:focus-within {
	transform: translateY(-2px);
	box-shadow: 0 4px 12px rgba(0,0,0,0.08);
	border-color: var(--color-primary);
}
.guide-memo-card--v2 .guide-memo-card__link {
	display: block;
	padding: var(--spacing-4);
	color: var(--color-text);
	text-decoration: none;
}
.guide-memo-card--v2 .guide-memo-card__body {
	display: flex;
	flex-direction: column;
	gap: var(--spacing-2);
}
.guide-memo-card--v2 .guide-memo-card__title {
	margin: 0 0 4px;
	font-size: var(--font-size-md);
	font-weight: 700;
	color: var(--color-text);
	line-height: 1.4;
}
.guide-memo-card--v2 .guide-memo-card__excerpt {
	margin: 0;
	font-size: var(--font-size-sm);
	color: var(--color-text);
	line-height: 1.6;
}
.guide-memo-card__why {
	display: flex;
	flex-direction: column;
	gap: 6px;
	align-items: flex-start;
	padding: 8px var(--spacing-3);
	background-color: var(--color-bg);
	border-radius: var(--border-radius-base);
	font-size: var(--font-size-sm);
	line-height: 1.5;
}
.guide-memo-card__why-tag {
	flex-shrink: 0;
	display: inline-block;
	font-size: var(--font-size-xs);
	font-weight: 700;
	color: var(--color-primary-dark);
	background-color: #fff;
	padding: 2px 8px;
	border-radius: var(--border-radius-full);
	border: 1px solid var(--color-primary-light);
	white-space: nowrap;
}
.guide-memo-card__why-text {
	display: block;
	color: var(--color-text);
	word-break: break-word;
}
.guide-memo-card--v2 .guide-memo-card__meta {
	margin: 0;
	font-size: var(--font-size-xs);
	color: var(--color-text-light);
	display: inline-flex;
	align-items: center;
	gap: 4px;
}
.guide-memo-card--v2 .guide-memo-card__cta {
	display: inline-flex;
	align-items: center;
	gap: 6px;
	margin-top: var(--spacing-2);
	padding: 8px 16px;
	background-color: var(--color-primary);
	color: #fff;
	border-radius: var(--border-radius-full);
	font-size: var(--font-size-sm);
	font-weight: 700;
	align-self: flex-end;
	transition: background-color var(--transition);
}
.guide-memo-card--v2 .guide-memo-card__link:hover .guide-memo-card__cta,
.guide-memo-card--v2 .guide-memo-card__link:focus .guide-memo-card__cta {
	background-color: var(--color-primary-dark);
}
.guide-memo-card--v2 .guide-memo-card__cta-arrow {
	transition: transform var(--transition);
}
.guide-memo-card--v2 .guide-memo-card__link:hover .guide-memo-card__cta-arrow {
	transform: translateX(3px);
}

/* 末尾CTA */
.guide-end-cta {
	margin-top: var(--spacing-6);
	padding: var(--spacing-5);
	background-color: var(--color-bg);
	border-radius: var(--border-radius-lg);
	border: 1px solid var(--color-border);
}
.guide-end-cta__heading {
	margin: 0 0 var(--spacing-3);
	font-size: var(--font-size-md);
	font-weight: 700;
	color: var(--color-text);
	text-align: center;
}
.guide-end-cta__buttons {
	display: flex;
	flex-direction: column;
	gap: var(--spacing-2);
}
@media (min-width: 720px) {
	.guide-end-cta__buttons {
		flex-direction: row;
		flex-wrap: wrap;
		justify-content: center;
	}
}
.guide-end-cta__btn {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: 8px;
	padding: 12px var(--spacing-4);
	background-color: #fff;
	border: 2px solid var(--color-border);
	border-radius: var(--border-radius-full);
	color: var(--color-text);
	font-size: var(--font-size-sm);
	font-weight: 700;
	text-decoration: none;
	transition: all var(--transition);
	flex: 1;
	min-width: 0;
}
@media (min-width: 720px) {
	.guide-end-cta__btn { flex: 0 1 auto; min-width: 240px; }
}
.guide-end-cta__btn:hover,
.guide-end-cta__btn:focus {
	border-color: var(--color-primary);
	background-color: var(--color-primary-light);
	color: var(--color-primary-dark);
}
.guide-end-cta__btn--primary {
	background-color: var(--color-primary);
	border-color: var(--color-primary);
	color: #fff;
}
.guide-end-cta__btn--primary:hover,
.guide-end-cta__btn--primary:focus {
	background-color: var(--color-primary-dark);
	border-color: var(--color-primary-dark);
	color: #fff;
}
.guide-end-cta__btn-icon {
	font-size: 14px;
	line-height: 1;
}

/* レスポンシブ */
@media (max-width: 480px) {
	.guide-howto__inner { gap: var(--spacing-3); }
	.guide-howto__mascot { width: 48px; }
	.guide-action-card { flex-direction: column; gap: var(--spacing-2); }
	.guide-action-card__done { width: 100%; flex-direction: row; min-width: 0; }
	.guide-trouble-card__row { flex-direction: column; gap: 6px; padding: var(--spacing-3); }
	.guide-official-card__row { flex-direction: column; gap: 4px; }
}






/* ================================================
   Phase 20: 災害時の情報の見方ページ 再設計
   ================================================ */

/* リード文の調整（Phase 20上書き） */
.joho-intro {
background-color: #FFF5E6;
border-left: 4px solid var(--color-primary);
padding: var(--spacing-4) var(--spacing-5);
border-radius: var(--border-radius-base);
}
.joho-intro__lead { line-height: 1.8; }
.joho-intro__lead strong { color: var(--color-primary-dark); }

/* まずは30秒だけ確認（イントロ） */
.joho-quick {
background: linear-gradient(180deg, #FFF8E8 0%, #FFFDF6 100%);
border-radius: var(--border-radius-lg);
padding: var(--spacing-5);
text-align: center;
border: 1px solid var(--color-primary-light);
margin-bottom: var(--spacing-5);
}
.joho-quick .joho-section__title {
border-bottom: none;
color: var(--color-primary-dark);
margin-bottom: var(--spacing-2);
padding-bottom: 0;
font-size: var(--font-size-xl);
}
.joho-quick .joho-section__sub {
margin: 0;
color: var(--color-text);
line-height: 1.7;
}

/* 確認する3つのポイント（カード） */
.joho-points { margin-bottom: var(--spacing-7); }
.joho-point-cards {
list-style: none;
margin: 0;
padding: 0;
display: grid;
grid-template-columns: 1fr;
gap: var(--spacing-4);
}
@media (min-width: 720px) {
.joho-point-cards { grid-template-columns: repeat(3, 1fr); }
}
.joho-point-card {
position: relative;
background-color: var(--color-surface);
border: 1px solid var(--color-border);
border-radius: var(--border-radius-lg);
padding: var(--spacing-5) var(--spacing-4) var(--spacing-4);
display: flex;
flex-direction: column;
gap: var(--spacing-2);
box-shadow: 0 2px 8px rgba(0,0,0,0.05);
overflow: hidden;
}
/* カラフルな上部ヘッダー帯 */
.joho-point-card::before {
content: '';
position: absolute;
top: 0; left: 0; right: 0;
height: 90px;
background: linear-gradient(135deg, #FFE9C2 0%, #FFF5E0 100%);
z-index: 0;
}
.joho-point-card--who::before { background: linear-gradient(135deg, #D6EAFE 0%, #EBF4FF 100%); }
.joho-point-card--where::before { background: linear-gradient(135deg, #D5F0DC 0%, #EAF8EE 100%); }

.joho-point-card > * { position: relative; z-index: 1; }

.joho-point-card__visual {
display: flex;
align-items: center;
justify-content: center;
position: relative;
margin: 0 auto var(--spacing-3);
width: 84px;
height: 84px;
border-radius: var(--border-radius-full);
background-color: #fff;
box-shadow: 0 4px 12px rgba(0,0,0,0.08);
color: var(--color-primary-dark);
}
.joho-point-card--who  .joho-point-card__visual { color: #1769b3; }
.joho-point-card--where .joho-point-card__visual { color: #1f7a3a; }

.joho-point-card__icon {
display: inline-flex;
align-items: center;
justify-content: center;
width: 56px;
height: 56px;
}
.joho-point-card__icon svg { width: 100%; height: 100%; }

.joho-point-card__label {
margin: 0;
text-align: center;
font-size: 26px;
font-weight: 800;
color: var(--color-primary-dark);
letter-spacing: 0.02em;
}
.joho-point-card--who  .joho-point-card__label { color: #1769b3; }
.joho-point-card--where .joho-point-card__label { color: #1f7a3a; }

.joho-point-card__text {
margin: 0;
text-align: center;
font-size: var(--font-size-base);
font-weight: 700;
color: var(--color-text);
line-height: 1.5;
}
.joho-point-card__example {
margin: var(--spacing-2) 0 0;
display: flex;
flex-wrap: wrap;
align-items: center;
gap: 6px;
padding: 8px 12px;
background-color: rgba(255,255,255,0.85);
border: 1px dashed rgba(0,0,0,0.12);
border-radius: var(--border-radius-base);
font-size: var(--font-size-sm);
}
.joho-point-card__example-label {
font-size: var(--font-size-xs);
font-weight: 700;
color: var(--color-text-light);
}
.joho-point-card__example-value {
font-weight: 700;
color: var(--color-text);
font-variant-numeric: tabular-nums;
}
.joho-point-card__chip {
display: inline-block;
padding: 2px 8px;
font-size: var(--font-size-xs);
font-weight: 700;
border-radius: var(--border-radius-full);
background-color: #fff;
color: var(--color-text);
border: 1px solid rgba(0,0,0,0.1);
}
.joho-point-card--who .joho-point-card__chip { color: #1769b3; border-color: rgba(23,105,179,0.25); }
.joho-point-card__note {
margin: var(--spacing-2) 0 0;
font-size: var(--font-size-sm);
color: var(--color-text-light);
line-height: 1.6;
}

/* 判断練習クイズ：回答の深掘り */
.joho-practice .mini-quiz {
margin-bottom: var(--spacing-5);
}
.mini-quiz__answer-recommend {
margin: 0 0 var(--spacing-3);
font-size: var(--font-size-base);
line-height: 1.5;
display: flex;
flex-direction: column;
gap: 6px;
}
.mini-quiz__answer-tag {
display: inline-block;
align-self: flex-start;
font-size: var(--font-size-xs);
font-weight: 700;
color: #fff;
background-color: #2e7d57;
padding: 2px 10px;
border-radius: var(--border-radius-full);
}
.mini-quiz__answer-recommend strong {
color: #1f5a40;
font-size: var(--font-size-md);
}
.mini-quiz__answer-dl {
margin: 0;
display: flex;
flex-direction: column;
gap: var(--spacing-3);
background-color: #fff;
border-radius: var(--border-radius-base);
padding: var(--spacing-3) var(--spacing-4);
}
.mini-quiz__answer-row {
display: grid;
grid-template-columns: 1fr;
gap: 4px;
}
@media (min-width: 600px) {
.mini-quiz__answer-row {
grid-template-columns: 110px 1fr;
gap: var(--spacing-3);
}
}
.mini-quiz__answer-row dt {
font-size: var(--font-size-sm);
font-weight: 700;
color: #2e7d57;
}
.mini-quiz__answer-row dd {
margin: 0;
font-size: var(--font-size-sm);
color: var(--color-text);
line-height: 1.7;
}
.mini-quiz__answer-link {
display: inline-block;
margin-top: 6px;
color: var(--color-primary-dark);
font-weight: 700;
text-decoration: underline;
}
.mini-quiz__answer-link:hover { color: var(--color-primary); }

/* 覚えておく合言葉 */
.joho-motto-section .joho-section__title {
text-align: center;
border-bottom: none;
padding-bottom: 0;
}
.joho-motto {
background: linear-gradient(135deg, #F5A32A 0%, #E89220 100%);
color: #fff;
border-radius: var(--border-radius-lg);
padding: var(--spacing-6) var(--spacing-5);
text-align: center;
box-shadow: 0 4px 12px rgba(245,163,42,0.25);
}
.joho-motto__text {
margin: 0 0 var(--spacing-3);
font-size: 22px;
font-weight: 700;
line-height: 1.5;
letter-spacing: 0.02em;
}
@media (min-width: 720px) {
.joho-motto__text { font-size: 26px; }
}
.joho-motto__sub {
margin: 0;
font-size: var(--font-size-sm);
line-height: 1.7;
color: rgba(255,255,255,0.95);
}
.joho-motto__sub strong { color: #fff; background-color: rgba(255,255,255,0.18); padding: 1px 6px; border-radius: 4px; }

/* もっと確認したいときは（3カード導線） */
.joho-more-cards {
list-style: none;
margin: 0;
padding: 0;
display: grid;
grid-template-columns: 1fr;
gap: var(--spacing-3);
}
@media (min-width: 720px) {
.joho-more-cards { grid-template-columns: repeat(3, 1fr); }
}
.joho-more-card {
position: relative;
background-color: var(--color-surface);
border: 1px solid var(--color-border);
border-radius: var(--border-radius-lg);
padding: 0;
display: flex;
flex-direction: column;
overflow: hidden;
box-shadow: 0 2px 8px rgba(0,0,0,0.05);
transition: transform var(--transition), box-shadow var(--transition), border-color var(--transition);
}
.joho-more-card:hover {
transform: translateY(-3px);
box-shadow: 0 10px 22px rgba(0,0,0,0.1);
border-color: var(--color-primary-light);
}

/* カード上部ヘッダー帯 */
.joho-more-card__head {
display: flex;
align-items: center;
gap: var(--spacing-3);
padding: var(--spacing-4);
background: linear-gradient(135deg, #FFE9C2 0%, #FFF5E0 100%);
border-bottom: 1px solid rgba(0,0,0,0.05);
}
.joho-more-card--memo  .joho-more-card__head { background: linear-gradient(135deg, #D6EAFE 0%, #EBF4FF 100%); }
.joho-more-card--today .joho-more-card__head { background: linear-gradient(135deg, #D5F0DC 0%, #EAF8EE 100%); }

.joho-more-card__icon {
display: inline-flex;
align-items: center;
justify-content: center;
flex-shrink: 0;
width: 64px;
height: 64px;
margin: 0;
border-radius: var(--border-radius-full);
background-color: #fff;
color: var(--color-primary-dark);
box-shadow: 0 3px 8px rgba(0,0,0,0.1);
}
.joho-more-card--memo  .joho-more-card__icon { color: #1769b3; }
.joho-more-card--today .joho-more-card__icon { color: #1f7a3a; }

.joho-more-card__head-text {
display: flex;
flex-direction: column;
gap: 2px;
min-width: 0;
}
.joho-more-card__label {
margin: 0;
font-size: var(--font-size-xs);
font-weight: 700;
color: var(--color-text-light);
background: none;
padding: 0;
border-radius: 0;
align-self: auto;
}
.joho-more-card__target {
margin: 0;
font-size: var(--font-size-sm);
font-weight: 700;
color: var(--color-text);
line-height: 1.4;
}
.joho-more-card--memo  .joho-more-card__target { color: #1769b3; }
.joho-more-card--today .joho-more-card__target { color: #1f7a3a; }
.joho-more-card--memo  .joho-more-card__label,
.joho-more-card--today .joho-more-card__label { color: var(--color-text-light); }

/* カード本体 */
.joho-more-card__title {
margin: var(--spacing-4) var(--spacing-4) var(--spacing-2);
font-size: var(--font-size-lg);
font-weight: 800;
color: var(--color-text);
line-height: 1.4;
letter-spacing: 0.01em;
}
.joho-more-card--memo  .joho-more-card__title { color: #115394; }
.joho-more-card--today .joho-more-card__title { color: #18602e; }
.joho-more-card__title { color: var(--color-primary-dark); }
.joho-more-card--memo  .joho-more-card__title { color: #115394; }
.joho-more-card--today .joho-more-card__title { color: #18602e; }

.joho-more-card__text {
margin: 0 var(--spacing-4) var(--spacing-3);
font-size: var(--font-size-sm);
color: var(--color-text-light);
line-height: 1.6;
}

/* このサイトで見られることリスト */
ul.joho-more-card__features {
list-style: none;
margin: 0 var(--spacing-4) var(--spacing-4);
padding: var(--spacing-3);
background-color: var(--color-gray-50, #f8f8f8);
border-radius: var(--border-radius-base);
flex: 1;
display: flex;
flex-direction: column;
gap: 6px;
}
ul.joho-more-card__features li {
position: relative;
padding-left: 22px;
margin-bottom: 0;
font-size: var(--font-size-sm);
font-weight: 600;
color: var(--color-text);
line-height: 1.5;
}
ul.joho-more-card__features li::before {
content: '';
position: absolute;
left: 4px;
top: 0.55em;
width: 10px;
height: 5px;
border-left: 2px solid var(--color-primary);
border-bottom: 2px solid var(--color-primary);
transform: rotate(-45deg);
}
.joho-more-card--memo  ul.joho-more-card__features li::before { border-color: #1769b3; }
.joho-more-card--today ul.joho-more-card__features li::before { border-color: #1f7a3a; }
.joho-more-card__text {
margin: 0 var(--spacing-4) var(--spacing-3);
font-size: var(--font-size-sm);
color: var(--color-text-light);
line-height: 1.6;
}
.joho-more-card__btn {
display: inline-flex;
align-items: center;
justify-content: center;
gap: 6px;
margin: 0 var(--spacing-4) var(--spacing-4);
padding: 12px var(--spacing-4);
background-color: var(--color-primary);
color: #fff;
border-radius: var(--border-radius-full);
font-size: var(--font-size-sm);
font-weight: 700;
text-decoration: none;
transition: background-color var(--transition);
align-self: stretch;
}
.joho-more-card__btn:hover,
.joho-more-card__btn:focus {
background-color: var(--color-primary-dark);
color: #fff;
}
.joho-more-card--memo  .joho-more-card__btn { background-color: #1769b3; }
.joho-more-card--memo  .joho-more-card__btn:hover,
.joho-more-card--memo  .joho-more-card__btn:focus { background-color: #115394; }
.joho-more-card--today .joho-more-card__btn { background-color: #1f7a3a; }
.joho-more-card--today .joho-more-card__btn:hover,
.joho-more-card--today .joho-more-card__btn:focus { background-color: #18602e; }
.joho-more-card__arrow { transition: transform var(--transition); }
.joho-more-card:hover .joho-more-card__arrow { transform: translateX(3px); }

/* 旧 .joho-steps / .check-list / .remember-box--single / .joho-remember-more / .joho-links は新マークアップでは未使用。
   念のため残置スタイルが影響しないよう、page-joho 側では別マークアップを使用する。 */

@media (max-width: 480px) {
.joho-motto { padding: var(--spacing-5) var(--spacing-4); }
.joho-motto__text { font-size: 19px; }
.joho-point-card { padding: var(--spacing-3); }
}

/* ============================================================
   Phase 21: 公式情報リンク集 — 再設計
   ============================================================ */

/* 既存の旧 .link-card 系より後ろに置いて上書き */

/* ヒーロー */
.page-hero--links { background: linear-gradient(135deg, #FFF8EC 0%, #FFEFD3 100%); }

/* リード */
.links-intro {
background: var(--color-surface);
border: 1px solid var(--color-border);
border-radius: var(--border-radius-lg);
padding: var(--spacing-5);
margin-bottom: var(--spacing-6);
box-shadow: var(--shadow-sm);
}
.links-intro__lead {
font-size: var(--font-size-base);
line-height: 1.8;
color: var(--color-text);
margin: 0 0 var(--spacing-3);
}
.links-intro__lead strong { color: var(--color-primary-dark); font-weight: 700; }
.links-intro__howto {
background: var(--color-gray-50);
border-radius: var(--border-radius-base);
padding: var(--spacing-3) var(--spacing-4);
margin-top: var(--spacing-3);
}
.links-intro__howto > summary {
cursor: pointer;
font-weight: 600;
color: var(--color-text);
list-style: none;
position: relative;
padding-left: 1.4em;
font-size: var(--font-size-sm);
}
.links-intro__howto > summary::-webkit-details-marker { display: none; }
.links-intro__howto > summary::before {
content: '▶';
position: absolute; left: 0; top: 0;
font-size: 0.7em; color: var(--color-primary);
transition: transform var(--transition);
}
.links-intro__howto[open] > summary::before { transform: rotate(90deg); }
.links-intro__howto ul { margin: var(--spacing-3) 0 0; padding-left: 1.2em; font-size: var(--font-size-sm); line-height: 1.8; }

/* セクション共通 */
.links-section { margin-bottom: var(--spacing-8); }
.links-section__title {
font-size: var(--font-size-xl);
font-weight: 700;
color: var(--color-text);
margin: 0 0 var(--spacing-2);
}
.links-section__title--picks {
display: block;
padding: 0;
background: none;
}
.links-section__title--picks .marker {
display: inline;
background-image: linear-gradient(transparent 60%, #FFE3A6 60%);
padding: 0 6px;
-webkit-box-decoration-break: clone;
box-decoration-break: clone;
}
@media (max-width: 600px) {
.links-section__title--picks { font-size: var(--font-size-lg); line-height: 1.7; }
.links-section__title--picks .marker {
background-image: linear-gradient(transparent 65%, #FFE3A6 65%);
padding: 0 4px;
}
}
.links-section__sub {
color: var(--color-text-light);
font-size: var(--font-size-sm);
margin: 0 0 var(--spacing-5);
}

/* カードグリッド */
.link-cards { display: grid; gap: var(--spacing-4); grid-template-columns: 1fr; }
@media (min-width: 600px) { .link-cards { grid-template-columns: repeat(2, 1fr); } }
@media (min-width: 900px) { .link-cards { grid-template-columns: repeat(3, 1fr); } }

/* リンクカード（v2） */
.link-card {
position: relative;
display: flex;
flex-direction: column;
background: var(--color-surface);
border: 1px solid var(--color-border);
border-radius: var(--border-radius-lg);
padding: var(--spacing-4);
box-shadow: var(--shadow-sm);
transition: transform var(--transition), box-shadow var(--transition);
height: 100%;
}
.link-card:hover { transform: translateY(-2px); box-shadow: 0 6px 16px rgba(0,0,0,.08); }
.link-card--bookmark { border-color: var(--color-primary); border-width: 2px; }

/* しおり風ブックマーク推奨バッジ（カード右上、カード上辺から頭を出す） */
.link-card__ribbon {
position: absolute;
top: -4px;
right: 12px;
width: 78px;
background: var(--color-primary);
color: #fff;
font-size: 11px;
font-weight: 700;
line-height: 1.3;
text-align: center;
padding: 4px 4px 10px;
clip-path: polygon(0 0, 100% 0, 100% 100%, 50% 80%, 0 100%);
box-shadow: 0 2px 4px rgba(0,0,0,.12);
z-index: 2;
letter-spacing: 0.04em;
}
.link-card__ribbon-text { display: inline-block; }

.link-card__head {
display: flex; align-items: flex-start; justify-content: space-between;
gap: var(--spacing-2);
margin-bottom: var(--spacing-3);
}
/* ブックマーク推奨カードはタイトルをしおりの下に落とすためだけ上マージンを追加。横は干渉しない。 */
.link-card--bookmark .link-card__head { padding-top: 22px; }
.link-card:not(.link-card--bookmark) .link-card__head { padding-right: 0; padding-top: 0; }
h3.link-card__title {
font-size: var(--font-size-md);
font-weight: 700;
color: var(--color-text);
margin: 0;
margin-top: var(--spacing-1);
line-height: 1.4;
word-break: auto-phrase;
overflow-wrap: anywhere;
}
.link-card__badge { display: none; }

.link-card__dl { margin: 0 0 var(--spacing-4); flex: 1; }
.link-card__row {
padding: var(--spacing-2) 0;
border-bottom: 1px dashed var(--color-border);
}
.link-card__row:last-child { border-bottom: 0; }
.link-card__row dt {
font-size: var(--font-size-xs);
font-weight: 700;
color: var(--color-text-light);
margin: 0 0 2px;
letter-spacing: 0.02em;
}
.link-card__row dd {
font-size: var(--font-size-sm);
color: var(--color-text);
margin: 0;
line-height: 1.7;
}
.link-card__row--point dd {
color: var(--color-primary-dark);
font-weight: 600;
}
.link-card__row--region dd {
display: inline-block;
font-size: var(--font-size-xs);
background: var(--color-gray-50);
padding: 2px 8px;
border-radius: var(--border-radius-base);
color: var(--color-text-light);
}

.link-card__btn {
display: flex; align-items: center; justify-content: center;
gap: 6px;
width: 100%;
padding: var(--spacing-3);
background: var(--color-primary);
color: #fff;
font-weight: 700;
font-size: var(--font-size-base);
border-radius: var(--border-radius-base);
text-decoration: none;
transition: background var(--transition);
}
.link-card__btn:hover { background: var(--color-primary-dark); color: #fff; text-decoration: none; }
.link-card__btn-text { line-height: 1.2; }
.link-card__btn-icon {
	stroke: currentColor;
	flex-shrink: 0;
	transition: transform var(--transition);
}
.link-card__btn:hover .link-card__btn-icon { transform: translate(2px, -2px); }
.sr-only {
	position: absolute !important;
	width: 1px; height: 1px;
	padding: 0; margin: -1px;
	overflow: hidden; clip: rect(0,0,0,0);
	white-space: nowrap; border: 0;
}

/* 目次（カテゴリ別リンク一覧） */
.links-toc {
	background: var(--color-surface);
	border: 1px solid var(--color-border);
	border-radius: var(--border-radius-lg);
	padding: var(--spacing-4) var(--spacing-5);
	margin-bottom: var(--spacing-6);
	box-shadow: var(--shadow-sm);
}
.links-toc__label {
	margin: 0 0 var(--spacing-3);
	font-weight: 700;
	color: var(--color-text);
	font-size: var(--font-size-lg);
	letter-spacing: 0.02em;
	display: flex;
	align-items: center;
	gap: var(--spacing-2);
}
.links-toc__label::before {
	content: '';
	width: 4px; height: 1.1em;
	background: var(--color-primary);
	border-radius: 2px;
}
.links-toc__cats {
	list-style: none;
	padding: 0;
	margin: 0;
	display: grid;
	gap: var(--spacing-3);
	grid-template-columns: 1fr;
}
@media (min-width: 640px) { .links-toc__cats { grid-template-columns: repeat(2, 1fr); } }
@media (min-width: 960px) { .links-toc__cats { grid-template-columns: repeat(3, 1fr); } }

.links-toc__cat {
	background: var(--color-gray-50);
	border-radius: var(--border-radius-base);
	padding: 0;
	overflow: hidden;
}
.links-toc__cat-head {
	display: flex;
	align-items: center;
	gap: var(--spacing-2);
	padding: 6px var(--spacing-3);
	background: var(--color-primary);
	color: #fff;
	font-weight: 700;
	font-size: var(--font-size-sm);
	text-decoration: none;
	transition: background var(--transition);
}
.links-toc__cat-head:hover { background: var(--color-primary-dark); color: #fff; text-decoration: none; }
.links-toc__cat-icon {
	display: inline-flex;
	width: 22px; height: 22px;
	background: rgba(255,255,255,0.22);
	border-radius: var(--border-radius-full);
	align-items: center; justify-content: center;
	flex-shrink: 0;
}
.links-toc__cat-icon svg { stroke: currentColor; width: 14px; height: 14px; }
.links-toc__cat-name { flex: 1; line-height: 1.3; }
.links-toc__cat-count {
	font-size: 11px;
	background: rgba(255,255,255,0.25);
	padding: 1px 7px;
	border-radius: var(--border-radius-full);
	white-space: nowrap;
}
.links-toc__items {
	list-style: none;
	padding: 4px var(--spacing-2);
	margin: 0;
}
ul.links-toc__items { list-style: none; }
ul.links-toc__cats { list-style: none; }
.links-toc__items li { margin: 0; list-style: none; }
.links-toc__items a {
	display: block;
	padding: 4px 6px;
	color: var(--color-text);
	font-size: 13px;
	text-decoration: none;
	border-radius: var(--border-radius-base);
	line-height: 1.5;
	transition: background var(--transition);
}
.links-toc__items a:hover { background: #FFF8EC; color: var(--color-primary-dark); text-decoration: none; }
.links-toc__bm {
	display: inline-block;
	font-size: 10px;
	font-weight: 700;
	color: var(--color-primary-dark);
	background: #FFE3A6;
	padding: 1px 6px;
	border-radius: var(--border-radius-full);
	margin-left: 6px;
	white-space: nowrap;
	vertical-align: 2px;
}
html { scroll-behavior: smooth; scroll-padding-top: 80px; }

.link-card__note {
font-size: var(--font-size-sm);
color: var(--color-text-light);
background: var(--color-gray-50);
padding: var(--spacing-3);
border-radius: var(--border-radius-base);
margin: 0;
line-height: 1.7;
}

/* ピック（番号付きラッパ） */
.link-cards--picks { gap: var(--spacing-5); }
.link-pick { position: relative; display: flex; }
.link-pick > .link-card { flex: 1; padding-top: var(--spacing-5); }
.link-pick__num {
position: absolute;
top: -14px; left: var(--spacing-3);
width: 36px; height: 36px;
background: var(--color-primary);
color: #fff;
font-size: var(--font-size-lg);
font-weight: 700;
border-radius: var(--border-radius-full);
display: inline-flex; align-items: center; justify-content: center;
box-shadow: 0 2px 6px rgba(245,163,42,.3);
z-index: 1;
}

/* カテゴリ */
.links-category {
background: var(--color-surface);
border: 1px solid var(--color-border);
border-radius: var(--border-radius-lg);
padding: var(--spacing-5);
margin-bottom: var(--spacing-5);
}
.links-category__head {
display: grid;
grid-template-columns: auto 1fr;
column-gap: var(--spacing-3);
margin-bottom: var(--spacing-4);
padding-bottom: var(--spacing-3);
border-bottom: 2px solid var(--color-primary-light);
}
.links-category__icon {
width: 44px; height: 44px;
background: var(--color-primary);
color: #fff;
border-radius: var(--border-radius-full);
display: inline-flex; align-items: center; justify-content: center;
grid-row: span 2;
}
.links-category__icon svg { stroke: currentColor; }
h3.links-category__title {
font-size: var(--font-size-lg);
font-weight: 700;
color: var(--color-text);
margin: 0;
margin-top: var(--spacing-1);
align-self: end;
}
p.links-category__when {
margin: 0;
color: var(--color-text-light);
font-size: var(--font-size-xs);
align-self: start;
}

/* SNS情報 → /joho/ 導線カード */
.links-section--joho-cta { margin-top: var(--spacing-8); }
.links-joho-card {
background: linear-gradient(135deg, #E8F5E9 0%, #F1F8E9 100%);
border: 2px solid var(--color-green);
border-radius: var(--border-radius-lg);
padding: var(--spacing-5);
display: grid;
grid-template-columns: auto 1fr auto;
gap: var(--spacing-4);
align-items: center;
}
.links-joho-card__icon {
width: 56px; height: 56px;
background: var(--color-green);
color: #fff;
border-radius: var(--border-radius-full);
display: inline-flex; align-items: center; justify-content: center;
}
.links-joho-card__icon svg { stroke: currentColor; }
.links-joho-card__body { min-width: 0; }
.links-joho-card__label {
font-size: var(--font-size-xs);
color: var(--color-text-light);
font-weight: 700;
margin: 0 0 4px;
letter-spacing: 0.04em;
}
.links-joho-card__title {
font-size: var(--font-size-lg);
font-weight: 700;
color: var(--color-text);
margin: 0 0 var(--spacing-1);
}
.links-joho-card__text {
margin: 0;
font-size: var(--font-size-sm);
color: var(--color-text);
line-height: 1.7;
}
.links-joho-card__btn {
display: inline-flex; align-items: center; gap: 6px;
background: var(--color-green);
color: #fff;
font-weight: 700;
font-size: var(--font-size-base);
padding: var(--spacing-3) var(--spacing-4);
border-radius: var(--border-radius-base);
text-decoration: none;
white-space: nowrap;
transition: background var(--transition), transform var(--transition);
}
.links-joho-card__btn:hover { background: #2E7D32; color: #fff; text-decoration: none; transform: translateX(2px); }
.links-joho-card__arrow { font-size: 1.1em; }

@media (max-width: 720px) {
.links-joho-card {
grid-template-columns: auto 1fr;
grid-template-rows: auto auto;
}
.links-joho-card__icon { grid-row: span 2; }
.links-joho-card__btn { grid-column: 1 / -1; justify-content: center; }
}

/* 旧コンポーネントの非表示／無効化（残骸対策） */
.link-card__bookmark-badge,
.links-section__title--bookmark::before { display: none !important; }


/* ================================================================
   Phase 22 — そなえメモ 一覧/詳細 再設計（refined）
   ================================================================ */

/* ---- カード（一覧/アーカイブ共通：全カードで完全同一レイアウト） ---- */
.memo-card,
.memo-card--featured {
position: relative;
display: flex;
flex-direction: column;
background-color: var(--color-surface);
border: 1px solid var(--color-border);
border-radius: var(--border-radius-lg);
overflow: hidden;
text-decoration: none;
color: var(--color-text);
transition: box-shadow var(--transition), transform var(--transition), border-color var(--transition);
padding: 0;
gap: 0;
}
.memo-card:hover {
box-shadow: var(--shadow-md);
transform: translateY(-2px);
border-color: var(--color-primary);
text-decoration: none;
}
/* featured は枠線のみ強調（レイアウトは同一） */
.memo-card--featured {
border: 2px solid var(--color-primary);
box-shadow: 0 2px 0 0 rgba(245,163,42,.08);
}

.memo-card__feature-badge {
position: absolute;
top: var(--spacing-2);
left: var(--spacing-2);
background: var(--color-primary);
color: #fff;
font-size: 11px;
font-weight: 700;
padding: 3px 10px;
border-radius: var(--border-radius-base);
letter-spacing: 0.06em;
z-index: 2;
box-shadow: 0 2px 4px rgba(245,163,42,.3);
}

/* サムネ：縦長を抑えるため 2:1 に（画像なしカードは非表示） */
.memo-card__thumb,
.memo-card--featured .memo-card__thumb {
width: 100%;
aspect-ratio: 2 / 1;
overflow: hidden;
background-color: var(--color-gray-50);
}
.memo-card__thumb img,
.memo-card--featured .memo-card__thumb img {
width: 100%;
height: 100%;
object-fit: cover;
display: block;
}

.memo-card__body {
padding: var(--spacing-4);
display: flex;
flex-direction: column;
gap: var(--spacing-2);
flex: 1;
}

.memo-card__cat {
display: inline-block;
align-self: flex-start;
font-size: 11px;
font-weight: 700;
color: var(--color-primary-dark);
background: var(--color-primary-light);
padding: 2px 8px;
border-radius: var(--border-radius-base);
letter-spacing: 0.02em;
margin-bottom: 0;
}

.memo-card__title {
font-size: var(--font-size-base);
font-weight: 700;
color: var(--color-text);
line-height: 1.45;
margin: 0;
word-break: auto-phrase;
overflow-wrap: anywhere;
}

.memo-card__excerpt {
font-size: var(--font-size-sm);
color: var(--color-text-light);
line-height: 1.55;
margin: 0;
display: -webkit-box;
-webkit-line-clamp: 2;
-webkit-box-orient: vertical;
overflow: hidden;
}

/* メタ：横並びでコンパクトに */
.memo-card__meta {
display: flex;
flex-wrap: wrap;
gap: 4px var(--spacing-3);
margin: var(--spacing-1) 0 0;
padding: var(--spacing-2) 0 0;
border-top: 1px dashed var(--color-border);
font-size: 12px;
}
.memo-card__meta-row { display: inline-flex; align-items: center; gap: 4px; margin: 0; }
.memo-card__meta-label {
color: var(--color-text-light);
font-weight: 500;
margin: 0;
}
.memo-card__meta-label::after { content: '：'; }
.memo-card__meta-value { margin: 0; color: var(--color-text); font-weight: 600; }
.memo-card__meta-value .memo-chip { font-size: 11px; padding: 1px 6px; }

/* CTA をボタン化 */
.memo-card__cta {
display: flex;
align-items: center;
justify-content: center;
gap: 4px;
margin-top: auto;
padding: var(--spacing-2) var(--spacing-3);
background: var(--color-primary);
color: #fff;
border-radius: var(--border-radius-base);
font-size: 13px;
font-weight: 700;
text-align: center;
letter-spacing: 0.02em;
transition: background-color var(--transition);
}
.memo-card__cta::after { content: '→'; transition: transform var(--transition); }
.memo-card:hover .memo-card__cta { background: var(--color-primary-dark); }
.memo-card:hover .memo-card__cta::after { transform: translateX(2px); }

/* ---- セクション間隔 ---- */
.memo-featured-section { margin-bottom: var(--spacing-8); }
.memo-all-section { margin-bottom: var(--spacing-8); }

/* ---- 末尾CTA（背景色を切り替えたフルブリード帯） ---- */
.memo-bottom-cta {
margin-top: var(--spacing-10, var(--spacing-8));
padding: var(--spacing-8, var(--spacing-7)) 0 var(--spacing-7, var(--spacing-6));
background: var(--color-gray-50);
border-top: 1px solid var(--color-border);
border-bottom: 1px solid var(--color-border);
text-align: center;
}
.memo-bottom-cta__title {
display: inline-flex;
align-items: center;
justify-content: center;
gap: 8px;
font-size: var(--font-size-lg);
font-weight: 700;
color: var(--color-text);
margin: 0 0 var(--spacing-2);
}
.memo-bottom-cta__title::before {
content: '';
display: inline-block;
width: 8px;
height: 8px;
background: var(--color-primary);
border-radius: 50%;
}
.memo-bottom-cta__text {
font-size: var(--font-size-base);
line-height: 1.7;
margin: 0 auto var(--spacing-5);
max-width: 36em;
color: var(--color-text-light);
}
.memo-bottom-cta__actions {
display: flex;
flex-wrap: wrap;
justify-content: center;
gap: var(--spacing-3);
}
.memo-bottom-cta__actions .btn { min-width: 220px; }

/* ---- 詳細ページ：メタバー（dl化） ---- */
.memo-meta-bar {
display: flex;
flex-wrap: wrap;
gap: var(--spacing-2) var(--spacing-4);
margin: var(--spacing-3) 0 0;
font-size: var(--font-size-sm);
}
.memo-meta-bar__row { display: inline-flex; align-items: center; gap: 4px; margin: 0; }
.memo-meta-bar__label { margin: 0; color: var(--color-text-light); font-weight: 500; }
.memo-meta-bar__label::after { content: '：'; }
.memo-meta-bar__value { margin: 0; color: var(--color-text); font-weight: 600; }

/* ---- 詳細ページ：このメモで分かること ---- */
.memo-overview {
background: var(--color-gray-50);
border-left: 4px solid var(--color-primary);
border-radius: var(--border-radius-base);
padding: var(--spacing-5) var(--spacing-5);
margin: var(--spacing-7, var(--spacing-6)) 0;
}
.memo-overview__title {
font-size: var(--font-size-base);
font-weight: 700;
color: var(--color-text);
margin: 0 0 var(--spacing-3);
display: flex;
align-items: center;
gap: 8px;
}
.memo-overview__title::before {
content: '';
display: inline-block;
width: 14px;
height: 14px;
background: var(--color-primary);
border-radius: 50%;
flex-shrink: 0;
}
.memo-overview__list {
list-style: none;
margin: 0;
padding: 0;
display: flex;
flex-direction: column;
gap: var(--spacing-2);
}
.memo-overview__list li {
font-size: var(--font-size-sm);
line-height: 1.7;
padding-left: var(--spacing-4);
position: relative;
color: var(--color-text);
}
.memo-overview__list li::before {
content: '';
position: absolute;
left: 4px;
top: 0.65em;
width: 8px;
height: 8px;
background: var(--color-primary);
border-radius: 50%;
}

/* ---- 詳細ページ：本文セクション間の余白を確保 ---- */
.memo-body .memo-section,
.memo-body .memo-overview,
.memo-body .memo-advice,
.memo-body .memo-related-guides,
.memo-body .memo-toc,
.memo-body .memo-body-content {
margin-top: var(--spacing-7, var(--spacing-6));
margin-bottom: var(--spacing-7, var(--spacing-6));
}
.memo-body > *:first-child { margin-top: var(--spacing-5); }
.memo-body .memo-body-content > * + * { margin-top: var(--spacing-3); }
.memo-body .memo-body-content h2 { margin-top: var(--spacing-7, var(--spacing-6)); }
.memo-body .memo-body-content h3 { margin-top: var(--spacing-5); }

/* ---- 詳細ページ：アドバイス（絵文字なし） ---- */
.memo-advice {
padding: var(--spacing-5);
}
.memo-advice__icon {
display: inline-flex;
align-items: center;
justify-content: center;
width: 36px;
height: 36px;
background: var(--color-green);
color: #fff;
border-radius: 50%;
flex-shrink: 0;
}
.memo-advice__icon svg { stroke: #fff; }

/* ---- 詳細ページ：関連ガイドリンク（アイコンSVG化） ---- */
.memo-related-guide-link__icon {
display: inline-flex;
align-items: center;
justify-content: center;
width: 36px;
height: 36px;
background: var(--color-primary-light);
color: var(--color-primary-dark);
border-radius: 50%;
flex-shrink: 0;
}
.memo-related-guide-link__icon svg { stroke: var(--color-primary-dark); }
.memo-related-guide-link__arrow {
display: inline-flex;
align-items: center;
color: var(--color-text-light);
}

/* ---- 詳細ページ：末尾ナビ ---- */
.memo-bottom-nav {
display: flex;
flex-wrap: wrap;
gap: var(--spacing-3);
margin-top: var(--spacing-8);
padding-top: var(--spacing-6);
border-top: 1px solid var(--color-border);
}
.memo-bottom-nav .btn {
flex: 1 1 auto;
min-width: 220px;
text-align: center;
justify-content: center;
}

/* ---- 詳細ページ：末尾「今日できること」を CTA の下に置いたときの余白 ---- */
.memo-body .today-task,
.memo-body .today-task-section {
margin-top: var(--spacing-8);
}

.single-sonae_memo .task-hint {
	margin-bottom: var(--spacing-6);
}

/* ---- 古い memo-post-nav 上書き（同居時の互換） ---- */
.memo-post-nav .btn { justify-content: center; }

/* ---- レスポンシブ ---- */
@media (min-width: 640px) {
.memo-card-grid { grid-template-columns: repeat(2, 1fr); }
}
@media (min-width: 960px) {
.memo-card-grid { grid-template-columns: repeat(3, 1fr); }
}



/* ================================================================
   Phase 23 v3 — このサイトについて（細部までこだわった版）
   ================================================================ */

/* ---------------- ヒーロー ---------------- */
.about-hero {
	position: relative;
	overflow: hidden;
	background:
		radial-gradient(circle at 85% 15%, rgba(245,163,42,0.10), transparent 55%),
		linear-gradient(180deg, #FFF6E0 0%, #FFFAEC 60%, #FFFDF7 100%);
	padding: var(--spacing-8) 0 var(--spacing-9, calc(var(--spacing-8) + var(--spacing-2)));
	margin-bottom: var(--spacing-10, var(--spacing-8));
}
.about-hero::after {
	content: '';
	position: absolute;
	left: 0; right: 0; bottom: 0;
	height: 1px;
	background: linear-gradient(90deg, transparent, var(--color-border), transparent);
}
.about-hero__bg { position: absolute; inset: 0; pointer-events: none; }
.about-hero__bg-sun { position: absolute; top: -28px; right: -28px; color: rgba(245,163,42,0.22); }
.about-hero__bg-cloud { position: absolute; color: rgba(200,220,234,0.55); }
.about-hero__bg-cloud--1 { top: 18%; left: -24px; }
.about-hero__bg-cloud--2 { bottom: 8%; right: 6%; }
.about-hero__bg-spark { position: absolute; top: 24%; right: 14%; color: rgba(245,163,42,0.55); animation: about-spark 3.4s ease-in-out infinite; }
@keyframes about-spark {
	0%,100% { transform: rotate(0) scale(1);    opacity: 0.5; }
	50%     { transform: rotate(18deg) scale(1.15); opacity: 1; }
}

.about-hero__inner {
	position: relative;
	display: flex;
	flex-direction: column;
	align-items: center;
	gap: var(--spacing-5);
	text-align: center;
}
@media (min-width: 720px) {
	.about-hero__inner {
		flex-direction: row;
		align-items: center;
		justify-content: center;
		text-align: left;
		gap: var(--spacing-8);
	}
}
.about-hero__mascot { flex-shrink: 0; }
.about-hero__text { max-width: 560px; }
.about-hero__eyebrow {
	display: inline-block;
	margin: 0 0 var(--spacing-3);
	padding: 5px 14px 4px;
	background: var(--color-primary);
	color: #fff;
	font-size: 12px;
	font-weight: 700;
	letter-spacing: 0.12em;
	border-radius: var(--border-radius-full);
}
.about-hero__title {
	font-size: clamp(1.6rem, 4.6vw, 2.4rem);
	font-weight: 800;
	line-height: 1.45;
	color: var(--color-text);
	margin: 0 0 var(--spacing-4);
	letter-spacing: 0.01em;
}
.about-hero__title strong {
	color: var(--color-primary-dark);
	font-weight: 800;
	background: linear-gradient(transparent 65%, rgba(245,163,42,0.28) 65%);
	padding: 0 4px;
}
.about-hero__desc {
	font-size: var(--font-size-base);
	line-height: 1.9;
	color: var(--color-text);
	margin: 0;
}
.about-hero__desc strong { color: var(--color-primary-dark); font-weight: 700; }


/* ---------------- 共通：セクション見出し ---------------- */
.about-section-head {
	text-align: center;
	margin-bottom: var(--spacing-7, var(--spacing-6));
}
.about-section-head__eyebrow {
	display: inline-block;
	font-size: 11px;
	font-weight: 700;
	letter-spacing: 0.22em;
	color: var(--color-primary-dark);
	background: var(--color-primary-light);
	padding: 4px 12px 3px;
	border-radius: var(--border-radius-full);
	margin-bottom: var(--spacing-3);
}
.about-section-head__eyebrow--alert { color: #fff; background: var(--color-alert); }
.about-section-head__title {
	font-size: clamp(1.25rem, 2.8vw, 1.6rem);
	font-weight: 800;
	color: var(--color-text);
	margin: 0 0 var(--spacing-3);
	line-height: 1.4;
	letter-spacing: 0.01em;
}
.about-section-head__sub {
	font-size: var(--font-size-sm);
	color: var(--color-text-light);
	line-height: 1.8;
	margin: 0;
}


/* ---------------- 5ステップ ---------------- */
.about-usage {
	margin-bottom: var(--spacing-10, var(--spacing-8));
}
.about-usage__list.about-usage__list {
	list-style: none;
	margin: 0;
	padding: 0;
	display: flex;
	flex-direction: column;
	gap: var(--spacing-5);
	max-width: 760px;
	margin-left: auto;
	margin-right: auto;
}
.about-usage__item {
	position: relative;
	display: grid;
	grid-template-columns: 88px 1fr;
	gap: 0;
	background: var(--color-surface);
	border: 1px solid var(--color-border);
	border-radius: var(--border-radius-lg);
	margin: 0;
	overflow: hidden;
	transition: transform var(--transition), box-shadow var(--transition), border-color var(--transition);
}
.about-usage__item:hover {
	transform: translateY(-2px);
	box-shadow: 0 10px 22px rgba(0,0,0,0.07);
	border-color: var(--color-primary-light);
}

/* ステップ間コネクター（縦線）— rail 中央に配置 */
.about-usage__item::after {
	content: '';
	position: absolute;
	left: 44px;            /* rail 幅 88px の中央 */
	bottom: -28px;         /* gap = spacing-5(=20px相当) を跨ぐ */
	width: 2px;
	height: var(--spacing-5);
	background: linear-gradient(to bottom, var(--color-primary-light), rgba(245,163,42,0));
	transform: translateX(-50%);
	z-index: 1;
}
.about-usage__item:last-child::after { display: none; }

/* 左の縦バー（ステップ番号） */
.about-usage__rail {
	position: relative;
	display: flex;
	flex-direction: column;
	align-items: center;
	justify-content: center;
	gap: 2px;
	padding: var(--spacing-5) var(--spacing-3);
	color: #fff;
	background: linear-gradient(180deg, var(--color-primary) 0%, var(--color-primary-dark) 100%);
}
.about-usage__rail-label {
	font-size: 10px;
	font-weight: 700;
	letter-spacing: 0.18em;
	color: rgba(255,255,255,0.85);
}
.about-usage__rail-num {
	font-size: 36px;
	font-weight: 800;
	line-height: 1;
	letter-spacing: -0.02em;
	font-feature-settings: "tnum";
}

/* 右側本文 */
.about-usage__body {
	padding: var(--spacing-5) var(--spacing-5) var(--spacing-5);
	min-width: 0;
}
.about-usage__head {
	display: flex;
	align-items: center;
	gap: var(--spacing-3);
	margin-bottom: var(--spacing-2);
}
.about-usage__icon {
	flex-shrink: 0;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 36px;
	height: 36px;
	border-radius: 10px;
	background: var(--color-primary-light);
	color: var(--color-primary-dark);
}
.about-usage__title {
	font-size: var(--font-size-lg);
	font-weight: 800;
	color: var(--color-text);
	margin: 0;
	line-height: 1.4;
	letter-spacing: 0.01em;
}
.about-usage__text {
	font-size: var(--font-size-sm);
	color: var(--color-text);
	line-height: 1.85;
	margin: 0 0 var(--spacing-3);
}
.about-usage__links { display: flex; flex-wrap: wrap; gap: var(--spacing-3) var(--spacing-4); }
.about-usage__link {
	display: inline-flex;
	align-items: center;
	gap: 6px;
	font-size: 13px;
	font-weight: 700;
	color: var(--color-primary-dark);
	text-decoration: none;
	padding: 4px 0;
}
.about-usage__link span {
	border-bottom: 1px solid var(--color-primary);
	padding-bottom: 1px;
}
.about-usage__link svg { stroke: currentColor; transition: transform var(--transition); }
.about-usage__link:hover svg { transform: translateX(3px); }

/* per-step アクセントカラー（rail とアイコンチップに適用） */
.about-usage__item--shindan  .about-usage__icon { background: #FFEFD0; color: #B36F0A; }
.about-usage__item--kyou     .about-usage__icon { background: #FFF3CD; color: #B07900; }
.about-usage__item--check    .about-usage__icon { background: #E0F5E5; color: #1F7A3A; }
.about-usage__item--guide    .about-usage__icon { background: #DDE9F8; color: #1769B3; }
.about-usage__item--official .about-usage__icon { background: #EFE0F8; color: #6A2899; }

/* スマホ：縦に重ねる */
@media (max-width: 560px) {
	.about-usage__item {
		grid-template-columns: 1fr;
	}
	.about-usage__rail {
		flex-direction: row;
		justify-content: flex-start;
		gap: var(--spacing-2);
		padding: var(--spacing-2) var(--spacing-4);
	}
	.about-usage__rail-num { font-size: 22px; }
	.about-usage__item::after {
		left: 50%;
		bottom: calc(-1 * var(--spacing-5));
		height: var(--spacing-5);
	}
	.about-usage__body {
		padding: var(--spacing-4);
	}
}


/* ---------------- コンセプト ---------------- */
.about-concept {
	position: relative;
	overflow: hidden;
	margin: var(--spacing-10, var(--spacing-8)) 0;
	padding: var(--spacing-8) var(--spacing-6);
	text-align: center;
	background:
		radial-gradient(circle at 20% 30%, rgba(255,255,255,0.18), transparent 60%),
		radial-gradient(circle at 80% 70%, rgba(255,255,255,0.14), transparent 60%),
		linear-gradient(135deg, #F5A32A 0%, #E89220 100%);
	color: #fff;
	border-radius: var(--border-radius-lg);
	box-shadow: 0 10px 28px rgba(245,163,42,0.28);
}
.about-concept__bg { position: absolute; inset: 0; pointer-events: none; color: rgba(255,255,255,0.32); }
.about-concept__bg-spark { position: absolute; }
.about-concept__bg-spark--1 { top: 14%;  left: 9%;   animation: about-spark 4s ease-in-out infinite; }
.about-concept__bg-spark--2 { bottom: 18%; right: 11%; animation: about-spark 3.6s ease-in-out infinite 0.4s; }
.about-concept__bg-spark--3 { top: 52%;  right: 32%; animation: about-spark 3.2s ease-in-out infinite 1s; }

.about-concept__eyebrow {
	position: relative;
	display: inline-block;
	font-size: 11px;
	font-weight: 700;
	letter-spacing: 0.32em;
	margin: 0 0 var(--spacing-4);
	padding: 4px 14px 3px;
	color: #fff;
	background: rgba(255,255,255,0.18);
	border-radius: var(--border-radius-full);
}
.about-concept__lead {
	position: relative;
	font-size: clamp(1rem, 2.2vw, 1.15rem);
	font-weight: 700;
	margin: 0 0 var(--spacing-2);
	color: rgba(255,255,255,0.96);
	letter-spacing: 0.06em;
}
.about-concept__main {
	position: relative;
	font-size: clamp(1.7rem, 5.2vw, 2.4rem);
	font-weight: 800;
	margin: 0 0 var(--spacing-4);
	line-height: 1.45;
	letter-spacing: 0.04em;
	text-shadow: 0 2px 10px rgba(0,0,0,0.14);
}
.about-concept__sub {
	position: relative;
	font-size: var(--font-size-sm);
	margin: 0 auto;
	max-width: 28em;
	color: rgba(255,255,255,0.95);
	line-height: 1.8;
}


/* ---------------- 立ち位置 3カード ---------------- */
.about-position { margin-bottom: var(--spacing-10, var(--spacing-8)); }
.about-position__grid.about-position__grid {
	list-style: none;
	margin: 0;
	padding: 0;
	display: grid;
	grid-template-columns: 1fr;
	gap: var(--spacing-4);
}
@media (min-width: 720px) {
	.about-position__grid { grid-template-columns: repeat(3, 1fr); gap: var(--spacing-5); }
}
.about-position__item {
	--card-bg-from: #FFF6E5;
	--card-bg-to:   #FFE6BD;
	--card-accent:  #B36F0A;
	--card-icon-bg: #FFFFFF;
	--card-no:      #C44747;
	--card-yes:     #1F7A3A;
	position: relative;
	display: flex;
	flex-direction: column;
	background: var(--color-surface);
	border: 1px solid var(--color-border);
	border-radius: var(--border-radius-lg);
	overflow: hidden;
	margin: 0;
	transition: transform var(--transition), box-shadow var(--transition), border-color var(--transition);
}
.about-position__item:hover {
	transform: translateY(-4px);
	box-shadow: 0 14px 30px rgba(0,0,0,0.09);
	border-color: var(--card-accent);
}
.about-position__item--entry {
	--card-bg-from: #FFF6E5;
	--card-bg-to:   #FFE6BD;
	--card-accent:  #B36F0A;
}
.about-position__item--official {
	--card-bg-from: #EAF2FC;
	--card-bg-to:   #C8DDF5;
	--card-accent:  #1769B3;
}
.about-position__item--continue {
	--card-bg-from: #E8F7EC;
	--card-bg-to:   #C2E8CC;
	--card-accent:  #1F7A3A;
}

/* 上部のカラーバンド：ラベル＋大型アイコン */
.about-position__head {
	position: relative;
	padding: var(--spacing-5);
	background:
		radial-gradient(120% 120% at 100% 0%, rgba(255,255,255,0.55) 0%, transparent 55%),
		linear-gradient(135deg, var(--card-bg-from) 0%, var(--card-bg-to) 100%);
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: var(--spacing-3);
	min-height: 96px;
	border-bottom: 1px solid rgba(0,0,0,0.05);
}
.about-position__head::before {
	content: '';
	position: absolute;
	left: 0;
	top: 0;
	bottom: 0;
	width: 4px;
	background: var(--card-accent);
}
.about-position__badge {
	display: inline-flex;
	align-items: center;
	padding: 4px 10px;
	background: rgba(255,255,255,0.85);
	color: var(--card-accent);
	font-size: 10px;
	font-weight: 800;
	letter-spacing: 0.16em;
	border-radius: var(--border-radius-full);
	box-shadow: 0 1px 3px rgba(0,0,0,0.05);
}
.about-position__icon {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 60px;
	height: 60px;
	border-radius: 16px;
	background: var(--card-icon-bg);
	color: var(--card-accent);
	box-shadow: 0 4px 12px rgba(0,0,0,0.08);
	flex-shrink: 0;
}

/* 本文 */
.about-position__body {
	padding: var(--spacing-5);
	display: flex;
	flex-direction: column;
	gap: var(--spacing-4);
	flex-grow: 1;
}
.about-position__title {
	font-size: var(--font-size-lg);
	font-weight: 800;
	color: var(--color-text);
	margin: 0;
	line-height: 1.4;
	letter-spacing: 0.01em;
	position: relative;
	padding-bottom: var(--spacing-2);
}
.about-position__title::after {
	content: '';
	display: block;
	width: 32px;
	height: 3px;
	background: var(--card-accent);
	border-radius: var(--border-radius-full);
	margin-top: var(--spacing-2);
}
.about-position__lead {
	font-size: var(--font-size-sm);
	color: var(--color-text);
	line-height: 1.8;
	margin: 0;
}

/* NOT / YES の対比ブロック */
.about-position__compare {
	margin: 0;
	padding: var(--spacing-3);
	background: var(--color-gray-50, #FAFAF7);
	border-radius: var(--border-radius-base);
	display: flex;
	flex-direction: column;
	gap: var(--spacing-2);
	margin-top: auto;
}
.about-position__compare-row {
	display: grid;
	grid-template-columns: 28px 1fr;
	align-items: center;
	gap: var(--spacing-3);
}
.about-position__compare-row dt {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 24px;
	height: 24px;
	border-radius: 50%;
	font-size: 14px;
	font-weight: 800;
	line-height: 1;
	color: #fff;
}
.about-position__compare-row dd {
	margin: 0;
	font-size: 13px;
	line-height: 1.55;
	color: var(--color-text);
}
.about-position__compare-row--no dt {
	background: var(--card-no);
}
.about-position__compare-row--no dd {
	color: var(--color-text-light);
	text-decoration: line-through;
	text-decoration-color: rgba(196,71,71,0.4);
	text-decoration-thickness: 1.5px;
}
.about-position__compare-row--yes dt {
	background: var(--card-yes);
}
.about-position__compare-row--yes dd {
	font-weight: 700;
}


/* ---------------- 注意事項 ---------------- */
.about-notice {
	margin-bottom: var(--spacing-10, var(--spacing-8));
	padding: var(--spacing-6);
	background: #FFF8F6;
	border: 1px solid #FFD9D2;
	border-radius: var(--border-radius-lg);
}
.about-notice__head {
	display: flex;
	align-items: flex-start;
	gap: var(--spacing-4);
	margin-bottom: var(--spacing-5);
	padding-bottom: var(--spacing-4);
	border-bottom: 1px dashed #FFC9C0;
}
.about-notice__head-icon {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 40px;
	height: 40px;
	border-radius: 12px;
	background: var(--color-alert);
	color: #fff;
	flex-shrink: 0;
}
.about-notice__head-text { min-width: 0; }
.about-notice__head .about-section-head__eyebrow { margin-bottom: var(--spacing-2); }
.about-notice__head .about-section-head__title {
	font-size: var(--font-size-lg);
	margin: 0 0 4px;
	text-align: left;
}
.about-notice__head-sub {
	font-size: var(--font-size-sm);
	color: var(--color-text-light);
	line-height: 1.7;
	margin: 0;
}

.about-notice__list.about-notice__list {
	list-style: none;
	margin: 0;
	padding: 0;
	display: flex;
	flex-direction: column;
	gap: var(--spacing-3);
}
.about-notice__item {
	display: grid;
	grid-template-columns: 130px 1fr;
	gap: var(--spacing-4);
	align-items: center;
	padding: var(--spacing-3) var(--spacing-4);
	background: #fff;
	border: 1px solid #FFE0D8;
	border-radius: var(--border-radius-base);
}
.about-notice__label {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	padding: 5px 10px;
	background: var(--color-alert);
	color: #fff;
	font-size: 12px;
	font-weight: 700;
	border-radius: var(--border-radius-base);
	white-space: nowrap;
	letter-spacing: 0.04em;
	line-height: 1.3;
	text-align: center;
	min-height: 28px;
}
.about-notice__item p {
	font-size: var(--font-size-sm);
	line-height: 1.85;
	color: var(--color-text);
	margin: 0;
}
.about-notice__item p a { color: var(--color-primary-dark); font-weight: 700; }
.about-notice__item p strong { color: var(--color-alert); font-weight: 800; }
@media (max-width: 560px) {
	.about-notice { padding: var(--spacing-5) var(--spacing-4); }
	.about-notice__item {
		grid-template-columns: 1fr;
		gap: var(--spacing-2);
		align-items: start;
	}
	.about-notice__label { justify-self: start; }
}


/* ---------------- 末尾CTA（フルブリードの帯） ---------------- */
.about-cta {
	margin-top: var(--spacing-10, var(--spacing-8));
	padding: var(--spacing-8) 0 var(--spacing-7);
	background: var(--color-gray-50);
	border-top: 1px solid var(--color-border);
	border-bottom: 1px solid var(--color-border);
	text-align: center;
}
.about-cta__container {
	padding-top: var(--spacing-5);
	padding-bottom: var(--spacing-8);
}
.about-cta__title {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: 8px;
	font-size: var(--font-size-lg);
	font-weight: 700;
	color: var(--color-text);
	margin: 0 0 var(--spacing-2);
	line-height: 1.5;
}
.about-cta__title::before {
	content: '';
	display: inline-block;
	width: 8px;
	height: 8px;
	background: var(--color-primary);
	border-radius: 50%;
}
.about-cta__text {
	font-size: var(--font-size-base);
	line-height: 1.8;
	margin: 0 auto var(--spacing-5);
	max-width: 36em;
	color: var(--color-text-light);
}
.about-cta__actions {
	display: flex;
	flex-wrap: wrap;
	justify-content: center;
	gap: var(--spacing-3);
}
.about-cta__actions .btn { min-width: 220px; }


/* ---- prefers-reduced-motion ---- */
@media (prefers-reduced-motion: reduce) {
	.about-hero__bg-spark,
	.about-concept__bg-spark { animation: none; }
	.about-usage__item,
	.about-position__item { transition: none; }
}


/* ============================================================
   Phase 24 追加：共通の出口CTAブロック
   ============================================================ */
.front-exit-cta,
.guide-list-exit-cta {
margin: var(--spacing-8) auto var(--spacing-6);
padding: var(--spacing-6) var(--spacing-5);
background: linear-gradient(135deg, #FFF8E8 0%, #FFEFD0 100%);
border: 1px solid #F2D89A;
border-radius: var(--border-radius-lg);
text-align: center;
box-shadow: 0 4px 16px rgba(245,163,42,0.08);
}
.guide-list-exit-cta { max-width: 720px; }
.front-exit-cta__title,
.guide-list-exit-cta__title {
font-size: var(--font-size-lg);
font-weight: 800;
color: var(--color-text);
margin: 0 0 var(--spacing-2);
line-height: 1.4;
}
.front-exit-cta__text,
.guide-list-exit-cta__text {
font-size: var(--font-size-sm);
color: var(--color-text-light);
margin: 0 0 var(--spacing-5);
line-height: 1.7;
}
.front-exit-cta__actions,
.guide-list-exit-cta__actions {
display: flex;
flex-direction: column;
gap: var(--spacing-3);
align-items: center;
}
.front-exit-cta__actions .btn,
.guide-list-exit-cta__actions .btn {
width: 100%;
max-width: 320px;
min-height: 48px;
}
@media (min-width: 720px) {
.front-exit-cta__actions,
.guide-list-exit-cta__actions {
flex-direction: row;
justify-content: center;
flex-wrap: wrap;
}
.front-exit-cta__actions .btn,
.guide-list-exit-cta__actions .btn {
width: auto;
min-width: 220px;
}
}


/* ============================================================
   Phase 24b：TOPページ スマホ特化UI 強化
   （ヒーロー / next-step / situation / five-grid / howto を
   モバイル375pxで「直感的に伝わる」見せ方に最適化）
   ※「Phase 25」は別件（マスコット連動強化）に正式割当のため改名
   ============================================================ */

/* ---- 25-1. ヒーロー：マスコット主役・タイトル可読性UP ---- */
.hero--front .hero__inner {
display: flex;
flex-direction: column;
align-items: center;
text-align: center;
gap: var(--spacing-3);
padding: var(--spacing-6) 0 var(--spacing-5);
}
.hero--front .hero__mascot {
	width: 120px;
	max-width: 40vw;
	margin: 0 auto;
	filter: drop-shadow(0 6px 12px rgba(245,163,42,0.18));
	display: flex;
	align-items: center;
	justify-content: center;
}
.hero--front .hero__mascot img,
.hero--front .hero__mascot svg {
width: 100%;
height: auto;
display: block;
}
.hero--front .hero__eyebrow {
display: inline-block;
padding: 4px 12px;
background: #fff;
border: 1px solid var(--color-primary-light);
border-radius: var(--border-radius-full);
font-size: var(--font-size-xs);
font-weight: 700;
color: var(--color-primary-dark);
margin: 0;
box-shadow: 0 2px 6px rgba(245,163,42,0.10);
}
.hero--front .hero__title {
font-size: clamp(1.5rem, 6.5vw, 2rem);
line-height: 1.45;
font-weight: 800;
margin: var(--spacing-1) 0 0;
}
.hero--front .hero__title strong {
color: var(--color-primary-dark);
background: linear-gradient(transparent 60%, #FFE5B5 60%);
padding: 0 4px;
}
.hero--front .hero__desc {
font-size: var(--font-size-sm);
color: var(--color-text-light);
margin: 0;
line-height: 1.7;
}
.hero--front .hero__actions {
display: flex;
flex-direction: column;
gap: var(--spacing-2);
width: 100%;
max-width: 320px;
margin: var(--spacing-2) auto 0;
}
.hero--front .hero__actions .btn {
min-height: 52px;
font-size: var(--font-size-md);
font-weight: 700;
}

/* 背景の太陽・雲をマスコットの邪魔にならない位置へ */
@media (max-width: 600px) {
.hero--front .hero__bg-sun { top: 12px; right: 12px; opacity: 0.6; }
.hero--front .hero__bg-cloud--1 { top: 28px; left: 4%; opacity: 0.7; }
.hero--front .hero__bg-cloud--2 { top: 100px; right: 6%; opacity: 0.65; }
}

/* ---- 25-2. next-step（3つの入口）：番号+大アイコンを上に、本文を下に ---- */
.next-step-card.next-step-card {
display: flex;
flex-direction: column;
align-items: stretch;
gap: var(--spacing-3);
padding: var(--spacing-4);
min-height: auto;
border-left-width: 1px;
border-top: 6px solid var(--color-primary);
border-radius: var(--border-radius-lg);
position: relative;
}
.next-step-card.next-step-card--shindan { border-top-color: var(--color-primary); }
.next-step-card.next-step-card--guide   { border-top-color: var(--color-info); }
.next-step-card.next-step-card--kyou    { border-top-color: #2E8B57; }
/* 既存の左ボーダーは無効化（上ボーダーへ統一） */
.next-step-card.next-step-card--shindan,
.next-step-card.next-step-card--guide,
.next-step-card.next-step-card--kyou {
border-left-color: var(--color-border);
}
/* 上端の細い色帯は冗長なので非表示 */
.next-step-card::before { display: none; }

/* 横並びヘッダー：番号バッジ + 大きいアイコン + タイトル */
.next-step-card .next-step-card__num {
position: absolute;
top: 12px;
right: 12px;
width: 28px;
height: 28px;
font-size: var(--font-size-sm);
background: var(--color-primary);
color: #fff;
box-shadow: 0 2px 6px rgba(0,0,0,0.12);
}
.next-step-card--guide .next-step-card__num { background: var(--color-info); color: #fff; }
.next-step-card--kyou  .next-step-card__num { background: #2E8B57; color: #fff; }

.next-step-card .next-step-card__icon {
width: 72px;
height: 72px;
margin: var(--spacing-1) auto var(--spacing-2);
}
.next-step-card .next-step-card__icon svg {
width: 44px;
height: 44px;
}

.next-step-card__body {
text-align: center;
}
.next-step-card .next-step-card__title {
font-size: var(--font-size-lg);
line-height: 1.45;
margin: 0 0 var(--spacing-1);
}
.next-step-card .next-step-card__desc {
font-size: var(--font-size-sm);
margin: 0 0 var(--spacing-3);
line-height: 1.7;
}
.next-step-card .next-step-card__cta {
align-self: center;
padding: 8px 18px;
background: var(--color-primary-light);
color: var(--color-primary-dark);
border-radius: var(--border-radius-full);
transition: background-color var(--transition), color var(--transition);
}
.next-step-card--guide .next-step-card__cta { background: #EEF5FA; color: var(--color-info); }
.next-step-card--kyou  .next-step-card__cta { background: #E6F4EE; color: #2E8B57; }
.next-step-card:hover .next-step-card__cta {
background: var(--color-primary);
color: #fff;
}
.next-step-card--guide:hover .next-step-card__cta { background: var(--color-info); color: #fff; }
.next-step-card--kyou:hover  .next-step-card__cta { background: #2E8B57; color: #fff; }

/* ---- 25-3. situation グリッド：アイコン色を濃く、タップ感UP ---- */
.situation-card.situation-card {
padding: var(--spacing-3) var(--spacing-3);
gap: var(--spacing-3);
border-radius: var(--border-radius-lg);
border: 1px solid var(--color-border);
background: #fff;
min-height: 72px;
}
.situation-card .situation-card__icon {
width: 56px;
height: 56px;
}
.situation-card .situation-card__icon svg {
width: 32px;
height: 32px;
}
.situation-card .situation-card__label {
font-size: var(--font-size-md);
line-height: 1.4;
}
.situation-card .situation-card__sub {
font-size: var(--font-size-xs);
line-height: 1.5;
color: var(--color-text-light);
}
.situation-card .situation-card__arrow {
width: 28px;
height: 28px;
display: inline-flex;
align-items: center;
justify-content: center;
border-radius: var(--border-radius-full);
background: var(--color-gray-100);
color: var(--color-text-light);
}
.situation-card:hover .situation-card__arrow {
background: var(--color-primary);
color: #fff;
}
/* 状況別の左アクセントバー（一目で属性が分かる） */
.situation-card { position: relative; overflow: hidden; }
.situation-card::before {
content: '';
position: absolute;
left: 0; top: 0; bottom: 0;
width: 4px;
background: var(--color-gray-300, #ccc);
}
.situation-card--earthquake::before { background: var(--color-alert); }
.situation-card--typhoon::before    { background: var(--color-info); }
.situation-card--rain::before       { background: #3A88B8; }
.situation-card--blackout::before   { background: var(--color-warning); }
.situation-card--water_cut::before  { background: #2A8C7C; }
.situation-card--normal::before     { background: var(--color-primary); }

/* situation-grid のすき間と1列固定 */
.situation-grid {
display: flex;
flex-direction: column;
gap: var(--spacing-2);
list-style: none;
margin: 0;
padding: 0;
}

/* ---- 25-4. five-grid：縦並び・テキスト改行防止 ---- */
.five-grid.five-grid {
display: grid;
grid-template-columns: repeat(5, 1fr);
gap: var(--spacing-1);
padding: 0;
margin: var(--spacing-4) 0;
list-style: none;
}
.five-grid__item.five-grid__item {
display: flex;
flex-direction: column;
align-items: center;
gap: 2px;
padding: var(--spacing-2) 2px;
background: #fff;
border-radius: var(--border-radius-base);
border: 1px solid var(--color-border);
margin: 0;
text-align: center;
}
.five-grid__name {
font-size: var(--font-size-sm);
font-weight: 700;
margin: 0;
line-height: 1.3;
}
.five-grid__sub {
font-size: 10px;
color: var(--color-text-light);
margin: 0;
line-height: 1.3;
white-space: nowrap;
}
@media (max-width: 380px) {
.five-grid.five-grid { gap: 4px; }
.five-grid__sub { font-size: 9px; }
}

/* ---- 25-5. howto-steps：縦のフロー線でつなぐ ---- */
.howto-steps {
position: relative;
display: flex;
flex-direction: column;
gap: var(--spacing-3);
list-style: none;
margin: var(--spacing-5) 0 var(--spacing-4);
padding: 0;
}
.howto-steps::before {
content: '';
position: absolute;
left: 19px;
top: 20px;
bottom: 20px;
width: 2px;
background: var(--color-primary-light);
z-index: 0;
}
.howto-steps__item.howto-steps__item {
display: flex;
gap: var(--spacing-3);
align-items: flex-start;
background: #fff;
border: 1px solid var(--color-border);
border-radius: var(--border-radius-base);
padding: var(--spacing-3);
margin: 0;
position: relative;
z-index: 1;
}
.howto-steps__item .howto-steps__num {
flex-shrink: 0;
width: 40px;
height: 40px;
display: inline-flex;
align-items: center;
justify-content: center;
background: var(--color-primary);
color: #fff;
border-radius: var(--border-radius-full);
font-weight: 800;
font-size: var(--font-size-md);
box-shadow: 0 0 0 3px #fff;
}
.howto-steps__item .howto-steps__text {
font-size: var(--font-size-sm);
line-height: 1.7;
}
.howto-steps__item .howto-steps__text strong {
display: block;
font-size: var(--font-size-md);
margin-bottom: 2px;
color: var(--color-text);
}

/* デスクトップ横並びの旧スタイルはモバイル前提で無効化 */
@media (min-width: 720px) {
.howto-steps {
flex-direction: column;
}
.howto-steps::before {
left: 19px;
right: auto;
top: 20px;
bottom: 20px;
height: auto;
width: 2px;
}
.howto-steps__item.howto-steps__item {
flex-direction: row;
text-align: left;
background: #fff;
padding: var(--spacing-3);
}
.howto-steps__item .howto-steps__num {
width: 40px;
height: 40px;
font-size: var(--font-size-md);
}
}

/* ---- 25-6. today-step フィーチャー：マスコット並びのバランス ---- */
.today-step-item--featured .today-step-item__featured-head {
gap: var(--spacing-2);
}
.today-step-item--featured .today-step-item__lead {
font-size: var(--font-size-md);
line-height: 1.45;
}

/* ---- 25-7. section 全般のモバイル余白を均す（セクション間の余白を確保） ---- */
@media (max-width: 600px) {
.section {
padding-top: var(--spacing-8);
padding-bottom: var(--spacing-8);
}
.section__title {
font-size: var(--font-size-xl);
line-height: 1.4;
}
.section__desc {
font-size: var(--font-size-sm);
line-height: 1.7;
}
}

/* ---- 25-8. 隣接セクションの境界を視覚的に区切る ---- */
.hero--front + .section { margin-top: 0; }
/* 同色背景が連続するときに境界が消えないよう、上に細い区切り */
.section + .section,
.hero--front + .section,
.section + .front-exit-cta {
position: relative;
}
/* 透明背景セクション直前の有色セクションに下シャドウで段差感 */
.section--peach,
.section--lavender,
.section--beige,
.section--primary-light,
.section--next-step {
box-shadow: inset 0 1px 0 rgba(255,255,255,0.6);
}

/* ============================================================
   Phase 29: 情報の見方クイズ（X風カード）
   ============================================================ */

.joho-feed-section {
  margin-top: 2rem;
}

ol.joho-feed {
  list-style: none;
  padding: 0;
  margin: 1.25rem 0 0;
  display: flex;
  flex-direction: column;
  gap: 1rem;
	list-style: none;
}

.joho-feed__item {
  margin: 0;
}

/* ---- X風カード本体 ---- */
.x-card {
  background: #fff;
  border: 1px solid #e2e2e2;
  border-radius: 16px;
  padding: 1.5rem 1rem 0.85rem;
  box-shadow: 0 1px 2px rgba(0,0,0,0.04);
  position: relative;
  overflow: hidden;
}

.x-card__head {
  display: flex;
  align-items: center;
  gap: 0.6rem;
  margin-bottom: 0.65rem;
}

.x-card__avatar {
  width: 40px;
  height: 40px;
  border-radius: 50%;
  flex-shrink: 0;
  background: #d8d8d8;
}

.x-card__meta {
  flex: 1;
  min-width: 0;
  line-height: 1.25;
}

p.x-card__name {
  font-weight: 600;
  font-size: 0.95rem;
  margin: 0;
  color: #333;
}

p.x-card__handle {
  margin: 0;
  font-size: 0.8rem;
  color: #777;
  word-break: break-all;
}

.x-card__badge {
	flex-shrink: 0;
	align-self: flex-start;
	background: #fff3e0;
	color: #c66a1a;
	border: 1px solid #f3c79a;
	border-radius: 999px;
	font-size: 0.7rem;
	padding: 0.15rem 0.6rem;
	font-weight: 600;
	letter-spacing: 0.04em;
}

/* ---- 本文 ---- */
.x-card__bodywrap {
  position: relative;
}

.x-card__body {
  font-size: 1rem;
  line-height: 1.7;
  color: #2a2a2a;
  margin: 0 0 0.75rem;
  white-space: pre-wrap;
  word-wrap: break-word;
}

/* ---- 画像メディア (Xの単一画像表示に合わせ 16:9 クロップ) ---- */
.x-card__media {
  position: relative;
  margin: 0.5rem 0 0;
  border-radius: 16px;
  overflow: hidden;
  border: 1px solid #e6e6e6;
  aspect-ratio: 16 / 9;
  background: #f4f4f4;
}

.x-card__media img {
  display: block;
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.x-card__pin {
  position: absolute;
  /* ピン先端（下） を座標位置に揃える */
  transform: translate(-50%, -100%);
  display: inline-flex;
  align-items: center;
  gap: 0.35rem;
  pointer-events: auto;
}

.x-card__pin-dot {
  width: 28px;
  height: 28px;
  /* マップピン形状: 上が円、左下が尖る */
  border-radius: 50% 50% 50% 0;
  transform: rotate(-45deg);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  color: #fff;
  background: #e07a30;
  box-shadow: 0 0 0 2px #fff, 0 2px 5px rgba(0,0,0,0.28);
}

.x-card__pin-num {
  /* 親の rotate を打ち消し、数字を水平表示 */
  display: inline-block;
  transform: rotate(45deg);
  font-size: 0.78rem;
  font-weight: 700;
  line-height: 1;
}

.x-card__pin.is-ok .x-card__pin-dot { background: #3a8a4a; }
.x-card__pin.is-check .x-card__pin-dot { background: #2f74b8; }
.x-card__pin.is-caution .x-card__pin-dot { background: #e07a30; }

.x-card__pin-tip {
  background: #fff;
  color: #333;
  font-size: 0.8rem;
  line-height: 1.35;
  padding: 0.35rem 0.55rem;
  border-radius: 8px;
  border: 1px solid #ddd;
  box-shadow: 0 2px 6px rgba(0,0,0,0.08);
  max-width: 180px;
}

/* ---- 画像なしのときのテキスト注釈リスト ---- */
.x-card__notes {
  list-style: none;
  padding: 0;
  margin: 0 0 0.85rem;
  display: flex;
  flex-direction: column;
  gap: 0.4rem;
}

.x-card__note {
  display: flex;
  align-items: flex-start;
  gap: 0.55rem;
  background: #fafafa;
  border: 1px solid #ececec;
  border-left: 4px solid #e07a30;
  border-radius: 10px;
  padding: 0.55rem 0.7rem;
  font-size: 0.88rem;
  line-height: 1.5;
}

.x-card__note.is-ok      { border-left-color: #3a8a4a; }
.x-card__note.is-check   { border-left-color: #2f74b8; }
.x-card__note.is-caution { border-left-color: #e07a30; }

.x-card__note-num {
  flex-shrink: 0;
  width: 22px;
  height: 22px;
  border-radius: 50%;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  background: #e07a30;
  color: #fff;
  font-size: 0.72rem;
  font-weight: 700;
}

.x-card__note.is-ok .x-card__note-num      { background: #3a8a4a; }
.x-card__note.is-check .x-card__note-num   { background: #2f74b8; }
.x-card__note.is-caution .x-card__note-num { background: #e07a30; }

.x-card__note-label { color: #333; }

/* ---- 3軸（いつ・誰が・どこ） ---- */
.x-card__axes {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 0.4rem;
  margin: 0.4rem 0 0.6rem;
  padding: 0;
}

.x-card__axis {
  margin: 0;
  background: #fafafa;
  border: 1px solid #ececec;
  border-radius: 10px;
  padding: 0.45rem 0.5rem;
  text-align: center;
}

.x-card__axis dt {
  font-size: 0.78rem;
  color: #666;
  font-weight: 600;
  margin: 0 0 0.2rem;
}

.x-card__axis dd {
  margin: 0;
  font-size: 0.7rem;
  color: #555;
  line-height: 1.3;
}

.x-card__axis-mark {
  display: inline-block;
  font-size: 1.05rem;
  font-weight: 700;
  margin-right: 0.25rem;
  vertical-align: -1px;
}

.x-card__axis.is-ok   { background: #eaf6ec; border-color: #c8e6cd; }
.x-card__axis.is-ok   .x-card__axis-mark { color: #2e7138; }
.x-card__axis.is-warn { background: #fff7e8; border-color: #f3dcad; }
.x-card__axis.is-warn .x-card__axis-mark { color: #c97e1a; }
.x-card__axis.is-ng   { background: #fbecec; border-color: #efc7c7; }
.x-card__axis.is-ng   .x-card__axis-mark { color: #b53030; }

/* ---- 詳細パネル ---- */
.x-card__details {
  margin-top: 0.4rem;
  border-top: 1px solid #efefef;
  padding-top: 0.55rem;
}

.x-card__summary {
  list-style: none;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: space-between;
  font-size: 0.92rem;
  font-weight: 600;
  color: #c66a1a;
  padding: 0.35rem 0.2rem;
  border-radius: 8px;
}

.x-card__summary::-webkit-details-marker { display: none; }
.x-card__summary:hover { background: #fff8ef; }

.x-card__summary-icon {
  display: inline-block;
  transition: transform 0.2s ease;
  font-size: 0.85rem;
}

.x-card__details[open] .x-card__summary-icon { transform: rotate(180deg); }

.x-card__answer {
  display: flex;
  flex-direction: column;
  gap: 0.7rem;
  padding: 0.6rem 0.2rem 0.2rem;
}

.x-card__safe,
.x-card__avoid {
  border-radius: 10px;
  padding: 0.65rem 0.8rem;
}

.x-card__safe {
  background: #eaf6ec;
  border: 1px solid #c8e6cd;
}

.x-card__avoid {
  background: #fbecec;
  border: 1px solid #efc7c7;
}

.x-card__safe-title,
.x-card__avoid-title {
  margin: 0 0 0.35rem;
  font-size: 0.9rem;
  font-weight: 700;
}

.x-card__safe-title  { color: #2e7138; }
.x-card__avoid-title { color: #b53030; }

.x-card__safe-list,
.x-card__avoid-list {
  margin: 0;
  padding-left: 1.15rem;
  font-size: 0.9rem;
  line-height: 1.55;
  color: #333;
}

.x-card__safe-list li,
.x-card__avoid-list li { margin-bottom: 0.2rem; }

.x-card__answer-link {
  margin: 0.2rem 0 0;
  font-size: 0.85rem;
  color: #555;
}

.x-card__answer-link a {
  color: #c66a1a;
  text-decoration: underline;
  text-underline-offset: 2px;
}

/* ---- レスポンシブ調整 ---- */
@media (max-width: 380px) {
  .x-card__axes { grid-template-columns: 1fr; }
  .x-card__pin-tip { max-width: 140px; font-size: 0.74rem; }
  .x-card__badge { font-size: 0.65rem; padding: 0.1rem 0.45rem; }
}

/* ============================================================
   Phase 29 修正: ピン浮き・トグル中身強化
   ============================================================ */

/* 画像なしカードでも本文の上にピンを浮かせる */
.x-card__pin--floating {
  position: absolute;
  z-index: 2;
  /* tipは表示せずドットだけ。labelはトグル内のpinguideで読める */
  pointer-events: auto;
}

.x-card__pin--floating .x-card__pin-tip {
  display: none;
}

.x-card__pin--floating .x-card__pin-dot {
  width: 30px;
  height: 30px;
  cursor: help;
}

.x-card__pin--floating .x-card__pin-num {
  font-size: 0.85rem;
}

/* 大画面では fly-out tip を表示 */
@media (min-width: 480px) {
  .x-card__pin--floating .x-card__pin-tip {
    display: inline-block;
    position: absolute;
    left: calc(100% + 0.4rem);
    top: 50%;
    transform: translateY(-50%);
    white-space: nowrap;
    max-width: 200px;
    overflow: hidden;
    text-overflow: ellipsis;
  }
}

/* ---- トグル内のピン解説 ---- */
.x-card__pinguide {
  background: #fff8ef;
  border: 1px solid #f3c79a;
  border-radius: 10px;
  padding: 0.65rem 0.8rem;
}

.x-card__pinguide-title {
  margin: 0 0 0.4rem;
  font-size: 0.9rem;
  font-weight: 700;
  color: #c66a1a;
}

.x-card__pinguide-list {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: 0.4rem;
}

.x-card__pinguide-item {
  display: flex;
  align-items: flex-start;
  gap: 0.5rem;
  font-size: 0.9rem;
  line-height: 1.45;
  color: #333;
}

.x-card__pinguide-num {
  flex-shrink: 0;
  width: 22px;
  height: 22px;
  border-radius: 50%;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  background: #e07a30;
  color: #fff;
  font-size: 0.72rem;
  font-weight: 700;
  margin-top: 0.1rem;
}

.x-card__pinguide-item.is-ok      .x-card__pinguide-num { background: #3a8a4a; }
.x-card__pinguide-item.is-check   .x-card__pinguide-num { background: #2f74b8; }
.x-card__pinguide-item.is-caution .x-card__pinguide-num { background: #e07a30; }

/* ---- 3軸（トグル内に移動後の見栄え調整） ---- */
.x-card__details .x-card__axes {
  margin-top: 0;
}

.x-card__axis dt {
  font-size: 0.82rem;
  font-weight: 700;
  color: #333;
}

.x-card__axis dd {
  font-size: 0.72rem;
  color: #555;
  margin-top: 0.1rem;
}

/* ---- 画像なしカードのダミーメディア領域 ---- */
.x-card__placeholder {
  position: relative;
  margin: 0.5rem 0 0.85rem;
  height: 200px;
  border-radius: 12px;
  border: 1px dashed #d3d3d3;
  background:
    repeating-linear-gradient(135deg, #f7f5f0 0 12px, #fffaf2 12px 24px);
}

.x-card__placeholder-label {
  position: absolute;
  top: 0.5rem;
  right: 0.6rem;
  font-size: 0.7rem;
  color: #999;
  background: rgba(255,255,255,0.85);
  padding: 0.1rem 0.45rem;
  border-radius: 999px;
  letter-spacing: 0.04em;
}

/* placeholder 内のピンは fly-out tip を表示 */
.x-card__placeholder .x-card__pin--floating .x-card__pin-tip {
  display: inline-block;
  position: absolute;
  top: 50%;
  left: calc(100% + 0.4rem);
  transform: translateY(-50%);
  white-space: nowrap;
  max-width: 160px;
  overflow: hidden;
  text-overflow: ellipsis;
}

/* x>50% のピンは tip を左側に出す */
.x-card__placeholder .x-card__pin--floating[style*="left: 5"] .x-card__pin-tip,
.x-card__placeholder .x-card__pin--floating[style*="left: 6"] .x-card__pin-tip,
.x-card__placeholder .x-card__pin--floating[style*="left: 7"] .x-card__pin-tip,
.x-card__placeholder .x-card__pin--floating[style*="left: 8"] .x-card__pin-tip,
.x-card__placeholder .x-card__pin--floating[style*="left: 9"] .x-card__pin-tip {
  left: auto;
  right: calc(100% + 0.4rem);
}

@media (max-width: 380px) {
  .x-card__placeholder { height: 170px; }
  .x-card__placeholder .x-card__pin--floating .x-card__pin-tip { display: none; }
}

/* ============================================================
   Phase 29 v3: 投稿全体ピンレイヤー / 番号別色 / 出現アニメ
   ============================================================ */

/* フィードを中央配置・横幅広く */
.joho-feed {
  max-width: 720px;
  margin: 0 auto;
  padding: 0;
  list-style: none;
}
.joho-feed__item {
  margin: 0 0 1rem;
}
.x-card {
  margin: 0 auto;
}

/* 投稿イメージラッパ (ヘッダ+本文+プレビュー) = ピンレイヤー基準 */
.x-card__post {
  position: relative;
}

/* 本文側の旧調整解除 */
.x-card__bodywrap { position: static; min-height: 0; }
.x-card__body { padding-right: 0; }

/* 添付プレビュー(ダミー) = 投稿の一部 (本文の下、トグルの上) — X同様の 16:9 */
.x-card__preview {
  position: relative;
  margin: 0.55rem 0 0;
  aspect-ratio: 16 / 9;
  border-radius: 16px;
  border: 1px dashed #d3d3d3;
  background: repeating-linear-gradient(135deg, #f7f5f0 0 12px, #fffaf2 12px 24px);
}
.x-card__preview-label {
  position: absolute;
  top: 0.5rem;
  right: 0.6rem;
  font-size: 0.7rem;
  color: #999;
  background: rgba(255,255,255,0.85);
  padding: 0.1rem 0.5rem;
  border-radius: 999px;
  letter-spacing: 0.04em;
}

/* ピンレイヤー: 投稿全体に被さる。展開前は非表示 */
.x-card__pin-layer {
  position: absolute;
  inset: 0;
  pointer-events: none;
  opacity: 0;
  visibility: hidden;
  transition: opacity 0.25s ease;
  z-index: 3;
}
.x-card:has(details[open]) .x-card__pin-layer,
.x-card.is-revealed .x-card__pin-layer {
  opacity: 1;
  visibility: visible;
}

/* 個別ピン: 出現アニメ (フェード+下から上スライド) */
.x-card__pin-layer .x-card__pin {
  opacity: 0;
  transform: translate(-50%, -70%);
  transition: opacity 0.45s ease, transform 0.45s ease;
  transition-delay: var(--pin-delay, 0s);
  pointer-events: auto;
}
.x-card:has(details[open]) .x-card__pin-layer .x-card__pin,
.x-card.is-revealed .x-card__pin-layer .x-card__pin {
  opacity: 1;
  transform: translate(-50%, -100%);
}

/* 番号別ピン色 (1=赤 / 2=青 / 3=緑 / 4=紫) */
.x-card__pin--n1 .x-card__pin-dot { background: #d94545; }
.x-card__pin--n2 .x-card__pin-dot { background: #2f74b8; }
.x-card__pin--n3 .x-card__pin-dot { background: #3a8a4a; }
.x-card__pin--n4 .x-card__pin-dot { background: #7a4dab; }

/* tip 常時表示 (スマホでも) */
.x-card__pin-layer .x-card__pin-tip {
  display: inline-block;
  position: absolute;
  left: calc(100% + 0.45rem);
  top: 50%;
  transform: translateY(-50%);
  white-space: normal;
  max-width: 160px;
  font-size: 0.74rem;
  line-height: 1.3;
  padding: 0.3rem 0.5rem;
  background: #fff;
  border: 1px solid #ddd;
  border-radius: 8px;
  box-shadow: 0 2px 6px rgba(0,0,0,0.1);
}

/* 右側ピン: tip を左に */
.x-card__pin-layer .x-card__pin[style*="left: 5"] .x-card__pin-tip,
.x-card__pin-layer .x-card__pin[style*="left: 6"] .x-card__pin-tip,
.x-card__pin-layer .x-card__pin[style*="left: 7"] .x-card__pin-tip,
.x-card__pin-layer .x-card__pin[style*="left: 8"] .x-card__pin-tip,
.x-card__pin-layer .x-card__pin[style*="left: 9"] .x-card__pin-tip {
  left: auto;
  right: calc(100% + 0.45rem);
}

@media (max-width: 480px) {
	.x-card__scenario-tab-badge,
	.x-card__summary-badge {
		padding: 0.32em 1em 0.22em 1em;
		font-size: 0.8em;
	}
}

/* スマホで tip がはみ出さないよう幅縮小 */
@media (max-width: 380px) {
  .x-card__pin-layer .x-card__pin-tip {
    max-width: 130px;
    font-size: 0.7rem;
  }
}
/* Phase 29 v3 補正: ol indentを潰してカードを広く + ヘッダ折返し抑制 */
.joho-feed { padding: 0 !important; padding-inline-start: 0 !important; }
.x-card { padding: 1.85rem 0.85rem 0.75rem; }
.x-card__head { flex-wrap: nowrap; }
.x-card__meta { min-width: 0; flex: 1 1 auto; }
.x-card__name {
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.x-card__handle {
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  font-size: 0.78rem;
}
.x-card__avatar { flex-shrink: 0; }
.x-card__badge { flex-shrink: 0; }
/* prefers-reduced-motion 配慮 */
@media (prefers-reduced-motion: reduce) {
  .x-card__pin-layer,
  .x-card__pin-layer .x-card__pin {
    transition: none !important;
  }
}
/* Phase 29 v4: tipは一言チップ、pinguideカラーを番号色に合わせ */
.x-card__pin-layer .x-card__pin-tip {
  white-space: nowrap;
  max-width: none;
  font-size: 0.7rem;
  font-weight: 600;
  padding: 0.15rem 0.45rem;
  background: rgba(255,255,255,0.95);
  border-radius: 999px;
  box-shadow: 0 1px 3px rgba(0,0,0,0.12);
}

/* tipの色を番号に合わせる */
.x-card__pin--n1 .x-card__pin-tip { color: #c33b3b; border-color: #f0c0c0; }
.x-card__pin--n2 .x-card__pin-tip { color: #2766a4; border-color: #c2d6ec; }
.x-card__pin--n3 .x-card__pin-tip { color: #2f7340; border-color: #c4dec9; }
.x-card__pin--n4 .x-card__pin-tip { color: #6a3f99; border-color: #d6c4e7; }

/* pinguide番号もピン番号色に */
.x-card__pinguide-item--n1 .x-card__pinguide-num { background: #d94545; }
.x-card__pinguide-item--n2 .x-card__pinguide-num { background: #2f74b8; }
.x-card__pinguide-item--n3 .x-card__pinguide-num { background: #3a8a4a; }
.x-card__pinguide-item--n4 .x-card__pinguide-num { background: #7a4dab; }


/* ============================
   そなえるリスト：関連タスクカード
   ============================ */
.sonaeru-related-task-list {
	display: flex;
	flex-direction: column;
	gap: 10px;
	list-style: none;
	margin: 0;
	padding: 0;
}
.sonaeru-related-task-item {
	background: var(--color-gray-50);
	border: 1.5px solid var(--color-gray-200);
	border-radius: 10px;
	box-shadow: none;
	padding: 12px 18px;
	font-size: 0.97rem;
	color: var(--color-text);
	display: flex;
	align-items: center;
	min-width: 120px;
	transition: box-shadow 0.2s, border-color 0.2s;
	text-decoration: none;
	font-weight: 500;
	cursor: pointer;
}
.sonaeru-related-task-item:hover {
	border-color: var(--color-primary);
	box-shadow: 0 2px 8px rgba(245,163,42,0.10);
	text-decoration: none;
}
.sonaeru-related-task-item a {
  color: var(--color-text);
  text-decoration: none;
  font-weight: 500;
}
.sonaeru-related-task-item:hover {
  box-shadow: 0 2px 8px rgba(245,163,42,0.15);
}