/* 対馬地鶏ブランド — ベースレイアウト（tsushima-jidori） */

:root {
	--tj-bg: #000;
	--tj-surface: #0a0a0a;
	--tj-ink: var(--wp--preset--color--body, #3d342b);
	--tj-dark: var(--wp--preset--color--contrast, #1a1410);
	--tj-wine: var(--wp--preset--color--primary, #5c2418);
	--tj-brand: var(--wp--preset--color--brand, #b33a3a);
	--tj-gold: var(--wp--preset--color--accent, #d4a853);
	--tj-font-mincho: "Shippori Mincho", "Hiragino Mincho ProN", "Yu Mincho", "YuMincho", "MS PMincho", serif;
	--tj-font-gothic: "Zen Kaku Gothic New", "Hiragino Sans", "Yu Gothic UI", "Meiryo", sans-serif;
	--tj-fs-body: clamp(14px, 0.25vw + 13.25px, 16px);
	--tj-fs-h2: clamp(24px, 1.2vw + 18px, 34px);
	--tj-radius: 1rem;
	--tj-shadow: 0 24px 60px rgba(26, 20, 16, 0.12);
	--tj-header-h: 4.5rem;
	--tj-hero-h: 100vh;
	--tj-hero-h: 100dvh;
}

html {
	scroll-padding-top: var(--tj-header-h);
	scroll-behavior: auto;
}

*,
*::before,
*::after {
	box-sizing: border-box;
}

body {
	margin: 0;
	padding-top: var(--tj-header-h);
	font-family: var(--tj-font-gothic);
	font-size: var(--tj-fs-body);
	color: rgba(255, 255, 255, 0.92);
	background: #000;
	line-height: 1.8;
}

img {
	max-width: 100%;
	height: auto;
	display: block;
}

a {
	color: inherit;
}

.alignwide {
	width: min(1200px, calc(100% - 2.5rem));
	margin-inline: auto;
}

.alignfull {
	width: 100%;
	max-width: none;
}

html {
	overflow-x: hidden;
	background: var(--tj-bg);
}

.screen-reader-text {
	border: 0;
	clip: rect(1px, 1px, 1px, 1px);
	clip-path: inset(50%);
	height: 1px;
	margin: -1px;
	overflow: hidden;
	padding: 0;
	position: absolute;
	width: 1px;
}

/* ----- Buttons ----- */
.tj-btn {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: 0.5rem;
	padding: 0.85rem 1.5rem;
	border-radius: 999px;
	font-size: 0.875rem;
	font-weight: 600;
	text-decoration: none;
	border: 1px solid transparent;
	transition: transform 0.2s ease, background 0.2s ease, color 0.2s ease, border-color 0.2s ease;
}

.tj-btn:hover {
	transform: translateY(-1px);
}

.tj-btn--primary {
	background: var(--tj-brand);
	color: #fff;
}

.tj-btn--primary:hover {
	background: color-mix(in srgb, var(--tj-brand) 88%, #000);
}

.tj-btn--ghost {
	background: transparent;
	border-color: color-mix(in srgb, var(--tj-ink) 25%, transparent);
	color: var(--tj-ink);
}

/* ----- Header ----- */
.tj-header {
	position: fixed;
	top: 0;
	right: 0;
	left: 0;
	z-index: 200;
	width: 100%;
	color: #fff;
	background: transparent;
	border-bottom: none;
	font-family: var(--tj-font-mincho);
}

.tj-header__bar {
	position: relative;
	padding-block: 0.85rem;
	padding-inline: clamp(1rem, 2vw, 2rem);
	background: transparent;
}

.tj-header__inner {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 1rem;
}

.tj-header__toggle {
	display: none;
	border: none;
	background: transparent;
	border-radius: 0.5rem;
	padding: 0.45rem 0.55rem;
	cursor: pointer;
	color: inherit;
}

.tj-header__toggle-lines {
	display: block;
	width: 1.35rem;
	height: 2px;
	background: currentColor;
	box-shadow: 0 6px 0 currentColor, 0 12px 0 currentColor;
}

.tj-header__nav .tj-nav__list {
	list-style: none;
	margin: 0;
	padding: 0;
	display: flex;
	flex-wrap: wrap;
	gap: 0.35rem 0.75rem;
	justify-content: flex-end;
}

.tj-header .tj-nav__link {
	display: inline-flex;
	align-items: center;
	padding: 0.45rem 0.85rem;
	border-radius: 999px;
	text-decoration: none;
	text-underline-offset: 0.22em;
	color: inherit;
	font-size: 0.9375rem;
	font-weight: 500;
	border: 1px solid transparent;
	transition: color 0.2s, text-decoration-color 0.2s;
}

.tj-header .tj-nav__link:hover,
.tj-header .tj-nav__link:focus-visible {
	text-decoration: underline;
	text-decoration-thickness: 1.5px;
	opacity: 0.9;
}

@media (max-width: 899px) {
	.tj-header__toggle {
		display: inline-flex;
	}

	.tj-header__nav {
		position: absolute;
		left: 0;
		right: 0;
		top: 100%;
		background: rgba(26, 20, 16, 0.94);
		max-height: 0;
		overflow: hidden;
		opacity: 0;
		pointer-events: none;
		transition: max-height 0.35s ease, opacity 0.25s ease;
	}

	.tj-header.is-nav-open .tj-header__nav {
		max-height: 70vh;
		opacity: 1;
		pointer-events: auto;
	}

	.tj-header__nav .tj-nav__list {
		flex-direction: column;
		align-items: stretch;
		padding: 0.75rem 1.25rem 1rem;
		gap: 0.25rem;
	}

	.tj-header .tj-nav__link {
		justify-content: flex-start;
		border-radius: 0.5rem;
	}
}

.tj-header__brand {
	text-decoration: none;
	color: inherit;
}

.tj-header__site-name {
	font-size: 1.125rem;
	font-weight: 600;
	text-decoration: none;
	color: #fff;
	text-shadow: 0 1px 12px rgba(26, 20, 16, 0.45);
}

.tj-header__brand:hover .tj-header__site-name {
	opacity: 0.88;
}

/* ----- Breadcrumbs (フッター直上) ----- */
.tj-breadcrumbs-bar {
	background: #000;
	color: rgba(255, 255, 255, 0.82);
	padding: clamp(1.25rem, 3vw, 1.75rem) 0;
	border: none;
	font-family: var(--tj-font-mincho);
}

.tj-breadcrumbs-bar__inner {
	width: min(1200px, calc(100% - 2.5rem));
	margin-inline: auto;
}

.tj-breadcrumbs-bar .tj-breadcrumbs__list {
	margin: 0;
}

.tj-breadcrumbs-bar .tj-breadcrumbs__link {
	color: rgba(255, 255, 255, 0.72);
	text-decoration: none;
}

.tj-breadcrumbs-bar .tj-breadcrumbs__link:hover,
.tj-breadcrumbs-bar .tj-breadcrumbs__link:focus-visible {
	color: #fff;
	text-decoration: underline;
	text-underline-offset: 0.2em;
}

.tj-breadcrumbs-bar .tj-breadcrumbs__current {
	color: #fff;
}

.tj-breadcrumbs-bar .tj-breadcrumbs__item:not(:last-child)::after {
	content: "/";
	margin-inline: 0.35rem;
	color: rgba(255, 255, 255, 0.35);
}

/* ----- Footer ----- */
.tj-footer {
	background: #000;
	color: rgba(255, 255, 255, 0.82);
	padding: clamp(2.5rem, 5vw, 4rem) 0 2rem;
	font-family: var(--tj-font-mincho);
}

.tj-footer__inner {
	width: min(1200px, calc(100% - 2.5rem));
	margin-inline: auto;
}

.tj-footer__top {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	justify-content: space-between;
	gap: 1rem 1.5rem;
}

.tj-footer__brand {
	flex: 0 0 auto;
	text-decoration: none;
	color: inherit;
}

.tj-footer__site-name {
	font-size: 1.125rem;
	font-weight: 600;
	text-decoration: none;
	color: #fff;
}

.tj-footer__nav {
	flex: 1 1 auto;
	min-width: 0;
}

.tj-footnav__list {
	list-style: none;
	margin: 0;
	padding: 0;
	display: flex;
	flex-wrap: wrap;
	gap: 0.5rem 1rem;
}

.tj-footnav__link {
	color: rgba(255, 255, 255, 0.82);
	text-decoration: none;
	font-size: 0.875rem;
}

.tj-footnav__link:hover,
.tj-footnav__link:focus-visible {
	color: #fff;
	text-decoration: underline;
	text-underline-offset: 0.2em;
}

.tj-footer__copy {
	margin: 1.5rem 0 0;
	padding-top: 1.25rem;
	border-top: 1px solid rgba(255, 255, 255, 0.1);
	font-size: 0.75rem;
	color: rgba(255, 255, 255, 0.55);
}

@media (min-width: 900px) {
	.tj-footer__copy {
		margin-top: 2rem;
	}
}

/* ----- Front hero ----- */
.tj-hero {
	position: relative;
	height: var(--tj-hero-h);
	min-height: var(--tj-hero-h);
	max-height: var(--tj-hero-h);
	overflow: hidden;
}

.tj-hero__grid {
	display: grid;
	grid-template-columns: repeat(2, minmax(0, 1fr));
	grid-template-rows: minmax(0, 1fr);
	height: 100%;
	min-height: 0;
}

.tj-hero__media {
	position: relative;
	overflow: hidden;
	min-height: 0;
}

.tj-hero__media img {
	position: absolute;
	inset: 0;
	width: 100%;
	height: 100%;
	object-fit: cover;
}

.tj-hero__overlay {
	position: absolute;
	inset: 0;
	display: grid;
	place-items: center;
	padding: clamp(1.5rem, 4vw, 3rem);
	background: rgba(26, 20, 16, 0.38);
	pointer-events: none;
}

.tj-hero__title {
	margin: 0;
	max-width: 14em;
	font-family: var(--tj-font-mincho);
	font-size: clamp(1.75rem, 3vw + 1rem, 3rem);
	font-weight: 400;
	line-height: 1.45;
	letter-spacing: 0.06em;
	text-align: center;
	color: #fff;
	text-shadow: 0 2px 24px rgba(26, 20, 16, 0.55);
}

.tj-hero__title-line {
	display: block;
}

/* ヘッダー直下〜ヒーローまでの余白をなくす（WP block-gap / root padding 対策） */
main.tj-page--front.alignfull {
	margin-block-start: 0;
	padding-block-start: 0;
	padding-block-end: 0;
}

main.tj-page--front.is-layout-flow {
	gap: 0;
	--wp--style--block-gap: 0;
}

/* is-layout-flow が子に margin-block-start（block-gap）を付与して白帯になるのを防ぐ */
main.tj-page--front.is-layout-flow > * + * {
	margin-block-start: 0 !important;
}

main.tj-page--front > .tj-hero:first-child {
	margin-block-start: calc(-1 * var(--tj-header-h));
}

main.tj-page--jidori-towa,
main.tj-page--seisan-ikusei,
main.tj-page--oshirase,
main.tj-page--contact {
	background: #000;
}

main.tj-page--jidori-towa.alignfull,
main.tj-page--seisan-ikusei.alignfull,
main.tj-page--oshirase.alignfull,
main.tj-page--contact.alignfull {
	display: flow-root;
	margin-block-start: 0;
	padding-block-start: 0;
	padding-block-end: 0;
}

main.tj-page--jidori-towa.is-layout-flow,
main.tj-page--seisan-ikusei.is-layout-flow,
main.tj-page--oshirase.is-layout-flow,
main.tj-page--contact.is-layout-flow {
	gap: 0;
	--wp--style--block-gap: 0;
}

main.tj-page--jidori-towa.is-layout-flow > * + *,
main.tj-page--jidori-towa > * + *,
main.tj-page--seisan-ikusei.is-layout-flow > * + *,
main.tj-page--seisan-ikusei > * + *,
main.tj-page--oshirase.is-layout-flow > * + *,
main.tj-page--oshirase > * + *,
main.tj-page--contact.is-layout-flow > * + *,
main.tj-page--contact > * + * {
	margin-block-start: 0 !important;
}

main.tj-page--jidori-towa > .tj-hero:first-child {
	margin-block-start: calc(-1 * var(--tj-header-h));
}

main.tj-page--jidori-towa > .tj-hero,
main.tj-page--jidori-towa > .tj-jidori-intro,
main.tj-page--jidori-towa > .tj-jidori-page-links,
main.tj-page--seisan-ikusei > .tj-seisan {
	margin-block-end: 0 !important;
}

main.tj-page--front > .tj-hero,
main.tj-page--front > .tj-front-about,
main.tj-page--front > .tj-front-spotlight,
main.tj-page--front > .tj-front-features,
main.tj-page--front > .tj-front-parts,
main.tj-page--front > .tj-front-producer,
main.tj-page--front > .tj-front-oshirase,
main.tj-page--front > .tj-front-faq,
main.tj-page--front > .tj-front-contact {
	margin-block-end: 0 !important;
}

/* main 直下フッターまでの wp-site-blocks 由来の隙間 */
.wp-site-blocks > main.tj-page--front + footer,
.wp-site-blocks > main.tj-page--jidori-towa + footer,
.wp-site-blocks > main.tj-page--seisan-ikusei + footer,
.wp-site-blocks > main.tj-page--oshirase + footer,
.wp-site-blocks > main.tj-page--contact + footer {
	margin-block-start: 0 !important;
}

body:has(main.tj-page--jidori-towa),
body:has(main.tj-page--seisan-ikusei),
body:has(main.tj-page--oshirase),
body:has(main.tj-page--contact) {
	width: 100vw;
	overflow-x: hidden;
	background: #000;
}

body:has(main.tj-page--seisan-ikusei) .tj-header,
body:has(main.tj-page--jidori-towa) .tj-header {
	background: #000;
}

body.tj-seisan-is-pinned {
	overscroll-behavior-y: none;
}

html:has(main.tj-page--jidori-towa),
html:has(main.tj-page--seisan-ikusei),
html:has(main.tj-page--oshirase),
html:has(main.tj-page--contact) {
	background: #000;
}

main.tj-page--oshirase > .tj-oshirase-hero:first-child,
main.tj-page--contact > .tj-contact-hero:first-child {
	margin-block-start: 0;
}

main > .tj-pagehero:first-child {
	margin-block-start: calc(-1 * var(--tj-header-h));
}

.tj-hero.has-global-padding {
	padding-block-start: 0;
	padding-inline: 0;
}

/* ----- Front about (奄美大島風コラージュ) ----- */
.tj-front-about {
	--tj-about-stage-inset: clamp(1.5rem, 10%, 4rem);
	--tj-about-block-padding: clamp(3.25rem, 8vw, 5.5rem);
	--tj-about-block-gap: clamp(2.5rem, 6vw, 4.5rem);
	--tj-about-stage-panel-gap: clamp(1.25rem, 3vw, 2rem);
	--tj-about-section-gap: calc(var(--tj-about-block-padding) + var(--tj-about-block-gap));
	--tj-about-label: color-mix(in srgb, #fff 62%, transparent);
	--tj-about-ink-muted: color-mix(in srgb, #fff 45%, transparent);
	position: relative;
	overflow: hidden;
	padding-block-start: calc(var(--tj-about-block-padding) + var(--tj-about-section-gap));
	padding-block-end: 0;
	padding-inline: 0;
	color: #fff;
	background: #000;
}

.tj-front-about__inner {
	position: relative;
	z-index: 1;
}

/* 画像とテキストを同一ラッパーで重ねる */
.tj-front-about__stage {
	position: relative;
	width: 100%;
	/* padding-top は in-flow の大画像だけを下げる。小画像・タイトルは absolute のためヒーローとの余白には効かない */
	padding-block-end: 0;
}

.tj-front-about__figure {
	margin: 0;
	overflow: hidden;
	box-shadow: 0 20px 50px rgba(0, 0, 0, 0.35);
}

.tj-front-about__figure img {
	display: block;
	width: 100%;
	height: 100%;
	object-fit: cover;
}

.tj-front-about__figure--large {
	position: relative;
	z-index: 1;
	width: 100%;
	aspect-ratio: 21 / 9;
}

.tj-front-about__figure--small {
	position: absolute;
	left: var(--tj-about-stage-inset);
	top: 0;
	z-index: 2;
	width: min(44%, 24rem);
	aspect-ratio: 5 / 3;
	transform: translateY(-28%);
}

.tj-front-about__title {
	position: absolute;
	right: clamp(1.75rem, 7vw, 4.5rem);
	top: clamp(-1.5rem, -1.1vw, -0.9rem);
	z-index: 3;
	display: grid;
	grid-template-columns: auto auto minmax(min-content, 1fr);
	align-items: start;
	column-gap: clamp(0.5rem, 1.15vw, 0.9rem);
	max-width: min(58%, 34rem);
	padding-inline-start: clamp(0.5rem, 2vw, 1rem);
	transform: translateY(clamp(-2.75rem, -5.5vw, -1.75rem));
}

.tj-front-about__label {
	margin: clamp(0.35rem, 1vw, 0.75rem) 0 0;
	align-self: start;
	font-family: var(--tj-font-mincho);
	font-size: clamp(1.1rem, 0.7vw + 0.98rem, 1.45rem);
	font-weight: 400;
	line-height: 1.1;
	letter-spacing: 0.04em;
	white-space: nowrap;
	color: var(--tj-about-label);
}

.tj-front-about__slash {
	display: block;
	width: 1px;
	height: clamp(5.35rem, 10.8vw, 7.5rem);
	margin-block-start: 0.12em;
	margin-inline-end: clamp(1rem, 3.2vw, 2.15rem);
	background: color-mix(in srgb, #fff 55%, transparent);
	transform: rotate(-22deg);
	transform-origin: center top;
}

.tj-front-about__headline {
	display: flex;
	flex-direction: column;
	gap: clamp(0.75rem, 2vw, 1.5rem);
	margin: 0;
	font-family: var(--tj-font-mincho);
	font-weight: 400;
	line-height: 1.1;
	letter-spacing: 0.04em;
	color: #fff;
}

.tj-front-about__headline-line {
	display: block;
	font-size: clamp(1.9rem, 2.6vw + 1rem, 3.15rem);
	line-height: 1.1;
	white-space: nowrap;
}

.tj-front-about__headline-line--muted {
	color: var(--tj-about-ink-muted);
}

@media (max-width: 767px) {
	.tj-front-about {
		--tj-about-block-padding: clamp(2.75rem, 10vw, 4rem);
		--tj-about-block-gap: clamp(2rem, 8vw, 3rem);
		--tj-about-stage-panel-gap: clamp(1rem, 4vw, 1.5rem);
		padding-block-end: 0;
	}

	.tj-front-about__figure--large {
		aspect-ratio: 16 / 10;
	}

	.tj-front-about {
		--tj-about-stage-inset: clamp(1rem, 8%, 2.5rem);
	}

	.tj-front-about__figure--small {
		left: var(--tj-about-stage-inset);
		width: min(50%, 14rem);
		transform: translateY(-24%);
	}

	.tj-front-about__title {
		right: clamp(0.75rem, 5vw, 2rem);
		top: clamp(-1.45rem, -2vw, -0.85rem);
		max-width: min(84%, 22rem);
		transform: translateY(clamp(-2.1rem, -6.75vw, -1.25rem));
		column-gap: clamp(0.35rem, 2.5vw, 0.65rem);
	}

	.tj-front-about__label {
		font-size: clamp(1rem, 2.8vw + 0.82rem, 1.25rem);
	}

	.tj-front-about__slash {
		height: clamp(4.6rem, 18.5vw, 6.1rem);
		margin-block-start: 0.1em;
		margin-inline-end: clamp(0.75rem, 4.5vw, 1.35rem);
		transform: rotate(-20deg);
	}

	.tj-front-about__headline-line {
		font-size: clamp(1.5rem, 5.4vw + 0.45rem, 2.2rem);
	}
}

/* ----- Front about: two-column panel ----- */
.tj-front-about__panel {
	margin-block-start: 0;
	padding-block-start: var(--tj-about-stage-panel-gap);
	padding-block-end: var(--tj-about-block-padding);
	padding-inline-start: var(--tj-about-stage-inset);
	padding-inline-end: clamp(1.75rem, 5vw, 3.5rem);
	color: #fff;
	background: transparent;
}

.tj-front-about__panel-grid {
	display: grid;
	grid-template-columns: minmax(0, 1fr) minmax(0, 1.05fr);
	column-gap: clamp(2rem, 6vw, 5rem);
	row-gap: clamp(2rem, 4vw, 3rem);
	align-items: start;
}

.tj-front-about__panel-headline {
	display: flex;
	flex-direction: column;
	gap: clamp(0.65rem, 1.5vw, 1.1rem);
	margin: 0;
	font-family: var(--tj-font-mincho);
	font-size: clamp(1.85rem, 2.4vw + 1rem, 3rem);
	font-weight: 400;
	line-height: 1.25;
	letter-spacing: 0.06em;
	color: #fff;
}

.tj-front-about__panel-headline-line {
	display: block;
}

.tj-front-about__panel-body-col {
	display: flex;
	flex-direction: column;
	min-height: 100%;
}

.tj-front-about__panel-body {
	font-family: var(--tj-font-mincho);
	font-size: clamp(0.9rem, 0.35vw + 0.82rem, 1.05rem);
	font-weight: 400;
	line-height: 2;
	letter-spacing: 0.04em;
}

.tj-front-about__panel-body p {
	margin: 0 0 1.35em;
}

.tj-front-about__panel-body p:last-child {
	margin-block-end: 0;
}

.tj-front-about__panel-cta-wrap {
	margin: clamp(2rem, 4vw, 3rem) 0 0;
	align-self: flex-end;
}

.tj-front-about__panel-cta {
	display: inline-flex;
	align-items: center;
	gap: clamp(0.85rem, 2vw, 1.35rem);
	font-family: var(--tj-font-mincho);
	font-size: clamp(0.85rem, 0.25vw + 0.78rem, 0.95rem);
	font-weight: 400;
	letter-spacing: 0.08em;
	text-decoration: none;
	color: #fff;
	transition: opacity 0.2s ease;
}

.tj-front-about__panel-cta:hover {
	opacity: 0.82;
}

.tj-front-about__panel-cta-text {
	white-space: nowrap;
}

.tj-front-about__panel-cta-icon {
	display: flex;
	flex-shrink: 0;
	align-items: center;
	justify-content: center;
	width: clamp(2.5rem, 4vw, 2.85rem);
	height: clamp(2.5rem, 4vw, 2.85rem);
	border: 1px solid color-mix(in srgb, #fff 85%, transparent);
	border-radius: 50%;
}

.tj-front-about__panel-cta-arrow {
	display: block;
}

@media (max-width: 767px) {
	.tj-front-about__panel {
		padding-inline-start: var(--tj-about-stage-inset);
		padding-inline-end: clamp(1.25rem, 6vw, 2rem);
	}

	.tj-front-about__panel-grid {
		grid-template-columns: 1fr;
		row-gap: clamp(1.75rem, 6vw, 2.5rem);
	}

	.tj-front-about__panel-headline {
		font-size: clamp(1.55rem, 5.5vw + 0.5rem, 2.15rem);
	}

	.tj-front-about__panel-body {
		line-height: 1.95;
	}

	.tj-front-about__panel-cta-wrap {
		margin-block-start: clamp(1.5rem, 5vw, 2.25rem);
		align-self: flex-start;
	}
}

/* ----- Front spotlight (れんと風 3カラム) ----- */
.tj-front-spotlight {
	--tj-spotlight-bg: #000;
	--tj-spotlight-block-padding: clamp(3.25rem, 8vw, 5.5rem);
	--tj-spotlight-block-gap: clamp(2.5rem, 6vw, 4.5rem);
	--tj-spotlight-section-gap: calc(var(--tj-spotlight-block-padding) + var(--tj-spotlight-block-gap));
	--tj-spotlight-padding-block-start: clamp(2.5rem, 6vw, 4.5rem);
	--tj-spotlight-inset: clamp(1.5rem, 10%, 4rem);
	--tj-spotlight-media-w: clamp(16rem, 36vw, 28rem);
	--tj-spotlight-overlap: clamp(3rem, 12vw, 7rem);
	position: relative;
	overflow: hidden;
	padding-block-start: var(--tj-spotlight-padding-block-start);
	/* about: stage padding-bottom + panel margin-top + panel padding-top と同値 */
	padding-block-end: calc(var(--tj-spotlight-block-padding) + var(--tj-spotlight-section-gap));
	padding-inline: 0;
	color: #fff;
	background: var(--tj-spotlight-bg);
}

.tj-front-spotlight__inner {
	position: relative;
	z-index: 1;
}

.tj-front-spotlight__grid {
	display: grid;
	grid-template-columns: minmax(0, 1fr) var(--tj-spotlight-media-w) minmax(0, 1fr);
	column-gap: clamp(1.25rem, 3.5vw, 2.75rem);
	align-items: center;
	min-height: clamp(26rem, 58vw, 40rem);
}

.tj-front-spotlight__left {
	grid-column: 1 / 3;
	grid-row: 1;
	position: relative;
	z-index: 2;
	align-self: stretch;
	display: flex;
	flex-direction: column;
	justify-content: flex-start;
	overflow: visible;
	padding-inline-start: var(--tj-spotlight-inset);
	padding-block: clamp(0.5rem, 2vw, 1.5rem);
}

.tj-front-spotlight__headline {
	position: relative;
	z-index: 3;
	display: flex;
	flex-direction: column;
	gap: clamp(0.35rem, 1vw, 0.65rem);
	width: fit-content;
	max-width: min(26rem, calc(100% - var(--tj-spotlight-media-w) * 0.15 + var(--tj-spotlight-overlap)));
	margin: 0;
	margin-inline-end: clamp(-5rem, -12vw, -2rem);
	font-family: var(--tj-font-mincho);
	font-size: clamp(1.85rem, 3.2vw + 0.9rem, 3.1rem);
	font-weight: 400;
	line-height: 1.15;
	letter-spacing: 0.04em;
	color: #fff;
}

.tj-front-spotlight__headline-line {
	display: block;
}

.tj-front-spotlight__media {
	position: relative;
	z-index: 1;
	grid-column: 2;
	grid-row: 1;
	align-self: center;
	width: var(--tj-spotlight-media-w);
	margin: 0;
	overflow: hidden;
	box-shadow: 0 24px 56px rgba(0, 0, 0, 0.28);
}

.tj-front-spotlight__media img {
	display: block;
	width: 100%;
	height: 100%;
	aspect-ratio: 2 / 3;
	object-fit: cover;
	object-position: center top;
}

.tj-front-spotlight__right {
	position: relative;
	z-index: 2;
	grid-column: 3;
	grid-row: 1;
	display: flex;
	flex-direction: column;
	justify-content: center;
	min-height: 100%;
	padding-inline-end: clamp(1.75rem, 5vw, 3.5rem);
}

.tj-front-spotlight__copy {
	display: flex;
	flex-direction: column;
	gap: clamp(0.65rem, 1.5vw, 1rem);
}

.tj-front-spotlight__text {
	margin: 0;
	font-family: var(--tj-font-mincho);
	font-size: clamp(0.9rem, 0.35vw + 0.82rem, 1.05rem);
	font-weight: 400;
	line-height: 2;
	letter-spacing: 0.08em;
}

.tj-front-spotlight__cta-wrap {
	margin: clamp(2.5rem, 5vw, 4rem) 0 0;
	align-self: flex-end;
}

.tj-front-spotlight__cta {
	display: inline-flex;
	align-items: center;
	gap: clamp(0.85rem, 2vw, 1.35rem);
	font-family: var(--tj-font-mincho);
	font-size: clamp(0.85rem, 0.25vw + 0.78rem, 0.95rem);
	font-weight: 400;
	letter-spacing: 0.08em;
	text-decoration: none;
	color: #fff;
	transition: opacity 0.2s ease;
}

.tj-front-spotlight__cta:hover {
	opacity: 0.82;
}

.tj-front-spotlight__cta-text {
	white-space: nowrap;
}

.tj-front-spotlight__cta-icon {
	display: flex;
	flex-shrink: 0;
	align-items: center;
	justify-content: center;
	width: clamp(2.5rem, 4vw, 2.85rem);
	height: clamp(2.5rem, 4vw, 2.85rem);
	border: 1px solid color-mix(in srgb, #fff 85%, transparent);
	border-radius: 50%;
	background: color-mix(in srgb, #fff 12%, transparent);
}

.tj-front-spotlight__cta-arrow {
	display: block;
}

@media (max-width: 767px) {
	.tj-front-spotlight {
		--tj-spotlight-block-padding: clamp(2.75rem, 10vw, 4rem);
		--tj-spotlight-block-gap: clamp(2rem, 8vw, 3rem);
		--tj-spotlight-padding-block-start: clamp(2rem, 8vw, 3rem);
		--tj-spotlight-inset: clamp(1rem, 8%, 2.5rem);
		--tj-spotlight-media-w: min(80vw, 18rem);
	}

	.tj-front-spotlight__grid {
		grid-template-columns: 1fr;
		row-gap: clamp(2rem, 7vw, 3rem);
		min-height: 0;
	}

	.tj-front-spotlight__left {
		grid-column: 1;
		grid-row: auto;
		order: 1;
		padding-inline: var(--tj-spotlight-inset);
		padding-block: 0;
	}

	.tj-front-spotlight__headline {
		width: auto;
		max-width: none;
		margin-inline-end: 0;
		font-size: clamp(1.45rem, 5vw + 0.45rem, 2.15rem);
	}

	.tj-front-spotlight__media {
		order: 2;
		grid-column: 1;
		grid-row: auto;
		justify-self: center;
		width: var(--tj-spotlight-media-w);
	}

	.tj-front-spotlight__right {
		order: 3;
		grid-column: 1;
		grid-row: auto;
		padding-inline: var(--tj-spotlight-inset);
	}

	.tj-front-spotlight__cta-wrap {
		margin-block-start: clamp(1.75rem, 6vw, 2.5rem);
		align-self: flex-start;
	}
}

/* ----- Front features (こだわり・左右交互) ----- */
.tj-front-features {
	--tj-feature-block-gap: clamp(1.5rem, 4vw, 3rem);
	display: flex;
	flex-direction: column;
	gap: var(--tj-feature-block-gap);
	background-color: #000;
}

.tj-front-feature {
	--tj-feature-min-h: 100vh;
	--tj-feature-min-h: 100svh;
	--tj-feature-min-h: 100dvh;
	--tj-feature-inset: clamp(1.5rem, 8vw, 4.5rem);
	--tj-feature-content-w: min(28rem, 48vw);
	--tj-feature-label: color-mix(in srgb, #fff 62%, transparent);
	--tj-feature-scrim-strong: rgba(12, 10, 8, 0.78);
	--tj-feature-scrim-soft: rgba(12, 10, 8, 0.2);
	position: relative;
	display: flex;
	align-items: stretch;
	min-height: var(--tj-feature-min-h);
	overflow: hidden;
	color: #fff;
}

.tj-front-feature__bg {
	position: absolute;
	inset: 0;
	background-color: var(--tj-dark);
	background-size: cover;
	background-position: center;
	background-repeat: no-repeat;
}

.tj-front-feature__scrim {
	position: absolute;
	inset: 0;
	pointer-events: none;
}

.tj-front-feature--left .tj-front-feature__scrim {
	background: linear-gradient(
		90deg,
		var(--tj-feature-scrim-strong) 0%,
		color-mix(in srgb, var(--tj-feature-scrim-strong) 72%, transparent) 38%,
		var(--tj-feature-scrim-soft) 62%,
		transparent 100%
	);
}

.tj-front-feature--right .tj-front-feature__scrim {
	background: linear-gradient(
		270deg,
		var(--tj-feature-scrim-strong) 0%,
		color-mix(in srgb, var(--tj-feature-scrim-strong) 72%, transparent) 38%,
		var(--tj-feature-scrim-soft) 62%,
		transparent 100%
	);
}

.tj-front-feature__inner {
	position: relative;
	z-index: 1;
	display: flex;
	align-items: center;
	width: 100%;
	min-height: var(--tj-feature-min-h);
	padding-block: clamp(3rem, 8vw, 5.5rem);
	padding-inline: var(--tj-feature-inset);
}

.tj-front-feature--left .tj-front-feature__inner {
	justify-content: flex-start;
}

.tj-front-feature--right .tj-front-feature__inner {
	justify-content: flex-end;
}

.tj-front-feature__content {
	width: var(--tj-feature-content-w);
	max-width: 100%;
}

.tj-front-feature__label {
	margin: 0 0 0.85rem;
	font-family: var(--tj-font-mincho);
	font-size: clamp(0.75rem, 0.2vw + 0.7rem, 0.85rem);
	font-weight: 400;
	line-height: 1.1;
	letter-spacing: 0.08em;
	color: var(--tj-feature-label);
}

.tj-front-feature__title {
	margin: 0 0 clamp(1.25rem, 3vw, 1.75rem);
	font-family: var(--tj-font-mincho);
	font-size: clamp(1.85rem, 2.4vw + 1rem, 3rem);
	font-weight: 400;
	line-height: 1.25;
	letter-spacing: 0.04em;
}

.tj-front-feature__body {
	font-family: var(--tj-font-mincho);
	font-size: clamp(0.9rem, 0.35vw + 0.82rem, 1.05rem);
	font-weight: 400;
	line-height: 2;
	letter-spacing: 0.04em;
}

.tj-front-feature__body p {
	margin: 0 0 1.15em;
}

.tj-front-feature__body p:last-child {
	margin-block-end: 0;
}

.tj-front-feature__actions {
	display: flex;
	flex-wrap: wrap;
	gap: 0.85rem 1rem;
	margin-block-start: clamp(1.75rem, 4vw, 2.5rem);
}

.tj-front-feature__btn {
	display: inline-flex;
	align-items: center;
	gap: 0.65rem;
	padding: 0.55rem 1.1rem;
	font-family: var(--tj-font-mincho);
	font-size: clamp(0.85rem, 0.25vw + 0.78rem, 0.95rem);
	font-weight: 400;
	line-height: 1.4;
	letter-spacing: 0.08em;
	color: #fff;
	text-decoration: none;
	border: 1px solid color-mix(in srgb, #fff 55%, transparent);
	transition: background-color 0.2s ease, border-color 0.2s ease;
}

.tj-front-feature__btn:hover {
	background: color-mix(in srgb, #fff 12%, transparent);
	border-color: #fff;
}

.tj-front-feature__btn--link {
	padding-inline-end: 1rem;
	font-family: var(--tj-font-mincho);
}

.tj-front-feature__btn-icon {
	display: inline-flex;
	flex-shrink: 0;
	align-items: center;
	justify-content: center;
}

.tj-front-feature__btn-play-svg {
	display: block;
}

.tj-front-feature__btn-arrow {
	display: block;
}

@media (max-width: 767px) {
	.tj-front-features {
		--tj-feature-block-gap: clamp(1.25rem, 5vw, 2rem);
	}

	.tj-front-feature {
		--tj-feature-content-w: 100%;
	}

	.tj-front-feature--left .tj-front-feature__scrim,
	.tj-front-feature--right .tj-front-feature__scrim {
		background: linear-gradient(
			180deg,
			var(--tj-feature-scrim-soft) 0%,
			color-mix(in srgb, var(--tj-feature-scrim-strong) 88%, transparent) 42%,
			var(--tj-feature-scrim-strong) 100%
		);
	}

	.tj-front-feature__inner {
		align-items: flex-end;
		justify-content: flex-start;
		padding-block: clamp(2.5rem, 10vw, 4rem);
	}

	.tj-front-feature__title {
		font-size: clamp(1.55rem, 5.5vw + 0.5rem, 2.15rem);
	}

	.tj-front-feature__body {
		line-height: 1.95;
	}

	.tj-front-feature__actions {
		flex-direction: column;
		align-items: flex-start;
	}
}

/* ----- Scroll reveal (front page images) ----- */
.tj-scroll-reveal > img,
.tj-front-feature__bg.tj-scroll-reveal {
	--tj-reveal-duration: 1.8s;
	opacity: 0;
	transform: scale(1.08);
	filter: blur(12px);
	transition:
		opacity var(--tj-reveal-duration) cubic-bezier(0.22, 1, 0.36, 1),
		transform calc(var(--tj-reveal-duration) * 1.05) cubic-bezier(0.22, 1, 0.36, 1),
		filter var(--tj-reveal-duration) cubic-bezier(0.22, 1, 0.36, 1);
	will-change: opacity, transform, filter;
}

.tj-scroll-reveal.is-revealed > img,
.tj-front-feature__bg.tj-scroll-reveal.is-revealed {
	opacity: 1;
	transform: scale(1);
	filter: blur(0);
}

.tj-scroll-reveal--delay > img,
.tj-front-feature__bg.tj-scroll-reveal--delay {
	transition-delay: 0.4s;
}

@media (prefers-reduced-motion: reduce) {
	.tj-scroll-reveal > img,
	.tj-front-feature__bg.tj-scroll-reveal {
		opacity: 1;
		transform: none;
		filter: none;
		transition: none;
	}
}

/* ----- Front parts & delivery info (お届け・取り扱い) ----- */
.tj-front-parts {
	--tj-parts-block-padding: clamp(3.25rem, 8vw, 5.5rem);
	--tj-parts-block-gap: clamp(2.5rem, 6vw, 4.5rem);
	--tj-parts-section-gap: calc(var(--tj-parts-block-padding) + var(--tj-parts-block-gap));
	--tj-parts-inset: clamp(1.5rem, 10%, 4rem);
	--tj-parts-bg: #000;
	--tj-parts-cell-bg: transparent;
	--tj-parts-cell-ink: #fff;
	--tj-parts-row-border: #fff;
	position: relative;
	overflow: hidden;
	padding-block-start: calc(var(--tj-parts-block-padding) + var(--tj-parts-section-gap));
	padding-block-end: var(--tj-parts-block-padding);
	padding-inline: 0;
	color: #fff;
	background: var(--tj-parts-bg);
}

.tj-front-parts__inner {
	position: relative;
	z-index: 1;
	display: flex;
	flex-direction: column;
	gap: clamp(2rem, 4vw, 3rem);
}

.tj-front-parts__grid {
	display: grid;
	grid-template-columns: minmax(0, 1.3fr) minmax(0, 1.7fr);
	grid-template-rows: auto auto;
	column-gap: clamp(0.75rem, 2vw, 1.5rem);
	row-gap: clamp(1.75rem, 3.5vw, 2.5rem);
	align-items: start;
}

.tj-front-parts__content {
	grid-column: 1;
	grid-row: 1;
	align-self: stretch;
	display: flex;
	flex-direction: column;
	justify-content: center;
	padding-inline: 0;
}

.tj-front-parts__media {
	grid-column: 2;
	grid-row: 1;
	align-self: start;
	display: flex;
	flex-direction: column;
	align-items: flex-start;
	width: 100%;
	margin: 0;
}

.tj-front-parts__title {
	position: absolute;
	width: 1px;
	height: 1px;
	padding: 0;
	margin: -1px;
	overflow: hidden;
	clip: rect(0, 0, 0, 0);
	white-space: nowrap;
	border: 0;
}

.tj-front-parts__row2 {
	grid-column: 1 / -1;
	grid-row: 2;
	display: grid;
	grid-template-columns: minmax(0, 2fr) minmax(0, 1fr);
	column-gap: clamp(0.75rem, 2vw, 1.5rem);
	align-items: start;
}

.tj-front-parts__intro {
	grid-column: 1;
	align-self: start;
	width: 100%;
	max-width: none;
	margin: 0;
	padding-inline: 0;
	font-family: var(--tj-font-mincho);
	font-size: clamp(0.9rem, 0.35vw + 0.82rem, 1.05rem);
	font-weight: 400;
	line-height: 2;
	letter-spacing: 0.06em;
}

.tj-front-parts__intro p {
	margin: 0 0 0.35em;
}

.tj-front-parts__intro p:last-child {
	margin-block-end: 0;
}

.tj-front-parts__info-table {
	width: 100%;
}

.tj-front-parts__info-table-body {
	border: none;
}

.tj-front-parts__info-row {
	display: grid;
	grid-template-columns: minmax(7.5rem, 38%) minmax(0, 1fr);
	border: none;
}

.tj-front-parts__info-row + .tj-front-parts__info-row {
	border-block-start: 1px solid var(--tj-parts-row-border);
}

.tj-front-parts__info-cell {
	display: flex;
	align-items: center;
	justify-content: flex-start;
	min-height: 0;
	padding: clamp(1rem, 2.2vw, 1.35rem) clamp(1rem, 2vw, 1.5rem);
	font-family: var(--tj-font-mincho);
	font-size: clamp(0.88rem, 0.3vw + 0.8rem, 1rem);
	line-height: 1.6;
	letter-spacing: 0.06em;
	text-align: left;
}

.tj-front-parts__info-cell--label {
	font-weight: 700;
	color: var(--tj-parts-cell-ink);
	background: var(--tj-parts-cell-bg);
}

.tj-front-parts__info-cell--value {
	font-weight: 400;
	color: var(--tj-parts-cell-ink);
	background: var(--tj-parts-cell-bg);
}

.tj-front-parts__cta-wrap {
	grid-column: 2;
	display: flex;
	justify-content: flex-end;
	align-self: start;
	width: 100%;
	margin: 0;
}

.tj-front-parts__cta {
	display: inline-flex;
	align-items: center;
	gap: clamp(0.85rem, 2vw, 1.35rem);
	font-family: var(--tj-font-mincho);
	font-size: clamp(0.85rem, 0.25vw + 0.78rem, 0.95rem);
	font-weight: 400;
	letter-spacing: 0.08em;
	text-decoration: none;
	color: #fff;
	transition: opacity 0.2s ease;
}

.tj-front-parts__cta:hover {
	opacity: 0.72;
}

.tj-front-parts__cta-icon {
	display: flex;
	flex-shrink: 0;
	align-items: center;
	justify-content: center;
	width: clamp(2.5rem, 4vw, 2.85rem);
	height: clamp(2.5rem, 4vw, 2.85rem);
	border: 1px solid color-mix(in srgb, #fff 35%, transparent);
	border-radius: 50%;
}

.tj-front-parts__cta-arrow {
	display: block;
}

.tj-front-parts__slider {
	width: 100%;
}

.tj-front-parts__slider-viewport {
	overflow: hidden;
	width: 100%;
	aspect-ratio: 4 / 3;
	box-shadow: 0 20px 48px rgba(26, 20, 16, 0.12);
}

.tj-front-parts__slider-track {
	position: relative;
	width: 100%;
	height: 100%;
}

.tj-front-parts__slide {
	position: absolute;
	inset: 0;
	width: 100%;
	height: 100%;
	transform: translateY(-100%);
	transition: transform 650ms ease;
	z-index: 0;
	visibility: hidden;
}

.tj-front-parts__slide.is-active {
	transform: translateY(0);
	z-index: 1;
	visibility: visible;
}

.tj-front-parts__slide.is-leaving {
	transform: translateY(100%);
	z-index: 1;
	visibility: visible;
}

.tj-front-parts__slide.is-entering,
.tj-front-parts__slide.is-entering-from {
	z-index: 2;
	visibility: visible;
}

.tj-front-parts__slide.is-entering-from {
	transform: translateY(-100%);
	transition: none;
}

.tj-front-parts__slide.is-entering {
	transform: translateY(0);
}

.tj-front-parts__slide img {
	display: block;
	width: 100%;
	height: 100%;
	object-fit: cover;
	object-position: center;
}

.tj-front-parts__slider-status {
	margin: 0;
}

@media (prefers-reduced-motion: reduce) {
	.tj-front-parts__slide {
		transition: none !important;
	}
}

@media (max-width: 767px) {
	.tj-front-parts {
		--tj-parts-block-padding: clamp(2.75rem, 10vw, 4rem);
		--tj-parts-block-gap: clamp(2rem, 8vw, 3rem);
		--tj-parts-inset: clamp(1rem, 8%, 2.5rem);
	}

	.tj-front-parts__grid {
		grid-template-columns: 1fr;
		grid-template-rows: auto;
		row-gap: clamp(2rem, 7vw, 3rem);
	}

	.tj-front-parts__media {
		grid-column: 1;
		grid-row: auto;
		order: 1;
	}

	.tj-front-parts__content {
		grid-column: 1;
		grid-row: auto;
		order: 2;
		align-self: auto;
		display: block;
		padding-inline: 0;
	}

	.tj-front-parts__row2 {
		grid-column: 1;
		grid-row: auto;
		order: 3;
		grid-template-columns: 1fr;
		row-gap: clamp(1.25rem, 4vw, 1.75rem);
	}

	.tj-front-parts__intro {
		grid-column: 1;
		align-self: auto;
	}

	.tj-front-parts__cta-wrap {
		grid-column: 1;
		justify-content: flex-start;
		align-self: auto;
	}
}

/* ----- Front producer (生産者の想い) ----- */
.tj-front-producer {
	--tj-producer-block-padding: clamp(3.25rem, 8vw, 5.5rem);
	--tj-producer-block-gap: clamp(2.5rem, 6vw, 4.5rem);
	--tj-producer-section-gap: calc(var(--tj-producer-block-padding) + var(--tj-producer-block-gap));
	position: relative;
	overflow: hidden;
	padding-block-start: calc(var(--tj-producer-block-padding) + var(--tj-producer-section-gap));
	padding-block-end: var(--tj-producer-block-padding);
	padding-inline: 0;
	color: #fff;
	background: #000;
}

.tj-front-producer__inner {
	position: relative;
	z-index: 1;
}

.tj-front-producer__grid {
	display: grid;
	grid-template-columns: minmax(0, 0.95fr) minmax(0, 1.15fr) minmax(0, 0.75fr);
	column-gap: clamp(1.25rem, 3vw, 2.5rem);
	row-gap: clamp(2rem, 4vw, 3rem);
	align-items: center;
}

.tj-front-producer__portrait {
	margin: 0;
	overflow: hidden;
	box-shadow: 0 20px 48px rgba(0, 0, 0, 0.28);
}

.tj-front-producer__portrait img {
	display: block;
	width: 100%;
	height: 100%;
	aspect-ratio: 4 / 5;
	object-fit: cover;
	object-position: center;
}

.tj-front-producer__content {
	display: flex;
	flex-direction: column;
	justify-content: center;
	min-height: 100%;
	padding-inline: clamp(0.25rem, 2vw, 1rem);
}

.tj-front-producer__title {
	margin: 0 0 clamp(1.5rem, 3vw, 2.25rem);
	font-family: var(--tj-font-mincho);
	font-size: clamp(1.75rem, 2.4vw + 0.85rem, 2.75rem);
	font-weight: 400;
	line-height: 1.35;
	letter-spacing: 0.06em;
	color: #fff;
}

.tj-front-producer__body {
	font-family: var(--tj-font-mincho);
	font-size: clamp(0.9rem, 0.35vw + 0.82rem, 1.05rem);
	font-weight: 400;
	line-height: 2;
	letter-spacing: 0.06em;
}

.tj-front-producer__body p {
	margin: 0 0 1.1em;
}

.tj-front-producer__body p:last-child {
	margin-block-end: 0;
}

.tj-front-producer__cta-wrap {
	margin: clamp(2rem, 4vw, 3rem) 0 0;
}

.tj-front-producer__cta {
	display: inline-flex;
	align-items: center;
	gap: clamp(0.85rem, 2vw, 1.35rem);
	font-family: var(--tj-font-mincho);
	font-size: clamp(0.85rem, 0.25vw + 0.78rem, 0.95rem);
	font-weight: 400;
	letter-spacing: 0.08em;
	text-decoration: none;
	color: #fff;
	transition: opacity 0.2s ease;
}

.tj-front-producer__cta:hover {
	opacity: 0.72;
}

.tj-front-producer__cta-icon {
	display: flex;
	flex-shrink: 0;
	align-items: center;
	justify-content: center;
	width: clamp(2.5rem, 4vw, 2.85rem);
	height: clamp(2.5rem, 4vw, 2.85rem);
	border: 1px solid color-mix(in srgb, #fff 35%, transparent);
	border-radius: 50%;
}

.tj-front-producer__cta-arrow {
	display: block;
}

.tj-front-producer__stack {
	display: flex;
	flex-direction: column;
	gap: clamp(0.85rem, 2vw, 1.25rem);
	align-self: stretch;
	justify-content: center;
}

.tj-front-producer__mini {
	margin: 0;
	overflow: hidden;
	box-shadow: 0 16px 36px rgba(0, 0, 0, 0.24);
}

.tj-front-producer__mini img {
	display: block;
	width: 100%;
	height: 100%;
	aspect-ratio: 5 / 3.6;
	object-fit: cover;
	object-position: center;
}

@media (max-width: 767px) {
	.tj-front-producer {
		--tj-producer-block-padding: clamp(2.75rem, 10vw, 4rem);
		--tj-producer-block-gap: clamp(2rem, 8vw, 3rem);
	}

	.tj-front-producer__grid {
		grid-template-columns: 1fr;
		row-gap: clamp(1.75rem, 6vw, 2.5rem);
	}

	.tj-front-producer__portrait {
		order: 1;
	}

	.tj-front-producer__content {
		order: 2;
		padding-inline: 0;
	}

	.tj-front-producer__stack {
		order: 3;
		flex-direction: row;
	}

	.tj-front-producer__mini {
		flex: 1 1 0;
		min-width: 0;
	}
}

/* ----- Front oshirase (お知らせ) ----- */
.tj-front-oshirase {
	--tj-oshirase-block-padding: clamp(3.25rem, 8vw, 5.5rem);
	--tj-oshirase-block-gap: clamp(2.5rem, 6vw, 4.5rem);
	--tj-oshirase-section-gap: calc(var(--tj-oshirase-block-padding) + var(--tj-oshirase-block-gap));
	--tj-oshirase-row-border: #fff;
	position: relative;
	overflow: hidden;
	padding-block-start: calc(var(--tj-oshirase-block-padding) + var(--tj-oshirase-section-gap));
	padding-block-end: var(--tj-oshirase-block-padding);
	padding-inline: 0;
	color: #fff;
	background: #000;
}

.tj-front-oshirase__inner {
	position: relative;
	z-index: 1;
	display: flex;
	flex-direction: column;
	gap: clamp(2rem, 4vw, 3rem);
}

.tj-front-oshirase__header {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	justify-content: space-between;
	gap: 1rem 1.5rem;
}

.tj-front-oshirase__title {
	margin: 0;
	font-family: var(--tj-font-mincho);
	font-size: clamp(1.75rem, 2.4vw + 0.85rem, 2.75rem);
	font-weight: 400;
	line-height: 1.35;
	letter-spacing: 0.06em;
	color: #fff;
}

.tj-front-oshirase__cta-wrap {
	margin: 0;
}

.tj-front-oshirase__cta {
	display: inline-flex;
	align-items: center;
	gap: clamp(0.85rem, 2vw, 1.35rem);
	font-family: var(--tj-font-mincho);
	font-size: clamp(0.85rem, 0.25vw + 0.78rem, 0.95rem);
	font-weight: 400;
	letter-spacing: 0.08em;
	text-decoration: none;
	color: #fff;
	transition: opacity 0.2s ease;
}

.tj-front-oshirase__cta:hover {
	opacity: 0.72;
}

.tj-front-oshirase__cta-icon {
	display: flex;
	flex-shrink: 0;
	align-items: center;
	justify-content: center;
	width: clamp(2.5rem, 4vw, 2.85rem);
	height: clamp(2.5rem, 4vw, 2.85rem);
	border: 1px solid color-mix(in srgb, #fff 35%, transparent);
	border-radius: 50%;
}

.tj-front-oshirase__cta-arrow {
	display: block;
}

.tj-front-oshirase__list {
	display: grid;
	gap: 0;
	border-block-start: 1px solid color-mix(in srgb, var(--tj-oshirase-row-border) 22%, transparent);
}

.tj-front-oshirase__item {
	display: grid;
	grid-template-columns: minmax(6.5rem, 7.5rem) minmax(4.5rem, 6rem) minmax(0, 1fr);
	column-gap: clamp(1rem, 2.5vw, 1.75rem);
	align-items: center;
	padding-block: clamp(1.15rem, 2.5vw, 1.5rem);
	border-block-end: 1px solid color-mix(in srgb, var(--tj-oshirase-row-border) 22%, transparent);
}

.tj-front-oshirase__date {
	font-family: var(--tj-font-gothic);
	font-size: clamp(0.8125rem, 0.2vw + 0.76rem, 0.9375rem);
	font-weight: 500;
	letter-spacing: 0.04em;
	color: color-mix(in srgb, #fff 62%, transparent);
	white-space: nowrap;
}

.tj-front-oshirase__tag {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	min-width: 4.5rem;
	padding: 0.25rem 0.65rem;
	font-family: var(--tj-font-gothic);
	font-size: 0.75rem;
	font-weight: 600;
	line-height: 1.4;
	letter-spacing: 0.04em;
	color: var(--tj-gold);
	border: 1px solid color-mix(in srgb, var(--tj-gold) 45%, transparent);
	border-radius: 999px;
	white-space: nowrap;
}

.tj-front-oshirase__item-title {
	margin: 0;
	font-family: var(--tj-font-mincho);
	font-size: clamp(0.95rem, 0.35vw + 0.86rem, 1.1rem);
	font-weight: 400;
	line-height: 1.65;
	letter-spacing: 0.04em;
}

.tj-front-oshirase__item-title a {
	text-decoration: none;
	color: #fff;
	transition: color 0.2s ease;
}

.tj-front-oshirase__item-title a:hover {
	color: var(--tj-gold);
}

.tj-front-oshirase__empty {
	margin: 0;
	padding-block: clamp(1.5rem, 3vw, 2rem);
	font-family: var(--tj-font-mincho);
	font-size: clamp(0.9rem, 0.35vw + 0.82rem, 1rem);
	line-height: 1.8;
	letter-spacing: 0.04em;
	color: color-mix(in srgb, #fff 65%, transparent);
}

@media (max-width: 767px) {
	.tj-front-oshirase {
		--tj-oshirase-block-padding: clamp(2.75rem, 10vw, 4rem);
		--tj-oshirase-block-gap: clamp(2rem, 8vw, 3rem);
	}

	.tj-front-oshirase__header {
		flex-direction: column;
		align-items: flex-start;
	}

	.tj-front-oshirase__item {
		grid-template-columns: 1fr;
		row-gap: 0.5rem;
		align-items: start;
	}

	.tj-front-oshirase__tag {
		justify-self: start;
	}
}

/* ----- Front FAQ (よくあるご質問) ----- */
.tj-front-faq {
	--tj-faq-block-padding: clamp(3.25rem, 8vw, 5.5rem);
	--tj-faq-block-gap: clamp(2.5rem, 6vw, 4.5rem);
	--tj-faq-section-gap: calc(var(--tj-faq-block-padding) + var(--tj-faq-block-gap));
	--tj-faq-row-border: #fff;
	position: relative;
	overflow: hidden;
	padding-block-start: calc(var(--tj-faq-block-padding) + var(--tj-faq-section-gap));
	padding-block-end: var(--tj-faq-block-padding);
	padding-inline: 0;
	color: #fff;
	background: #000;
}

.tj-front-faq__inner {
	position: relative;
	z-index: 1;
	display: flex;
	flex-direction: column;
	gap: clamp(2rem, 4vw, 3rem);
}

.tj-front-faq__title {
	margin: 0;
	font-family: var(--tj-font-mincho);
	font-size: clamp(1.75rem, 2.4vw + 0.85rem, 2.75rem);
	font-weight: 400;
	line-height: 1.35;
	letter-spacing: 0.06em;
	color: #fff;
}

.tj-front-faq__list {
	display: grid;
	gap: 0;
	border-block-start: 1px solid color-mix(in srgb, var(--tj-faq-row-border) 22%, transparent);
}

.tj-front-faq .tj-acc {
	border: none;
	border-radius: 0;
	background: transparent;
	overflow: hidden;
	border-block-end: 1px solid color-mix(in srgb, var(--tj-faq-row-border) 22%, transparent);
}

.tj-front-faq .tj-acc__q {
	position: relative;
	z-index: 1;
	padding: clamp(1.15rem, 2.5vw, 1.5rem) clamp(2.5rem, 5vw, 3rem) clamp(1.15rem, 2.5vw, 1.5rem) 0;
	margin: 0;
	font-family: var(--tj-font-mincho);
	font-size: clamp(0.95rem, 0.35vw + 0.86rem, 1.1rem);
	font-weight: 400;
	line-height: 1.65;
	letter-spacing: 0.04em;
	list-style: none;
	cursor: pointer;
	color: #fff;
}

.tj-front-faq .tj-acc__q::-webkit-details-marker {
	display: none;
}

.tj-front-faq .tj-acc__q::after {
	content: "";
	position: absolute;
	right: 0;
	top: 50%;
	width: 0.45rem;
	height: 0.45rem;
	margin-top: -0.28rem;
	border-right: 1.5px solid currentcolor;
	border-bottom: 1.5px solid currentcolor;
	transform: rotate(45deg);
	opacity: 0.62;
	transition: transform 420ms cubic-bezier(0.33, 1, 0.68, 1);
}

@media (prefers-reduced-motion: reduce) {
	.tj-front-faq .tj-acc__q::after {
		transition: none;
	}
}

.tj-front-faq .tj-acc.is-open .tj-acc__q::after {
	transform: rotate(225deg);
	margin-top: -0.12rem;
}

.tj-front-faq .tj-acc__q:focus-visible {
	outline: 2px solid var(--tj-gold);
	outline-offset: -2px;
}

.tj-front-faq .tj-acc__a {
	max-height: 0;
	overflow: hidden;
	transition: max-height 420ms cubic-bezier(0.33, 1, 0.68, 1);
	padding: 0;
	border-top: none;
}

.tj-front-faq .tj-acc__a p {
	margin: 0;
	padding-bottom: clamp(1.15rem, 2.5vw, 1.5rem);
	font-family: var(--tj-font-mincho);
	font-size: clamp(0.9rem, 0.35vw + 0.82rem, 1rem);
	font-weight: 400;
	line-height: 1.8;
	letter-spacing: 0.04em;
	color: color-mix(in srgb, #fff 65%, transparent);
}

@media (prefers-reduced-motion: reduce) {
	.tj-front-faq .tj-acc__a {
		transition: none;
	}

	.tj-front-faq .tj-acc[open] > .tj-acc__a {
		max-height: none;
	}
}

@media (max-width: 767px) {
	.tj-front-faq {
		--tj-faq-block-padding: clamp(2.75rem, 10vw, 4rem);
		--tj-faq-block-gap: clamp(2rem, 8vw, 3rem);
	}
}

/* ----- Front contact (お問い合わせ) ----- */
.tj-front-contact {
	--tj-contact-block-padding: clamp(3.25rem, 8vw, 5.5rem);
	--tj-contact-field-border: #fff;
	position: relative;
	overflow: hidden;
	padding-block: var(--tj-contact-block-padding);
	padding-inline: 0;
	color: #fff;
	background: #000;
	font-family: var(--tj-font-mincho);
}

.tj-front-contact__inner {
	position: relative;
	z-index: 1;
	display: flex;
	flex-direction: column;
	align-items: center;
	gap: clamp(2rem, 4vw, 3rem);
	width: 100%;
}

.tj-front-contact__header {
	display: grid;
	gap: clamp(1rem, 2vw, 1.5rem);
	width: min(100%, 40rem);
	max-width: 40rem;
	text-align: center;
}

.tj-front-contact__title {
	margin: 0;
	font-family: var(--tj-font-mincho);
	font-size: clamp(1.75rem, 2.4vw + 0.85rem, 2.75rem);
	font-weight: 400;
	line-height: 1.35;
	letter-spacing: 0.06em;
	color: #fff;
}

.tj-front-contact__lead {
	margin: 0;
	font-size: clamp(0.875rem, 0.25vw + 0.82rem, 0.95rem);
	line-height: 1.85;
	letter-spacing: 0.04em;
	color: color-mix(in srgb, #fff 65%, transparent);
}

.tj-front-contact__form {
	width: min(100%, 40rem);
	max-width: 40rem;
	margin-inline: auto;
}

.tj-front-contact__form .tj-form,
.tj-front-contact__form .tj-contact-form {
	width: 100%;
	margin-inline: auto;
}

.tj-front-contact .tj-form__actions {
	display: flex;
	justify-content: center;
}

.tj-front-contact .tj-form__label {
	color: #fff;
}

.tj-front-contact .tj-form__badge {
	color: var(--tj-gold);
}

.tj-front-contact .tj-form__hint {
	color: color-mix(in srgb, #fff 55%, transparent);
}

.tj-front-contact .tj-form input[type="text"],
.tj-front-contact .tj-form input[type="email"],
.tj-front-contact .tj-form input[type="tel"],
.tj-front-contact .tj-form select,
.tj-front-contact .tj-form textarea {
	color: #fff;
	background: color-mix(in srgb, #fff 6%, #000);
	border-color: color-mix(in srgb, var(--tj-contact-field-border) 22%, transparent);
}

.tj-front-contact .tj-form input::placeholder,
.tj-front-contact .tj-form textarea::placeholder {
	color: color-mix(in srgb, #fff 38%, transparent);
	opacity: 1;
}

.tj-front-contact .tj-form select:required:invalid {
	color: color-mix(in srgb, #fff 38%, transparent);
}

.tj-front-contact .tj-form__notice--success {
	background: color-mix(in srgb, var(--tj-gold) 12%, #000);
	border-color: color-mix(in srgb, var(--tj-gold) 35%, transparent);
	color: #fff;
}

.tj-front-contact .tj-form__notice--error {
	background: color-mix(in srgb, var(--tj-brand) 18%, #000);
	border-color: color-mix(in srgb, var(--tj-brand) 40%, transparent);
	color: #fff;
}

.tj-front-contact .tj-form__check {
	color: color-mix(in srgb, #fff 82%, transparent);
}

.tj-front-contact .tj-form__btn {
	background: var(--tj-brand);
	color: #fff;
}

.tj-front-contact .tj-form__btn:hover {
	background: color-mix(in srgb, var(--tj-brand) 88%, #000);
}

@media (max-width: 767px) {
	.tj-front-contact {
		--tj-contact-block-padding: clamp(2.75rem, 10vw, 4rem);
	}
}

/* ----- Page / Feed ----- */
.tj-page,
.tj-feed,
main.tj-single {
	margin-block-start: 0;
	padding-block-start: 0;
	padding-top: 0;
	background: #000;
	color: rgba(255, 255, 255, 0.92);
}

.wp-site-blocks {
	background: #000;
}

.tj-page--front .tj-page__inner {
	padding: 0;
}

/* ----- Jidori-towa intro (h2 + text 2-column) ----- */
.tj-jidori-intro {
	--tj-jidori-intro-padding: clamp(3.25rem, 8vw, 5.5rem);
	position: relative;
	overflow: hidden;
	padding-block: var(--tj-jidori-intro-padding);
	padding-inline: 0;
	color: #fff;
	background: #000;
}

.tj-jidori-intro__inner {
	display: flex;
	flex-direction: column;
	gap: clamp(2.5rem, 5vw, 4rem);
}

.tj-jidori-intro__title {
	display: flex;
	flex-direction: column;
	align-items: center;
	gap: clamp(0.35rem, 1.5vw, 0.75rem);
	margin: 0;
	font-family: var(--tj-font-mincho);
	font-weight: 400;
	font-size: clamp(1.65rem, 3.2vw, 2.65rem);
	line-height: 1.5;
	letter-spacing: 0.14em;
	color: #fff;
	text-align: center;
}

.tj-jidori-intro__title-line {
	display: block;
	white-space: nowrap;
}

.tj-jidori-intro__text-grid {
	display: grid;
	grid-template-columns: repeat(2, minmax(0, 1fr));
	column-gap: clamp(2rem, 6vw, 5rem);
	row-gap: clamp(1.75rem, 3.5vw, 2.5rem);
	align-items: start;
}

.tj-jidori-intro__text-col {
	font-family: var(--tj-font-mincho);
	font-size: clamp(0.8125rem, 0.22vw + 0.76rem, 0.9375rem);
	font-weight: 400;
	line-height: 2.45;
	letter-spacing: 0.08em;
	color: rgba(255, 255, 255, 0.92);
}

.tj-jidori-intro__text-col p {
	margin: 0 0 clamp(1.75rem, 3.5vw, 2.5rem);
}

.tj-jidori-intro__text-col p:last-child {
	margin-block-end: 0;
}

@media (max-width: 767px) {
	.tj-jidori-intro {
		--tj-jidori-intro-padding: clamp(2.75rem, 10vw, 4rem);
	}

	.tj-jidori-intro__inner {
		gap: clamp(2rem, 6vw, 3rem);
	}

	.tj-jidori-intro__title {
		flex-direction: column;
		align-items: center;
		font-size: clamp(1.45rem, 6.5vw, 1.85rem);
		gap: clamp(0.25rem, 2vw, 0.5rem);
	}

	.tj-jidori-intro__text-grid {
		grid-template-columns: 1fr;
		row-gap: clamp(1.5rem, 5vw, 2rem);
	}

	.tj-jidori-intro__text-col {
		line-height: 2.2;
	}
}

/* ----- Jidori-towa page links (2-column connected images) ----- */
.tj-jidori-page-links {
	--tj-jidori-page-links-h: clamp(16rem, 42vw, 28rem);
	--tj-jidori-page-links-padding: var(--tj-jidori-intro-padding, clamp(3.25rem, 8vw, 5.5rem));
	padding-block-end: var(--tj-jidori-page-links-padding);
	background: #000;
}

.tj-jidori-page-links__grid {
	display: grid;
	grid-template-columns: repeat(2, minmax(0, 1fr));
	gap: 0;
}

.tj-jidori-page-links__item {
	position: relative;
	display: block;
	min-height: var(--tj-jidori-page-links-h);
	overflow: hidden;
	color: #fff;
	text-decoration: none;
}

.tj-jidori-page-links__media {
	position: absolute;
	inset: 0;
}

.tj-jidori-page-links__media img {
	position: absolute;
	inset: 0;
	width: 100%;
	height: 100%;
	object-fit: cover;
	transition: transform 0.55s ease;
}

.tj-jidori-page-links__scrim {
	position: absolute;
	inset: 0;
	background: rgba(12, 10, 8, 0.42);
	transition: background-color 0.35s ease;
	pointer-events: none;
}

.tj-jidori-page-links__content {
	position: relative;
	z-index: 1;
	display: flex;
	flex-direction: column;
	align-items: center;
	justify-content: center;
	gap: clamp(0.85rem, 2vw, 1.35rem);
	min-height: var(--tj-jidori-page-links-h);
	padding: clamp(1.5rem, 4vw, 2.5rem);
	text-align: center;
}

.tj-jidori-page-links__title {
	font-family: var(--tj-font-mincho);
	font-size: clamp(1.35rem, 2.2vw + 0.65rem, 2.15rem);
	font-weight: 400;
	line-height: 1.45;
	letter-spacing: 0.12em;
	text-shadow: 0 2px 20px rgba(0, 0, 0, 0.45);
}

.tj-jidori-page-links__cta {
	display: inline-flex;
	align-items: center;
	gap: clamp(0.65rem, 1.5vw, 1rem);
	font-family: var(--tj-font-mincho);
	font-size: clamp(0.8125rem, 0.2vw + 0.76rem, 0.9375rem);
	font-weight: 400;
	letter-spacing: 0.1em;
	color: rgba(255, 255, 255, 0.9);
}

.tj-jidori-page-links__cta-icon {
	display: flex;
	flex-shrink: 0;
	align-items: center;
	justify-content: center;
	width: 2rem;
	height: 2rem;
	border: 1px solid rgba(255, 255, 255, 0.55);
	border-radius: 50%;
}

.tj-jidori-page-links__cta-arrow {
	display: block;
}

.tj-jidori-page-links__item:hover .tj-jidori-page-links__media img,
.tj-jidori-page-links__item:focus-visible .tj-jidori-page-links__media img {
	transform: scale(1.04);
}

.tj-jidori-page-links__item:hover .tj-jidori-page-links__scrim,
.tj-jidori-page-links__item:focus-visible .tj-jidori-page-links__scrim {
	background: rgba(12, 10, 8, 0.28);
}

.tj-jidori-page-links__item:hover .tj-jidori-page-links__cta,
.tj-jidori-page-links__item:focus-visible .tj-jidori-page-links__cta {
	opacity: 0.85;
}

@media (max-width: 767px) {
	.tj-jidori-page-links {
		--tj-jidori-page-links-h: clamp(12rem, 52vw, 18rem);
		--tj-jidori-page-links-padding: clamp(2.75rem, 10vw, 4rem);
	}

	.tj-jidori-page-links__grid {
		grid-template-columns: 1fr;
	}

	.tj-jidori-page-links__title {
		font-size: clamp(1.2rem, 5.5vw, 1.55rem);
	}
}

.tj-pagehero {
	padding: calc(var(--tj-header-h) + 2rem) 0 2.5rem;
	background: #000;
	color: #fff;
}

.tj-pagehero__title {
	margin: 0;
	font-family: var(--tj-font-mincho);
	font-size: var(--tj-fs-h2);
	font-weight: 600;
}

.tj-page__inner,
.tj-feed__in,
main.tj-single .alignwide {
	padding: 2.5rem 0 4rem;
	color: rgba(255, 255, 255, 0.92);
}

main.tj-single .wp-block-post-title {
	margin: 0 0 0.75rem;
	font-family: var(--tj-font-gothic);
	font-size: clamp(1.75rem, 3.2vw, 2.65rem);
	font-weight: 700;
	line-height: 1.45;
	letter-spacing: 0.02em;
	color: #fff;
}

main.tj-single .wp-block-post-featured-image {
	overflow: hidden;
}

main.tj-single .wp-block-post-featured-image img {
	width: 100%;
	height: auto;
	object-fit: cover;
}

main.tj-single .wp-block-post-content :where(.wp-block-image img, figure img) {
	max-width: 100%;
	height: auto;
}

main.tj-single .wp-block-post-content {
	font-family: var(--tj-font-gothic);
	font-size: var(--tj-fs-body);
	line-height: 1.9;
	color: rgba(255, 255, 255, 0.88);
}

main.tj-single .wp-block-post-content :where(h2, h2.wp-block-heading) {
	margin: clamp(2rem, 4vw, 2.75rem) 0 clamp(0.85rem, 2vw, 1.15rem);
	font-family: var(--tj-font-gothic);
	font-size: clamp(1.375rem, 2vw, 1.75rem);
	font-weight: 700;
	line-height: 1.5;
	letter-spacing: 0.02em;
	color: #fff;
}

main.tj-single .wp-block-post-content :where(h3, h3.wp-block-heading) {
	margin: clamp(1.5rem, 3vw, 2rem) 0 clamp(0.65rem, 1.5vw, 0.9rem);
	font-family: var(--tj-font-gothic);
	font-size: clamp(1.125rem, 1.4vw, 1.375rem);
	font-weight: 700;
	line-height: 1.55;
	letter-spacing: 0.02em;
	color: rgba(255, 255, 255, 0.96);
}

main.tj-single .wp-block-post-content :where(p, .wp-block-paragraph) {
	margin: 0 0 1.25rem;
	font-family: var(--tj-font-gothic);
	font-size: var(--tj-fs-body);
	font-weight: 400;
	line-height: 1.9;
	color: rgba(255, 255, 255, 0.82);
}

main.tj-single .wp-block-post-content :where(p, .wp-block-paragraph):last-child {
	margin-block-end: 0;
}

main.tj-single .wp-block-post-content a:where(:not(.wp-element-button)) {
	color: var(--tj-gold);
}

main.tj-page--no-hero > .tj-page__inner:first-child {
	padding-top: calc(var(--tj-header-h) + 2rem);
}

.tj-page__inner :where(h1, h2, h3, h4, h5, h6) {
	color: #fff;
}

.tj-page__inner :where(p, li, figcaption) {
	color: rgba(255, 255, 255, 0.88);
}

.tj-page__inner a:where(:not(.wp-element-button)) {
	color: var(--tj-gold);
}

.tj-feed__title {
	color: #fff;
}

.tj-card {
	border-bottom-color: rgba(255, 255, 255, 0.12);
}

.tj-card-meta {
	color: rgba(255, 255, 255, 0.55);
}

.tj-page__inner .tj-oshirase-item {
	border-bottom-color: rgba(255, 255, 255, 0.12);
}

.tj-page__inner .tj-oshirase-item__title a {
	color: #fff;
}

.tj-page__inner .tj-oshirase-item__title a:hover,
.tj-page__inner .tj-oshirase-item__title a:focus-visible {
	color: var(--tj-gold);
}

.tj-page__inner .tj-oshirase-item__more-link {
	color: var(--tj-gold);
}

.tj-page__inner .tj-oshirase-empty {
	color: rgba(255, 255, 255, 0.55);
}

/* 固定ページ内お問い合わせフォーム（暗色背景） */
.tj-page__inner .tj-form__label {
	color: #fff;
}

.tj-page__inner .tj-form__badge {
	color: var(--tj-gold);
}

.tj-page__inner .tj-form__hint {
	color: rgba(255, 255, 255, 0.55);
}

.tj-page__inner .tj-form input[type="text"],
.tj-page__inner .tj-form input[type="email"],
.tj-page__inner .tj-form input[type="tel"],
.tj-page__inner .tj-form input[type="url"],
.tj-page__inner .tj-form select,
.tj-page__inner .tj-form textarea {
	color: #fff;
	background: color-mix(in srgb, #fff 6%, #000);
	border-color: rgba(255, 255, 255, 0.22);
}

.tj-page__inner .tj-form input::placeholder,
.tj-page__inner .tj-form textarea::placeholder {
	color: rgba(255, 255, 255, 0.38);
}

.tj-page__inner .tj-form__check {
	color: rgba(255, 255, 255, 0.82);
}

.tj-breadcrumbs__list {
	display: flex;
	flex-wrap: wrap;
	gap: 0.35rem 0.5rem;
	list-style: none;
	margin: 0 0 1rem;
	padding: 0;
	font-size: 0.8125rem;
}

.tj-breadcrumbs__link {
	color: rgba(255, 255, 255, 0.78);
	text-decoration: none;
}

.tj-breadcrumbs__current {
	color: #fff;
}

.tj-card {
	padding: 1.25rem 0;
	border-bottom: 1px solid color-mix(in srgb, var(--tj-ink) 12%, transparent);
}

.tj-card-meta {
	display: flex;
	flex-wrap: wrap;
	gap: 0.75rem;
	font-size: 0.8125rem;
	color: color-mix(in srgb, var(--tj-ink) 55%, transparent);
	margin-bottom: 0.5rem;
}

/* ----- お知らせ・読み物ページ ----- */
.tj-oshirase-hero {
	--tj-oshirase-band-max: min(920px, 100%);
	color: #fff;
	background: transparent;
	padding: 2rem 0 1.5rem;
	box-sizing: border-box;
}

.tj-oshirase-hero__inner {
	padding-block-start: 0;
}

.tj-oshirase-hero__head {
	max-width: var(--tj-oshirase-band-max);
	margin-inline: auto;
}

.tj-oshirase-stage {
	position: relative;
	padding-bottom: clamp(2.5rem, 6vw, 4.5rem);
}

.tj-oshirase-panel {
	max-width: min(920px, 100%);
	margin-inline: auto;
	padding: clamp(1.25rem, 3vw, 2rem) clamp(1rem, 2.5vw, 1.75rem);
	background: #000;
	color: rgba(255, 255, 255, 0.92);
	box-shadow: none;
}

.tj-oshirase-panel .tj-oshirase-item {
	border-bottom-color: color-mix(in srgb, #fff 22%, transparent);
}

.tj-oshirase-panel .tj-oshirase-item__media {
	background: color-mix(in srgb, #fff 8%, #000);
}

.tj-oshirase-panel .tj-oshirase-item__title a {
	color: #fff;
}

.tj-oshirase-panel .tj-oshirase-item__title a:hover,
.tj-oshirase-panel .tj-oshirase-item__title a:focus-visible {
	color: var(--tj-gold);
}

.tj-oshirase-panel .tj-oshirase-item__excerpt {
	color: rgba(255, 255, 255, 0.78);
}

.tj-oshirase-panel .tj-oshirase-item__more-link {
	color: var(--tj-gold);
}

.tj-oshirase-panel .tj-oshirase-empty {
	color: rgba(255, 255, 255, 0.55);
}

/* ----- お問い合わせページ ----- */
main.tj-page--contact {
	--tj-contact-band-max: min(920px, 100%);
}

.tj-contact-hero {
	color: #fff;
	background: transparent;
	padding: calc(var(--tj-header-h) + 2rem) 0 1.5rem;
	box-sizing: border-box;
}

.tj-contact-hero__inner {
	padding-block-start: 0;
}

.tj-contact-hero__head,
.tj-contact-panel {
	width: 100%;
	max-width: var(--tj-contact-band-max);
	margin-inline: auto;
}

.tj-contact-hero__lead {
	margin: 1rem 0 0;
	max-width: none;
	font-size: clamp(0.9375rem, 1.6vw, 1.0625rem);
	line-height: 1.85;
	color: rgba(255, 255, 255, 0.78);
}

.tj-contact-stage {
	position: relative;
	padding-bottom: clamp(2.5rem, 6vw, 4.5rem);
}

.tj-contact-panel {
	padding-block: clamp(1.25rem, 3vw, 2rem);
	padding-inline: 0;
	background: #000;
	color: rgba(255, 255, 255, 0.92);
	box-sizing: border-box;
}

.tj-contact-panel .tj-contact-form,
.tj-contact-panel .tj-form {
	width: 100%;
	max-width: none;
	margin-inline: 0;
}

.tj-contact-panel .tj-form__label {
	color: #fff;
}

.tj-contact-panel .tj-form__badge {
	color: var(--tj-gold);
}

.tj-contact-panel .tj-form__hint {
	color: rgba(255, 255, 255, 0.55);
}

.tj-contact-panel .tj-form input[type="text"],
.tj-contact-panel .tj-form input[type="email"],
.tj-contact-panel .tj-form input[type="tel"],
.tj-contact-panel .tj-form select,
.tj-contact-panel .tj-form textarea {
	color: #fff;
	background: color-mix(in srgb, #fff 6%, #000);
	border-color: rgba(255, 255, 255, 0.22);
}

.tj-contact-panel .tj-form input::placeholder,
.tj-contact-panel .tj-form textarea::placeholder {
	color: rgba(255, 255, 255, 0.38);
}

.tj-contact-panel .tj-form select:required:invalid {
	color: rgba(255, 255, 255, 0.38);
}

.tj-contact-panel .tj-form__check {
	color: rgba(255, 255, 255, 0.82);
}

.tj-contact-panel .tj-form__notice--success {
	color: #fff;
	background: color-mix(in srgb, var(--tj-gold) 18%, #000);
	border-color: color-mix(in srgb, var(--tj-gold) 45%, transparent);
}

.tj-contact-panel .tj-form__notice--error {
	color: #fff;
	background: color-mix(in srgb, #c44 22%, #000);
	border-color: color-mix(in srgb, #c44 40%, transparent);
}

.tj-contact-panel .tj-form__btn {
	color: #000;
	background: var(--tj-gold);
}

.tj-contact-panel .tj-form__btn:hover {
	background: color-mix(in srgb, var(--tj-gold) 88%, #fff);
}

/* ----- Oshirase list ----- */
.tj-oshirase-list {
	display: flex;
	flex-direction: column;
	margin: 0;
	padding: 0;
}

.tj-oshirase-item {
	display: grid;
	grid-template-columns: minmax(0, clamp(7.5rem, 22vw, 11.5rem)) minmax(0, 1fr);
	gap: clamp(1rem, 2.5vw, 1.75rem);
	align-items: start;
	padding-block: clamp(1.35rem, 3vw, 2rem);
	border-bottom: 2px dotted color-mix(in srgb, var(--tj-brand) 35%, transparent);
}

.tj-oshirase-item:first-child {
	padding-top: 0;
}

.tj-oshirase-item:last-child {
	border-bottom: none;
	padding-bottom: 0;
}

.tj-oshirase-item--no-media {
	grid-template-columns: minmax(0, 1fr);
}

.tj-oshirase-item__media {
	display: block;
	overflow: hidden;
	aspect-ratio: 4 / 3;
	background: color-mix(in srgb, var(--tj-ink) 8%, #fff);
	text-decoration: none;
}

.tj-oshirase-item__media img {
	width: 100%;
	height: 100%;
	object-fit: cover;
}

.tj-oshirase-item__body {
	display: flex;
	flex-direction: column;
	align-items: flex-start;
	min-height: 100%;
}

.tj-oshirase-item__tag {
	display: inline-block;
	margin: 0 0 0.65rem;
	padding: 0.35rem 1rem;
	border-radius: 0;
	background: var(--tj-brand);
	color: #fff;
	font-size: 0.8rem;
	font-weight: 500;
	line-height: 1.35;
}

.tj-oshirase-item__title {
	margin: 0 0 0.5rem;
	font-family: var(--tj-font-gothic);
	font-size: clamp(1.05rem, 1.6vw, 1.25rem);
	font-weight: 700;
	line-height: 1.45;
}

.tj-oshirase-item__title a {
	text-decoration: none;
	color: var(--tj-ink);
}

.tj-oshirase-item__title a:hover,
.tj-oshirase-item__title a:focus-visible {
	color: var(--tj-brand);
}

.tj-oshirase-item__excerpt {
	margin: 0;
	flex: 1 1 auto;
	font-size: 0.9rem;
	line-height: 1.75;
	color: color-mix(in srgb, var(--tj-ink) 82%, transparent);
}

.tj-oshirase-item__more {
	margin: 0.75rem 0 0 auto;
	align-self: flex-end;
}

.tj-oshirase-item__more-link {
	display: inline-flex;
	align-items: center;
	gap: 0.15rem;
	font-size: 0.9rem;
	font-weight: 500;
	color: var(--tj-brand);
	text-decoration: none;
}

.tj-oshirase-item__more-link:hover,
.tj-oshirase-item__more-link:focus-visible {
	text-decoration: underline;
}

.tj-oshirase-empty {
	margin: 0;
	padding: 1.5rem 1rem;
	text-align: center;
	font-size: 0.9rem;
	color: color-mix(in srgb, var(--tj-ink) 60%, transparent);
}

/* ----- Responsive ----- */
@media (max-width: 900px) {
	.tj-hero__grid {
		display: flex;
		flex-direction: column;
		height: 100%;
		min-height: 0;
	}

	.tj-hero__media {
		flex: 1 1 0;
		min-height: 0;
	}

	.tj-hero__media:first-child img {
		object-position: center 35%;
	}

	.tj-hero__media:last-child img {
		object-position: center center;
	}

	.tj-oshirase-item {
		grid-template-columns: minmax(0, 6.5rem) minmax(0, 1fr);
		gap: 0.85rem;
	}

	.tj-oshirase-item--no-media {
		grid-template-columns: 1fr;
	}

	.tj-oshirase-item__excerpt {
		font-size: 0.85rem;
		line-height: 1.65;
	}
}

/* ----- 生産・育成（1画面固定・スクロールで中身だけ進む） ----- */
.tj-seisan {
	--tj-seisan-steps: 5;
	--tj-seisan-vh: calc(100dvh - var(--tj-header-h));
	--tj-seisan-media-gap: clamp(1.25rem, 2.5vw, 2rem);
	--tj-seisan-slide-h: calc(
		var(--tj-seisan-vh) - 2 * clamp(1.5rem, 4vw, 2.5rem)
	);
	--tj-seisan-text-shift: clamp(1rem, 2.5vh, 1.75rem);
	position: relative;
}

.tj-seisan__viewport {
	position: fixed;
	top: var(--tj-header-h);
	right: 0;
	left: 0;
	z-index: 10;
	width: 100%;
	height: var(--tj-seisan-vh);
	overflow: hidden;
	background: #000;
}

.tj-seisan__spacer {
	height: calc(var(--tj-seisan-steps) * var(--tj-seisan-vh));
	pointer-events: none;
}

.tj-seisan--complete .tj-seisan__viewport {
	position: relative;
	top: auto;
	right: auto;
	left: auto;
}

.tj-seisan__stage {
	display: grid;
	grid-template-columns: minmax(0, clamp(14rem, 30vw, 20rem)) 1px minmax(0, 1fr);
	align-items: stretch;
	gap: clamp(1.25rem, 3.5vw, 2.75rem);
	height: 100%;
	padding-block: clamp(1.5rem, 4vw, 2.5rem);
	box-sizing: border-box;
}

.tj-seisan__text {
	position: relative;
	min-width: 0;
	min-height: 0;
	padding-inline-end: clamp(0.5rem, 2vw, 1.25rem);
	isolation: isolate;
}

.tj-seisan__copy {
	position: absolute;
	inset: 0;
	display: none;
	margin: 0;
	opacity: 0;
	visibility: hidden;
	pointer-events: none;
	will-change: transform, opacity;
	transform: translate3d(0, 0, 0);
}

.tj-seisan__rule {
	width: 1px;
	min-height: 0;
	align-self: stretch;
	background: rgba(255, 255, 255, 0.22);
}

.tj-seisan__title {
	margin: 0 0 clamp(1.5rem, 3vw, 2.25rem);
	font-family: var(--tj-font-mincho);
	font-size: clamp(1.5rem, 2.4vw + 0.5rem, 2.35rem);
	font-weight: 400;
	line-height: 1.55;
	letter-spacing: 0.14em;
	color: #fff;
}

.tj-seisan__body p {
	margin: 0 0 clamp(1.25rem, 2.5vw, 1.75rem);
	font-family: var(--tj-font-mincho);
	font-size: clamp(0.8125rem, 0.22vw + 0.76rem, 0.9375rem);
	font-weight: 400;
	line-height: 2.35;
	letter-spacing: 0.08em;
	color: rgba(255, 255, 255, 0.88);
}

.tj-seisan__body p:last-child {
	margin-block-end: 0;
}

.tj-seisan__media {
	position: relative;
	min-width: 0;
	min-height: 0;
	overflow: hidden;
}

.tj-seisan__media-track {
	display: flex;
	flex-direction: column;
	gap: var(--tj-seisan-media-gap);
	will-change: transform;
}

.tj-seisan__media-slide {
	position: relative;
	flex: 0 0 var(--tj-seisan-slide-h);
	width: 100%;
	height: var(--tj-seisan-slide-h);
	min-height: 0;
	margin: 0;
	overflow: hidden;
}

.tj-seisan__media-slide img {
	position: absolute;
	inset: 0;
	display: block;
	width: 100%;
	height: 100%;
	object-fit: cover;
	object-position: center;
	will-change: transform;
	transform: scale(1);
	transform-origin: center center;
}

main.tj-page--seisan-ikusei > .tj-seisan {
	margin-block-end: 0 !important;
}

@media (prefers-reduced-motion: reduce) {
	.tj-seisan__viewport {
		position: relative;
		top: auto;
		height: auto;
		min-height: 0;
		overflow: visible;
	}

	.tj-seisan__stage {
		height: auto;
		padding-block: clamp(3rem, 8vw, 5rem);
	}

	.tj-seisan__text {
		position: static;
		display: grid;
		gap: clamp(3rem, 8vw, 5rem);
	}

	.tj-seisan__copy {
		position: static;
		opacity: 1;
		visibility: visible;
	}

	.tj-seisan__media {
		min-height: clamp(14rem, 50vw, 24rem);
		overflow: visible;
	}

	.tj-seisan__media-track {
		transform: none !important;
		height: auto;
		gap: var(--tj-seisan-media-gap, clamp(1.5rem, 4vw, 2.5rem));
	}

	.tj-seisan__media-slide {
		flex: none;
		width: 100%;
		height: clamp(14rem, 50vw, 24rem);
		flex-basis: clamp(14rem, 50vw, 24rem);
	}

	.tj-seisan__spacer {
		display: none;
	}
}

@media (max-width: 900px) {
	.tj-seisan__stage {
		grid-template-columns: minmax(0, clamp(12rem, 38vw, 16rem)) 1px minmax(0, 1fr);
		gap: clamp(1rem, 3vw, 1.75rem);
	}
}

@media (max-width: 767px) {
	.tj-seisan__stage {
		grid-template-columns: 1fr;
		grid-template-rows: auto auto 1fr;
	}

	.tj-seisan__rule {
		display: none;
	}

	.tj-seisan__text {
		position: relative;
		min-height: 12rem;
		padding-inline-end: 0;
	}

	.tj-seisan__media {
		min-height: clamp(12rem, 52vw, 22rem);
	}
}
