@charset "UTF-8";
/* ==========================================================================
   04-sections.css (v2)
   セクション共通 + Categories 6カードグリッド + Stats(数字で見る)
   + CTA banner（角丸濃青グラデ）
   ========================================================================== */

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

.l-container {
	max-width: var(--mishima-container-max);
	margin-inline: auto;
	padding-inline: var(--mishima-gutter);
}

.p-mishimaSection {
	padding-block: clamp(2rem, 4vw, 3.5rem);  /* 上下スペースを半減 */
}

.p-mishimaSection__inner {
	max-width: var(--mishima-container-max);
	margin-inline: auto;
	padding-inline: var(--mishima-gutter);
}

.p-mishimaSection.-bg-cream { background: var(--mishima-color-cream); }
.p-mishimaSection.-bg-alt   { background: var(--mishima-color-bg-alt); }
.p-mishimaSection.-bg-pale  { background: var(--mishima-color-blue-pale); }

/* セクションヘッダ:  ── PICKUP / 編集部おすすめ記事 / description --- */
.p-mishimaSecHead {
	margin-bottom: clamp(2rem, 5vw, 4rem);
	max-width: 720px;
}

.p-mishimaSecHead.-center {
	text-align: center;
	margin-inline: auto;
}

.p-mishimaSecHead__sub {
	display: inline-flex;
	align-items: center;
	gap: 0.6em;
	font-family: var(--mishima-font-en);
	font-size: var(--mishima-fz-xs);
	font-weight: 500;
	color: var(--mishima-color-blue);
	letter-spacing: var(--mishima-ls-wide);
	text-transform: uppercase;
	margin-bottom: var(--mishima-space-s);
}

.p-mishimaSecHead__sub::before {
	content: "";
	width: 24px;
	height: 1px;
	background: var(--mishima-color-blue);
}

.p-mishimaSecHead.-center .p-mishimaSecHead__sub {
	justify-content: center;
}

.p-mishimaSecHead__title {
	font-family: var(--mishima-font-jp);
	font-weight: 700;
	font-size: clamp(1.75rem, 4vw, 2.5rem);
	line-height: 1.3;
	letter-spacing: 0.04em;
	color: var(--mishima-color-text);
	margin: 0 0 var(--mishima-space-s);
}

.p-mishimaSecHead__desc {
	font-size: var(--mishima-fz-base);
	line-height: var(--mishima-lh-loose);
	color: var(--mishima-color-text-sub);
	margin: 0;
	max-width: 36em;
}

.p-mishimaSecHead.-center .p-mishimaSecHead__desc {
	margin-inline: auto;
}

/* セクション末尾の読了リンク */
.p-mishimaMoreLink {
	display: inline-flex;
	align-items: center;
	gap: 0.5em;
	color: var(--mishima-color-blue);
	font-family: var(--mishima-font-jp);
	font-weight: 500;
	font-size: var(--mishima-fz-s);
	text-decoration: none;
	padding-bottom: 0.3em;
	border-bottom: 1px solid var(--mishima-color-blue);
	transition: gap var(--mishima-dur-base) var(--mishima-ease);
}

.p-mishimaMoreLink::after { content: "→"; font-family: var(--mishima-font-en); }
.p-mishimaMoreLink:hover { gap: 0.9em; color: var(--mishima-color-navy); }

.p-mishimaSectionFoot {
	margin-top: clamp(2rem, 4vw, 3rem);
	text-align: center;
}

/* ==========================================================================
   Categories セクション (6カード横並び)
   ========================================================================== */

.p-mishimaCatGrid {
	display: grid;
	grid-template-columns: repeat(2, 1fr);
	gap: var(--mishima-space-s);
}

.p-mishimaCatCard {
	display: flex;
	flex-direction: column;
	align-items: center;
	justify-content: center;
	gap: var(--mishima-space-xs);
	padding: var(--mishima-space-m) var(--mishima-space-s);
	background: var(--mishima-color-bg);
	border: 1px solid var(--mishima-color-border-thin);
	border-radius: var(--mishima-radius-m);
	color: var(--mishima-color-text);
	text-decoration: none;
	transition: transform var(--mishima-dur-base) var(--mishima-ease),
	            box-shadow var(--mishima-dur-base) var(--mishima-ease),
	            border-color var(--mishima-dur-base) var(--mishima-ease);
	min-height: 140px;
}

