/* ============================================================
   CHINOCHIKARA — layout.css （ライトテーマ）
   ============================================================ */

/* ----- Header ----- */
.site-header {
	position: sticky;
	top: 0;
	z-index: 50;
	background: rgba(250, 246, 237, 0.96);
	backdrop-filter: blur(10px);
	border-bottom: 1px solid var(--c-border-soft);
}
/* 最上部の金のヘアライン（雑誌の背表紙のようなアクセント） */
.site-header::before {
	content: "";
	display: block;
	height: 3px;
	background: var(--c-gold-grad);
}
.site-header__bar {
	display: grid;
	grid-template-columns: 1fr auto 1fr;
	align-items: center;
	gap: var(--sp-5);
	padding: var(--sp-3) var(--sp-5);
	max-width: 1480px;
	margin-inline: auto;
	min-height: 72px;
}

.site-header__tagline {
	justify-self: start;
	font-family: var(--ff-serif-jp);
	font-size: var(--fs-sm);
	color: var(--c-text);
	letter-spacing: 0.1em;
	line-height: 1.4;
	font-weight: 600;
}
.site-header__tagline a { color: inherit; }

.site-header__brand {
	justify-self: center;
	text-align: center;
}
.site-header__brand a {
	display: inline-flex;
	flex-direction: column;
	align-items: center;
	gap: 4px;
}
.site-header__brand img {
	height: 52px;
	width: auto;
	display: block;
}
.site-header__brand-sub {
	font-family: var(--ff-serif-jp);
	font-size: 10px;
	font-weight: 600;
	letter-spacing: 0.45em;
	color: var(--c-gold-bright);
	padding-left: 0.45em;
}

