@charset "UTF-8";

/**
 * ダッシュボード共通 UI（会社・スタッフ共通）
 * enqueue: staff-dashboard / recruit-company-dashboard のみ（functions.php）
 * セレクタは dashboard-*（body: .matching-staff-dashboard-body）
 */

html:has(body.matching-staff-dashboard-body) {
	font-size: 1.1rem;
}

.matching-staff-dashboard-body {
	/* ダッシュボードはビューポート内に収め、サイドバーは固定・メインのみ縦スクロール */
	height: 100vh;
	overflow: hidden;
	--sd-bg-deep: #070a0f;
	--sd-sidebar-bg: linear-gradient(165deg, #121826 0%, #0c1018 48%, #0a0e14 100%);
	--sd-sidebar-border: rgba(255, 255, 255, 0.06);
	--sd-text: #f1f5f9;
	--sd-text-dim: #94a3b8;
	--sd-accent: #0077c7;
	--sd-accent-soft: rgba(0, 119, 199, 0.14);
	--sd-accent-glow: rgba(0, 119, 199, 0.35);
	--sd-main-bg: #e8ecf2;
	--sd-card: #ffffff;
	--sd-card-border: rgba(15, 23, 42, 0.08);
	--sd-heading: #0f172a;
	--sd-muted: #64748b;
	--sd-row-hover: #f8fafc;
	--sd-danger: #f87171;
	--sd-radius: 12px;
	--sd-radius-sm: 8px;
	--sd-shadow: 0 4px 24px var(--sd-card-border, rgba(15, 23, 42, 0.08));
	--sd-sidebar-w: 300px;
	--sd-sidebar-w-collapsed: 5.75rem;
	--sd-topbar-h: auto;
	/* サイドバー: 4px グリッド。html は 1.1rem のため、ここは相殺後の rem リテラル */
	--sd-space-1: 0.5rem;
	--sd-space-2: 0.75rem;
	--sd-space-3: 1rem;
	--sd-space-4: 1.25rem;
	--sd-space-5: 1.5rem;
	--sd-text-meta: 0.625rem;
	--sd-text-nav: 0.85rem;
	--sd-text-strong: 0.85rem;
	--sd-filter-control-min-height: 2.65rem;

	/* タイポ：ダッシュ全体（html:has の 1.1rem スケール下） */
	--sd-panel-title-size: 1.05rem;
	--sd-panel-title-size-lg: 1.175rem;
	--sd-text-xs: 0.72rem;
	--sd-text-sm: 0.78rem;
	--sd-text-base: 0.875rem;
	--sd-text-lg: 0.95rem;

	/* ボタン高さ：コンパクト / 標準 / 大 */
	--sd-btn-h-sm: 2.4rem;
	--sd-btn-h-md: 2.6rem;
	--sd-btn-h-lg: 2.75rem;

	/* 結果メッセージ（公開面の --matching-color-*-{bg,border,text} を再利用） */
	--sd-result-ok-bg: var(--matching-color-success-bg, #f0fdf4);
	--sd-result-ok-border: var(--matching-color-success-border, #15803d);
	--sd-result-ok-text: var(--matching-color-success-text, #166534);
	--sd-result-err-bg: var(--matching-color-danger-bg, #fef2f2);
	--sd-result-err-border: var(--matching-color-danger-border, #b91c1c);
	--sd-result-err-text: var(--matching-color-danger-text, #991b1b);
	--sd-result-warn-bg: var(--matching-color-warning-bg, #fffbeb);
	--sd-result-warn-border: var(--matching-color-warning-border, #b45309);
	--sd-result-warn-text: var(--matching-color-warning-text, #92400e);

	/* ステータスドット（募集中 / 一時停止 / 募集終了 / すべて） */
	--sd-status-open: #16a34a;
	--sd-status-paused: #ea580c;
	--sd-status-closed: #dc2626;
	--sd-status-all: #94a3b8;
	--sd-status-open-ring: rgba(22, 163, 74, 0.22);
	--sd-status-paused-ring: rgba(234, 88, 12, 0.22);
	--sd-status-closed-ring: rgba(220, 38, 38, 0.22);

	/* 必須マーカー（公開面の --matching-color-required と同色） */
	--sd-required: var(--matching-color-required, #c5221f);

	/* ライトメイン領域の本文・枠・サーフェス（会社/スタッフダッシュボード共通） */
	--sd-text-body: #334155;
	--sd-text-secondary: #475569;
	--sd-border-subtle: #e2e8f0;
	--sd-border-hairline: #e9e8e6;
	--sd-surface-subtle: #f1f5f9;
	--sd-surface-inset: #eef2f6;
	--sd-surface-inset-border: #dbe3ec;
	--sd-overlay: #000000;
	--sd-link: var(--matching-color-link);
	--sd-link-hover: var(--matching-color-link-hover);

	/* 応募ステータス pill（応募一覧） */
	--sd-app-status-new: var(--sd-accent);
	--sd-app-status-read: var(--sd-muted);
	--sd-app-status-replied: #7c4dff;
	--sd-app-status-interview: #f59e0b;
	--sd-app-status-passed: var(--sd-status-open);
	--sd-app-status-rejected: var(--sd-status-closed);

	/* パフォーマンスチャート系列色 */
	--sd-chart-orange: #e67e22;
	--sd-chart-indigo: #6366f1;
	--sd-chart-violet: #7c3aed;
	--sd-chart-warn-gradient-start: #f59e0b;
	--sd-chart-danger: #ef4444;

	/* アクティブフィルタチップ（白基底 + アクティブ青） */
	--sd-chip-bg: var(--sd-card);
	--sd-chip-bg-active: var(--sd-accent-soft);
	--sd-chip-border: var(--sd-card-border);
	--sd-chip-border-active: rgba(0, 119, 199, 0.25);
	--sd-chip-color: var(--sd-heading);
	--sd-chip-color-active: var(--sd-accent);

	/* テーブル Stone（公開面と語彙統一） */
	--sd-table-head-bg: #edebe8;
	--sd-table-head-color: #23221e;
	--sd-table-row-color: #23221e;
	--sd-table-row-alt-bg: #f8f7f6;
	--sd-table-border: #d6d3d0;

	margin: 0;
	background: var(--sd-bg-deep);
	color: var(--sd-heading);
	-webkit-font-smoothing: antialiased;
}

.matching-staff-dashboard-body .dashboard-app {
	display: flex;
	height: 100%;
	max-height: 100vh;
	min-height: 0;
	position: relative;
	overflow: hidden;
}

/* ── オーバーレイ（モバイル） ── */
.dashboard-backdrop {
	display: none;
	position: fixed;
	inset: 0;
	z-index: 80;
	background: rgba(7, 10, 15, 0.55);
	backdrop-filter: blur(4px);
	opacity: 0;
	transition: opacity 0.25s ease;
}

html.dashboard-sidebar-open .dashboard-backdrop {
	display: block;
	opacity: 1;
}

/* ── サイドバー ── */
.dashboard-sidebar {
	flex: 0 0 var(--sd-sidebar-w);
	max-width: var(--sd-sidebar-w);
	height: 100vh;
	max-height: 100vh;
	background: var(--sd-sidebar-bg);
	border-right: 1px solid var(--sd-sidebar-border);
	box-shadow: 4px 0 32px rgba(0, 0, 0, 0.25);
	z-index: 100;
	display: flex;
	flex-direction: column;
	overflow-x: hidden;
	overflow-y: auto;
	overscroll-behavior: contain;
	transition:
		flex-basis 0.25s ease,
		max-width 0.25s ease;
}

.dashboard-sidebar-inner {
	display: flex;
	flex-direction: column;
	flex: 1 1 auto;
	min-height: 0;
	padding: var(--sd-space-5) var(--sd-space-3) var(--sd-space-4);
	box-sizing: border-box;
}

.dashboard-sidebar-brand {
	display: flex;
	align-items: center;
	gap: 0.65rem;
	margin-bottom: 1.75rem;
	flex-wrap: wrap;
}

.dashboard-brand-logo .custom-logo-link {
	display: flex;
	align-items: center;
	max-width: 160px;
}

.dashboard-brand-logo .custom-logo {
	max-height: 40px;
	width: auto;
	height: auto;
}

.dashboard-brand-text {
	/* html 1.1rem 時も読みやすいようやや抑えたサイズ */
	font-size: 0.95rem;
	font-weight: 700;
	color: var(--sd-text);
	text-decoration: none;
	letter-spacing: 0.02em;
	line-height: 1.3;
}

.dashboard-brand-text:hover {
	color: var(--sd-accent);
}

.dashboard-brand-badge {
	font-size: var(--sd-text-xs, 0.72rem);
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: 0.12em;
	padding: 0.2rem 0.5rem;
	border-radius: 999px;
	background: var(--sd-accent-soft);
	color: var(--sd-accent);
	border: 1px solid rgba(0, 119, 199, 0.25);
}

.dashboard-sidebar-user {
	margin: 0 0 var(--sd-space-5);
	padding: var(--sd-space-3) var(--sd-space-4);
	border-radius: var(--sd-radius-sm);
	background: rgba(255, 255, 255, 0.04);
	border: 1px solid var(--sd-sidebar-border);
}

/* サイドバー先頭（旧ブランド枠の代わり） */
.dashboard-sidebar-user--header {
	margin-bottom: var(--sd-space-5);
}

.dashboard-sidebar-user-label {
	display: block;
	font-size: var(--sd-text-meta);
	text-transform: uppercase;
	letter-spacing: 0.08em;
	color: var(--sd-text-dim);
	margin-bottom: var(--sd-space-1);
	line-height: 1.35;
}

.dashboard-sidebar-user-name {
	display: block;
	font-size: var(--sd-text-strong);
	font-weight: 600;
	line-height: 1.45;
	color: var(--sd-text);
	overflow-wrap: break-word;
	word-break: normal;
}

.dashboard-nav {
	flex: 1;
}

.dashboard-nav-list {
	list-style: none;
	margin: 0;
	padding: 0;
	display: flex;
	flex-direction: column;
	gap: var(--sd-space-1);
}

.dashboard-nav-link {
	display: flex;
	flex-direction: row;
	flex-wrap: nowrap;
	align-items: center;
	gap: 0.55rem;
	padding: var(--sd-space-2) var(--sd-space-2);
	border-radius: var(--sd-radius-sm);
	color: var(--sd-text-dim);
	text-decoration: none;
	font-weight: 500;
	transition: color 0.15s ease, background 0.15s ease, box-shadow 0.15s ease;
	border: 1px solid transparent;
	min-width: 0;
}

/* サイドメニューラベル（展開 / 折りたたみで出し分け） */
.dashboard-nav-label {
	flex: 1 1 auto;
	min-width: 0;
}

.dashboard-nav-label-full {
	display: block;
	font-size: var(--sd-text-nav);
	font-weight: 600;
	line-height: 1.35;
	letter-spacing: 0;
	white-space: nowrap;
}

.dashboard-nav-label-collapsed {
	display: none;
}

.dashboard-nav-link:hover {
	color: var(--sd-text);
	background: rgba(255, 255, 255, 0.05);
}

.dashboard-nav-link.is-active {
	color: var(--sd-text);
	background: var(--sd-accent-soft);
	border-color: rgba(0, 119, 199, 0.22);
	box-shadow: 0 0 0 1px rgba(0, 119, 199, 0.08);
}

.dashboard-nav-link--logout {
	color: rgba(248, 113, 113, 0.85);
}

.dashboard-nav-link--logout:hover {
	color: var(--sd-danger);
	background: rgba(248, 113, 113, 0.08);
}

.dashboard-nav-icon {
	flex: 0 0 auto;
	width: 1rem;
	height: 1rem;
	margin: 0;
	align-self: center;
	border-radius: 3px;
	background: linear-gradient(135deg, #38bdf8 0%, var(--sd-accent, #0077c7) 100%);
	opacity: 0.92;
}

/* 一覧（求人 / 登録） */
.dashboard-nav-icon--list {
	background: linear-gradient(135deg, #38bdf8 0%, var(--sd-accent, #0077c7) 100%);
}

/* 新規作成 */
.dashboard-nav-icon--create {
	background: linear-gradient(135deg, #4ade80 0%, #16a34a 100%);
}

/* 取り込み / インポート */
.dashboard-nav-icon--import {
	background: linear-gradient(135deg, #22d3ee 0%, #0891b2 100%);
}

/* CSV（スタッフ） */
.dashboard-nav-icon--csv {
	background: linear-gradient(135deg, #fcd34d 0%, #d97706 100%);
}

/* 応募（クールトーン：赤・オレンジと被らない） */
.dashboard-nav-icon--applications {
	background: linear-gradient(135deg, #8b5cf6 0%, #4338ca 100%);
}

/* 会員・ユーザー */
.dashboard-nav-icon--members {
	background: linear-gradient(135deg, #a78bfa 0%, #7c3aed 100%);
}

/* メール送信 */
.dashboard-nav-icon--mail {
	background: linear-gradient(135deg, #f472b6 0%, #db2777 100%);
}

/* 集計・結果 */
.dashboard-nav-icon--stats {
	background: linear-gradient(135deg, #fbbf24 0%, #f59e0b 100%);
}

/* マニュアル */
.dashboard-nav-icon--manual {
	background: linear-gradient(135deg, #2dd4bf 0%, #0d9488 100%);
}

/* 公開ページ（外部表示） */
.dashboard-nav-icon--public {
	background: linear-gradient(135deg, #60a5fa 0%, #2563eb 100%);
}

/* サイトトップ */
.dashboard-nav-icon--home {
	background: linear-gradient(135deg, #86efac 0%, #22c55e 100%);
}

/* 他ダッシュボード切替 */
.dashboard-nav-icon--staff-dashboard {
	background: linear-gradient(135deg, #818cf8 0%, #6366f1 100%);
}

.dashboard-nav-icon--company-dashboard {
	background: linear-gradient(135deg, #67e8f9 0%, #0891b2 100%);
}

/* WordPress 管理画面 */
.dashboard-nav-icon--wp {
	background: linear-gradient(135deg, #c084fc 0%, #9333ea 100%);
}

.dashboard-nav-icon--logout {
	background: linear-gradient(135deg, #fb7185 0%, #ef4444 100%);
	opacity: 0.95;
}


.dashboard-sidebar-footer {
	margin-top: auto;
	padding-top: 1.25rem;
	border-top: 1px solid var(--sd-sidebar-border);
}

/* デスクトップ：サイドバー折りたたみ（上部トグル・1列＋アイコン下ラベル） */
.dashboard-sidebar-collapse-toggle {
	display: none;
	flex: 0 0 auto;
	align-items: center;
	justify-content: flex-start;
	gap: 0.5rem;
	width: 100%;
	margin: 0;
	padding: 0.48rem 0.6rem;
	border: 0;
	border-bottom: 1px solid var(--sd-sidebar-border);
	background: rgba(0, 0, 0, 0.18);
	color: var(--sd-text-dim);
	font-size: var(--sd-text-xs, 0.72rem);
	font-weight: 600;
	line-height: 1.35;
	cursor: pointer;
	transition: color 0.15s ease, background 0.15s ease;
}

.dashboard-sidebar-collapse-toggle:hover {
	color: var(--sd-text);
	background: rgba(255, 255, 255, 0.06);
}

.dashboard-sidebar-collapse-toggle:focus-visible {
	outline: 2px solid rgba(0, 119, 199, 0.55);
	outline-offset: -2px;
}

.dashboard-sidebar-collapse-icon {
	flex: 0 0 auto;
	width: 0.5rem;
	height: 0.5rem;
	border-right: 1.5px solid currentColor;
	border-bottom: 1.5px solid currentColor;
	transform: rotate(-45deg);
	transition: transform 0.2s ease;
}

.dashboard-sidebar-collapse-text {
	flex: 1 1 auto;
	min-width: 0;
	font-size: var(--sd-text-xs, 0.72rem);
	letter-spacing: 0.02em;
	text-align: left;
	white-space: nowrap;
	overflow: hidden;
	text-overflow: ellipsis;
}

@media (min-width: 961px) {
	.dashboard-sidebar-collapse-toggle {
		display: flex;
	}

	html.dashboard-sidebar-collapsed .dashboard-sidebar {
		flex-basis: var(--sd-sidebar-w-collapsed);
		max-width: var(--sd-sidebar-w-collapsed);
	}

	html.dashboard-sidebar-collapsed .dashboard-sidebar-inner {
		display: flex;
		flex-direction: column;
		flex: 1 1 auto;
		min-height: 0;
		padding: 0.55rem 0.4rem 0.65rem;
		align-items: stretch;
	}

	html.dashboard-sidebar-collapsed .dashboard-sidebar-collapse-text,
	html.dashboard-sidebar-collapsed .dashboard-sidebar-user-label,
	html.dashboard-sidebar-collapsed .dashboard-sidebar-user-name {
		position: absolute;
		width: 1px;
		height: 1px;
		padding: 0;
		margin: -1px;
		overflow: hidden;
		clip: rect(0, 0, 0, 0);
		white-space: nowrap;
		border: 0;
	}

	html.dashboard-sidebar-collapsed .dashboard-sidebar-collapse-toggle {
		justify-content: center;
		padding: 0.45rem 0.35rem;
	}

	html.dashboard-sidebar-collapsed .dashboard-sidebar-collapse-icon {
		transform: rotate(135deg);
	}

	html.dashboard-sidebar-collapsed .dashboard-sidebar-user--header {
		display: flex;
		justify-content: center;
		width: 100%;
		margin: 0 0 0.4rem;
		padding: 0.25rem 0;
		background: transparent;
		border: 0;
	}

	html.dashboard-sidebar-collapsed .dashboard-sidebar-user--header::before {
		content: attr(data-user-initial);
		display: inline-flex;
		align-items: center;
		justify-content: center;
		width: 1.65rem;
		height: 1.65rem;
		border-radius: 50%;
		font-size: 0.72rem;
		font-weight: 700;
		line-height: 1;
		color: var(--sd-text);
		background: rgba(255, 255, 255, 0.1);
		border: 1px solid rgba(255, 255, 255, 0.14);
		text-transform: uppercase;
	}

	html.dashboard-sidebar-collapsed .dashboard-sidebar-locale {
		position: static;
		flex-shrink: 0;
		width: 100%;
		height: auto;
		margin: 0 0 0.4rem;
		padding: 0 0 0.45rem;
		overflow: visible;
		clip: auto;
		border-bottom: 1px solid var(--sd-sidebar-border);
	}

	html.dashboard-sidebar-collapsed .dashboard-locale-tabs--sidebar {
		gap: 0.25rem;
	}

	html.dashboard-sidebar-collapsed .dashboard-locale-tabs--sidebar .dashboard-locale-tab {
		padding: 0.38rem 0.15rem;
		text-align: center;
	}

	html.dashboard-sidebar-collapsed .dashboard-locale-tabs--sidebar .dashboard-locale-tab[data-locale-short] {
		font-size: 0;
		line-height: 0;
	}

	html.dashboard-sidebar-collapsed .dashboard-locale-tabs--sidebar .dashboard-locale-tab[data-locale-short]::before {
		content: attr(data-locale-short);
		display: block;
		font-size: var(--sd-text-xs, 0.72rem);
		font-weight: 600;
		line-height: 1.25;
		color: var(--sd-text-dim);
	}

	html.dashboard-sidebar-collapsed .dashboard-locale-tabs--sidebar .dashboard-locale-tab[data-locale-short]:hover::before {
		color: var(--sd-text);
	}

	html.dashboard-sidebar-collapsed .dashboard-locale-tabs--sidebar .dashboard-locale-tab.is-active[data-locale-short]::before {
		color: var(--sd-text);
	}

	html.dashboard-sidebar-collapsed .dashboard-nav {
		flex: 1 1 auto;
		min-height: 0;
		width: 100%;
		overflow-y: auto;
	}

	html.dashboard-sidebar-collapsed .dashboard-nav-list {
		display: flex;
		flex-direction: column;
		gap: 0.25rem;
		width: 100%;
	}

	html.dashboard-sidebar-collapsed .dashboard-nav-list > li {
		margin: 0;
		min-width: 0;
	}

	html.dashboard-sidebar-collapsed .dashboard-sidebar-footer {
		display: flex;
		flex-direction: column;
		flex-shrink: 0;
		width: 100%;
		margin-top: auto;
		padding-top: 0.65rem;
		border-top: 1px solid var(--sd-sidebar-border);
	}

	html.dashboard-sidebar-collapsed .dashboard-nav-link {
		flex-direction: column;
		align-items: center;
		justify-content: center;
		gap: 0.28rem;
		width: 100%;
		padding: 0.42rem 0.15rem;
		text-align: center;
	}

	html.dashboard-sidebar-collapsed .dashboard-nav-label {
		flex: none;
		width: 100%;
		max-width: 100%;
	}

	html.dashboard-sidebar-collapsed .dashboard-nav-label-full {
		display: none;
	}

	html.dashboard-sidebar-collapsed .dashboard-nav-label-collapsed {
		display: block;
		font-size: var(--sd-text-xs, 0.72rem);
		font-weight: 600;
		line-height: 1.25;
		letter-spacing: -0.01em;
		word-break: keep-all;
		overflow-wrap: normal;
	}

	html.dashboard-sidebar-collapsed .dashboard-nav-label-collapsed--multiline {
		font-size: 0.625rem;
		line-height: 1.2;
		letter-spacing: -0.02em;
	}

	html.dashboard-sidebar-collapsed .dashboard-nav-link:has(.dashboard-nav-label-collapsed:not(.dashboard-nav-label-collapsed--multiline)) {
		min-height: 3.35rem;
	}

	html.dashboard-sidebar-collapsed .dashboard-nav-link:has(.dashboard-nav-label-collapsed--multiline) {
		min-height: 3.55rem;
	}

	html.dashboard-sidebar-collapsed .dashboard-nav-icon {
		width: 0.85rem;
		height: 0.85rem;
	}
}

/* サイドバー：日本語登録 / 英語登録の切替 */
.dashboard-sidebar-locale {
	margin: 0 0 var(--sd-space-5);
	padding-bottom: var(--sd-space-4);
	border-bottom: 1px solid var(--sd-sidebar-border);
}

.dashboard-locale-tabs--sidebar {
	display: flex;
	flex-direction: column;
	flex-wrap: nowrap;
	gap: var(--sd-space-1);
	margin-top: 0;
}

.dashboard-locale-tabs--sidebar .dashboard-locale-tab {
	width: 100%;
	justify-content: center;
	box-sizing: border-box;
	padding: var(--sd-space-2) var(--sd-space-2);
	font-size: var(--sd-text-nav);
	font-weight: 500;
	line-height: 1.3;
	letter-spacing: -0.01em;
	white-space: nowrap;
	color: var(--sd-text-dim);
	background: rgba(255, 255, 255, 0.04);
	border: 1px solid var(--sd-sidebar-border);
	border-radius: var(--sd-radius-sm);
}

.dashboard-locale-tabs--sidebar .dashboard-locale-tab:hover {
	color: var(--sd-text);
	background: rgba(255, 255, 255, 0.06);
	border-color: rgba(255, 255, 255, 0.1);
}

.dashboard-locale-tabs--sidebar .dashboard-locale-tab.is-active {
	color: var(--sd-text);
	background: var(--sd-accent-soft);
	border-color: rgba(0, 119, 199, 0.35);
	font-weight: 600;
	box-shadow: 0 0 0 1px rgba(0, 119, 199, 0.08);
}

/* ── メインカラム ── */
.dashboard-main {
	flex: 1;
	min-width: 0;
	min-height: 0;
	display: flex;
	flex-direction: column;
	overflow: hidden;
	background: var(--sd-main-bg);
}

.dashboard-topbar {
	flex-shrink: 0;
	display: flex;
	align-items: flex-start;
	gap: 1rem;
	padding: 1.25rem 1.5rem 1rem;
	background: var(--sd-card);
	border-bottom: 1px solid var(--sd-card-border);
	box-shadow: var(--sd-shadow);
	position: sticky;
	top: 0;
	z-index: 40;
}

.dashboard-menu-toggle {
	display: none;
	flex: 0 0 44px;
	width: 44px;
	height: 44px;
	align-items: center;
	justify-content: center;
	border: 1px solid var(--sd-card-border);
	border-radius: var(--sd-radius-sm);
	background: var(--sd-row-hover);
	cursor: pointer;
	transition: background 0.15s ease, border-color 0.15s ease;
}

.dashboard-menu-toggle:hover {
	background: #fff;
	border-color: rgba(0, 119, 199, 0.35);
}

.dashboard-menu-toggle-bars,
.dashboard-menu-toggle-bars::before,
.dashboard-menu-toggle-bars::after {
	display: block;
	width: 18px;
	height: 2px;
	background: var(--sd-heading);
	border-radius: 1px;
	position: relative;
}

.dashboard-menu-toggle-bars::before,
.dashboard-menu-toggle-bars::after {
	content: "";
	position: absolute;
	left: 0;
}

.dashboard-menu-toggle-bars::before {
	top: -6px;
}

.dashboard-menu-toggle-bars::after {
	top: 6px;
}

.dashboard-topbar-titles {
	min-width: 0;
	flex: 1;
}

.dashboard-topbar-title {
	margin: 0;
	font-size: 1.35rem;
	font-weight: 700;
	color: var(--sd-heading);
	letter-spacing: -0.02em;
	line-height: 1.25;
}

.dashboard-topbar-lead {
	margin: 0.4rem 0 0;
	font-size: 0.9rem;
	color: var(--sd-muted);
	line-height: 1.55;
	max-width: 52rem;
}

.dashboard-main-scroll {
	flex: 1;
	min-height: 0;
	overflow-x: hidden;
	overflow-y: auto;
	overscroll-behavior: contain;
	padding: 1.25rem 1.5rem 2rem;
}

.dashboard-site-main.page-staff-dashboard,
.dashboard-site-main.page-recruit-company-dashboard {
	margin: 0;
	padding: 0;
	max-width: none;
}

/* ── パネル・フォーム ── */
.dashboard-panel {
	min-width: 0;
	max-width: 100%;
	background: var(--sd-card);
	border: 1px solid var(--sd-card-border);
	border-radius: var(--sd-radius);
	box-shadow: var(--sd-shadow);
	padding: 1.5rem 1.5rem 1.75rem;
	box-sizing: border-box;
}

.dashboard-panel-head {
	margin-bottom: 1.25rem;
	padding-bottom: 1rem;
	border-bottom: 1px solid rgba(15, 23, 42, 0.06);
}

.dashboard-panel-title {
	margin: 0;
	font-size: 1.1rem;
	font-weight: 700;
	color: var(--sd-heading);
	letter-spacing: -0.01em;
}

/* ── 利用マニュアル ── */
.dashboard-manual {
	display: flex;
	flex-direction: column;
	gap: var(--sd-space-3, 1rem);
	scroll-margin-top: 1rem;
}

.dashboard-manual-meta {
	display: flex;
	flex-wrap: wrap;
	align-items: flex-start;
	gap: 0.65rem 0.9rem;
	padding: 0.95rem 1.05rem;
	border: 1px solid var(--sd-card-border, rgba(15, 23, 42, 0.08));
	border-radius: var(--sd-radius-sm);
	background: linear-gradient(135deg, rgba(0, 119, 199, 0.06) 0%, rgba(0, 119, 199, 0.02) 42%, #f8fbff 100%);
	box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.85);
}

.dashboard-manual-badge {
	display: inline-flex;
	align-items: center;
	flex: 0 0 auto;
	padding: 0.38rem 0.62rem;
	border-radius: 999px;
	font-size: var(--sd-text-xs, 0.72rem);
	font-weight: 700;
	letter-spacing: 0.04em;
	color: #065f46;
	background: #d1fae5;
	border: 1px solid rgba(6, 95, 70, 0.22);
}

.dashboard-manual-badge--company {
	color: #1e40af;
	background: #dbeafe;
	border-color: rgba(30, 64, 175, 0.22);
}

.dashboard-manual-note {
	flex: 1 1 16rem;
	margin: 0;
	min-width: min(100%, 14rem);
	font-size: var(--sd-text-base, 0.875rem);
	line-height: 1.6;
	color: var(--sd-muted);
}

.dashboard-manual-block {
	padding: 1rem 1.05rem 1.1rem;
	border: 1px solid rgba(15, 23, 42, 0.1);
	border-radius: var(--sd-radius-sm);
	background: #fff;
	box-shadow: 0 1px 0 rgba(255, 255, 255, 0.9);
	scroll-margin-top: 5.5rem;
}

.dashboard-manual-block--index {
	background: linear-gradient(180deg, #fafbfc 0%, #fff 100%);
	border-color: rgba(15, 23, 42, 0.08);
}

.dashboard-manual-section-heading {
	margin: 0 0 0.55rem;
	padding-bottom: 0.45rem;
	border-bottom: 1px solid rgba(15, 23, 42, 0.08);
	font-size: var(--sd-text-lg, 0.95rem);
	font-weight: 700;
	letter-spacing: -0.01em;
	line-height: 1.45;
	color: var(--sd-heading);
	text-transform: none;
}

.dashboard-manual-index {
	margin: 0.35rem 0 0;
	padding: 0;
	list-style: none;
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(13.5rem, 1fr));
	gap: 0.45rem;
}

.dashboard-manual-index li {
	margin: 0;
}

.dashboard-manual-index a {
	display: flex;
	align-items: center;
	min-height: 2.35rem;
	padding: 0.45rem 0.65rem;
	border: 1px solid rgba(15, 23, 42, 0.1);
	border-radius: var(--sd-radius-sm);
	background: #fff;
	color: var(--sd-heading);
	text-decoration: none;
	font-size: var(--sd-text-sm, 0.78rem);
	font-weight: 600;
	line-height: 1.45;
	letter-spacing: 0;
	transition: border-color 0.15s ease, background 0.15s ease, color 0.15s ease, box-shadow 0.15s ease;
}

.dashboard-manual-index a:hover {
	border-color: rgba(0, 119, 199, 0.35);
	background: var(--sd-accent-soft);
	color: var(--sd-accent);
	box-shadow: 0 2px 8px rgba(0, 119, 199, 0.08);
	text-decoration: none;
}

.dashboard-manual-index a:focus-visible {
	outline: 2px solid rgba(0, 119, 199, 0.45);
	outline-offset: 2px;
}

.dashboard-manual-steps,
.dashboard-manual-list {
	margin: 0.6rem 0 0;
	padding-left: 1.35rem;
	display: grid;
	gap: 0.42rem;
}

.dashboard-manual-steps {
	counter-reset: dashboard-manual-step;
	list-style: none;
	padding-left: 0;
}

.dashboard-manual-steps li {
	position: relative;
	padding-left: 2rem;
	font-size: var(--sd-text-base, 0.875rem);
	line-height: 1.65;
	color: var(--sd-heading);
	letter-spacing: 0;
	counter-increment: dashboard-manual-step;
}

.dashboard-manual-steps li::before {
	content: counter(dashboard-manual-step);
	position: absolute;
	left: 0;
	top: 0.08rem;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 1.35rem;
	height: 1.35rem;
	border-radius: 999px;
	font-size: var(--sd-text-xs, 0.72rem);
	font-weight: 700;
	color: var(--sd-accent);
	background: var(--sd-accent-soft);
	border: 1px solid rgba(0, 119, 199, 0.2);
}

.dashboard-manual-list li {
	font-size: var(--sd-text-base, 0.875rem);
	line-height: 1.65;
	color: var(--sd-heading);
	letter-spacing: 0;
}

.dashboard-manual-callout {
	margin-top: 0.5rem;
	padding: 0.65rem 0.8rem;
	border-left: 4px solid var(--sd-accent);
	background: var(--sd-row-hover, #f8fafc);
	border-radius: 0 var(--sd-radius-sm) var(--sd-radius-sm) 0;
}

.dashboard-manual-callout p {
	margin: 0;
	font-size: var(--sd-text-sm, 0.78rem);
	line-height: 1.6;
	color: #334155;
}

.dashboard-manual-details {
	margin-top: 0.7rem;
	border: 1px solid rgba(15, 23, 42, 0.1);
	border-radius: var(--sd-radius-sm);
	background: #fcfdff;
	padding: 0.55rem 0.75rem 0.7rem;
	transition: border-color 0.15s ease, box-shadow 0.15s ease;
}

.dashboard-manual-details[open] {
	border-color: rgba(0, 119, 199, 0.18);
	box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.9);
}

.dashboard-manual-details > summary {
	cursor: pointer;
	font-size: var(--sd-text-base, 0.875rem);
	font-weight: 700;
	color: var(--sd-heading);
	letter-spacing: 0;
	line-height: 1.5;
	list-style: none;
}

.dashboard-manual-details > summary::-webkit-details-marker {
	display: none;
}

.dashboard-manual-details > summary::before {
	content: "▸";
	display: inline-block;
	margin-right: 0.35rem;
	color: var(--sd-accent);
	transition: transform 0.15s ease;
}

.dashboard-manual-details[open] > summary::before {
	transform: rotate(90deg);
}

.dashboard-manual-details > summary + .dashboard-manual-list {
	margin-top: 0.55rem;
}

.dashboard-manual-details[open] > summary + .dashboard-manual-list {
	margin-top: 0.65rem;
}

/* Q&A */
.dashboard-manual-block--faq {
	background: linear-gradient(180deg, #fff 0%, #fafcff 100%);
}

.dashboard-manual-faq-intro {
	margin: 0 0 0.75rem;
	font-size: var(--sd-text-base, 0.875rem);
	line-height: 1.65;
	color: var(--sd-muted);
}

.dashboard-manual-faq {
	display: grid;
	gap: 0.6rem;
}

.dashboard-manual-faq-item {
	border: 1px solid rgba(15, 23, 42, 0.1);
	border-radius: var(--sd-radius-sm);
	background: #fff;
	overflow: hidden;
	transition: border-color 0.15s ease, box-shadow 0.15s ease;
}

.dashboard-manual-faq-item[open] {
	border-color: rgba(0, 119, 199, 0.22);
	box-shadow: 0 2px 10px rgba(0, 119, 199, 0.06);
}

.dashboard-manual-faq-question {
	display: flex;
	align-items: flex-start;
	gap: 0.6rem;
	padding: 0.75rem 0.85rem;
	cursor: pointer;
	font-size: inherit;
	font-weight: inherit;
	line-height: inherit;
	color: inherit;
	list-style: none;
}

.dashboard-manual-faq-question::-webkit-details-marker {
	display: none;
}

.dashboard-manual-faq-question-text {
	flex: 1 1 auto;
	min-width: 0;
	font-size: var(--sd-text-lg, 0.95rem);
	font-weight: 700;
	line-height: 1.55;
	color: var(--sd-heading);
	letter-spacing: 0;
}

.dashboard-manual-faq-answer {
	display: flex;
	align-items: flex-start;
	gap: 0.6rem;
	padding: 0 0.85rem 0.8rem;
	border-top: 1px solid rgba(15, 23, 42, 0.06);
	margin-top: -0.05rem;
	padding-top: 0.7rem;
}

.dashboard-manual-faq-answer p {
	margin: 0;
	flex: 1 1 auto;
	min-width: 0;
	font-size: var(--sd-text-base, 0.875rem);
	line-height: 1.7;
	color: var(--sd-heading);
	letter-spacing: 0;
}

.dashboard-manual-faq-label {
	flex: 0 0 auto;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 1.5rem;
	height: 1.5rem;
	margin-top: 0.05rem;
	border-radius: 0.35rem;
	font-size: var(--sd-text-sm, 0.78rem);
	font-weight: 800;
	line-height: 1;
	letter-spacing: 0.02em;
}

.dashboard-manual-faq-label--q {
	color: var(--sd-accent);
	background: var(--sd-accent-soft);
	border: 1px solid rgba(0, 119, 199, 0.2);
}

.dashboard-manual-faq-label--a {
	color: #065f46;
	background: #ecfdf5;
	border: 1px solid rgba(6, 95, 70, 0.18);
}

.dashboard-manual-gallery {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
	gap: 0.85rem;
	margin-top: 0.6rem;
}

.dashboard-manual-figure {
	margin: 0;
	border: 1px solid rgba(15, 23, 42, 0.1);
	border-radius: var(--sd-radius-sm);
	background: #fff;
	overflow: hidden;
}

.dashboard-manual-figure a {
	display: block;
	background: #0b1220;
}

.dashboard-manual-figure img {
	display: block;
	width: 100%;
	height: auto;
	aspect-ratio: 16 / 10;
	object-fit: cover;
}

.dashboard-manual-figure figcaption {
	display: grid;
	gap: 0.2rem;
	padding: 0.55rem 0.65rem 0.65rem;
}

.dashboard-manual-figure figcaption strong {
	font-size: 0.83rem;
	color: var(--sd-heading);
}

.dashboard-manual-figure figcaption span {
	font-size: 0.76rem;
	line-height: 1.5;
	color: var(--sd-muted);
}

.dashboard-manual-figure-desc {
	display: block;
	margin-top: 0.25rem;
	white-space: normal;
}

.dashboard-manual-note--tight {
	margin-top: 0.35rem;
	font-size: 0.82rem;
}

/* 操作の流れ（手順＋差し込み画像） */
.dashboard-manual-flow-intro {
	margin: 0 0 0.9rem;
	font-size: 0.88rem;
	line-height: 1.6;
	color: #334155;
}

.dashboard-manual-flow {
	display: flex;
	flex-direction: column;
	gap: 1.25rem;
}

.dashboard-manual-flow-step {
	padding: 1rem 1.05rem 1.05rem;
	border: 1px solid rgba(15, 23, 42, 0.1);
	border-radius: var(--sd-radius-sm);
	background: linear-gradient(180deg, #fff 0%, #fafbfc 100%);
}

.dashboard-manual-flow-step-title {
	margin: 0 0 0.65rem;
	font-size: 0.95rem;
	font-weight: 700;
	color: var(--sd-heading);
	letter-spacing: -0.01em;
}

.dashboard-manual-flow-dl {
	margin: 0;
	display: grid;
	gap: 0.6rem;
}

.dashboard-manual-flow-dl > div {
	margin: 0;
	display: grid;
	grid-template-columns: 4.5rem 1fr;
	gap: 0.4rem 0.75rem;
	align-items: start;
}

.dashboard-manual-flow-dl dt {
	margin: 0;
	font-size: 0.72rem;
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: 0.06em;
	color: var(--sd-muted);
	line-height: 1.4;
	padding-top: 0.12rem;
}

.dashboard-manual-flow-dl dd {
	margin: 0;
	font-size: 0.88rem;
	line-height: 1.55;
	color: var(--sd-heading);
}

.dashboard-manual-flow-figure {
	margin: 0.85rem 0 0;
	border: 1px solid rgba(15, 23, 42, 0.12);
	border-radius: var(--sd-radius-sm);
	overflow: hidden;
	background: #0b1220;
}

.dashboard-manual-flow-figure img {
	display: block;
	width: 100%;
	height: auto;
	max-height: 22rem;
	object-fit: contain;
	object-position: top center;
}

.dashboard-manual-flow-caption {
	margin: 0;
	padding: 0.4rem 0.55rem;
	font-size: 0.72rem;
	color: var(--sd-muted);
	background: #f1f5f9;
}

.dashboard-manual-flow-placeholder {
	margin: 0.75rem 0 0;
	padding: 0.55rem 0.65rem;
	font-size: 0.8rem;
	line-height: 1.5;
	color: var(--sd-muted, #64748b);
	background: var(--sd-row-hover, #f8fafc);
	border: 1px dashed rgba(15, 23, 42, 0.18);
	border-radius: var(--sd-radius-sm);
}

.dashboard-manual-actions {
	margin: 0.85rem 0 0;
}

/* 利用マニュアル内のボタンは destyle の a 既定を打ち消して標準サイズを維持 */
.matching-staff-dashboard-body .dashboard-manual-actions .btn {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: auto;
	height: auto;
	min-height: 2.4rem;
	padding: 0.45rem 0.9rem;
	font-size: 0.85rem;
	line-height: 1.25;
	letter-spacing: 0.02em;
	white-space: nowrap;
}


.dashboard-subsection {
	margin-bottom: 1.35rem;
}

.dashboard-subsection-heading {
	margin: 0 0 0.65rem;
	font-size: 0.78rem;
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: 0.08em;
	color: var(--sd-muted);
	line-height: 1.35;
}

.dashboard-subsection--data {
	padding: 1rem 1.15rem 1.15rem;
	border-radius: var(--sd-radius-sm);
	background: linear-gradient(180deg, #fafbfc 0%, #f4f6f9 100%);
	border: 1px solid rgba(15, 23, 42, 0.09);
	box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.75);
}

.dashboard-subsection--data .dashboard-tools {
	margin-bottom: 1rem;
}

.dashboard-filters {
	display: flex;
	flex-direction: column;
	gap: 1.15rem;
	margin-bottom: 0;
}

.dashboard-filters--panel {
	padding: 1.05rem 1.15rem 1.2rem;
	border-radius: var(--sd-radius-sm);
	border: 1px solid rgba(15, 23, 42, 0.09);
	background: linear-gradient(165deg, #fff 0%, var(--sd-row-hover, #f8fafc) 55%, #f1f5f9 100%);
	box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.9);
}

.dashboard-filters-row {
	display: flex;
	flex-wrap: wrap;
	align-items: flex-end;
	gap: 0.85rem 1.1rem;
}

/* 1行目に 4 フィールドを並べる（地域 / 職種 / 年齢帯=details / 就業状況）。
 * 年齢帯は details ドロップダウン化したのでコンパクト枠で OK。 */
@media (min-width: 960px) {
	.dashboard-filters-row--primary {
		display: grid;
		grid-template-columns: minmax(10rem, 1fr) minmax(18rem, 2.4fr) minmax(8rem, 0.95fr) minmax(10rem, 1.1fr);
		align-items: start;
		gap: 0.85rem 1.15rem;
	}

	.dashboard-filters-row--primary > .dashboard-field:nth-child(1) {
		grid-column: 1;
		grid-row: 1;
	}

	.dashboard-filters-row--primary > .dashboard-field:nth-child(2) {
		grid-column: 2;
		grid-row: 1;
	}

	.dashboard-filters-row--primary > .dashboard-field:nth-child(3) {
		grid-column: 3;
		grid-row: 1;
	}

	.dashboard-filters-row--primary > .dashboard-field:nth-child(4) {
		grid-column: 4;
		grid-row: 1;
	}
}

.dashboard-filters-row-search {
	align-items: flex-end;
}

.dashboard-filters-row-search.dashboard-filters-row {
	gap: 0.85rem 1rem;
}

.dashboard-field {
	display: flex;
	flex-direction: column;
	gap: 0.35rem;
	min-width: 0;
}

.dashboard-field--grow {
	flex: 1 1 14rem;
}

/* キーワード行：広い画面では検索欄を横いっぱい＋ボタン右端 */
@supports selector(:has(*)) {
	@media (min-width: 640px) {
		.dashboard-filters-row-search:has([data-dashboard-search="keyword"]) {
			display: grid;
			grid-template-columns: minmax(0, 1fr) auto;
			align-items: end;
			gap: 0.85rem 1rem;
		}

		.dashboard-filters-row-search:has([data-dashboard-search="keyword"]) .dashboard-field--grow {
			min-width: 0;
		}
	}
}

.dashboard-field--submit {
	flex: 0 0 auto;
	align-self: flex-end;
	padding-bottom: 0.12rem;
}

.dashboard-filters-row--actions {
	justify-content: flex-end;
	align-items: center;
	gap: 0.65rem;
	padding-top: 0.05rem;
}

.dashboard-filters-row--actions .btn-primary {
	min-width: 6.5rem;
}

/* キーワード検索は項目絞り込みと別ブロックとして区切る */
.dashboard-filters-row--keyword {
	padding-top: 0.75rem;
	margin-top: 0.25rem;
	border-top: 1px solid rgba(15, 23, 42, 0.09);
}

.dashboard-filter-label {
	font-size: 0.78rem;
	font-weight: 600;
	text-transform: uppercase;
	letter-spacing: 0.06em;
	color: var(--sd-muted);
	margin: 0;
}

.dashboard-select,
.dashboard-search-input {
	font-size: 0.95rem;
	padding: 0.55rem 0.75rem;
	border: 1px solid rgba(15, 23, 42, 0.12);
	border-radius: var(--sd-radius-sm);
	background: #fff;
	color: var(--sd-heading);
	transition: border-color 0.15s ease, box-shadow 0.15s ease;
	min-width: 0;
}

.dashboard-select,
.dashboard-search-input {
	min-height: var(--sd-filter-control-min-height);
}

.dashboard-select {
	min-width: 11rem;
}

/* 登録地域：アカウント固定（セレクト＋バッジ＋注記を縦にまとめる） */
.dashboard-select-lock-stack {
	display: flex;
	flex-direction: column;
	align-items: stretch;
	gap: 0.35rem;
	min-width: 0;
	width: 100%;
}

.dashboard-select-lock-row {
	display: flex;
	align-items: center;
	flex-wrap: nowrap;
	gap: 0.5rem;
	min-width: 0;
}

.dashboard-select-lock-row .dashboard-select--locked {
	flex: 1 1 auto;
	min-width: 0;
	width: 100%;
	max-width: 100%;
	cursor: not-allowed;
	opacity: 0.98;
	background: linear-gradient(180deg, var(--sd-row-hover, #f8fafc) 0%, #fff 100%);
	border-style: dashed;
	border-color: rgba(15, 23, 42, 0.16);
	color: var(--sd-heading);
	box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.85);
}

.dashboard-select--locked:focus {
	border-color: rgba(15, 23, 42, 0.22);
	box-shadow: none;
}

.dashboard-lock-badge {
	flex: 0 0 auto;
	display: inline-flex;
	align-items: center;
	align-self: center;
	padding: 0.42rem 0.6rem;
	font-size: var(--sd-text-xs, 0.72rem);
	font-weight: 700;
	letter-spacing: 0.05em;
	text-transform: uppercase;
	color: var(--sd-accent);
	background: var(--sd-accent-soft);
	border: 1px solid rgba(15, 23, 42, 0.1);
	border-radius: 999px;
	line-height: 1;
	white-space: nowrap;
}

.dashboard-lock-hint {
	margin: 0;
	font-size: 0.7rem;
	line-height: 1.4;
	color: var(--sd-muted);
	max-width: 100%;
}

.dashboard-select[data-dashboard-select="industry"] {
	min-width: min(100%, 36rem);
	width: 100%;
	max-width: 100%;
	box-sizing: border-box;
}

.dashboard-search-input {
	width: 100%;
	box-sizing: border-box;
}

.dashboard-select:focus,
.dashboard-search-input:focus {
	outline: none;
	border-color: var(--sd-accent);
	box-shadow: 0 0 0 3px var(--sd-accent-soft);
}

.dashboard-age-checks {
	display: grid;
	grid-template-columns: repeat(auto-fill, minmax(5.75rem, 1fr));
	gap: 0.45rem 0.55rem;
	width: 100%;
	max-width: 100%;
	padding: 0.55rem 0.65rem;
	border: 1px solid rgba(15, 23, 42, 0.1);
	border-radius: var(--sd-radius-sm);
	background: #fff;
	box-sizing: border-box;
	min-height: var(--sd-filter-control-min-height);
}

.dashboard-age-check {
	display: flex;
	align-items: center;
	gap: 0.25rem;
	font-size: 0.78rem;
	line-height: 1.3;
	color: var(--sd-heading);
	padding: 0.05rem 0;
	white-space: nowrap;
}

.dashboard-age-check span {
	font-size: 0.78rem;
	line-height: 1.3;
}

.dashboard-age-check input[type="checkbox"] {
	margin: 0;
	inline-size: 0.9rem;
	block-size: 0.9rem;
}

.dashboard-filters-details {
	border: 1px solid rgba(15, 23, 42, 0.1);
	border-radius: var(--sd-radius-sm);
	padding: 0.55rem 0.85rem 0.65rem;
	background: rgba(255, 255, 255, 0.65);
	transition: border-color 0.15s ease, box-shadow 0.15s ease;
}

.dashboard-filters-details[open] {
	border-color: rgba(15, 23, 42, 0.14);
	box-shadow: 0 1px 0 rgba(255, 255, 255, 0.8) inset;
}

.dashboard-filters-details-summary {
	cursor: pointer;
	font-size: 0.82rem;
	font-weight: 700;
	color: var(--sd-heading);
	list-style: none;
	display: flex;
	align-items: center;
	gap: 0.4rem;
	padding: 0.2rem 0;
}

.dashboard-filters-details-summary::-webkit-details-marker {
	display: none;
}

.dashboard-filters-details-summary::before {
	content: '';
	display: inline-block;
	width: 0.45rem;
	height: 0.45rem;
	border-right: 2px solid var(--sd-muted);
	border-bottom: 2px solid var(--sd-muted);
	transform: rotate(-45deg);
	transition: transform 0.2s ease;
	margin-right: 0.15rem;
	flex-shrink: 0;
}

.dashboard-filters-details[open] .dashboard-filters-details-summary::before {
	transform: rotate(45deg);
	margin-top: -0.1rem;
}

.dashboard-filters-details[open] .dashboard-filters-row {
	margin-top: 0.75rem;
}

.dashboard-filters-details .dashboard-filters-row + .dashboard-filters-row {
	margin-top: 0.65rem;
}

/* ── 絞り込みドロップダウン（クリックで展開：会社/スタッフ共通） ── */
.dashboard-filter-dropdown {
	position: relative;
	width: 100%;
}

.dashboard-filter-trigger {
	display: inline-flex;
	align-items: center;
	gap: 0.4rem;
	width: 100%;
	min-height: 2.4rem;
	padding: 0.45rem 0.7rem;
	background: #fff;
	border: 1px solid #d6d3d0;
	border-radius: 6px;
	cursor: pointer;
	font-size: 0.95rem;
	line-height: 1.3;
	color: #23221e;
	box-sizing: border-box;
	list-style: none;
	user-select: none;
	transition: border-color 0.15s ease, box-shadow 0.15s ease, background 0.15s ease;
}

.dashboard-filter-trigger::-webkit-details-marker {
	display: none;
}

.dashboard-filter-trigger:hover {
	border-color: var(--sd-accent, #0077c7);
	background: #fafafa;
}

.dashboard-filter-trigger:focus-visible {
	outline: none;
	border-color: var(--sd-accent, #0077c7);
	box-shadow: 0 0 0 2px rgba(0, 119, 199, 0.2);
}

.dashboard-filter-dropdown[open] > .dashboard-filter-trigger {
	border-color: var(--sd-accent, #0077c7);
	box-shadow: 0 0 0 2px rgba(0, 119, 199, 0.15);
	background: #fff;
}

.dashboard-filter-trigger-value {
	flex: 1 1 auto;
	min-width: 0;
	white-space: nowrap;
	font-size: 0.95rem;
	line-height: 1.3;
	color: #23221e;
}

.dashboard-filter-trigger-value--placeholder {
	color: #706d65;
}

.dashboard-filter-trigger-value--count {
	color: var(--sd-accent, #0066ad);
	font-weight: 700;
	font-variant-numeric: tabular-nums;
}

.dashboard-filter-trigger-badge {
	flex: 0 0 auto;
	font-size: 0.7rem;
	font-weight: 700;
	line-height: 1;
	padding: 0.22rem 0.45rem;
	border-radius: 999px;
	background: var(--sd-accent, #0077c7);
	color: #fff;
	min-width: 1.2rem;
	text-align: center;
	letter-spacing: 0;
}

.dashboard-filter-trigger-caret {
	flex: 0 0 auto;
	font-size: 0.8rem;
	color: #706d65;
	transition: transform 0.15s ease;
}

.dashboard-filter-dropdown[open] .dashboard-filter-trigger-caret {
	transform: rotate(180deg);
	color: var(--sd-accent, #0077c7);
}

.dashboard-filter-dropdown-panel {
	position: absolute;
	top: calc(100% + 0.3rem);
	left: 0;
	z-index: 40;
	min-width: 100%;
	max-width: min(22rem, 92vw);
	background: #fff;
	border: 1px solid #d6d3d0;
	border-radius: 6px;
	box-shadow: 0 4px 12px rgba(35, 34, 30, 0.12);
	padding: 0.5rem 0.5rem;
	box-sizing: border-box;
}

/* 年齢帯は選択肢が多いため 2 列で並べる幅を確保。 */
.dashboard-filter-dropdown-panel--age {
	min-width: 14rem;
	width: 17rem;
	max-width: min(20rem, 92vw);
}

/* 地域は選択肢が 47 都道府県相当まで増えるため、2 列幅をやや広めに確保。 */
.dashboard-filter-dropdown-panel--region {
	min-width: 16rem;
	width: 22rem;
	max-width: min(26rem, 92vw);
	max-height: 22rem;
	overflow-y: auto;
}

/* 希望職種はラベルが長い項目があるため 1 列だが幅を広めに取る。 */
.dashboard-filter-dropdown-panel--industry {
	min-width: 14rem;
	width: 18rem;
	max-width: min(24rem, 92vw);
	max-height: 22rem;
	overflow-y: auto;
}

/* 就業状況はラベルが長め（例: 就業中（自社派遣））のため 1 列で幅を確保。 */
.dashboard-filter-dropdown-panel--current-status {
	min-width: 14rem;
	width: 18rem;
	max-width: min(22rem, 92vw);
}

.dashboard-filter-checklist {
	list-style: none;
	margin: 0;
	padding: 0;
	display: flex;
	flex-direction: column;
	row-gap: 0.1rem;
	column-gap: 0.4rem;
	box-sizing: border-box;
}

.dashboard-filter-checklist--cols {
	display: grid;
	grid-template-columns: repeat(2, minmax(0, 1fr));
	gap: 0.1rem 0.5rem;
}

.dashboard-filter-checklist-item {
	margin: 0;
	padding: 0;
	list-style: none;
}

.dashboard-filter-check {
	display: flex;
	align-items: center;
	gap: 0.5rem;
	font-size: 0.78rem;
	line-height: 1.3;
	color: #23221e;
	cursor: pointer;
	user-select: none;
	padding: 0.4rem 0.5rem;
	border-radius: 4px;
	white-space: nowrap;
	transition: background 0.12s ease;
}

.dashboard-filter-check:hover {
	background: rgba(0, 119, 199, 0.06);
}

.dashboard-filter-check:has(input[type="checkbox"]:checked) {
	background: rgba(0, 119, 199, 0.08);
	color: var(--sd-accent, #0066ad);
	font-weight: 600;
}

.dashboard-filter-check input[type="checkbox"] {
	margin: 0;
	width: 0.9rem;
	height: 0.9rem;
	accent-color: var(--sd-accent, #0077c7);
	flex: 0 0 auto;
	cursor: pointer;
}

.dashboard-filter-check input[type="checkbox"]:focus-visible {
	outline: 2px solid var(--sd-accent, #0077c7);
	outline-offset: 1px;
	border-radius: 2px;
}

.dashboard-filter-check-label {
	white-space: nowrap;
	font-size: 0.78rem;
	line-height: 1.3;
}

/* ── 適用中フィルタ chips（共通：会社式 pill デザイン） ── */
.dashboard-active-filters {
	display: flex;
	flex-wrap: wrap;
	gap: 0.5rem 0.55rem;
	align-items: center;
	padding: 0.55rem 0.65rem;
	margin-top: 0.6rem;
	border-radius: var(--sd-radius-sm);
	background: rgba(255, 255, 255, 0.75);
	border: 1px dashed rgba(15, 23, 42, 0.12);
	font-size: 0.78rem;
}

.dashboard-active-filter-chip {
	display: inline-flex;
	align-items: center;
	gap: 0.3rem;
	padding: 0.32rem 0.65rem;
	border-radius: 999px;
	background: rgba(0, 119, 199, 0.08);
	color: var(--sd-accent, #0066ad);
	border: 1px solid rgba(0, 119, 199, 0.25);
	font-size: 0.78rem;
	line-height: 1;
	text-decoration: none;
	letter-spacing: normal;
	width: auto;
	height: auto;
	box-shadow: none;
	transition: background 0.15s ease, color 0.15s ease, border-color 0.15s ease;
}

.dashboard-active-filter-chip:hover {
	background: rgba(0, 119, 199, 0.15);
	color: var(--sd-accent, #0066ad);
	border-color: rgba(0, 119, 199, 0.45);
}

.dashboard-active-filter-chip--static {
	background: #edebe8;
	color: #4e4c49;
	border-color: #d6d3d0;
	cursor: default;
}

.dashboard-active-filter-chip--static:hover {
	background: #edebe8;
	color: #4e4c49;
	border-color: #d6d3d0;
}

.dashboard-active-filter-x {
	font-size: 0.95em;
	line-height: 1;
	opacity: 0.75;
	font-weight: 600;
}

.dashboard-active-filter-chip:hover .dashboard-active-filter-x {
	opacity: 1;
}

.dashboard-active-filter-clear {
	font-size: 0.78rem;
	color: #706d65;
	text-decoration: underline;
	margin-left: 0.35rem;
	padding: 0.25rem 0.35rem;
	border-radius: var(--sd-radius-sm);
	letter-spacing: normal;
	width: auto;
	height: auto;
}

.dashboard-active-filter-clear:hover {
	color: var(--sd-accent, #0077c7);
	text-decoration: underline;
}

.dashboard-tools {
	margin-bottom: 1.25rem;
}

.dashboard-csv-note {
	margin: 0 0 1rem;
	max-width: 52rem;
	font-size: 0.8125rem;
	line-height: 1.5;
	color: var(--sd-muted);
}

.dashboard-match-count {
	display: flex;
	align-items: baseline;
	justify-content: center;
	gap: 0.35rem;
	margin: 1rem 0;
	padding: 0.6rem 0.85rem;
	border-radius: var(--sd-radius-sm);
	background: rgba(14, 165, 233, 0.12);
	border: 1px solid rgba(14, 165, 233, 0.28);
}

.dashboard-match-count-label {
	font-size: 0.9rem;
	font-weight: 600;
	letter-spacing: 0.04em;
	color: var(--sd-muted);
}

.dashboard-match-count-value {
	font-size: 2.1rem;
	line-height: 1.05;
	font-weight: 800;
	color: var(--sd-heading);
	font-variant-numeric: tabular-nums;
}

.dashboard-match-count-unit {
	font-size: 1.1rem;
	font-weight: 700;
	color: var(--sd-heading);
}

.dashboard-import-form {
	margin: 0 0 0;
	padding: 1rem 1.1rem;
	border-radius: var(--sd-radius-sm);
	background: linear-gradient(135deg, rgba(0, 119, 199, 0.06) 0%, rgba(15, 118, 110, 0.05) 100%);
	border: 1px dashed rgba(0, 119, 199, 0.35);
}

.dashboard-import-row {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	gap: 0.75rem;
	margin-top: 0.35rem;
}

.dashboard-file-dropzone {
	flex: 1 1 16rem;
	min-width: min(100%, 12rem);
	display: flex;
	flex-direction: column;
	gap: 0.35rem;
}

.dashboard-file-dropzone-inner {
	position: relative;
	min-height: 5.75rem;
	border: 2px dashed rgba(0, 119, 199, 0.38);
	border-radius: var(--sd-radius-sm);
	background: rgba(255, 255, 255, 0.75);
	box-sizing: border-box;
	transition: border-color 0.15s ease, background-color 0.15s ease, box-shadow 0.15s ease;
}

.dashboard-file-dropzone-inner.is-dragover {
	border-color: var(--sd-accent);
	background: rgba(0, 119, 199, 0.08);
	box-shadow: 0 0 0 3px var(--sd-accent-soft);
}

.dashboard-file-dropzone-inner.is-filled {
	border-style: solid;
	border-color: rgba(0, 119, 199, 0.55);
	background: rgba(0, 119, 199, 0.06);
}

.dashboard-file-dropzone-inner.is-filled.is-dragover {
	border-color: var(--sd-accent);
	background: rgba(0, 119, 199, 0.1);
}

.dashboard-file-dropzone-inner.is-filled .dashboard-file-dropzone-ui {
	display: none;
}

.dashboard-file-dropzone-selected {
	display: none;
	position: relative;
	z-index: 0;
	align-items: center;
	gap: 0.75rem;
	min-height: 5.75rem;
	padding: 0.75rem 1rem;
	box-sizing: border-box;
	pointer-events: none;
}

.dashboard-file-dropzone-inner.is-filled .dashboard-file-dropzone-selected {
	display: flex;
}

.dashboard-file-dropzone-badge {
	flex: 0 0 auto;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	min-width: 3.25rem;
	padding: 0.35rem 0.45rem;
	border-radius: 4px;
	font-size: 0.72rem;
	font-weight: 700;
	letter-spacing: 0.04em;
	color: #fff;
	background: linear-gradient(135deg, var(--sd-accent) 0%, #0066ad 100%);
}

.dashboard-file-dropzone-file-info {
	flex: 1 1 auto;
	min-width: 0;
	display: flex;
	flex-direction: column;
	gap: 0.2rem;
}

.dashboard-file-dropzone-file-name {
	font-size: 0.92rem;
	font-weight: 600;
	color: var(--sd-heading);
	line-height: 1.35;
	word-break: break-all;
}

.dashboard-file-dropzone-file-detail {
	font-size: 0.78rem;
	color: var(--sd-muted);
	line-height: 1.4;
}

.dashboard-file-dropzone-change {
	flex: 0 0 auto;
	font-size: 0.78rem;
	font-weight: 600;
	color: var(--sd-accent);
	white-space: nowrap;
}

@media (max-width: 640px) {
	.dashboard-file-dropzone-inner.is-filled .dashboard-file-dropzone-selected {
		flex-wrap: wrap;
		row-gap: 0.45rem;
	}

	.dashboard-file-dropzone-change {
		width: 100%;
		text-align: center;
	}
}

.dashboard-file-dropzone-ui {
	position: relative;
	z-index: 0;
	display: flex;
	flex-direction: column;
	align-items: center;
	justify-content: center;
	gap: 0.25rem;
	min-height: 5.75rem;
	padding: 0.65rem 0.85rem;
	text-align: center;
	pointer-events: none;
}

.dashboard-file-dropzone-text {
	font-size: 0.88rem;
	font-weight: 600;
	color: var(--sd-heading);
	line-height: 1.35;
}

.dashboard-file-dropzone-sub {
	font-size: 0.78rem;
	color: var(--sd-muted);
	line-height: 1.4;
}

.dashboard-file-input {
	font-size: 0.875rem;
	max-width: 100%;
}

/* 広い枠全体がクリック・ドロップの対象になる */
.dashboard-file-input--zone {
	position: absolute;
	left: 0;
	top: 0;
	z-index: 1;
	width: 100%;
	height: 100%;
	min-height: 5.75rem;
	margin: 0;
	padding: 0;
	border: 0;
	opacity: 0.01;
	cursor: pointer;
	font-size: 1.5rem;
}

.dashboard-file-input--zone:focus {
	outline: none;
}

.dashboard-file-dropzone-inner:focus-within {
	border-color: var(--sd-accent);
	box-shadow: 0 0 0 3px var(--sd-accent-soft);
}

.dashboard-file-selected-name {
	margin: 0;
	font-size: 0.78rem;
	line-height: 1.4;
	color: var(--sd-muted);
	word-break: break-all;
}

.dashboard-import-result {
	margin: 1rem 0 1rem;
	font-size: 12px;
	line-height: 1.5;
	color: var(--sd-heading);
	font-weight: 500;
}

.dashboard-import-upload-error {
	margin: 0 0 0.75rem;
	font-size: 0.8125rem;
	line-height: 1.5;
	font-weight: 600;
	color: #b91c1c;
}

/* 取り込み失敗の詳細（求人・スタッフ共通） */
.dashboard-import-errors {
	margin: 0 0 1rem;
	padding: 0.75rem 0.95rem;
	border-radius: var(--sd-radius-sm);
	border: 1px solid rgba(248, 113, 113, 0.35);
	background: rgba(248, 113, 113, 0.06);
	font-size: 0.8125rem;
	line-height: 1.5;
	color: var(--sd-heading);
}

.dashboard-import-errors-title {
	margin: 0 0 0.5rem;
	font-size: 0.875rem;
	font-weight: 700;
	line-height: 1.35;
	color: #991b1b;
}

.dashboard-import-errors-list {
	margin: 0;
	padding-left: 1.1rem;
	font-size: 0.8125rem;
	line-height: 1.5;
	color: var(--sd-heading);
}

.dashboard-import-errors-list > li {
	margin-bottom: 0.5rem;
	font-size: 0.8125rem;
	color: var(--sd-heading);
}

.dashboard-import-errors-list > li:last-child {
	margin-bottom: 0;
}

/* 失敗「理由」の入れ子リスト。小さく薄くすると読めないので本文相当に揃える */
.dashboard-import-errors-list ul {
	margin: 0.35rem 0 0;
	padding-left: 1.05rem;
	font-size: 0.8125rem;
	line-height: 1.55;
	color: var(--sd-heading);
}

.dashboard-import-errors-list ul li {
	font-size: 0.8125rem;
	color: var(--sd-heading);
}

.dashboard-import-errors-list strong {
	font-size: inherit;
	font-weight: 700;
	color: var(--sd-heading);
}

.dashboard-empty {
	margin: 1.5rem 0;
	text-align: center;
	padding: 2rem 1rem;
	color: var(--sd-muted);
	font-size: 0.95rem;
	background: var(--sd-row-hover);
	border-radius: var(--sd-radius-sm);
}

/* ── テーブル（列幅・タイポのバランス／はみ出し時は横スクロール） ── */
.dashboard-table-wrap {
	overflow-x: auto;
	max-width: 100%;
	margin: 0 -0.25rem;
	padding: 0 0.25rem;
	border-radius: var(--sd-radius-sm);
}

.dashboard-table {
	width: 100%;
	max-width: 100%;
	table-layout: fixed;
	border-collapse: separate;
	border-spacing: 0;
	font-size: 0.9rem;
}

.dashboard-table th,
.dashboard-table td {
	box-sizing: border-box;
	min-width: 0;
	padding: 0.7rem 0.5rem;
	text-align: left;
	border-bottom: 1px solid rgba(15, 23, 42, 0.06);
	vertical-align: middle;
}

.dashboard-table thead th {
	font-weight: 700;
	font-size: 0.7rem;
	text-transform: uppercase;
	letter-spacing: 0.06em;
	color: var(--sd-muted);
	background: linear-gradient(180deg, var(--sd-row-hover, #f8fafc) 0%, #f1f5f9 100%);
	border-bottom: 1px solid var(--sd-card-border, rgba(15, 23, 42, 0.08));
	white-space: normal;
	line-height: 1.3;
	overflow-wrap: anywhere;
	word-break: break-word;
}

.dashboard-sort-head {
	display: inline-flex;
	align-items: center;
	gap: 0.3rem;
}

.dashboard-sort-label {
	display: inline-block;
	font-size: 0.7rem;
	line-height: 1.3;
	font-weight: 700;
	color: var(--sd-muted);
	letter-spacing: 0.02em;
}

.dashboard-sort-buttons {
	display: inline-flex;
	align-items: center;
	gap: 0.05rem;
}

.dashboard-sort-btn {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 0.9rem;
	height: 0.9rem;
	border: 0;
	border-radius: 0;
	background: transparent;
	color: var(--sd-muted, #64748b);
	font-size: var(--sd-text-xs, 0.72rem);
	font-weight: 700;
	line-height: 1;
	text-decoration: none;
	transition: color 0.12s ease;
}

.dashboard-sort-btn:hover {
	color: var(--sd-heading, #0f172a);
}

.dashboard-sort-btn.is-active,
.dashboard-sort-btn[aria-current="true"] {
	color: var(--sd-accent, #0077c7);
}

.dashboard-table th.dashboard-col-jobs,
.dashboard-table td.dashboard-cell-jobs {
	vertical-align: top;
}

.dashboard-table th:first-child,
.dashboard-table td:first-child {
	padding-left: 0.85rem;
}

.dashboard-table th:last-child,
.dashboard-table td:last-child {
	padding-right: 0.85rem;
}

.dashboard-table tbody tr:first-child td {
	border-top: 1px solid rgba(15, 23, 42, 0.04);
}

.dashboard-row {
	cursor: pointer;
	transition: background 0.12s ease;
}

.dashboard-row:hover {
	background: var(--sd-row-hover);
}

/* 列幅：合計100%（希望職種は長文が多いため幅を多めに、その他はコンパクト） */
.dashboard-col-num,
.dashboard-cell-num {
	width: 10%;
}

.dashboard-col-name,
.dashboard-cell-name {
	width: 16%;
}

.dashboard-col-jobs,
.dashboard-cell-jobs {
	width: 50%;
	min-width: 22rem;
}

.dashboard-col-date,
.dashboard-cell-date {
	width: 12%;
}

.dashboard-col-action {
	width: 12%;
	white-space: normal;
}

.dashboard-cell-num {
	font-size: 0.84rem;
	font-variant-numeric: tabular-nums;
	color: var(--sd-muted);
	text-align: left;
}

.dashboard-cell-name {
	font-size: 0.9rem;
	font-weight: 600;
	color: var(--sd-heading);
	line-height: 1.4;
	overflow-wrap: anywhere;
	word-break: break-word;
}

.dashboard-cell-jobs {
	font-size: 0.95rem;
	line-height: 1.5;
	overflow-wrap: anywhere;
	word-break: break-word;
	color: #334155;
	padding-left: 0.55rem;
	padding-right: 0.55rem;
}

.dashboard-table thead th.dashboard-col-jobs {
	hyphens: auto;
	text-align: left;
	padding-left: 0.55rem;
	padding-right: 0.55rem;
}

.dashboard-table thead th.dashboard-col-num,
.dashboard-table thead th.dashboard-col-date {
	font-size: 0.7rem;
	line-height: 1.3;
	text-align: left;
}

.dashboard-cell-date {
	font-size: 0.8rem;
	color: var(--sd-muted);
	text-align: center;
}

.dashboard-cell-date time {
	font-variant-numeric: tabular-nums;
}

.dashboard-table thead th.dashboard-col-action {
	text-align: center;
	padding-left: 0.5rem;
	padding-right: 0.5rem;
}

.dashboard-table td.dashboard-col-action {
	vertical-align: middle;
	text-align: center;
	padding: 0.4rem 0.45rem;
}

/* 一覧の「カードを見る」（位置は中央のまま・角丸は他ボタンと同系・コンパクト） */
.matching-staff-dashboard-body .dashboard-btn-view-card {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	min-width: 0;
	max-width: 100%;
	padding: 0.4rem 0.72rem;
	font-size: 0.8rem;
	font-weight: 600;
	line-height: 1.25;
	white-space: nowrap;
	text-align: center;
	text-decoration: none;
	border-radius: var(--sd-radius-sm);
	min-height: 2.35rem;
	/* 影は .btn-primary に任せる */
}

/* コンパクトボタン（絞り込み・検索 / CSV / 一斉送信など）
 * 共通 .btn の padding / 字サイズを上書きし、操作スタックの密度を統一する。
 */
.matching-staff-dashboard-body .dashboard-btn--compact,
.matching-staff-dashboard-body .dashboard-filters .btn,
.matching-staff-dashboard-body .dashboard-subsection--data .dashboard-tools .btn,
.matching-staff-dashboard-body .dashboard-import-form .btn,
.matching-staff-dashboard-body .dashboard-bulk-mail-actions .btn {
	min-height: var(--sd-btn-h-sm, 2.4rem);
	padding: 0.45rem 0.9rem;
	font-size: 0.85rem;
	line-height: 1.25;
	letter-spacing: 0.02em;
	border-width: 1px;
}

/* ── ページネーション ── */
.dashboard-pagination {
	margin-top: 1.5rem;
	padding-top: 1.25rem;
	border-top: 1px solid rgba(15, 23, 42, 0.06);
}

.dashboard-pagination .page-numbers {
	display: inline-flex;
	flex-wrap: wrap;
	gap: 0.4rem;
	list-style: none;
	margin: 0;
	padding: 0;
}

.dashboard-pagination .page-numbers li {
	margin: 0;
}

.dashboard-pagination .page-numbers a,
.dashboard-pagination .page-numbers span {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	min-width: 2.25rem;
	height: 2.25rem;
	padding: 0 0.5rem;
	border: 1px solid rgba(15, 23, 42, 0.1);
	border-radius: var(--sd-radius-sm);
	text-decoration: none;
	font-size: 0.875rem;
	font-weight: 500;
	color: var(--sd-heading);
	background: #fff;
	transition: border-color 0.12s ease, background 0.12s ease, color 0.12s ease;
}

.dashboard-pagination .page-numbers a:hover {
	border-color: var(--sd-accent);
	color: #0369a1;
}

.dashboard-pagination .page-numbers span.current {
	font-weight: 700;
	border-color: transparent;
	background: var(--sd-accent, #0077c7);
	color: #fff;
	box-shadow: 0 4px 12px var(--sd-accent-glow);
}

/* =========================================================
 * 共通仕上げ（会社・スタッフ同一トーン）
 * DESIGN.md / destyle 前提
 * =======================================================*/
.matching-staff-dashboard-body .dashboard-panel {
	border-color: #d6d3d0;
	box-shadow: 0 2px 10px rgba(15, 23, 42, 0.06);
}

.matching-staff-dashboard-body .dashboard-panel-head {
	margin-bottom: 1rem;
	padding-bottom: 0.75rem;
	border-bottom-color: var(--sd-card-border, rgba(15, 23, 42, 0.08));
}

.matching-staff-dashboard-body .dashboard-panel-title {
	font-size: var(--sd-panel-title-size, 1.05rem);
	line-height: 1.35;
	letter-spacing: 0;
	color: #23221e;
}

.matching-staff-dashboard-body .dashboard-subsection-heading {
	letter-spacing: 0.02em;
	line-height: 1.35;
}

.matching-staff-dashboard-body .dashboard-filter-label {
	letter-spacing: 0.04em;
}

.matching-staff-dashboard-body .dashboard-select,
.matching-staff-dashboard-body .dashboard-search-input,
.matching-staff-dashboard-body .dashboard-bulk-mail-textarea {
	border-color: #d6d3d0;
	font-size: 0.875rem;
	line-height: 1.45;
	letter-spacing: 0;
}

.matching-staff-dashboard-body .dashboard-select,
.matching-staff-dashboard-body .dashboard-search-input {
	min-height: 2.5rem;
}

.matching-staff-dashboard-body .dashboard-table {
	border: 1px solid #d6d3d0;
	border-radius: 8px;
	overflow: hidden;
}

.matching-staff-dashboard-body .dashboard-table thead th {
	background: #edebe8;
	color: #23221e;
	letter-spacing: 0;
	line-height: 1.3;
}

.matching-staff-dashboard-body .dashboard-table tbody td {
	color: #23221e;
	letter-spacing: 0;
	line-height: 1.45;
}

.matching-staff-dashboard-body .dashboard-empty {
	border: 1px solid #d6d3d0;
	background: #f8f7f6;
	color: #706d65;
}

/* 共通: 結果メッセージ（保存成功・バリデーションエラー等）
 * 公開面の .matching-form-message[data-variant] と語彙統一。
 * 装飾オフのバリアント（インライン埋め込み用）は呼び出し側でリセット可。
 */
.matching-staff-dashboard-body .dashboard-result {
	box-sizing: border-box;
	max-width: 48rem;
	margin-bottom: var(--sd-space-2, 0.75rem);
	border-radius: var(--sd-radius-sm, 8px);
	padding: 0.6rem 0.85rem;
	font-size: 0.8375rem;
	line-height: 1.42;
	border-width: 1px;
	border-style: solid;
	border-color: transparent;
	background: transparent;
}

.matching-staff-dashboard-body .dashboard-result.dashboard-result--ok {
	background: var(--sd-result-ok-bg);
	border-color: var(--sd-result-ok-border);
	color: var(--sd-result-ok-text);
}

.matching-staff-dashboard-body .dashboard-result.dashboard-result--err {
	background: var(--sd-result-err-bg);
	border-color: var(--sd-result-err-border);
	color: var(--sd-result-err-text);
}

.matching-staff-dashboard-body .dashboard-result.dashboard-result--warn {
	background: var(--sd-result-warn-bg);
	border-color: var(--sd-result-warn-border);
	color: var(--sd-result-warn-text);
}

.matching-staff-dashboard-body .dashboard-result + .dashboard-result {
	margin-top: var(--sd-space-1, 0.5rem);
}

/* 共通: テキストエリアの薄い基底（高さ・色は呼び出し側スコープで上書き） */
.matching-staff-dashboard-body .dashboard-textarea {
	box-sizing: border-box;
	width: 100%;
	font-family: inherit;
}

/* 共通: 必須マーカー（インライン用） */
.matching-staff-dashboard-body .dashboard-required-mark {
	display: inline;
	margin: 0;
	padding: 0;
	vertical-align: baseline;
	line-height: inherit;
	font-size: inherit;
	font-weight: 700;
	color: var(--sd-required);
}

.matching-staff-dashboard-body .btn {
	letter-spacing: 0;
	gap: 0.4rem;
	border-radius: var(--sd-radius-sm);
	transition: transform 0.12s ease, box-shadow 0.12s ease, background 0.12s ease, border-color 0.12s ease;
}

.matching-staff-dashboard-body .btn:hover {
	transform: translateY(-1px);
}

.matching-staff-dashboard-body .btn-primary {
	background: var(--sd-accent, #0077c7);
	border-color: var(--sd-accent, #0077c7);
}

.matching-staff-dashboard-body .btn-primary:hover {
	background: #0066ad;
	border-color: #0066ad;
}

.matching-staff-dashboard-body .btn-secondary {
	border-color: var(--sd-accent, #0077c7);
	color: var(--sd-accent, #0077c7);
}

.matching-staff-dashboard-body .btn-secondary:hover {
	background: rgba(0, 119, 199, 0.08);
	color: #0066ad;
	border-color: #0066ad;
}

/* ── モバイル：サイドバー Drawer ── */
@media (max-width: 960px) {
	html.dashboard-sidebar-open,
	html.dashboard-sidebar-open body {
		overflow: hidden;
	}

	.dashboard-menu-toggle {
		display: flex;
	}

	.dashboard-sidebar {
		position: fixed;
		left: 0;
		top: 0;
		bottom: 0;
		transform: translateX(-102%);
		transition: transform 0.3s cubic-bezier(0.4, 0, 0.2, 1);
		max-width: min(var(--sd-sidebar-w), 88vw);
		flex-basis: auto;
	}

	html.dashboard-sidebar-open .dashboard-sidebar {
		transform: translateX(0);
	}

	.dashboard-backdrop {
		display: block;
		pointer-events: none;
		opacity: 0;
	}

	html.dashboard-sidebar-open .dashboard-backdrop {
		pointer-events: auto;
	}

	.dashboard-topbar-title {
		font-size: 1.15rem;
	}

	.dashboard-main-scroll {
		padding: 1rem 1rem 1.5rem;
	}

	.dashboard-panel {
		padding: 1.15rem 1.1rem 1.35rem;
	}
}
@media (max-width: 600px) {
	.dashboard-age-checks {
		grid-template-columns: repeat(2, minmax(0, 1fr));
		max-width: 100%;
	}

	.dashboard-table {
		font-size: 0.82rem;
	}

	.dashboard-table th,
	.dashboard-table td {
		padding: 0.5rem 0.3rem;
	}

	.dashboard-table thead th {
		font-size: var(--sd-text-xs, 0.72rem);
		letter-spacing: 0.04em;
	}

	.dashboard-cell-jobs {
		font-size: 0.88rem;
	}

	.dashboard-cell-date {
		font-size: 0.72rem;
	}

	.matching-staff-dashboard-body .dashboard-btn-view-card {
		padding: 0.35rem 0.65rem;
		font-size: 0.75rem;
		white-space: normal;
		line-height: 1.25;
		min-height: 2.35rem;
	}

	.dashboard-field--submit {
		width: 100%;
	}

	.dashboard-field--submit .btn {
		width: 100%;
	}

	.dashboard-tools .btn {
		width: 100%;
		justify-content: center;
	}

	.dashboard-import-row {
		flex-direction: column;
		align-items: stretch;
	}

	.dashboard-import-row .btn {
		width: 100%;
	}

	.dashboard-bulk-mail-actions .btn {
		width: 100%;
		justify-content: center;
	}
}

@media print {
	.site-header,
	.site-footer {
		display: none !important;
	}
}

@media (prefers-reduced-motion: reduce) {
	.dashboard-sidebar,
	.dashboard-sidebar-collapse-icon,
	.dashboard-backdrop,
	.dashboard-row,
	.matching-staff-dashboard-body .btn {
		transition: none !important;
	}

	.matching-staff-dashboard-body .btn:hover {
		transform: none;
	}
}

/* 会社ダッシュ：求職者向けと同系の1カラム */
.page-recruit-company-dashboard .recruit-company-dashboard-create-grid {
	grid-template-columns: 1fr;
}