.p-mishimaCatCard:hover {
	transform: translateY(-3px);
	box-shadow: var(--mishima-shadow-m);
	border-color: var(--mishima-color-blue);
	color: var(--mishima-color-blue);
}

.p-mishimaCatCard__iconWrap {
	width: 48px;
	height: 48px;
	display: flex;
	align-items: center;
	justify-content: center;
	border-radius: var(--mishima-radius-m);
	background: var(--mishima-color-blue-pale);
	color: var(--mishima-color-blue);
}

.p-mishimaCatCard__icon {
	width: 28px;
	height: 28px;
	stroke: currentColor;
	stroke-width: 1.6;
	fill: none;
}

.p-mishimaCatCard__name {
	font-family: var(--mishima-font-jp);
	font-weight: 700;
	font-size: var(--mishima-fz-base);
	letter-spacing: 0.06em;
	margin: 0;
}

.p-mishimaCatCard__en {
	font-family: var(--mishima-font-en);
	font-size: var(--mishima-fz-2xs);
	font-weight: 500;
	color: var(--mishima-color-text-mute);
	letter-spacing: var(--mishima-ls-wide);
	text-transform: uppercase;
}

@media (min-width: 600px) {
	.p-mishimaCatGrid {
		grid-template-columns: repeat(3, 1fr);
		gap: var(--mishima-space-m);
	}
	.p-mishimaCatCard { min-height: 160px; }
}

@media (min-width: 1024px) {
	.p-mishimaCatGrid {
		grid-template-columns: repeat(6, 1fr);
	}
}

/* ==========================================================================
   MISHIMA BY NUMBERS セクション (4 stats)
   ========================================================================== */

.p-mishimaStatsGrid {
	display: grid;
	grid-template-columns: repeat(2, 1fr);
	gap: 0;
	margin-top: clamp(2rem, 5vw, 4rem);
}

.p-mishimaStat {
	padding: var(--mishima-space-m) var(--mishima-space-s);
	border-bottom: 1px solid var(--mishima-color-border-thin);
}

.p-mishimaStat:nth-child(odd) {
	border-right: 1px solid var(--mishima-color-border-thin);
}

.p-mishimaStat__label {
	font-family: var(--mishima-font-en);
	font-size: var(--mishima-fz-xs);
	font-weight: 600;
	color: var(--mishima-color-blue);
	letter-spacing: var(--mishima-ls-wide);
	text-transform: uppercase;
	margin-bottom: var(--mishima-space-s);
}

.p-mishimaStat__num {
	display: flex;
	align-items: baseline;
	gap: 0.1em;
	font-family: var(--mishima-font-jp);
	font-weight: 700;
	color: var(--mishima-color-text);
	letter-spacing: -0.02em;
	line-height: 1;
}

.p-mishimaStat__value {
	font-size: var(--mishima-fz-stat);
}

.p-mishimaStat__unit {
	font-size: clamp(1.25rem, 3vw, 2rem);
	color: var(--mishima-color-text);
}

.p-mishimaStat__caption {
	margin-top: var(--mishima-space-s);
	font-size: var(--mishima-fz-s);
	color: var(--mishima-color-text-sub);
	font-weight: 600;
}

.p-mishimaStat__detail {
	margin-top: 0.6em;
	font-size: 12px;
	line-height: 1.7;
	color: var(--pal-ink-2);
	max-width: 22em;
}

/* Stats label を日本語可読サイズに */
.p-mishimaStat__label {
	font-family: var(--mishima-font-jp) !important;
	font-size: 13px;
	font-weight: 600;
	color: var(--pal-accent-2);
	letter-spacing: 0.06em;
	margin-bottom: var(--mishima-space-s);
	text-transform: none;
}

@media (min-width: 860px) {
	.p-mishimaStatsGrid {
		grid-template-columns: repeat(4, 1fr);
	}
	.p-mishimaStat {
		padding: var(--mishima-space-m) var(--mishima-space-m);
		border-bottom: none;
		border-right: 1px solid var(--mishima-color-border-thin);
	}
	.p-mishimaStat:nth-child(odd) {
		border-right: 1px solid var(--mishima-color-border-thin);
	}
	.p-mishimaStat:last-child {
		border-right: none;
	}
}

