/* ============================================
 * DADS公式準拠 ユーティリティクラス
 * ============================================ */

/* ============================================
 * Accessibility Utilities
 * ============================================ */

/* Visually Hidden (Screen Reader Only) */
.dads-u-visually-hidden {
	position: absolute;
	width: 1px;
	height: 1px;
	padding: 0;
	margin: -1px;
	overflow: hidden;
	clip: rect(0, 0, 0, 0);
	white-space: nowrap;
	border: 0;
}

/* Legacy alias */
.dads-sr-only {
	position: absolute;
	width: 1px;
	height: 1px;
	padding: 0;
	margin: -1px;
	overflow: hidden;
	clip: rect(0, 0, 0, 0);
	white-space: nowrap;
	border: 0;
}

/* Focus Outline Utility */
.dads-u-focus-outline:focus-visible {
	outline: 4px solid var(--color-neutral-black);
	outline-offset: 2px;
	box-shadow: 0 0 0 2px var(--color-primitive-yellow-300);
}

.dads-u-focus-within-outline:focus-within {
	outline: 4px solid var(--color-neutral-black);
	outline-offset: 2px;
	box-shadow: 0 0 0 2px var(--color-primitive-yellow-300);
}

/* ============================================
 * Typography Utilities
 * ============================================ */

/* Display系（大見出し） */
.dads-u-dsp-64N-140 {
	font-size: var(--font-size-64);
	font-weight: var(--font-weight-400);
	line-height: var(--line-height-140);
}

.dads-u-dsp-48N-140 {
	font-size: var(--font-size-48);
	font-weight: var(--font-weight-400);
	line-height: var(--line-height-140);
}

/* Standard系（本文・小見出し） */
.dads-u-std-24B-150 {
	font-size: var(--font-size-24);
	font-weight: var(--font-weight-700);
	line-height: var(--line-height-150);
	letter-spacing: 0.02em;
}

.dads-u-std-20B-150 {
	font-size: var(--font-size-20);
	font-weight: var(--font-weight-700);
	line-height: var(--line-height-150);
	letter-spacing: 0.02em;
}

.dads-u-std-18N-175 {
	font-size: var(--font-size-18);
	font-weight: var(--font-weight-400);
	line-height: var(--line-height-175);
	letter-spacing: 0.02em;
}

.dads-u-std-16N-175 {
	font-size: var(--font-size-16);
	font-weight: var(--font-weight-400);
	line-height: var(--line-height-175);
	letter-spacing: 0.02em;
}

.dads-u-std-16B-175 {
	font-size: var(--font-size-16);
	font-weight: var(--font-weight-700);
	line-height: var(--line-height-175);
	letter-spacing: 0.02em;
}

/* Dense系（コンパクト表示） */
.dads-u-dns-14B-120 {
	font-size: var(--font-size-14);
	font-weight: var(--font-weight-700);
	line-height: var(--line-height-120);
}

.dads-u-dns-14N-150 {
	font-size: var(--font-size-14);
	font-weight: var(--font-weight-400);
	line-height: var(--line-height-150);
}

/* Outline系（ラベル等） */
.dads-u-oln-14N-100 {
	font-size: var(--font-size-14);
	font-weight: var(--font-weight-400);
	line-height: var(--line-height-100);
	letter-spacing: 0.02em;
}

/* Mono系（コード） */
.dads-u-mono-16N-150 {
	font-family: var(--font-family-mono);
	font-size: var(--font-size-16);
	font-weight: var(--font-weight-400);
	line-height: var(--line-height-150);
}

.dads-u-mono-14N-150 {
	font-family: var(--font-family-mono);
	font-size: var(--font-size-14);
	font-weight: var(--font-weight-400);
	line-height: var(--line-height-150);
}

/* ============================================
 * Legacy Utility Classes (互換性維持)
 * ============================================ */

.dads-text-mono {
	font-family: var(--font-family-mono);
	color: var(--color-neutral-solid-gray-600);
	font-size: 0.85rem;
}

.dads-flex {
	display: flex;
}

.dads-flex--column {
	flex-direction: column;
}

.dads-flex--center {
	align-items: center;
	justify-content: center;
}

.dads-gap-sm {
	gap: 0.5rem;
}

.dads-gap-md {
	gap: 1rem;
}
