/* Emoji Gen Minimal — コンパクト UI（トークン + カード）
   配色は emoji-list.jp（Swell / swell_custom）に合わせた温かみのあるクリーム地 + メインローズ */

.egm {
	--egm-radius: 12px;
	--egm-radius-sm: 8px;
	--egm-radius-xs: 6px;
	--egm-line: rgba(51, 51, 51, 0.09);
	--egm-line-strong: rgba(51, 51, 51, 0.14);
	--egm-surface: #ffffff;
	--egm-surface-muted: #f8f5ef;
	--egm-surface-inset: #e8e2d6;
	--egm-text: #333333;
	--egm-muted: #666666;
	--egm-accent: #d6869c;
	--egm-accent-hover: #c27388;
	--egm-accent-strong: #a16575;
	--egm-accent-soft: rgba(255, 168, 195, 0.14);
	--egm-accent-ring: rgba(214, 134, 156, 0.28);
	--egm-shadow: 0 1px 2px rgba(0, 0, 0, 0.06), 0 4px 12px rgba(0, 0, 0, 0.05);

	box-sizing: border-box;
	width: 100%;
	max-width: 36rem;
	margin: 0 auto;
	padding: 0.65rem;
	border: 1px solid var(--egm-line-strong);
	border-radius: var(--egm-radius);
	background: #fcfaf4;
	color: var(--egm-text);
	font-family: 'Noto Sans JP', sans-serif;
	font-size: 0.8125rem;
	line-height: 1.45;
}

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

.egm__ttl,
.egm__h {
	margin: 0;
	padding: 0;
	border: 0;
	background: none;
	font: inherit;
	font-weight: 600;
	line-height: 1.25;
	color: inherit;
	text-transform: none;
	letter-spacing: 0.01em;
}

.egm__ttl {
	font-size: 0.6875rem;
	color: var(--egm-muted);
	margin-bottom: 0.45rem;
}

.egm__h {
	font-size: 0.6875rem;
	color: var(--egm-muted);
	margin: 0 0 0.45rem;
	padding-bottom: 0.32rem;
	border-bottom: 1px solid var(--egm-line);
}

.egm__layout {
	display: flex;
	flex-direction: column;
	gap: 0.85rem;
}

@media (min-width: 680px) {
	.egm__layout {
		display: grid;
		grid-template-columns: minmax(13rem, 32%) 1fr;
		align-items: start;
		gap: 0.85rem 0.85rem;
	}
}

/* —— ステージ（プレビューカード） —— */
.egm__stage-card {
	padding: 0.65rem 0.65rem 0.6rem;
	border-radius: var(--egm-radius-sm);
	border: 1px solid var(--egm-line);
	background: var(--egm-surface);
	box-shadow: var(--egm-shadow);
	text-align: center;
}