/* ==========================================================================
   CTA Banner (フッター前の角丸濃青カード)
   ========================================================================== */

.p-mishimaCta {
	background: var(--mishima-grad-cta);
	color: var(--mishima-color-text-invert);
	border-radius: var(--mishima-radius-xl);
	padding: clamp(2rem, 5vw, 3.5rem) clamp(1.5rem, 4vw, 3rem);
	margin: clamp(3rem, 6vw, 5rem) 0;
	display: grid;
	grid-template-columns: 1fr;
	gap: var(--mishima-space-m);
	align-items: center;
	box-shadow: var(--mishima-shadow-m);
	max-width: var(--mishima-container-max);
	margin-inline: auto;
}

.p-mishimaCta__sub {
	display: inline-flex;
	align-items: center;
	gap: 0.6em;
	font-family: var(--mishima-font-en);
	font-size: var(--mishima-fz-xs);
	font-weight: 500;
	letter-spacing: var(--mishima-ls-wide);
	text-transform: uppercase;
	color: rgba(255, 255, 255, 0.85);
	margin-bottom: var(--mishima-space-s);
}

.p-mishimaCta__sub::before {
	content: "";
	width: 24px;
	height: 1px;
	background: rgba(255, 255, 255, 0.6);
}

/* SWELLの '.post_content h2' (specificity 0,1,1) を上書き (0,2,1) して
   CTAタイトルの背景・パディング・::before 境界線を消し、白文字でくっきり表示 */
.p-mishimaCta h2.p-mishimaCta__title {
	background: transparent;
	padding: 0;
	border: none;
	font-family: var(--mishima-font-jp);
	font-weight: 800;
	font-size: clamp(1.5rem, 4vw, 2.25rem);
	line-height: 1.3;
	letter-spacing: 0.02em;
	margin: 0 0 var(--mishima-space-s);
	color: #ffffff;
}

.p-mishimaCta h2.p-mishimaCta__title::before {
	content: none;
	display: none;
	border: none;
	background: none;
}

.p-mishimaCta__desc {
	font-size: var(--mishima-fz-s);
	line-height: var(--mishima-lh-loose);
	color: rgba(255, 255, 255, 0.95);  /* 視認性UP */
	margin: 0 0 var(--mishima-space-m);
	max-width: 32em;
}

.p-mishimaCta__btnWrap {
	display: flex;
	flex-direction: column;
	gap: var(--mishima-space-xs);
}

.p-mishimaCta__btn {
	display: inline-flex;
	align-items: center;
	justify-content: space-between;
	gap: 0.5em;
	padding: 1em 1.6em;
	background: #ffffff;                              /* 白くて明確 */
	color: var(--pal-ink);                            /* 濃いnavyテキスト */
	font-family: var(--mishima-font-jp);
	font-weight: 800;
	font-size: var(--mishima-fz-base);
	text-decoration: none;
	border-radius: var(--mishima-radius-pill);
	box-shadow: 0 4px 16px rgba(0, 0, 0, 0.18);       /* 影で浮き上がり */
	transition: transform var(--mishima-dur-base) var(--mishima-ease),
	            box-shadow var(--mishima-dur-base) var(--mishima-ease);
	min-width: 240px;
}

.p-mishimaCta__btn:hover {
	transform: translateY(-2px);
	box-shadow: 0 8px 24px rgba(0, 0, 0, 0.24);
	color: var(--pal-accent-2);
}

.p-mishimaCta__btn::after {
	content: "→";
	font-family: var(--mishima-font-en);
	color: var(--mishima-color-blue);
	font-weight: 700;
}

.p-mishimaCta__btn:hover {
	transform: translateY(-2px);
	color: var(--mishima-color-navy);
}

.p-mishimaCta__note {
	font-size: var(--mishima-fz-xs);
	color: rgba(255, 255, 255, 0.85);  /* 視認性UP */
	font-weight: 500;
}

@media (min-width: 860px) {
	.p-mishimaCta {
		grid-template-columns: 1.5fr 1fr;
		gap: var(--mishima-space-l);
	}
	.p-mishimaCta__btnWrap {
		align-items: stretch;
	}
}

/* ==========================================================================
   旧クラスの互換維持 (template-home.html v1 のクラスが残っている場合に備える)
   ========================================================================== */
