/*
Theme Name:   a-no-ne-2025
Theme URI:    https://hirohonshuku.com
Description:  Child theme of Twenty Twenty-Five for HiroHonshuku.com
Author:       Hiroaki Honshuku
Author URI:   https://hirohonshuku.com
Template:     twentytwentyfive
Version:      1.0.1
Text Domain:  a-no-ne-2025
*/

/* ============================================================
   DESIGN TOKENS
   ============================================================
   Nav/Dark   : #1e2433
   Background : #f9f7f4
   Text       : #232323
   Muted      : #6b6b6b
   Border     : #ebe7e0

   Jazz Theory : #1a5c3a
   Music       : #8a3020
   Computer    : #4a2d7a
   Drawings    : #b07820
   Blog        : #c04040
   ============================================================ */

/* ── Override WordPress global styles (theme.json cache workaround) ── */
:root {
	--wp--preset--color--background: #203a51 !important;
}

/* ── Base ── */
html {
	background-color: #1e2433 !important; /* フッターと同色 — フッター下の隙間をなくす */
}
body {
	background-color: #203a51 !important;
	color: #d8d4cc;
	font-family: 'Nunito', sans-serif;
	font-weight: 400;
	line-height: 1.65;
	/* Sticky footer: bodyがビューポートを満たすことでフッター下に隙間を作らない */
	display: flex;
	flex-direction: column;
	min-height: 100vh;
}
#site-main { flex: 1 0 auto; }
.hh-site-footer { flex-shrink: 0; }

/* ── Typography ── */
h1, h2, h3, h4, h5, h6 {
	font-family: 'Playfair Display', Georgia, serif;
	font-weight: 400;
	line-height: 1.25;
	color: #1e2433;
}

/* Japanese content */
:lang(ja) h1,
:lang(ja) h2,
:lang(ja) h3,
:lang(ja) h4 {
	font-family: 'Noto Serif JP', serif;
}

:lang(ja) body,
:lang(ja) p,
:lang(ja) li,
:lang(ja) .entry-content {
	font-family: 'Noto Sans JP', sans-serif;
	font-weight: 300;
	line-height: 1.9;
}

p, li {
	font-family: 'Nunito', sans-serif;
	font-size: 1rem;
	font-weight: 400;
}

a {
	color: #1e2433;
	text-decoration: none;
}

a:hover {
	color: #1a5c3a;
}

/* ── Site Header ── */
.hh-site-header {
	background: #1e2433;
	position: sticky;
	top: 0;
	z-index: 100;
	border-bottom: 1px solid rgba(255, 255, 255, 0.07);
}

.hh-header-inner {
	display: flex;
	align-items: center;
	gap: 20px;
	padding: 0 max(20px, calc((100% - 1360px) / 2 + 20px));
	height: 60px;
}

/* Logo */
.hh-logo-link {
	display: flex;
	align-items: center;
	gap: 8px;
	text-decoration: none;
	flex-shrink: 0;
}

.anone-logo-img {
	width: 36px;
	height: 36px;
	display: block;
	flex-shrink: 0;
}

/* Legacy text fallback (unused if image loads) */
.anone-logo-mark {
	font-family: 'Noto Serif JP', serif;
	font-size: 1.4rem;
	color: #f9f7f4;
	line-height: 1;
}

.hh-logo-wordmark {
	display: flex;
	flex-direction: column;
	line-height: 1;
}

.hh-logo-name {
	font-family: 'Playfair Display', serif;
	font-weight: 400;
	font-size: 0.95rem;
	color: rgba(255, 255, 255, 0.88);
	letter-spacing: 0.02em;
}

.hh-logo-sub {
	font-family: 'Nunito', -apple-system, BlinkMacSystemFont, sans-serif;
	font-size: 0.72rem;
	font-weight: 300;
	color: rgba(255, 255, 255, 0.55);
	letter-spacing: 0.06em;
	text-transform: uppercase;
	margin-top: 2px;
}

/* Social media icons */
.hh-social-links {
	display: flex;
	align-items: center;
	gap: 4px;
	margin-left: auto;
}

.hh-social-link {
	display: flex;
	align-items: center;
	justify-content: center;
	width: 32px;
	height: 32px;
	color: rgba(255, 255, 255, 0.55);
	border-radius: 50%;
	transition: color 0.15s, background 0.15s;
}

.hh-social-link:hover {
	color: #fff;
	background: rgba(255, 255, 255, 0.1);
}

/* Primary nav */
.hh-primary-nav {
	flex: 1;
}

/* Standalone nav bar (below hero) — top is set dynamically by nav-bar.php JS */
.hh-nav-bar {
	background: #1e2433;
	border-bottom: 1px solid rgba(255,255,255,0.07);
	padding: 0 max(20px, calc((100% - 1360px) / 2 + 20px));
	flex: unset;
	position: sticky;
	top: 60px; /* fallback; overridden by JS when hero is present */
	z-index: 499;
	display: flex;
	align-items: center;
}

.hh-nav-list {
	display: flex;
	align-items: center;
	gap: 0;
	list-style: none;
	margin: 0;
	padding: 0;
}

.hh-nav-list > li > a {
	display: block;
	font-family: 'Nunito', sans-serif;
	font-size: 0.88rem;
	font-weight: 700;
	color: rgba(255, 255, 255, 0.65);
	letter-spacing: 0.01em;
	text-transform: none;
	padding: 6px 10px;
	text-decoration: none;
	transition: color 0.15s;
}

.hh-nav-list > li > a:hover {
	color: #fff;
}