.egm__preview {
	display: flex;
	justify-content: center;
	margin: 0 auto 0.4rem;
	max-width: min(14rem, 88vw);
	padding: 0.35rem;
	border-radius: var(--egm-radius-xs);
	background: repeating-conic-gradient(#ded8cf 0% 25%, #ece6dd 0% 50%) 50% / 10px 10px;
	box-shadow: inset 0 0 0 1px var(--egm-line);
}

.egm__alt-row {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 0.45rem;
	max-width: min(14rem, 88vw);
	margin: 0 auto 0.55rem;
}

.egm__alt {
	display: flex;
	flex-direction: column;
	align-items: stretch;
	gap: 0.25rem;
	margin: 0;
	padding: 0.28rem 0.3rem 0.32rem;
	border: 1px solid var(--egm-line);
	border-radius: var(--egm-radius-xs);
	background: var(--egm-surface-muted);
	cursor: pointer;
	font: inherit;
	color: inherit;
	text-align: center;
	transition:
		border-color 0.12s ease,
		box-shadow 0.12s ease;
}

.egm__alt:hover {
	border-color: var(--egm-accent);
}

.egm__alt:focus-visible {
	outline: 2px solid var(--egm-accent);
	outline-offset: 2px;
}

.egm__alt-lbl {
	font-size: 0.5625rem;
	font-weight: 600;
	color: var(--egm-muted);
	line-height: 1.2;
}

.egm__alt-wrap {
	display: flex;
	justify-content: center;
	align-items: center;
	padding: 0.2rem;
	border-radius: 4px;
	background: repeating-conic-gradient(#ded8cf 0% 25%, #ece6dd 0% 50%) 50% / 10px 10px;
	box-shadow: inset 0 0 0 1px var(--egm-line);
}

.egm__canvas-alt {
	display: block;
	width: 100%;
	max-width: 100%;
	height: auto;
	border-radius: 3px;
	image-rendering: pixelated;
	image-rendering: crisp-edges;
}

.egm__canvas {
	display: block;
	width: 100%;
	max-width: 100%;
	height: auto;
	border-radius: 4px;
	box-shadow: 0 0 0 1px rgba(51, 51, 51, 0.07), 0 2px 8px rgba(0, 0, 0, 0.08);
	image-rendering: pixelated;
	image-rendering: crisp-edges;
}

.egm__actions {
	display: flex;
	flex-direction: column;
	align-items: stretch;
	gap: 0.5rem;
	width: 100%;
	text-align: left;
}

.egm__fieldset {
	margin: 0;
	padding: 0;
	border: 0;
	width: 100%;
	min-width: 0;
	text-align: left;
}

.egm__legend {
	margin: 0 0 0.35rem;
	padding: 0;
	border: 0;
	font: inherit;
	font-size: 0.625rem;
	font-weight: 600;
	color: var(--egm-muted);
	line-height: 1.2;
	text-transform: none;
	letter-spacing: 0.02em;
}

.egm__outlist {
	display: flex;
	flex-direction: column;
	gap: 0.35rem;
	width: 100%;
}

.egm__outopt {
	display: flex;
	align-items: flex-start;
	gap: 0.45rem;
	margin: 0;
	padding: 0.45rem 0.5rem;
	border: 1px solid var(--egm-line);
	border-radius: var(--egm-radius-xs);
	background: var(--egm-surface-muted);
	cursor: pointer;
	text-align: left;
	transition:
		border-color 0.12s ease,
		background 0.12s ease,
		box-shadow 0.12s ease;
}

.egm__outopt:hover {
	border-color: var(--egm-surface-inset);
}

.egm__outopt:has(input:checked) {
	border-color: var(--egm-accent);
	background: var(--egm-accent-soft);
	box-shadow: 0 0 0 1px rgba(214, 134, 156, 0.18);
}

.egm__outopt > input[type='radio'] {
	flex: 0 0 auto;
	width: 1rem;
	height: 1rem;
	margin: 0.2rem 0 0;
	accent-color: var(--egm-accent);
	cursor: pointer;
}

.egm__outopt:has(input:focus-visible) {
	outline: 2px solid var(--egm-accent);
	outline-offset: 2px;
}

.egm__out-body {
	flex: 1 1 auto;
	min-width: 0;
	display: flex;
	flex-direction: column;
	gap: 0.15rem;
}

.egm__out-head {
	font-size: 0.8125rem;
	font-weight: 600;
	color: var(--egm-text);
	line-height: 1.25;
}

.egm__out-px {
	font-weight: 700;
	font-variant-numeric: tabular-nums;
}

.egm__out-unit {
	font-weight: 500;
	font-size: 0.75rem;
	color: var(--egm-muted);
}

.egm__out-desc {
	font-size: 0.6875rem;
	line-height: 1.35;
	color: var(--egm-muted);
}

/* 右パネル内は同じ行 UI をややコンパクトに */
.egm__surface .egm__outlist {
	gap: 0.28rem;
}

.egm__surface .egm__outopt {
	padding: 0.38rem 0.45rem;
}

.egm__surface .egm__out-head {
	font-size: 0.78rem;
}

.egm__surface .egm__out-desc {
	font-size: 0.66rem;
	line-height: 1.32;
}

.egm__dl {
	box-sizing: border-box;
	width: 100%;
	flex: 0 0 auto;
	min-height: 2.45rem;
	padding: 0.4rem 0.85rem;
	font: inherit;
	font-size: 0.8125rem;
	font-weight: 600;
	line-height: 1.25;
	cursor: pointer;
	border: 1px solid var(--egm-accent-strong);
	border-radius: var(--egm-radius-xs);
	background: var(--egm-accent);
	color: #fff;
	white-space: nowrap;
	box-shadow: 0 1px 0 rgba(255, 255, 255, 0.12) inset;
}

.egm__dl:hover,
.egm__dl:focus {
	background: var(--egm-accent-hover);
}

.egm__dl:focus-visible {
	outline: 2px solid var(--egm-accent);
	outline-offset: 2px;
}

.egm__reset {
	align-self: center;
	margin: 0.2rem 0 0;
	padding: 0;
	border: 0;
	background: none;
	font: inherit;
	font-size: 0.6875rem;
	font-weight: 500;
	color: var(--egm-accent);
	text-decoration: underline;
	text-underline-offset: 0.12em;
	cursor: pointer;
	line-height: 1.3;
}

.egm__reset:hover {
	color: var(--egm-accent-hover);
}

.egm__reset:focus-visible {
	outline: 2px solid var(--egm-accent);
	outline-offset: 2px;
	border-radius: 2px;
}

/* —— パネル（一枚のカード） —— */
.egm__surface {
	border-radius: var(--egm-radius-sm);
	border: 1px solid var(--egm-line);
	background: var(--egm-surface);
	box-shadow: var(--egm-shadow);
	overflow: hidden;
}

.egm__panel {
	display: flex;
	flex-direction: column;
	min-width: 0;
}

.egm__block {
	padding: 0.5rem 0.6rem 0.48rem;
	border-bottom: 1px solid var(--egm-line);
}

.egm__block:last-child {
	border-bottom: 0;
	padding-bottom: 0.5rem;
}

/* 文字サイズブロック内: 整列・行間アコーディオン */
.egm__acc-stack {
	display: flex;
	flex-direction: column;
	gap: 0.45rem;
	margin-top: 0.55rem;
}

/* —— アコーディオン（整列・行間） —— */
.egm__acc {
	margin: 0;
	padding: 0;
	border: 1px solid var(--egm-line);
	border-radius: var(--egm-radius-xs);
	background: var(--egm-surface);
}

.egm__acc-sum {
	margin: 0;
	padding: 0.42rem 0.5rem 0.42rem 1.15rem;
	font: inherit;
	font-size: 0.6875rem;
	font-weight: 600;
	line-height: 1.3;
	cursor: pointer;
	list-style: none;
	color: var(--egm-muted);
	user-select: none;
	position: relative;
}

.egm__acc-sum::-webkit-details-marker {
	display: none;
}

.egm__acc-sum::before {
	content: '\25b8';
	position: absolute;
	left: 0.35rem;
	top: 50%;
	transform: translateY(-50%);
	font-size: 0.5rem;
	opacity: 0.55;
	line-height: 1;
}

.egm__acc[open] > .egm__acc-sum::before {
	content: '\25be';
}

.egm__acc[open] > .egm__acc-sum {
	color: var(--egm-text);
}

.egm__acc-body {
	padding: 0 0.5rem 0.5rem;
	border-top: 1px solid var(--egm-line);
}

.egm__acc-body > .egm__outlist:first-child {
	margin-top: 0.35rem;
}

.egm__acc-body > .egm__lab--range:first-child {
	margin-top: 0.35rem;
}

/* —— コンパクト1行ラジオ（文字サイズ・背景） —— */
.egm__outlist--inline {
	flex-direction: row;
	flex-wrap: nowrap;
	gap: 0.28rem;
}

.egm .egm__outlist--inline .egm__outopt--compact {
	flex: 1 1 0;
	min-width: 0;
	align-items: center;
	padding: 0.26rem 0.35rem;
}

.egm .egm__outopt--compact .egm__out-body {
	flex-direction: row;
	align-items: center;
	gap: 0.35rem;
}

.egm .egm__outopt--compact > input[type='radio'] {
	margin: 0;
	align-self: center;
	flex-shrink: 0;
}

.egm .egm__outopt--compact .egm__out-head {
	font-size: 0.72rem;
	line-height: 1.2;
}

/* 書き出し: 数値＋ラジオをセル中央に */
.egm__fieldset .egm__outlist--export.egm__outlist--inline {
	justify-content: stretch;
	gap: 0.22rem;
}

.egm__fieldset .egm__outlist--export .egm__outopt--compact {
	justify-content: center;
	padding: 0.28rem 0.2rem;
}

.egm__fieldset .egm__outlist--export .egm__outopt--compact > input[type='radio'] {
	margin: 0;
	flex-shrink: 0;
}

.egm__fieldset .egm__outlist--export .egm__outopt--compact .egm__out-body {
	flex: 0 0 auto;
	min-width: 0;
}

.egm__fieldset .egm__outlist--export .egm__outopt--compact .egm__out-head {
	text-align: center;
}

/* 右パネル: コンパクト行の直後の余白（縦方向） */
.egm__surface .egm__outlist--inline + .egm__lab--range {
	margin-top: 0.55rem;
}

.egm__surface .egm__outlist--inline + .egm__row--colors {
	margin-top: 0.55rem;
}

.egm__surface .egm__row--colors + .egm__lab--range {
	margin-top: 0.55rem;
}

.egm__export-hint {
	margin: 0.45rem 0 0;
	padding: 0;
	font-size: 0.6875rem;
	line-height: 1.38;
	color: var(--egm-muted);
	text-align: left;
	white-space: nowrap;
	overflow: hidden;
	text-overflow: ellipsis;
}

.egm__lab {
	display: flex;
	flex-direction: column;
	gap: 0.28rem;
	margin-bottom: 0.4rem;
}

.egm__lab:last-child {
	margin-bottom: 0;
}

.egm__lab--range {
	margin-bottom: 0.35rem;
}

.egm__lab-t {
	font-size: 0.6875rem;
	font-weight: 500;
	color: var(--egm-muted);
	line-height: 1.35;
}

.egm__range {
	display: flex;
	flex-direction: row;
	align-items: center;
	gap: 0.35rem;
	width: 100%;
	min-width: 0;
}

.egm__range input[type='range'] {
	flex: 1 1 auto;
	min-width: 0;
	width: 100%;
	max-width: 20rem;
	height: 1.25rem;
	margin: 0;
	accent-color: var(--egm-accent);
	cursor: pointer;
}

.egm__fsize-v,
.egm__bgtrans-v,
.egm__lead-v,
.egm__track-v {
	flex: 0 0 auto;
	min-width: 2.5rem;
	font-size: 0.6875rem;
	font-variant-numeric: tabular-nums;
	font-weight: 600;
	color: var(--egm-text);
	text-align: right;
	opacity: 0.9;
}

.egm__ta {
	width: 100%;
	min-height: 3.35rem;
	padding: 0.4rem 0.5rem;
	font: inherit;
	font-size: 0.8125rem;
	line-height: 1.4;
	resize: vertical;
	border: 1px solid var(--egm-line-strong);
	border-radius: var(--egm-radius-xs);
	background: var(--egm-surface);
	color: var(--egm-text);
	transition: border-color 0.12s ease, box-shadow 0.12s ease;
}

.egm__ta:hover {
	border-color: var(--egm-surface-inset);
}

.egm__ta:focus {
	outline: none;
	border-color: var(--egm-accent);
	box-shadow: 0 0 0 3px var(--egm-accent-ring);
}

.egm__row {
	display: flex;
	flex-wrap: wrap;
	gap: 0.4rem;
	align-items: center;
}

.egm__row--colors {
	align-items: flex-end;
	gap: 0.5rem;
}

.egm__swatches .egm__lab {
	margin-bottom: 0;
}

.egm__grow {
	flex: 1;
	min-width: 0;
}

/* —— カラーピッカー —— */
input[type='color'] {
	display: block;
	width: 100%;
	height: 2rem;
	padding: 2px;
	border: 1px solid var(--egm-line-strong);
	border-radius: var(--egm-radius-xs);
	background: var(--egm-surface);
	cursor: pointer;
}

input[type='color']:hover {
	border-color: var(--egm-surface-inset);
}

@media (min-width: 680px) {
	.egm__stage {
		position: sticky;
		top: 0.5rem;
	}
}
