/*
Theme Name: Cocoon Child (Huiming)
Theme URI: https://wp-cocoon.com/
Description: Cocoon の子テーマ。Huiming トップページ（front-page.php）専用のダークデザインを実装。
Author: Huiming
Template: cocoon-master
Version: 1.0.0
*/

/* =========================================================
 * Huiming Design Tokens
 * ======================================================= */
.huiming-wrapper {
	--hm-bg:        #0F0F0F;
	--hm-bg-sec:    #151515;
	--hm-bg-card:   #181818;
	--hm-text:      #F5F5F5;
	--hm-sub:       #B3B3B3;
	--hm-border:    #333333;
	--hm-accent:    #E8D54A;
	--hm-maxw:      1200px;
	--hm-pad:       48px;
	--hm-sans:      'Noto Sans JP', sans-serif;
	--hm-latin:     'Helvetica Neue', Arial, 'Noto Sans JP', sans-serif;
}

/* =========================================================
 * Cocoon オーバーライド（フロントページ = body.home のみ）
 *  - 通常記事ページの Cocoon レイアウトには一切影響しない
 * ======================================================= */
.home #header-container,
.home #header,
.home .navi,
.home #navi,
.home .breadcrumb,
.home #breadcrumb,
.home #sidebar,
.home .sidebar,
.home #footer,
.home .footer,
.home .pagination,
.home .go-to-top {
	display: none !important;
}

.home #container,
.home #wrap,
.home #main,
.home #content,
.home .content,
.home .content-in,
.home .main {
	width: 100% !important;
	max-width: none !important;
	margin: 0 !important;
	padding: 0 !important;
	background: transparent !important;
	border: none !important;
	box-shadow: none !important;
	float: none !important;
	overflow: visible !important;
}

.home,
.home #body,
.home .body,
.home #container,
.home #wrap {
	background: var(--hm-bg) !important;
}

/* =========================================================
 * ベース
 * ======================================================= */
.huiming-wrapper,
.huiming-wrapper * {
	box-sizing: border-box;
}
.huiming-wrapper {
	background: var(--hm-bg);
	color: var(--hm-text);
	font-family: var(--hm-sans);
	font-size: 15px;
	line-height: 1.85;
	letter-spacing: .01em;
	-webkit-font-smoothing: antialiased;
}
.huiming-wrapper a {
	color: inherit;
	text-decoration: none;
}
.huiming-wrapper img {
	display: block;
	max-width: 100%;
	height: auto;
}
.huiming-wrapper ::selection {
	background: var(--hm-accent);
	color: #0F0F0F;
}

.huiming-container {
	max-width: var(--hm-maxw);
	margin: 0 auto;
	padding: 0 var(--hm-pad);
}

/* 見出し共通 */
.huiming-eyebrow {
	font-family: var(--hm-latin);
	font-size: 12px;
	font-weight: 700;
	letter-spacing: .22em;
	text-transform: uppercase;
	color: var(--hm-accent);
	margin: 0;
}
.huiming-h2 {
	font-size: 28px;
	font-weight: 700;
	letter-spacing: .02em;
	margin: 8px 0 0;
	color: var(--hm-text);
	line-height: 1.3;
}

/* バッジ */
.huiming-badge {
	display: inline-block;
	align-self: flex-start;
	width: fit-content;
	max-width: 100%;
	background: var(--hm-accent);
	color: #0F0F0F;
	font-size: 11px;
	font-weight: 700;
	letter-spacing: .04em;
	line-height: 1.5;
	padding: 3px 9px;
	border-radius: 3px;
	white-space: nowrap;
}

/* 日付 */
.huiming-date {
	display: inline-flex;
	align-items: center;
	gap: 7px;
	color: var(--hm-sub);
	font-size: 12px;
	font-family: var(--hm-latin);
	letter-spacing: .04em;
}
.huiming-date__icon {
	width: 13px;
	height: 13px;
	stroke: var(--hm-sub);
	fill: none;
	stroke-width: 1.6;
	flex: none;
}