.site-header__tools {
	justify-self: end;
	display: flex;
	gap: var(--sp-2);
	align-items: center;
}
.hbtn {
	display: inline-flex;
	align-items: center;
	gap: var(--sp-2);
	background: none;
	border: 1px solid transparent;
	border-radius: 999px;
	color: var(--c-text);
	font-family: var(--ff-serif-jp);
	font-weight: 600;
	font-size: var(--fs-sm);
	padding: 7px 16px;
	letter-spacing: 0.12em;
	cursor: pointer;
	transition: color .2s ease, border-color .2s ease, background-color .2s ease;
}
.hbtn:hover {
	color: var(--c-gold-bright);
	border-color: var(--c-border);
	background: rgba(255, 255, 255, 0.55);
}
.hbtn__icon {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 18px; height: 18px;
	color: var(--c-gold-bright);
	transition: transform .25s ease;
}
.hbtn:hover .hbtn__icon { transform: scale(1.15); }
.hbtn__icon svg {
	width: 100%; height: 100%;
	display: block;
	stroke: currentColor;
	fill: none;
}
/* メニュー（CTA寄りの強調ボタン） */
.hbtn--menu {
	border-color: var(--c-gold);
	color: var(--c-gold-deep);
}
.hbtn--menu:hover {
	background: var(--c-gold);
	border-color: var(--c-gold);
	color: #fff;
}
.hbtn--menu:hover .hbtn__icon { color: #fff; }

/* ----- Nav ----- */
.site-nav {
	background: rgba(250, 246, 237, 0.96);
	border-bottom: 1px solid var(--c-border-soft);
}
.site-nav__inner {
	max-width: 1480px;
	margin-inline: auto;
	padding: 0 var(--sp-5);
}
.site-nav ul {
	list-style: none;
	margin: 0;
	padding: 0;
	display: flex;
	justify-content: center;
	flex-wrap: wrap;
	gap: 0;
}
.site-nav a {
	position: relative;
	display: block;
	padding: var(--sp-3) var(--sp-5);
	font-family: var(--ff-serif-jp);
	font-weight: 600;
	font-size: var(--fs-sm);
	letter-spacing: 0.16em;
	color: var(--c-text);
}
/* hover で金の下線が中央から伸びる */
.site-nav a::after {
	content: "";
	position: absolute;
	left: var(--sp-5);
	right: var(--sp-5);
	bottom: 7px;
	height: 1px;
	background: var(--c-gold-grad);
	transform: scaleX(0);
	transform-origin: center;
	transition: transform .3s ease;
}
.site-nav a:hover,
.site-nav .current-menu-item > a,
.site-nav .current-cat > a {
	color: var(--c-gold-bright);
}
.site-nav a:hover::after,
.site-nav .current-menu-item > a::after,
.site-nav .current-cat > a::after {
	transform: scaleX(1);
}

/* ----- Footer ----- */
.site-footer {
	margin-top: var(--sp-9);
	padding: var(--sp-7) 0 var(--sp-5);
	background: var(--c-ink);
	color: #d7ccb4;
	font-size: var(--fs-sm);
	border-top: 3px solid transparent;
	border-image: var(--c-gold-grad) 1;
}
.site-footer a {
	color: #d7ccb4;
	transition: color .2s ease, padding-left .25s ease;
}
.site-footer a:hover { color: #f3e3bd; }
/* リスト内リンクは hover で右へスッと寄る */
.site-footer li a:hover { padding-left: 6px; }
.site-footer__grid {
	display: grid;
	grid-template-columns: 1.6fr 1fr 1fr;
	gap: var(--sp-6);
	margin-bottom: var(--sp-6);
	max-width: 1480px;
	margin-inline: auto;
	padding-inline: var(--sp-5);
}
.site-footer__about p { margin-bottom: var(--sp-3); line-height: 1.9; }
.site-footer__about img {
	height: 44px;
	margin-bottom: var(--sp-3);
	width: auto;
	filter: brightness(1.1);
}
.site-footer h4 {
	font-size: var(--fs-sm);
	color: #e8d09a;
	letter-spacing: 0.2em;
	margin-bottom: var(--sp-3);
	font-family: var(--ff-serif-jp);
	font-weight: 600;
}
.site-footer ul { list-style: none; padding: 0; margin: 0; }
.site-footer li {
	margin-bottom: var(--sp-2);
	font-family: var(--ff-serif-jp);
	font-weight: 600;
	letter-spacing: 0.08em;
}
.site-footer__about p {
	font-family: var(--ff-serif-jp);
	letter-spacing: 0.04em;
}
.site-footer__copy {
	text-align: center;
	padding-top: var(--sp-5);
	border-top: 1px solid rgba(255, 255, 255, 0.1);
	font-family: var(--ff-serif-jp);
	font-weight: 600;
	letter-spacing: 0.2em;
	color: rgba(215, 204, 180, 0.6);
	font-size: var(--fs-xs);
	max-width: 1480px;
	margin-inline: auto;
	padding-inline: var(--sp-5);
}

/* ----- Main grid ----- */
.main-grid {
	display: grid;
	grid-template-columns: minmax(0, 1fr) 360px;
	gap: var(--sp-6);
	margin-top: var(--sp-6);
}
.main-grid--front { gap: var(--sp-7); }
.main-grid--single { grid-template-columns: minmax(0, 1fr) 300px; }

@media (max-width: 1100px) {
	.main-grid { grid-template-columns: minmax(0, 1fr) 300px; }
}
@media (max-width: 960px) {
	/* 1fr だと minmax(auto,1fr) 扱いになり、表など幅広コンテンツの min-content がカラムを押し広げる */
	.main-grid { grid-template-columns: minmax(0, 1fr); }
	.site-header__bar { grid-template-columns: 1fr auto 1fr; gap: var(--sp-3); }
	.site-header__tagline { display: none; }
	.site-header__brand img { height: 42px; }
	.site-footer__grid { grid-template-columns: 1fr; text-align: center; gap: var(--sp-7); }
	.site-footer__about img { margin-inline: auto; }
	.site-footer__about p { margin-inline: auto; max-width: 28em; }
	.site-nav ul { gap: 0; justify-content: flex-start; overflow-x: auto; flex-wrap: nowrap; padding-bottom: var(--sp-2); }
	.site-nav a { white-space: nowrap; padding: var(--sp-3) var(--sp-3); }
	.site-nav a::after { left: var(--sp-3); right: var(--sp-3); bottom: 6px; }
	.hbtn__label { display: none; }
	/* ラベル非表示時はアイコンを正方形ボタンの中央に置く（楕円化・左寄り防止） */
	.hbtn { width: 40px; height: 40px; padding: 0; justify-content: center; }
	.site-header__tools .hbtn + .hbtn { border-left: 0; }
	.site-header__tools { gap: var(--sp-2); }
}
/* 極狭幅（小型スマホ）でヘッダーのボタン群がはみ出すのを防ぐ */
@media (max-width: 360px) {
	.site-header__bar { padding-inline: var(--sp-3); gap: var(--sp-2); }
	.hbtn { width: 36px; height: 36px; }
	.site-header__tools { gap: var(--sp-1); }
}

/* ----- Section ----- */
.section { margin-top: var(--sp-7); }
.section--first { margin-top: var(--sp-6); }
.section__head {
	display: flex;
	align-items: flex-end;
	justify-content: space-between;
	margin-bottom: var(--sp-4);
	gap: var(--sp-4);
}
.section__heading {
	display: flex;
	flex-direction: column;
	gap: 2px;
}
.section__sub {
	font-family: var(--ff-serif-en);
	font-size: var(--fs-xs);
	letter-spacing: 0.32em;
	color: var(--c-gold-bright);
	line-height: 1;
}
.section__title {
	font-family: var(--ff-serif-jp);
	font-size: var(--fs-xl);
	font-weight: 600;
	letter-spacing: 0.1em;
	margin: 0;
	color: var(--c-text);
	display: inline-flex;
	align-items: center;
	gap: var(--sp-3);
}
.section__title::after {
	content: "✦";
	color: var(--c-gold);
	font-size: 14px;
	opacity: 0.85;
}
.section__more {
	display: inline-block;
	font-family: var(--ff-sans-jp);
	font-size: var(--fs-sm);
	color: var(--c-text-muted);
	letter-spacing: 0.08em;
	transition: color .2s ease, transform .25s ease;
}
.section__more:hover {
	color: var(--c-gold-bright);
	transform: translateX(4px);
}