/* Search toggle in nav */
.hh-nav-search-item > button {
	display: flex;
	align-items: center;
	justify-content: center;
	background: none;
	border: none;
	cursor: pointer;
	color: rgba(255,255,255,0.65);
	padding: 0 14px;
	height: 44px;
	transition: color 0.15s;
}
.hh-nav-search-item > button:hover { color: #fff; }

/* Search slide-down bar */
.hh-search-bar {
	background: #162030;
	border-top: 1px solid rgba(255,255,255,0.07);
	padding: 10px max(20px, calc((100% - 1360px) / 2 + 20px));
	display: none;
}
.hh-search-bar.hh-search-bar--open { display: block; }

.hh-search-form {
	display: flex;
	gap: 0;
	max-width: 560px;
}

.hh-search-input {
	flex: 1;
	background: rgba(255,255,255,0.08);
	border: 1px solid rgba(255,255,255,0.15);
	border-right: none;
	border-radius: 4px 0 0 4px;
	padding: 8px 14px;
	font-family: 'Nunito', sans-serif;
	font-size: 0.9rem;
	color: #fff;
	outline: none;
}
.hh-search-input::placeholder { color: rgba(255,255,255,0.35); }
.hh-search-input:focus { border-color: rgba(255,255,255,0.35); }

.hh-search-submit {
	background: rgba(255,255,255,0.12);
	border: 1px solid rgba(255,255,255,0.15);
	border-radius: 0 4px 4px 0;
	padding: 8px 14px;
	color: rgba(255,255,255,0.7);
	cursor: pointer;
	transition: background 0.15s;
}
.hh-search-submit:hover { background: rgba(255,255,255,0.22); color: #fff; }

/* Home icon item */
.hh-menu-home > a {
	display: flex;
	align-items: center;
	padding: 0 14px;
}
.hh-menu-home > a svg {
	display: block;
}

/* Dropdown chevron */
.hh-nav-list > li.menu-item-has-children > a::after {
	content: ' \25BE';
	font-size: 0.75em;
	opacity: 0.55;
	margin-left: 2px;
}

/* Dropdown */
.hh-nav-list li {
	position: relative;
}

.hh-nav-list .sub-menu {
	display: none;
	position: absolute;
	top: 100%;
	left: 0;
	background: #1e2433;
	border: 1px solid rgba(255, 255, 255, 0.1);
	border-radius: 4px;
	list-style: none;
	padding: 4px 0;
	margin: 0;
	min-width: 160px;
	z-index: 200;
}

.hh-nav-list li:hover > .sub-menu {
	display: block;
}

.hh-nav-list .sub-menu li a {
	display: block;
	font-family: 'Nunito', sans-serif;
	font-size: 0.88rem;
	font-weight: 600;
	color: rgba(255, 255, 255, 0.6);
	padding: 6px 16px;
	text-decoration: none;
	white-space: nowrap;
}

.hh-nav-list .sub-menu li a:hover {
	color: #fff;
	background: rgba(255, 255, 255, 0.05);
}

/* ── 3rd level: fly out to the right ── */
.hh-nav-list .sub-menu .sub-menu {
	position: absolute;
	top: -5px;      /* align with parent item top */
	left: 100%;
	margin: 0;
}

/* Chevron on sub-menu items that have children */
.hh-nav-list .sub-menu li.menu-item-has-children > a::after {
	content: ' \25B8'; /* ▸ */
	font-size: 0.75em;
	opacity: 0.55;
	float: right;
	margin-left: 8px;
}

/* Language switcher — hidden; Polylang already adds it inside the nav menu */
.hh-lang-switch {
	display: none;
}

/* Mobile menu toggle */
.hh-menu-toggle {
	display: none;
	flex-direction: column;
	gap: 4px;
	background: none;
	border: none;
	cursor: pointer;
	padding: 6px;
	flex-shrink: 0;
}

.hh-menu-toggle span {
	display: block;
	width: 22px;
	height: 2px;
	background: rgba(255, 255, 255, 0.7);
	border-radius: 2px;
}

/* ── Footer ── */
.hh-site-footer {
	background: #1e2433;
	padding: 28px 20px;
	margin-top: 0;
}

.hh-footer-inner {
	max-width: 1200px;
	margin: 0 auto;
	display: flex;
	align-items: center;
	gap: 24px;
	flex-wrap: wrap;
}

.hh-footer-logo-link {
	display: flex;
	align-items: center;
	gap: 6px;
	text-decoration: none;
}

.anone-logo-mark-sm {
	font-family: 'Noto Serif JP', serif;
	font-size: 1.1rem;
	color: rgba(255, 255, 255, 0.5);
}

.hh-footer-sitename {
	font-family: 'Playfair Display', serif;
	font-weight: 400;
	font-size: 0.85rem;
	color: rgba(255, 255, 255, 0.45);
}

.hh-footer-nav-list {
	display: flex;
	gap: 0;
	list-style: none;
	margin: 0;
	padding: 0;
}

.hh-footer-nav-list li a {
	font-family: 'Nunito', sans-serif;
	font-size: 0.65rem;
	font-weight: 600;
	color: rgba(255, 255, 255, 0.45);
	letter-spacing: 0.06em;
	text-transform: uppercase;
	padding: 0 10px;
	text-decoration: none;
}

.hh-footer-nav-list li a:hover {
	color: rgba(255, 255, 255, 0.8);
}

.hh-footer-copy {
	font-family: 'Nunito', sans-serif;
	font-size: 0.65rem;
	font-weight: 400;
	color: rgba(255, 255, 255, 0.3);
	margin: 0 0 0 auto;
}

.hh-footer-copy a {
	color: rgba(255, 255, 255, 0.45);
}

.hh-footer-copy a:hover {
	color: rgba(255, 255, 255, 0.75);
}

/* Mobile */
@media (max-width: 768px) {
	.hh-menu-toggle {
		display: flex;
	}

	.hh-primary-nav {
		display: none;
		position: fixed;
		top: 60px;
		left: 0;
		right: 0;
		background: #1e2433;
		border-top: 1px solid rgba(255,255,255,0.1);
		padding: 8px 0;
		z-index: 100;
	}

	.hh-primary-nav.hh-nav--open {
		display: block;
	}

	.hh-nav-list {
		flex-direction: column;
		align-items: flex-start;
		gap: 0;
	}

	.hh-nav-list > li > a {
		padding: 10px 20px;
	}

	.hh-nav-list .sub-menu {
		position: static;
		display: block;
		border: none;
		background: rgba(0,0,0,0.2);
		border-radius: 0;
		padding: 0;
	}

	.hh-nav-list .sub-menu li a {
		padding: 8px 32px;
	}

	.hh-nav-list .sub-menu .sub-menu {
		position: static;
	}

	.hh-nav-list .sub-menu .sub-menu li a {
		padding: 8px 48px;
	}

	.hh-footer-inner {
		flex-direction: column;
		align-items: flex-start;
		gap: 12px;
	}

	.hh-footer-copy {
		margin: 0;
	}
}

/* ── Section Widgets (Homepage) ── */
.hh-section {
	background: #fff;
	border: 1px solid #ebe7e0;
	border-radius: 7px;
	overflow: hidden;
}

.hh-section-body {
	padding: 10px 14px;
}

.hh-section-head {
	padding: 8px 14px;
	border-bottom: 2px solid transparent;
	display: flex;
	align-items: center;
	gap: 8px;
}

/* Section header underline colors */
.hh-section--instruments .hh-section-head { border-bottom-color: #5a7a9a; }
.hh-section--live-rig    .hh-section-head { border-bottom-color: #7a5a9a; }
.hh-section--discography .hh-section-head { border-bottom-color: #8a3020; }
.hh-section--videos      .hh-section-head { border-bottom-color: #c00;    }
.hh-section--jazz        .hh-section-head { border-bottom-color: #1a5c3a; }
.hh-section--computer    .hh-section-head { border-bottom-color: #4a2d7a; }
.hh-section--drawings    .hh-section-head { border-bottom-color: #b07820; }
.hh-section--blog        .hh-section-head { border-bottom-color: #c04040; }
.hh-section--popular     .hh-section-head { border-bottom-color: #888;    }
.hh-section--jazztokyo   .hh-section-head { border-bottom-color: #1a5c5c; }

.hh-section-dot {
	width: 8px;
	height: 8px;
	border-radius: 50%;
	flex-shrink: 0;
}

.hh-section-name {
	font-family: 'Nunito', sans-serif;
	font-size: 0.72rem;
	font-weight: 800;
	letter-spacing: 0.12em;
	text-transform: uppercase;
}



/* Section color themes */
/* Jazz Theory & Drawings: 記事を縦いっぱいに分散 */
.hh-section--jazz,
.hh-section--drawings {
	display: flex;
	flex-direction: column;
}
.hh-section--jazz .hh-section-body,
.hh-section--drawings .hh-section-body {
	flex: 1;
	display: flex;
	flex-direction: column;
	justify-content: space-between;
}

.hh-section--jazz .hh-section-dot  { background: #1a5c3a; }
.hh-section--jazz .hh-section-name { color: #1a5c3a; }
.hh-section--music .hh-section-dot  { background: #8a3020; }
.hh-section--music .hh-section-name { color: #8a3020; }
.hh-section--computer .hh-section-dot  { background: #4a2d7a; }
.hh-section--computer .hh-section-name { color: #4a2d7a; }
.hh-section--drawings .hh-section-dot  { background: #b07820; }
.hh-section--drawings .hh-section-name { color: #b07820; }
.hh-section--blog .hh-section-dot  { background: #c04040; }
.hh-section--blog .hh-section-name { color: #c04040; }

/* ── Article list items ── */
.hh-article {
	display: flex;
	gap: 12px;
	align-items: flex-start;
	padding: 10px 0;
	border-bottom: 1px solid #f5f0eb;
}

.hh-article:last-child {
	border-bottom: none;
	padding-bottom: 0;
}

.hh-article img {
	width: 64px;
	height: 56px;
	object-fit: cover;
	border-radius: 4px;
	flex-shrink: 0;
}

.hh-article-text h4 {
	font-family: 'Nunito', sans-serif;
	font-size: 0.9rem;
	font-weight: 600;
	color: #1e2433;
	line-height: 1.35;
	margin: 0 0 3px;
}

.hh-article-text .hh-meta {
	font-family: 'Nunito', sans-serif;
	font-size: 0.7rem;
	font-weight: 400;
	color: #aaa;
}

.hh-article-text .hh-meta.hh-meta--hot {
	color: #c04040;
	font-weight: 700;
}

/* ── Hero banner (static image) ── */
.hh-banner {
	width: 100%;
	overflow: hidden;
	line-height: 0;
}

.hh-banner img {
	width: 100%;
	height: auto;
	display: block;
}

/* ── Hero (post-based, kept for future use) ── */
.hh-hero {
	background: #1e2433;
	padding: 28px 32px;
	display: flex;
	gap: 20px;
	align-items: center;
	border-bottom: 2px solid #1a5c3a;
}

.hh-hero-image {
	width: 140px;
	height: 110px;
	object-fit: cover;
	border-radius: 6px;
	flex-shrink: 0;
}

.hh-hero-tag {
	display: inline-block;
	font-family: 'Nunito', sans-serif;
	font-size: 0.6rem;
	font-weight: 700;
	letter-spacing: 0.14em;
	text-transform: uppercase;
	padding: 3px 10px;
	border-radius: 20px;
	border: 1px solid;
	margin-bottom: 10px;
}

.hh-hero-title {
	font-family: 'Playfair Display', serif;
	font-size: 1.6rem;
	font-weight: 400;
	color: #f0ece4;
	line-height: 1.2;
	margin-bottom: 8px;
}

.hh-hero-desc {
	font-family: 'Nunito', sans-serif;
	font-size: 0.85rem;
	font-weight: 300;
	color: rgba(255, 255, 255, 0.5);
	line-height: 1.6;
}

/* ── Homepage grid ── */
.hh-grid {
	display: grid;
	gap: 14px;
	padding: 20px;
	background: #203a51;
}

.hh-grid-row {
	display: grid;
	gap: 14px;
}

/* Row 1: Instruments | Live Rig | Discography | Videos */
.hh-grid-row--quad {
	grid-template-columns: 1fr 1fr 1fr 1fr;
}

/* Row 2: Jazz Theory | Computer | Drawings | Listen | JazzTokyo */
.hh-grid-row--main {
	grid-template-columns: 1fr 1fr 1fr 1fr 1fr;
}

/* Row 3: Sorta Blog | Most Read */
.hh-grid-row--bottom {
	grid-template-columns: 1fr 1fr;
}

/* 画像タイルのみのセクション: ヘッダー固定・タイルを縦センター */
.hh-section--instruments,
.hh-section--live-rig,
.hh-section--computer,
.hh-section--jazztokyo,
.hh-section--videos {
	display: flex;
	flex-direction: column;
}
.hh-section--instruments .hh-cat-tile,
.hh-section--live-rig .hh-cat-tile,
.hh-section--computer .hh-cat-tile,
.hh-section--jazztokyo .hh-cat-tile,
.hh-section--videos .hh-video-thumb {
	margin: auto 0;
}

/* ── Category image tile ── */
.hh-cat-tile {
	display: block;
	width: 100%;
	aspect-ratio: 4/3;
	overflow: hidden;
	text-decoration: none;
}


.hh-cat-tile img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	display: block;
	transition: transform 0.2s;
}

.hh-cat-tile:hover img {
	transform: scale(1.03);
}

.hh-cat-tile--placeholder {
	background: #1e2433;
	display: flex;
	align-items: center;
	justify-content: center;
	color: rgba(255,255,255,0.4);
	font-family: 'Nunito', sans-serif;
	font-size: 0.8rem;
	min-height: 80px;
}

/* ── Discography panel ── */
.hh-disco-card {
	display: flex;
	gap: 10px;
	padding: 10px 14px;
	align-items: flex-start;
}

.hh-disco-cover img {
	width: 90px;
	height: 90px;
	object-fit: cover;
	border-radius: 4px;
	display: block;
}

.hh-disco-info {
	flex: 1;
}

.hh-disco-title {
	font-family: 'Nunito', sans-serif;
	font-size: 0.9rem;
	font-weight: 700;
	color: #1e2433;
	line-height: 1.25;
	margin-bottom: 3px;
}

.hh-disco-sub {
	font-family: 'Nunito', sans-serif;
	font-size: 0.75rem;
	color: #888;
	margin-bottom: 8px;
}

.hh-disco-services {
	display: flex;
	flex-wrap: wrap;
	gap: 3px;
}

.hh-disco-svc {
	font-family: 'Nunito', sans-serif;
	font-size: 0.6rem;
	font-weight: 700;
	padding: 1px 6px;
	border-radius: 10px;
	border: 1px solid;
	white-space: nowrap;
	text-decoration: none;
}

/* ── Videos panel ── */
.hh-video-thumb {
	display: block;
	position: relative;
	width: 100%;
	line-height: 0;
}

.hh-video-thumb img {
	width: 100%;
	height: auto;
	display: block;
	aspect-ratio: 16/9;
	object-fit: cover;
}

.hh-video-play {
	position: absolute;
	top: 50%;
	left: 50%;
	transform: translate(-50%, -50%);
	font-size: 1.8rem;
	color: rgba(255,255,255,0.9);
	text-shadow: 0 1px 6px rgba(0,0,0,0.6);
	pointer-events: none;
}

.hh-video-title {
	font-family: 'Nunito', sans-serif;
	font-size: 0.75rem;
	font-weight: 600;
	color: #1e2433;
	padding: 6px 10px 4px;
	line-height: 1.35;
}

.hh-yt-sub-row {
	display: flex;
	justify-content: flex-end;
	padding: 4px 10px 8px;
}

/* ── CD strip (2 cards inside Music section) ── */
.hh-cd-strip {
	display: flex;
	flex-direction: column;
	gap: 8px;
	padding: 6px 14px 4px;
	border-top: 1px solid #f5f0eb;
}

.hh-cd-card {
	display: flex;
	gap: 10px;
	align-items: flex-start;
}

.hh-cd-cover img {
	width: 52px;
	height: 52px;
	object-fit: cover;
	border-radius: 4px;
	display: block;
}

.hh-cd-info {
	flex: 1;
}

.hh-cd-title {
	font-family: 'Nunito', sans-serif;
	font-size: 0.72rem;
	font-weight: 700;
	color: #1e2433;
	line-height: 1.3;
	margin-bottom: 4px;
}

.hh-cd-services {
	display: flex;
	flex-wrap: wrap;
	gap: 3px;
}

.hh-cd-service-link {
	font-family: 'Nunito', sans-serif;
	font-size: 0.58rem;
	font-weight: 700;
	padding: 1px 6px;
	border-radius: 10px;
	border: 1px solid;
	white-space: nowrap;
}

/* ── YouTube CTA strip ── */
.hh-yt-strip {
	display: flex;
	align-items: center;
	justify-content: space-between;
	padding: 8px 14px;
	border-top: 1px solid #f5f0eb;
}

.hh-yt-label {
	font-family: 'Nunito', sans-serif;
	font-size: 0.65rem;
	font-weight: 700;
	color: #6b6b6b;
}

.hh-yt-button {
	font-family: 'Nunito', sans-serif;
	font-size: 0.65rem;
	font-weight: 700;
	color: #fff;
	background: #ff0000;
	padding: 3px 10px;
	border-radius: 4px;
	letter-spacing: 0.04em;
}

/* ── Drawings grid ── */
.hh-drawings-grid {
	display: grid;
	grid-template-columns: repeat(2, 1fr);
	gap: 6px;
	padding: 10px 12px 8px;
}

.hh-drawings-grid img {
	width: 100%;
	aspect-ratio: 1;
	object-fit: cover;
	border-radius: 4px;
}

.hh-see-all,
.hh-more-link {
	font-family: 'Nunito', sans-serif;
	font-size: 0.65rem;
	font-weight: 700;
	margin-left: auto;
}

/* 2-column article grid inside Jazz Theory section */
.hh-section-body--2col {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 0;
	padding: 10px 14px;
}

/* ── Popular section ── */
.hh-popular {
	background: #fff;
	border: 1px solid #ebe7e0;
	border-radius: 7px;
	padding: 12px 16px;
}

/* Inside a section panel — strip duplicate border/bg */
.hh-section--popular .hh-popular {
	background: none;
	border: none;
	border-radius: 0;
	padding: 6px 14px 10px;
}

.hh-popular-label {
	font-family: 'Nunito', sans-serif;
	font-size: 0.6rem;
	font-weight: 800;
	letter-spacing: 0.14em;
	text-transform: uppercase;
	color: #ccc;
	margin-bottom: 10px;
}

.hh-popular-item {
	display: flex;
	align-items: baseline;
	gap: 12px;
	padding: 5px 0;
	border-bottom: 1px solid #f5f0eb;
}

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

.hh-popular-num {
	font-family: 'Playfair Display', serif;
	font-size: 1rem;
	font-weight: 400;
	color: #ddd;
	width: 18px;
	text-align: right;
	flex-shrink: 0;
}

.hh-popular-title {
	font-family: 'Nunito', sans-serif;
	font-size: 0.8rem;
	font-weight: 600;
	color: #444;
	flex: 1;
	line-height: 1.3;
}

.hh-popular-views {
	font-family: 'Nunito', sans-serif;
	font-size: 0.65rem;
	color: #bbb;
	white-space: nowrap;
}

.hh-popular-views--hot {
	color: #c04040;
	font-weight: 700;
}

/* ── Single post ── */
.entry-title {
	font-family: 'Playfair Display', serif;
	font-weight: 400;
	font-size: 2rem;
	color: #1e2433;
	line-height: 1.2;
	margin-bottom: 0.5rem;
}

.entry-content p {
	font-size: 1rem;
	line-height: 1.75;
	color: #232323;
	margin-bottom: 1.2rem;
}

.breadcrumb-wrap {
	font-family: 'Nunito', sans-serif;
	font-size: 0.7rem;
	color: #aaa;
	padding-bottom: 10px;
	margin-bottom: 16px;
	border-bottom: 1px solid #ebe7e0;
}

/* ── Footer ── */
.wp-block-template-part.footer,
#site-footer {
	background: #1e2433;
	color: rgba(255, 255, 255, 0.5);
}

.wp-block-template-part.footer a {
	color: rgba(255, 255, 255, 0.6);
}

.wp-block-template-part.footer a:hover {
	color: #fff;
}

/* ════════════════════════════════════════════════════════════
   CATEGORY PAGE
   ════════════════════════════════════════════════════════════ */

/* ── Hero ── */
.hh-cat-hero {
	background: #1e2433;
	background-size: cover;
	background-position: center;
	position: sticky;
	top: 60px; /* fallback; overridden by JS */
	z-index: 500;
	isolation: isolate;
	min-height: 160px;
	display: flex;
	align-items: flex-end;
}

.hh-cat-hero--has-img::after {
	content: '';
	position: absolute;
	inset: 0;
	background: linear-gradient(to top, rgba(20,30,45,0.88) 0%, rgba(20,30,45,0.4) 60%, transparent 100%);
}

.hh-cat-hero-inner {
	position: relative;
	z-index: 1;
	padding: 24px max(20px, calc((100% - 1360px) / 2 + 20px));
	width: 100%;
}

/* ── Breadcrumb ── */
.hh-breadcrumb ol {
	display: flex;
	flex-wrap: wrap;
	gap: 4px;
	list-style: none;
	margin: 0 0 10px;
	padding: 0;
	font-family: 'Nunito', sans-serif;
	font-size: 0.72rem;
	color: rgba(255,255,255,0.5);
}

.hh-breadcrumb li + li::before {
	content: '›';
	margin-right: 4px;
	opacity: 0.4;
}

.hh-breadcrumb a {
	color: rgba(255,255,255,0.6);
	text-decoration: none;
}

.hh-breadcrumb a:hover { color: #fff; }
.hh-bc-current { color: rgba(255,255,255,0.85); }

/* ── Category title ── */
.hh-cat-title {
	font-family: 'Playfair Display', serif;
	font-size: 2rem;
	font-weight: 400;
	color: #fff;
	margin: 0 0 6px;
	line-height: 1.2;
}

.hh-cat-description {
	font-family: 'Nunito', sans-serif;
	font-size: 0.9rem;
	color: rgba(255,255,255,0.7);
	margin: 0;
}

/* ── Content wrapper ── */
.hh-cat-content {
	padding: 28px max(20px, calc((100% - 1360px) / 2 + 20px));
	background: #203a51;
}

/* ── Card grid ── */
.hh-card-grid {
	display: grid;
	grid-template-columns: 1fr 1fr 1fr;
	gap: 18px;
	margin-bottom: 32px;
}

/* ── Card ── */
.hh-card {
	background: #1a2840;
	border-radius: 8px;
	overflow: hidden;
	display: flex;
	flex-direction: column;
	transition: transform 0.15s, box-shadow 0.15s;
}

.hh-card:hover {
	transform: translateY(-2px);
	box-shadow: 0 8px 24px rgba(0,0,0,0.35);
}

.hh-card-thumb {
	display: block;
	aspect-ratio: 4/3;
	overflow: hidden;
	background: #141c28;
	flex-shrink: 0;
}

.hh-card-thumb img {
	width: 100%;
	height: 100%;
	object-fit: contain;
	display: block;
	transition: transform 0.2s;
}

.hh-card:hover .hh-card-thumb img {
	transform: scale(1.03);
}

.hh-card-body {
	padding: 14px 16px 16px;
	display: flex;
	flex-direction: column;
	flex: 1;
}

.hh-card-title {
	font-family: 'Playfair Display', serif;
	font-size: 1rem;
	font-weight: 400;
	margin: 0 0 8px;
	line-height: 1.35;
	color: rgba(255,255,255,0.88);
}

.hh-card-title a {
	color: inherit;
	text-decoration: none;
}

.hh-card-title a:hover { color: #4db8ff; }

.hh-card-meta {
	display: flex;
	gap: 10px;
	font-family: 'Nunito', sans-serif;
	font-size: 0.72rem;
	color: rgba(255,255,255,0.42);
	margin-bottom: 8px;
}

.hh-card-excerpt {
	font-family: 'Nunito', sans-serif;
	font-size: 0.85rem;
	color: rgba(255,255,255,0.6);
	line-height: 1.55;
	margin: 0;
	flex: 1;
}

/* ── Pagination ── */
.navigation.pagination {
	margin-top: 12px;
}

.nav-links {
	display: flex;
	justify-content: center;
	gap: 6px;
	flex-wrap: wrap;
}

.nav-links .page-numbers {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	min-width: 36px;
	height: 36px;
	padding: 0 10px;
	border-radius: 4px;
	font-family: 'Nunito', sans-serif;
	font-size: 0.85rem;
	background: rgba(255,255,255,0.1);
	color: rgba(255,255,255,0.7);
	text-decoration: none;
	transition: background 0.15s, color 0.15s;
}

.nav-links .page-numbers:hover,
.nav-links .page-numbers.current {
	background: rgba(255,255,255,0.22);
	color: #fff;
}

.hh-no-posts {
	color: rgba(255,255,255,0.6);
	font-family: 'Nunito', sans-serif;
	text-align: center;
	padding: 40px 0;
}

/* ── Audio page ── */
.hh-audio-content {
	max-width: 960px;
	margin: 0 auto;
	padding: 32px 20px 48px;
}
.hh-soundcloud { margin-bottom: 24px; }
.hh-soundcloud-credit {
	font-size: 0.72rem;
	color: rgba(255,255,255,0.35);
	white-space: nowrap;
	overflow: hidden;
	text-overflow: ellipsis;
	margin-top: 4px;
}
.hh-soundcloud-credit a { color: rgba(255,255,255,0.4); text-decoration: none; }
.hh-bandcamp-list { display: flex; flex-direction: column; gap: 10px; }

/* ── Videos page ── */
.hh-videos-content { padding: 32px max(20px, calc((100% - 1360px) / 2 + 20px)) 48px; }
.hh-yt-gallery { margin-bottom: 24px; }
.hh-yt-channel-link {
	text-align: right;
	margin-bottom: 24px;
}
.hh-yt-channel-link a {
	font-family: 'Nunito', sans-serif;
	font-weight: 700;
	font-size: 0.95rem;
	color: rgba(255,255,255,0.75);
	text-decoration: none;
	transition: color 0.15s;
}
.hh-yt-channel-link a:hover { color: #fff; }
.hh-yt-featured { max-width: 960px; margin: 0 auto; }
.hh-yt-featured iframe { width: 100%; aspect-ratio: 16/9; height: auto; }

/* ── Discography page ── */
.hh-disc-content { padding: 32px max(20px, calc((100% - 1360px) / 2 + 20px)) 48px; }
.hh-disc-section { margin-bottom: 40px; }
.hh-disc-section-title {
	font-family: 'Playfair Display', serif;
	font-size: 1.4rem;
	color: rgba(255,255,255,0.85);
	margin: 0 0 20px;
	padding-bottom: 8px;
	border-bottom: 1px solid rgba(255,255,255,0.1);
}
.hh-disc-grid {
	grid-template-columns: repeat(4, 1fr);
}
.hh-disc-count {
	font-family: 'Nunito', sans-serif;
	font-size: 0.8rem;
	color: rgba(255,255,255,0.45);
	margin: -4px 0 16px;
	letter-spacing: 0.03em;
}
.hh-disc-grid--5 {
	grid-template-columns: repeat(5, 1fr);
}
@media (max-width: 1100px) {
	.hh-disc-grid--5 { grid-template-columns: repeat(4, 1fr); }
}
@media (max-width: 900px) {
	.hh-disc-grid, .hh-disc-grid--5 { grid-template-columns: repeat(3, 1fr); }
}
@media (max-width: 600px) {
	.hh-disc-grid, .hh-disc-grid--5 { grid-template-columns: repeat(2, 1fr); }
}

/* ── WordPress Classic Gallery ──────────────────────────────── */
.hh-single-entry .gallery {
	display: grid;
	gap: 8px;
	margin: 1.5em 0;
}
.hh-single-entry .gallery-columns-1 { grid-template-columns: 1fr; }
.hh-single-entry .gallery-columns-2 { grid-template-columns: repeat(2, 1fr); }
.hh-single-entry .gallery-columns-3 { grid-template-columns: repeat(3, 1fr); }
.hh-single-entry .gallery-columns-4 { grid-template-columns: repeat(4, 1fr); }
.hh-single-entry .gallery-columns-5 { grid-template-columns: repeat(5, 1fr); }
.hh-single-entry .gallery-columns-6 { grid-template-columns: repeat(6, 1fr); }
.hh-single-entry .gallery-item {
	margin: 0;
	overflow: hidden;
}
.hh-single-entry .gallery-item img {
	width: 100%;
	height: auto;
	display: block;
	transition: transform 0.2s;
}
.hh-single-entry .gallery-item a:hover img { transform: scale(1.03); }
.hh-single-entry .gallery-caption {
	font-size: 0.78rem;
	color: rgba(255,255,255,0.5);
	text-align: center;
	padding: 4px 2px;
}
@media (max-width: 600px) {
	.hh-single-entry .gallery-columns-3,
	.hh-single-entry .gallery-columns-4,
	.hh-single-entry .gallery-columns-5,
	.hh-single-entry .gallery-columns-6 { grid-template-columns: repeat(2, 1fr); }
}

/* ── Single Post ────────────────────────────────────────────── */
.hh-single-hero {
	background: #0a1220;
	padding: 16px max(20px, calc((100% - 1100px) / 2 + 20px));
	position: sticky;
	top: 60px; /* fallback; overridden by JS */
	z-index: 500;
	isolation: isolate;
}
/* 2カラムhero: 左にテキスト、右にアルバムアート */
.hh-single-hero-inner {
	display: flex;
	align-items: center;
	gap: 24px;
}
.hh-single-hero-text {
	flex: 1;
	min-width: 0;
}
.hh-single-hero-art {
	flex: 0 0 auto;
	width: clamp(100px, 14vw, 180px);
}
.hh-single-hero-art img {
	display: block;
	width: 100%;
	height: auto;
	border-radius: 4px;
	box-shadow: 0 4px 20px rgba(0,0,0,0.6);
}
.hh-single-cats {
	display: flex;
	gap: 8px;
	flex-wrap: wrap;
	margin-bottom: 12px;
}
.hh-single-cat-badge {
	font-family: 'Nunito', sans-serif;
	font-size: 0.65rem;
	font-weight: 800;
	letter-spacing: 0.12em;
	text-transform: uppercase;
	color: #fff;
	background: rgba(255,255,255,0.15);
	border: 1px solid rgba(255,255,255,0.25);
	padding: 3px 10px;
	border-radius: 3px;
	text-decoration: none;
}
.hh-single-cat-badge:hover { background: rgba(255,255,255,0.25); }
.hh-single-title {
	font-family: 'Playfair Display', serif;
	font-size: clamp(1.6rem, 4vw, 2.8rem);
	font-weight: 500;
	color: #fff;
	margin: 0 0 12px;
	line-height: 1.25;
}
.hh-single-meta {
	display: flex;
	gap: 20px;
	font-family: 'Nunito', sans-serif;
	font-size: 0.8rem;
	color: rgba(255,255,255,0.5);
}
.hh-single-content {
	padding: 40px max(20px, calc((100% - 1100px) / 2 + 20px)) 64px;
}
.hh-single-body {
	display: flex;
	gap: 40px;
	align-items: flex-start;
}
.hh-single-thumb {
	flex: 0 0 280px;
	max-width: 280px;
}
.hh-single-thumb img {
	width: 100%;
	height: auto;
	display: block;
	border-radius: 4px;
	box-shadow: 0 8px 32px rgba(0,0,0,0.5);
}
.hh-single-entry {
	flex: 1;
	min-width: 0;
	font-family: 'Nunito', sans-serif;
	font-size: 0.95rem;
	line-height: 1.75;
	color: rgba(255,255,255,0.82);
}
.hh-single-entry h2, .hh-single-entry h3,
.hh-single-entry h4, .hh-single-entry h5, .hh-single-entry h6 {
	font-family: 'Playfair Display', serif;
	color: rgba(255,255,255,0.9);
	margin-top: 1.4em;
}
.hh-single-entry ul, .hh-single-entry ol {
	padding-left: 1.4em;
}
.hh-single-entry a { color: #4db8ff; }
.hh-single-entry a:hover { color: #80ccff; }
.hh-single-entry iframe, .hh-single-entry audio {
	max-width: 100%;
}
/* Prev/Next nav */
.hh-single-nav {
	display: flex;
	gap: 16px;
	margin-top: 48px;
	padding-top: 24px;
	border-top: 1px solid rgba(255,255,255,0.1);
}
.hh-single-nav__item {
	flex: 1;
	display: flex;
	flex-direction: column;
	gap: 4px;
	text-decoration: none;
	padding: 14px 18px;
	background: rgba(255,255,255,0.05);
	border: 1px solid rgba(255,255,255,0.1);
	border-radius: 6px;
	transition: background 0.2s;
}
.hh-single-nav__item:hover { background: rgba(255,255,255,0.09); }
.hh-single-nav__item--next { text-align: right; }
.hh-single-nav__label {
	font-family: 'Nunito', sans-serif;
	font-size: 0.7rem;
	font-weight: 700;
	letter-spacing: 0.08em;
	text-transform: uppercase;
	color: rgba(255,255,255,0.4);
}
.hh-single-nav__title {
	font-family: 'Playfair Display', serif;
	font-size: 0.95rem;
	color: rgba(255,255,255,0.82);
	line-height: 1.3;
}
@media (max-width: 720px) {
	.hh-single-body { flex-direction: column; }
	.hh-single-thumb { flex: none; max-width: 220px; }
	.hh-single-nav { flex-direction: column; }
}
/* ── Comments ───────────────────────────────────────────────── */
/* ── Streaming / Purchase Buttons ───────────────────────────── */
.hh-streaming-links {
	margin: 0 0 32px;
	padding: 0 0 24px;
	border-bottom: 1px solid rgba(255,255,255,0.1);
}
.hh-streaming-label {
	font-family: 'Nunito', sans-serif;
	font-size: 0.75rem;
	letter-spacing: 0.08em;
	text-transform: uppercase;
	color: rgba(255,255,255,0.45);
	margin: 0 0 12px;
}
/* Icon-only compact buttons (cards / homepage panels) */
.hh-stream-icons { display: flex; gap: 5px; flex-wrap: wrap; margin-top: 7px; }
.hh-stream-icon {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 26px;
	height: 26px;
	border-radius: 50%;
	background: var(--svc-color);
	color: #fff;
	text-decoration: none !important;
	transition: filter 0.15s, transform 0.15s;
	flex-shrink: 0;
}
.hh-stream-icon svg { width: 13px; height: 13px; flex-shrink: 0; }
.hh-stream-icon:hover { filter: brightness(1.2); transform: scale(1.12); }

/* ── Artist page icons (homepage panel) ──────────────────── */
/* 角丸四角 + ラベル付き — アルバムアイコン（丸）とは別デザイン  */
.hh-section--artist-pages { display: flex; flex-direction: column; }
.hh-section--artist-pages .hh-section-head { border-bottom-color: #2a6090; }
.hh-section--artist-pages .hh-section-dot  { background: #2a6090; }
.hh-section--artist-pages .hh-section-name { color: #2a6090; }
.hh-section--artist-pages .hh-section-body {
	flex: 1;
	display: flex;
	flex-direction: column;
	padding: 10px;
}

.hh-artist-icons {
	display: flex;
	flex-direction: column;
	gap: 8px;
	flex: 1;
}
.hh-artist-icon {
	display: flex;
	align-items: center;
	justify-content: center;
	gap: 12px;
	flex: 1;
	padding: 0 14px;
	border-radius: 8px;
	background: var(--svc-color);
	color: #fff;
	text-decoration: none !important;
	font-family: 'Nunito', sans-serif;
	font-size: 0.92rem;
	font-weight: 700;
	letter-spacing: 0.01em;
	transition: filter 0.15s, transform 0.15s;
	line-height: 1;
}
.hh-artist-icon:hover { filter: brightness(1.15); transform: translateY(-1px); }
.hh-artist-icon__svg { display: flex; flex-shrink: 0; }
.hh-artist-icon__svg svg { width: 22px; height: 22px; }
.hh-artist-icon__label { white-space: nowrap; }

/* Labeled buttons (single post) */
.hh-stream-btn-icon { display: inline-flex; align-items: center; }
.hh-stream-btn-icon svg { width: 18px; height: 18px; }
.hh-stream-btn {
	display: inline-flex;
	align-items: center;
	gap: 7px;
	padding: 9px 18px;
	margin: 0 8px 8px 0;
	border-radius: 24px;
	background: var(--svc-color);
	color: #fff !important;
	text-decoration: none !important;
	font-family: 'Nunito', sans-serif;
	font-size: 0.85rem;
	font-weight: 700;
	line-height: 1;
	transition: filter 0.15s, transform 0.15s;
}
.hh-stream-btn svg { flex-shrink: 0; }
.hh-stream-btn:hover {
	filter: brightness(1.15);
	transform: translateY(-1px);
	color: #fff !important;
}
.hh-amazon-link {
	display: inline-block;
	padding: 7px 16px;
	border-radius: 4px;
	background: #25a244;
	color: #fff !important;
	text-decoration: none;
	font-family: 'Nunito', sans-serif;
	font-size: 0.85rem;
	font-weight: 700;
}

.hh-single-comments {
	margin-top: 48px;
	padding-top: 32px;
	border-top: 1px solid rgba(255,255,255,0.1);
}
.hh-single-comments .comments-title,
.hh-single-comments #reply-title {
	font-family: 'Playfair Display', serif;
	font-size: 1.3rem;
	color: rgba(255,255,255,0.88);
	margin-bottom: 24px;
}
.hh-single-comments .comment-list { list-style: none; padding: 0; margin: 0 0 32px; }
.hh-single-comments .comment { margin-bottom: 20px; }
.hh-single-comments .comment-body {
	background: rgba(255,255,255,0.04);
	border: 1px solid rgba(255,255,255,0.08);
	border-radius: 6px;
	padding: 16px 20px;
}
.hh-single-comments .comment-author .fn {
	font-family: 'Nunito', sans-serif;
	font-weight: 700;
	font-size: 0.9rem;
	color: rgba(255,255,255,0.85);
}
.hh-single-comments .comment-metadata {
	font-size: 0.75rem;
	color: rgba(255,255,255,0.4);
	margin-bottom: 8px;
}
.hh-single-comments .comment-metadata a { color: rgba(255,255,255,0.4); }
.hh-single-comments .comment-content p {
	font-size: 0.9rem;
	color: rgba(255,255,255,0.75);
	line-height: 1.7;
	margin: 0;
}
.hh-single-comments .reply a {
	font-size: 0.75rem;
	color: #4db8ff;
	margin-top: 8px;
	display: inline-block;
}
/* Comment form */
.hh-single-comments .comment-form label {
	display: block;
	font-size: 0.8rem;
	color: rgba(255,255,255,0.6);
	margin-bottom: 4px;
}
.hh-single-comments .comment-form input[type="text"],
.hh-single-comments .comment-form input[type="email"],
.hh-single-comments .comment-form textarea {
	width: 100%;
	background: rgba(255,255,255,0.07);
	border: 1px solid rgba(255,255,255,0.15);
	border-radius: 4px;
	color: rgba(255,255,255,0.85);
	padding: 8px 12px;
	font-family: 'Nunito', sans-serif;
	font-size: 0.9rem;
	box-sizing: border-box;
}
.hh-single-comments .comment-form textarea { min-height: 120px; resize: vertical; }
.hh-single-comments .comment-form input:focus,
.hh-single-comments .comment-form textarea:focus {
	outline: none;
	border-color: rgba(77,184,255,0.5);
}
.hh-single-comments .comment-form .submit {
	background: #4db8ff;
	color: #0a1220;
	border: none;
	border-radius: 4px;
	padding: 9px 24px;
	font-family: 'Nunito', sans-serif;
	font-weight: 700;
	font-size: 0.85rem;
	cursor: pointer;
	transition: background 0.2s;
}
.hh-single-comments .comment-form .submit:hover { background: #80ccff; }

/* ── Page content (page.php) ────────────────────────────────── */
.hh-page-content {
	font-family: 'Nunito', sans-serif;
	font-size: 0.95rem;
	line-height: 1.75;
	color: rgba(255,255,255,0.82);
	max-width: 860px;
}
.hh-page-content h2, .hh-page-content h3,
.hh-page-content h4, .hh-page-content h5, .hh-page-content h6 {
	font-family: 'Playfair Display', serif;
	color: rgba(255,255,255,0.9);
	margin-top: 1.5em;
}
.hh-page-content a { color: #4db8ff; }

/* ── Formidable Forms — dark theme override ─────────────────── */
.frm-show-form .frm_form_field input[type="text"],
.frm-show-form .frm_form_field input[type="email"],
.frm-show-form .frm_form_field input[type="tel"],
.frm-show-form .frm_form_field input[type="url"],
.frm-show-form .frm_form_field select,
.frm-show-form .frm_form_field textarea,
.with_frm_style .frm_form_field input[type="text"],
.with_frm_style .frm_form_field input[type="email"],
.with_frm_style .frm_form_field textarea {
	background: rgba(255,255,255,0.07) !important;
	border: 1px solid rgba(255,255,255,0.18) !important;
	border-radius: 4px !important;
	color: rgba(255,255,255,0.88) !important;
	padding: 9px 12px !important;
	font-family: 'Nunito', sans-serif !important;
	font-size: 0.9rem !important;
	box-shadow: none !important;
	width: 100% !important;
	box-sizing: border-box !important;
}
.frm-show-form .frm_form_field input:focus,
.frm-show-form .frm_form_field textarea:focus {
	outline: none !important;
	border-color: rgba(77,184,255,0.55) !important;
	background: rgba(255,255,255,0.1) !important;
}
.frm-show-form .frm_form_field label,
.with_frm_style .frm_form_field label {
	color: rgba(255,255,255,0.65) !important;
	font-family: 'Nunito', sans-serif !important;
	font-size: 0.85rem !important;
}
.frm-show-form .frm_form_field textarea { min-height: 130px !important; resize: vertical !important; }
.frm-show-form input[type="submit"],
.frm-show-form button[type="submit"],
.with_frm_style .frm_submit input[type="submit"] {
	background: #4db8ff !important;
	color: #0a1220 !important;
	border: none !important;
	border-radius: 4px !important;
	padding: 10px 28px !important;
	font-family: 'Nunito', sans-serif !important;
	font-weight: 700 !important;
	font-size: 0.9rem !important;
	cursor: pointer !important;
	transition: background 0.2s !important;
}
.frm-show-form input[type="submit"]:hover,
.frm-show-form button[type="submit"]:hover { background: #80ccff !important; }
.frm-show-form .frm_error { color: #ff7b7b !important; font-size: 0.8rem !important; }

/* Album covers are square — override the default 16:9 ratio */
.hh-card-thumb--square { aspect-ratio: 1 / 1; }
.hh-card-thumb--square img { object-fit: cover; width: 100%; height: 100%; }
.hh-divider {
	border: none;
	border-top: 1px solid rgba(255,255,255,0.08);
	margin: 32px 0;
}

/* ── Responsive ── */
@media (max-width: 1200px) {
	/* Row 2: 5列 → 3列（tablet）*/
	.hh-grid-row--main {
		grid-template-columns: 1fr 1fr 1fr;
	}
}

@media (max-width: 768px) {
	.hh-grid-row--quad {
		grid-template-columns: 1fr 1fr;
	}

	.hh-grid-row--main,
	.hh-grid-row--bottom {
		grid-template-columns: 1fr;
	}

	.hh-hero {
		flex-direction: column;
		padding: 20px;
	}

	.hh-hero-image {
		width: 100%;
		height: 160px;
	}

	.hh-music-grid {
		grid-template-columns: 1fr 1fr;
	}
}

@media (max-width: 480px) {
	/* Category page */
	.hh-card-grid {
		grid-template-columns: 1fr;
	}
}

@media (max-width: 768px) {
	/* Category page */
	.hh-card-grid {
		grid-template-columns: 1fr 1fr;
	}

	.hh-cat-title {
		font-size: 1.5rem;
	}
}
