/* ==========================================================================
   Kami — Typography
   Type scale, heading styles, vertical Japanese (tategaki), editorial body.
   ========================================================================== */

h1,
h2,
h3,
h4 {
	font-family: var(--font-sans);
	font-weight: var(--fw-light);
	line-height: var(--lh-tight);
	letter-spacing: var(--ls-tight);
	color: var(--kami-text);
}

h1 {
	font-size: var(--fs-xxl);
}

h2 {
	font-size: var(--fs-xl);
}

h3 {
	font-size: var(--fs-lg);
}

h4 {
	font-size: var(--fs-md);
	font-weight: var(--fw-regular);
}

p {
	font-size: var(--fs-base);
	line-height: var(--lh-base);
}

p + p {
	margin-top: var(--space-sm);
}

/* Lowercase, generously spaced labels and eyebrow text */
.kami-eyebrow,
.kami-label {
	font-size: var(--fs-small);
	letter-spacing: var(--ls-wide);
	text-transform: lowercase;
	color: var(--kami-secondary);
	font-weight: var(--fw-regular);
}

.text-secondary {
	color: var(--kami-secondary);
}

.text-accent {
	color: var(--kami-accent);
}

/* --- Vertical Japanese (tategaki) ---------------------------------------- */
.tategaki {
	font-family: var(--font-serif-jp);
	font-feature-settings: "palt" 1;
	font-weight: var(--fw-regular);
	line-height: 1.05;
	letter-spacing: 0.12em;
}

@supports (writing-mode: vertical-rl) {
	.tategaki {
		writing-mode: vertical-rl;
		text-orientation: upright;
	}
}

/* On small screens vertical text flips to horizontal for legibility */
@media (max-width: 768px) {
	.tategaki {
		writing-mode: horizontal-tb;
		text-orientation: mixed;
		letter-spacing: 0.18em;
	}
}

/* Bilingual heading composite */
.kami-vhead {
	display: flex;
	align-items: flex-start;
	gap: var(--space-md);
}

.kami-vhead__jp {
	font-family: var(--font-serif-jp);
	font-size: var(--fs-lg);
	color: var(--kami-secondary);
	flex: 0 0 auto;
}

.kami-vhead__en {
	font-weight: var(--fw-light);
	text-transform: lowercase;
	letter-spacing: var(--ls-mid);
}

@media (max-width: 768px) {
	.kami-vhead {
		flex-direction: row;
		align-items: baseline;
		gap: var(--space-sm);
	}
	.kami-vhead__jp {
		font-size: var(--fs-md);
	}
}

/* --- Body copy regions --------------------------------------------------- */
.kami-prose {
	max-width: var(--measure);
}

.kami-prose p,
.kami-prose li {
	font-size: var(--fs-base);
	line-height: var(--lh-loose);
}

.kami-prose.kami-prose--large p {
	font-size: var(--fs-sm);
	line-height: var(--lh-loose);
}

.kami-prose h2,
.kami-prose h3 {
	margin-top: var(--space-lg);
	margin-bottom: var(--space-sm);
}

.kami-prose p + p {
	margin-top: var(--space-md);
}

.kami-prose a {
	color: var(--kami-accent);
	border-bottom: 1px solid var(--kami-line);
	padding-bottom: 1px;
}

.kami-prose a:hover {
	border-color: var(--kami-accent);
}

.kami-prose ul {
	list-style: none;
	margin: var(--space-md) 0;
}

.kami-prose ul li {
	position: relative;
	padding-left: var(--space-md);
	margin-bottom: var(--space-2xs);
}

.kami-prose ul li::before {
	content: "—";
	position: absolute;
	left: 0;
	color: var(--kami-secondary);
}

/* --- Pull quotes --------------------------------------------------------- */
.kami-pullquote {
	margin: var(--space-xl) 0;
	text-align: left;
}

.kami-pullquote__jp {
	display: block;
	font-family: var(--font-serif-jp);
	font-size: var(--fs-lg);
	color: var(--kami-accent);
	line-height: var(--lh-snug);
	margin-bottom: var(--space-xs);
}

.kami-pullquote__en {
	display: block;
	font-size: var(--fs-sm);
	color: var(--kami-secondary);
	font-weight: var(--fw-light);
	font-style: italic;
}

blockquote {
	border-left: 2px solid var(--kami-highlight);
	padding-left: var(--space-md);
	margin: var(--space-lg) 0;
	font-size: var(--fs-md);
	font-weight: var(--fw-light);
	line-height: var(--lh-snug);
	color: var(--kami-text);
}

/* Display kanji marks */
.kami-kanji-xl {
	font-family: var(--font-serif-jp);
	font-weight: var(--fw-regular);
	line-height: 1;
	display: block;
}