.p-mishimaSecTitle {
	display: flex;
	flex-direction: column;
	align-items: center;
	text-align: center;
	gap: 0.4em;
	margin: 0 0 var(--mishima-space-l);
}
.p-mishimaSecTitle__en  { font-family: var(--mishima-font-en); font-size: var(--mishima-fz-l); color: var(--mishima-color-blue); letter-spacing: var(--mishima-ls-wide); text-transform: uppercase; }
.p-mishimaSecTitle__jp  { font-family: var(--mishima-font-jp); font-weight: 700; font-size: clamp(1.5rem, 4vw, 2.25rem); color: var(--mishima-color-text); }
.p-mishimaSecTitle__desc{ font-size: var(--mishima-fz-s); color: var(--mishima-color-text-sub); }


/* ==========================================================================
   新スペック: 共通セクション (.sec / .wrap) + セクション見出し (.sec-hd)
   ========================================================================== */

.sec {
	padding-block: clamp(1.5rem, 3vw, 2.5rem);  /* さらに縮小 */
}

.wrap {
	max-width: 1280px;
	margin-inline: auto;
	padding-inline: clamp(1rem, 4vw, 2rem);
}

.sec-hd {
	margin-bottom: clamp(2rem, 5vw, 4rem);
	max-width: 720px;
}

.sec-hd--center {
	text-align: center;
	margin-inline: auto;
}

/* シンプル化: 横線装飾を削除、シンプルな英字ラベルだけに */
.sec-hd__eyebrow {
	display: inline-block;
	font-family: "Plus Jakarta Sans", sans-serif;
	font-size: 11px;
	font-weight: 600;
	letter-spacing: 0.18em;
	text-transform: uppercase;
	color: var(--pal-accent-2);
	margin-bottom: 8px;
}

/* SWELLの '.post_content h2{ background, color:white, padding, ::before }' を上書き
   セレクタ強化 (specificity 0,2,1) でSWELLに勝つ */
.sec-hd h2.sec-hd__title {
	background: transparent;
	padding: 0;
	border: none;
	color: var(--pal-ink);
	font-family: var(--mishima-font-jp);
	font-size: clamp(28px, 4vw, 40px);
	font-weight: 800;
	line-height: 1.3;
	letter-spacing: -0.02em;
	margin: 0 0 12px;
}

.sec-hd h2.sec-hd__title::before {
	content: none;
	display: none;
	border: none;
	background: none;
}

.sec-hd__sub {
	font-size: 16px;
	line-height: 1.85;
	color: var(--pal-ink-2);
	margin: 0;
}


/* ==========================================================================
   新スペック: Categories chips (.cats / .cat-chip)
   ========================================================================== */

.cats {
	display: grid;
	grid-template-columns: repeat(2, 1fr);   /* mobile-first: 2列 */
	gap: 12px;
}

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

@media (min-width: 1024px) {
	.cats { grid-template-columns: repeat(6, 1fr); gap: 12px; }
}

.cat-chip {
	display: flex;
	flex-direction: column;
	align-items: center;
	gap: 14px;
	padding: 28px 16px 24px;
	background: var(--pal-surface);
	border: 1px solid var(--pal-line);
	border-radius: 16px;
	text-align: center;
	text-decoration: none;
	color: inherit;
	transition: transform 220ms ease, box-shadow 220ms ease;
}

.cat-chip:hover {
	transform: translateY(-3px);
	box-shadow: 0 12px 28px rgba(27, 36, 32, 0.08);
}

.cat-chip__icon {
	width: 48px;
	height: 48px;
	border-radius: 12px;
	background: var(--pal-accent-soft);
	display: flex;
	align-items: center;
	justify-content: center;
	color: var(--pal-accent-2);
	transition: background 220ms ease, color 220ms ease;
}

.cat-chip:hover .cat-chip__icon {
	background: var(--pal-accent);
	color: #ffffff;
}

.cat-chip__icon svg {
	width: 26px;
	height: 26px;
}

.cat-chip__label {
	font-size: 14px;
	font-weight: 700;
	color: var(--pal-ink);
	letter-spacing: 0.02em;
	margin-bottom: 2px;
}

.cat-chip__en {
	font-family: "Plus Jakarta Sans", sans-serif;
	font-size: 10px;
	letter-spacing: 0.16em;
	color: var(--pal-ink-3);
	text-transform: uppercase;
	font-weight: 600;
}