/* 矢印リンク */
.huiming-wrapper .huiming-arrow {
	display: inline-flex;
	align-items: center;
	gap: 9px;
	font-size: 13px;
	font-weight: 700;
	color: var(--hm-accent);
	transition: gap .2s;
}
.huiming-arrow svg {
	width: 18px;
	height: 10px;
	stroke: currentColor;
	fill: none;
	stroke-width: 1.6;
}
.huiming-arrow:hover {
	gap: 14px;
}

/* サムネイル */
.huiming-thumb {
	display: block;
	position: relative;
	width: 100%;
	aspect-ratio: 16 / 10;
	overflow: hidden;
	background: var(--hm-bg-card);
}
.huiming-thumb__img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	transition: transform .4s ease, opacity .3s;
}
.huiming-card:hover .huiming-thumb__img {
	transform: scale(1.04);
}
.huiming-thumb__noimg {
	position: absolute;
	inset: 0;
	display: flex;
	align-items: center;
	justify-content: center;
	font-family: var(--hm-latin);
	font-size: 12px;
	letter-spacing: .18em;
	color: #5a5a5a;
	background:
		repeating-linear-gradient(45deg, #1d1d1d, #1d1d1d 7px, #191919 7px, #191919 14px);
}

/* カード地 */
.huiming-card {
	background: var(--hm-bg-card);
	border: 1px solid var(--hm-border);
	overflow: hidden;
	display: flex;
	flex-direction: column;
}
.huiming-empty {
	color: var(--hm-sub);
	margin-top: 28px;
}

/* =========================================================
 * セクションシェル
 * ======================================================= */
.huiming-section {
	padding: 88px 0;
}
.huiming-section--tint {
	background: var(--hm-bg-sec);
}

/* =========================================================
 * ヘッダー
 * ======================================================= */
.huiming-header {
	position: sticky;
	top: 0;
	z-index: 100;
	background: rgba(15, 15, 15, .92);
	backdrop-filter: blur(8px);
	-webkit-backdrop-filter: blur(8px);
	border-bottom: 1px solid var(--hm-border);
}
.huiming-header__inner {
	max-width: var(--hm-maxw);
	margin: 0 auto;
	padding: 0 var(--hm-pad);
	height: 72px;
	display: flex;
	align-items: center;
	gap: 40px;
}
.huiming-logo {
	font-family: var(--hm-latin);
	font-size: 24px;
	font-weight: 700;
	letter-spacing: .02em;
	color: var(--hm-text);
}
.huiming-nav {
	margin-left: auto;
	display: flex;
	align-items: center;
	gap: 32px;
}
.huiming-nav a {
	font-size: 14px;
	font-weight: 500;
	color: var(--hm-sub);
	white-space: nowrap;
	transition: color .18s;
}
.huiming-nav a:hover {
	color: var(--hm-text);
}
.huiming-search {
	display: flex;
	align-items: center;
	padding: 6px;
	color: var(--hm-text);
	background: none;
	border: none;
	cursor: pointer;
}
.huiming-search svg {
	width: 20px;
	height: 20px;
	stroke: currentColor;
	fill: none;
	stroke-width: 1.7;
}

/* =========================================================
 * ヘッダー検索バー（全ページ共通・色は他ページでも効くよう実値指定）
 * ======================================================= */
.huiming-search.is-open { color: #E8D54A; }
.huiming-searchbar {
	position: absolute;
	left: 0;
	right: 0;
	top: 72px;
	background: #151515;
	border-bottom: 1px solid #333333;
	overflow: hidden;
	max-height: 0;
	visibility: hidden;
	transition: max-height .28s ease, visibility .28s;
	z-index: 99;
}
.huiming-searchbar.is-open {
	max-height: 140px;
	visibility: visible;
}
.huiming-searchbar__form {
	max-width: 760px;
	margin: 0 auto;
	display: flex;
	align-items: center;
	gap: 0;
	padding: 16px 40px;
}
.huiming-searchbar__form svg {
	width: 18px;
	height: 18px;
	stroke: #B3B3B3;
	fill: none;
	stroke-width: 1.7;
	flex: none;
}
.huiming-searchbar__form input {
	flex: 1;
	min-width: 0;
	background: transparent;
	border: none;
	outline: none;
	color: #F5F5F5;
	font-family: 'Noto Sans JP', sans-serif;
	font-size: 15px;
	padding: 10px 14px;
}
.huiming-searchbar__form input::placeholder { color: #888888; }
.huiming-searchbar__form button {
	flex: none;
	border: none;
	cursor: pointer;
	background: #E8D54A;
	color: #0F0F0F;
	font-family: 'Noto Sans JP', sans-serif;
	font-size: 13px;
	font-weight: 700;
	border-radius: 100px;
	padding: 9px 22px;
}
.huiming-searchbar__form button:hover { filter: brightness(1.05); }
@media (max-width: 768px) {
	.huiming-searchbar__form { padding: 14px 22px; }
}
.huiming-burger {
	display: none;
	flex-direction: column;
	gap: 5px;
	background: none;
	border: none;
	cursor: pointer;
	padding: 8px;
	margin-left: auto;
}
.huiming-burger span {
	display: block;
	width: 22px;
	height: 1.6px;
	background: var(--hm-text);
	transition: transform .25s, opacity .25s;
}
.huiming-burger.is-open span:nth-child(1) { transform: translateY(6.6px) rotate(45deg); }
.huiming-burger.is-open span:nth-child(2) { opacity: 0; }
.huiming-burger.is-open span:nth-child(3) { transform: translateY(-6.6px) rotate(-45deg); }

/* =========================================================
 * ピックアップ
 * ======================================================= */
.huiming-pickup__grid {
	display: grid;
	grid-template-columns: 1.05fr 1fr;
	gap: 24px;
	margin-top: 36px;
	align-items: stretch;
}
.huiming-feature .huiming-thumb--feature {
	aspect-ratio: 16 / 10;
}
.huiming-feature__body {
	padding: 26px 28px 30px;
	display: flex;
	flex-direction: column;
	gap: 14px;
}
.huiming-feature__title {
	font-size: 30px;
	font-weight: 700;
	line-height: 1.32;
	letter-spacing: .01em;
	margin: 2px 0 0;
}
.huiming-feature__title a:hover { color: var(--hm-accent); }
.huiming-feature__excerpt {
	color: var(--hm-sub);
	font-size: 14px;
	line-height: 1.8;
	margin: 0;
}

.huiming-pickup__mini {
	display: grid;
	grid-template-columns: 1fr 1fr;
	grid-template-rows: 1fr 1fr;
	gap: 24px;
	height: 100%;
}
.huiming-pickup__mini .huiming-mini {
	height: 100%;
}
.huiming-mini .huiming-thumb--mini {
	aspect-ratio: 16 / 10;
}
.huiming-mini .huiming-badge {
	position: absolute;
	left: 12px;
	bottom: 12px;
	z-index: 2;
}
.huiming-mini__body {
	padding: 16px 16px 18px;
	display: flex;
	flex-direction: column;
	gap: 12px;
}
.huiming-mini__title {
	font-size: 16px;
	font-weight: 700;
	line-height: 1.5;
	margin: 0;
}
.huiming-mini__title a:hover { color: var(--hm-accent); }

/* =========================================================
 * 最新記事
 * ======================================================= */
.huiming-latest__head {
	display: flex;
	align-items: flex-end;
	justify-content: space-between;
	gap: 20px;
}
.huiming-latest__grid {
	display: grid;
	grid-template-columns: repeat(5, 1fr);
	gap: 24px;
	margin-top: 36px;
}
.huiming-post .huiming-thumb {
	aspect-ratio: 16 / 11;
}
.huiming-post__body {
	padding: 16px 16px 18px;
	display: flex;
	flex-direction: column;
	gap: 11px;
}
.huiming-post__body .huiming-badge {
	align-self: flex-start;
}
.huiming-post__title {
	font-size: 16px;
	font-weight: 700;
	line-height: 1.5;
	margin: 0;
}
.huiming-post__title a:hover { color: var(--hm-accent); }
.huiming-post__excerpt {
	color: var(--hm-sub);
	font-size: 13px;
	line-height: 1.75;
	margin: 0;
}

/* =========================================================
 * カテゴリー一覧
 * ======================================================= */
.huiming-category__grid {
	display: grid;
	grid-template-columns: repeat(5, 1fr);
	gap: 24px;
	margin-top: 36px;
}
.huiming-cat-card {
	border: 1px solid var(--hm-border);
	background: transparent;
	padding: 30px 22px 26px;
	display: flex;
	flex-direction: column;
	align-items: center;
	color: inherit;
	text-decoration: none;
	transition: border-color .2s, background .2s, transform .2s;
}
.huiming-cat-card:hover {
	border-color: #4a4a4a;
	background: var(--hm-bg-card);
	transform: translateY(-3px);
}
.huiming-cat-card:hover .huiming-cat-card__title { color: var(--hm-accent); }
.huiming-cat-card:hover .huiming-arrow { gap: 14px; }
.huiming-cat-card__icon {
	width: 46px;
	height: 46px;
	color: var(--hm-text);
	margin-bottom: 16px;
}
/* 画像アイコン（images/cat-*.jpg を入れた場合） */
.huiming-cat-card__icon--img {
	width: 72px;
	height: 72px;
	border-radius: 50%;
	overflow: hidden;
	background: var(--hm-bg-sec);
	margin-bottom: 18px;
}
.huiming-cat-card__icon--img img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	display: block;
}
.huiming-cat-card__icon svg {
	width: 100%;
	height: 100%;
	stroke: currentColor;
	fill: none;
	stroke-width: 1.4;
	stroke-linecap: round;
	stroke-linejoin: round;
}
.huiming-cat-card__title {
	font-size: 17px;
	font-weight: 700;
	text-align: center;
	margin: 0 0 20px;
}
.huiming-cat-card__list {
	list-style: none;
	width: 100%;
	margin: 0 0 24px;
	padding: 0;
	flex: 1;
}
.huiming-cat-card__empty {
	width: 100%;
	flex: 1;
	display: flex;
	align-items: center;
	justify-content: center;
	text-align: center;
	font-size: 12.5px;
	color: var(--hm-sub);
	margin: 0 0 24px;
	padding: 14px 0;
}
.huiming-cat-card__list li {
	position: relative;
	font-size: 12.5px;
	color: var(--hm-sub);
	line-height: 1.6;
	padding: 5px 0 5px 16px;
}
.huiming-cat-card__list li::before {
	content: "";
	position: absolute;
	left: 2px;
	top: 13px;
	width: 4px;
	height: 4px;
	border-radius: 50%;
	background: var(--hm-sub);
}
.huiming-cat-card .huiming-arrow {
	align-self: flex-start;
	font-size: 12.5px;
}

/* =========================================================
 * プロフィール
 * ======================================================= */
.huiming-profile__body {
	display: flex;
	gap: 44px;
	align-items: center;
	margin-top: 36px;
}
.huiming-profile__avatar {
	flex: none;
	width: 148px;
	height: 148px;
	border-radius: 50%;
	object-fit: cover;
	background: var(--hm-bg-card);
}
.huiming-profile__avatar--empty {
	display: flex;
	align-items: center;
	justify-content: center;
	font-family: var(--hm-latin);
	font-size: 12px;
	letter-spacing: .18em;
	color: #5a5a5a;
	border: 1px solid var(--hm-border);
}
.huiming-profile__name {
	font-family: var(--hm-latin);
	font-size: 26px;
	font-weight: 700;
	letter-spacing: .02em;
	margin: 0 0 14px;
}
.huiming-profile__text p {
	color: var(--hm-sub);
	font-size: 14px;
	line-height: 1.95;
	max-width: 640px;
	margin: 0 0 22px;
}
.huiming-socials {
	display: flex;
	gap: 18px;
}
.huiming-socials a {
	width: 22px;
	height: 22px;
	color: var(--hm-text);
	opacity: .92;
	transition: opacity .18s, color .18s;
}
.huiming-socials a:hover {
	opacity: 1;
	color: var(--hm-accent);
}
.huiming-socials svg {
	width: 100%;
	height: 100%;
	fill: currentColor;
}

/* =========================================================
 * フッター
 * ======================================================= */
.huiming-footer {
	background: var(--hm-bg);
	border-top: 1px solid var(--hm-border);
	padding: 64px 0 32px;
}
.huiming-footer__grid {
	display: grid;
	grid-template-columns: 1.6fr 1fr 1fr 1.2fr;
	gap: 40px;
}
.huiming-footer__brand .huiming-logo {
	display: inline-block;
	margin-bottom: 18px;
}
.huiming-footer__brand p {
	color: var(--hm-sub);
	font-size: 13px;
	line-height: 1.85;
	max-width: 280px;
	margin: 0;
}
.huiming-footer__col h5 {
	font-family: var(--hm-latin);
	font-size: 12px;
	font-weight: 700;
	letter-spacing: .18em;
	text-transform: uppercase;
	color: var(--hm-text);
	margin: 0 0 20px;
}
.huiming-footer__col ul {
	list-style: none;
	margin: 0;
	padding: 0;
	display: flex;
	flex-direction: column;
	gap: 11px;
}
.huiming-footer__col ul li a {
	font-size: 13px;
	color: var(--hm-sub);
	transition: color .18s;
}
.huiming-footer__col ul li a:hover {
	color: var(--hm-text);
}
.huiming-footer__copy {
	text-align: center;
	color: var(--hm-sub);
	font-size: 12px;
	font-family: var(--hm-latin);
	letter-spacing: .04em;
	margin: 56px 0 0;
	padding-top: 30px;
	border-top: 1px solid var(--hm-border);
}

/* =========================================================
 * レスポンシブ
 * ======================================================= */
@media (max-width: 1000px) {
	.huiming-wrapper { --hm-pad: 32px; }
	.huiming-latest__grid { grid-template-columns: repeat(3, 1fr); }
	.huiming-category__grid { grid-template-columns: repeat(3, 1fr); }
}

@media (max-width: 768px) {
	.huiming-wrapper { --hm-pad: 22px; }
	.huiming-section { padding: 60px 0; }
	.huiming-h2 { font-size: 22px; }

	/* ヘッダー: ドロワー */
	.huiming-search { display: none; }
	.huiming-burger { display: flex; }
	.huiming-nav {
		position: absolute;
		top: 72px;
		left: 0;
		right: 0;
		flex-direction: column;
		align-items: stretch;
		gap: 0;
		background: var(--hm-bg-sec);
		border-bottom: 1px solid var(--hm-border);
		max-height: 0;
		overflow: hidden;
		transition: max-height .3s ease;
	}
	.huiming-nav.is-open {
		max-height: 360px;
	}
	.huiming-nav a {
		padding: 15px var(--hm-pad);
		border-top: 1px solid var(--hm-border);
		font-size: 15px;
		color: var(--hm-text);
	}

	/* ピックアップ */
	.huiming-pickup__grid { grid-template-columns: 1fr; }
	.huiming-feature__title { font-size: 23px; }

	/* グリッド */
	.huiming-latest__grid { grid-template-columns: repeat(2, 1fr); }
	.huiming-category__grid { grid-template-columns: 1fr; }

	/* プロフィール */
	.huiming-profile__body {
		flex-direction: column;
		align-items: center;
		text-align: center;
		gap: 24px;
	}
	.huiming-profile__text p { margin-left: auto; margin-right: auto; }
	.huiming-socials { justify-content: center; }

	/* フッター */
	.huiming-footer__grid { grid-template-columns: 1fr 1fr; gap: 36px; }
	.huiming-footer__brand { grid-column: 1 / -1; }
}

@media (max-width: 480px) {
	.huiming-pickup__mini { grid-template-columns: 1fr; }
	.huiming-latest__grid { grid-template-columns: 1fr; }
	.huiming-footer__grid { grid-template-columns: 1fr; }
}
