@charset "UTF-8";

/**
 * スタッフ登録ページ専用スタイル
 * CF7フォーム・確認画面・サンクス画面
 */

/* ========== トークン（style.css の --matching-* を継承し、ページ固有のみ定義） ========== */
.page-staff-registration {
	--sr-primary: var(--matching-color-primary);
	--sr-primary-light: rgba(30, 86, 216, 0.1);
	--sr-border: var(--matching-color-border);
	--sr-border-hover: var(--matching-color-muted);
	--sr-surface: var(--matching-color-surface);
	--sr-surface-alt: var(--matching-color-surface-alt);
	--sr-bg: var(--matching-color-bg);
	--sr-radius: var(--matching-radius);
	--sr-transition: var(--matching-transition);
	--sr-input-max: 36em;
	--sr-input-h: 4rem;
	--sr-input-padding: 0.6rem 1rem;
	--sr-input-fs: 1.5rem;
	--sr-field-gap: 0.85rem;
	--sr-shadow: var(--matching-shadow-md);
	--sr-focus-ring: 0 0 0 3px rgba(30, 86, 216, 0.2);
	/* 法的文言・同意まわり（表セルや --sr-field-gap と同じ拍でそろえる） */
	/* 個人情報ブロック本文（contactTable td.input 1.5rem に近づけ、destyle の li 上書き用） */
	--sr-prose-fs: 1.5rem;
	--sr-prose-lh: 1.65;
	--sr-prose-title-fs: 1.9rem;
	--sr-prose-title-lh: 1.35;
	--sr-prose-meta-fs: 0.875rem;
	--sr-prose-meta-lh: 1.55;
	--sr-inset-y: 1.25rem;
	--sr-inset-x: 1.5rem;
	--sr-section-gap: 1.5rem;
	/* 個人情報ブロック：読みやすい字色・左にゆとり */
	--sr-handling-pad-x: 2.25rem;
	--sr-handling-ol-indent: 3rem;
	--sr-handling-ul-indent: 1.75rem;
	--sr-handling-text: #0f172a;
	--sr-handling-text-sub: #334155;
	--sr-handling-text-meta: #475569;
	--sr-consent-label-fs: 1.3rem;
	--sr-consent-label-lh: 1.55;
}

.page-staff-registration .site-container {
	padding-left: 1.2rem;
	padding-right: 1.2rem;
}

.page-staff-registration .entry-header {
	margin-bottom: 1.5rem;
	padding-bottom: 0.75rem;
	border-bottom: 2px solid var(--sr-primary);
}

.page-staff-registration .entry-title {
	font-size: 2.2rem;
	font-weight: 800;
	letter-spacing: 0.03em;
	line-height: 1.35;
	color: var(--matching-color-text);
}

.page-staff-registration .entry-title::after {
	display: none;
	content: none;
}

/* ========== サンクス画面 ========== */
.staff-registration-thanks {
	text-align: center;
	padding: 2.5rem 1.75rem;
	background: var(--sr-primary);
	border-radius: var(--sr-radius);
	color: #fff;
	box-shadow: var(--sr-shadow);
}

.staff-registration-thanks-title {
	font-size: 2rem;
	font-weight: 700;
	margin: 0 0 0.75rem;
	letter-spacing: 0.02em;
	color: #fff;
}

.staff-registration-thanks-text {
	margin: 0 0 1.5rem;
	color: rgba(255, 255, 255, 0.95);
	font-size: 1.6rem;
	line-height: 1.5;
}

.staff-registration-thanks .btn {
	margin-top: 0.5rem;
	background: #fff;
	color: var(--matching-color-primary);
	border-color: #fff;
}
.staff-registration-thanks .btn:hover {
	background: rgba(255, 255, 255, 0.9);
	color: var(--matching-color-primary-hover);
	border-color: rgba(255, 255, 255, 0.9);
	text-decoration: none;
}

/* ========== スタッフ登録フォーム（テーブルレイアウト） ========== */
.page-staff-registration .entry-content .staff-registration-form,
.page-staff-registration .entry-content .contact-form-container {
	max-width: 88em;
	margin: 0 auto;
	padding: 0;
}

.page-staff-registration .entry-content .contactTable {
	width: 100%;
	border-collapse: collapse;
	border: 1px solid var(--sr-border);
	border-radius: var(--sr-radius);
	overflow: hidden;
	background: var(--sr-bg);
	box-shadow: var(--sr-shadow);
}

.page-staff-registration .entry-content .contactTable tr {
	border-bottom: 1px solid var(--sr-border);
}
.page-staff-registration .entry-content .contactTable tr:last-child {
	border-bottom: 0;
}
.page-staff-registration .entry-content .contactTable td.input {
	background-color: var(--sr-bg);
}

.page-staff-registration .entry-content .contactTable th.title {
	width: 28%;
	min-width: 11rem;
	padding: 2rem;
	font-size: 1.5rem;
	font-weight: 600;
	letter-spacing: 0.02em;
	color: var(--matching-color-text);
	text-align: left;
	vertical-align: top;
	background: var(--sr-bg);
	border-right: 1px solid var(--sr-border);
}
.page-staff-registration .entry-content .contactTable th.title .must {
	display: inline-block;
	margin-left: 0.35rem;
	padding: 0.12em 0.45em;
	font-size: 1.05rem;
	font-weight: 600;
	color: #fff;
	background: #c5221f;
	border-radius: 4px;
	vertical-align: middle;
}

/* 英語スタッフ登録フォーム：質問見出しの日本語併記 */
.page-staff-registration .entry-content .contactTable th.title .title-ja {
	display: block;
	margin-top: 0.35rem;
	font-size: 1.1rem;
	font-weight: 500;
	letter-spacing: 0.04em;
	color: var(--matching-color-text);
	opacity: 0.88;
}
.page-staff-registration .entry-content .contactTable td.input .sr-other-field-label {
	font-size: 0.95rem;
	opacity: 0.92;
	margin-right: 0.35rem;
}
.page-staff-registration .entry-content .contactTable .career-wrap .title .title-ja-inline,
.page-staff-registration .entry-content .contactTable .qualification-wrap .title .title-ja-inline {
	font-size: 0.88rem;
	font-weight: 500;
	opacity: 0.85;
	margin-left: 0.25rem;
}

.page-staff-registration .entry-content .contactTable td.input {
	padding: 2rem;
	font-size: 1.5rem;
	vertical-align: top;
	line-height: 1.5;
}
/* 各項目ごとの余白 */
.page-staff-registration .entry-content .contactTable tr {
	padding: 0;
}
.page-staff-registration .entry-content .contactTable td.input p {
	margin: 0 0 var(--sr-field-gap);
}
.page-staff-registration .entry-content .contactTable td.input p:last-child {
	margin-bottom: 0;
}
.page-staff-registration .entry-content .contactTable .input-row {
	margin-bottom: var(--sr-field-gap);
}
.page-staff-registration .entry-content .contactTable .input-row:last-child {
	margin-bottom: 0;
}
/* 入力欄の親：テーブル内はブロック幅で統一（最大幅あり） */
.page-staff-registration .entry-content .contactTable td.input .wpcf7-form-control-wrap:not([class*="radio"]):not([class*="checkbox"]) {
	display: block;
	max-width: var(--sr-input-max);
	width: 100%;
	box-sizing: border-box;
}
/* 学歴・職務・勤務時間は上を打ち消し（レイアウト用にインラインで入力可能に） */
.page-staff-registration .entry-content .contactTable td.input #studies-wrapper .wpcf7-form-control-wrap,
.page-staff-registration .entry-content .contactTable td.input #career-wrapper .wpcf7-form-control-wrap,
.page-staff-registration .entry-content .contactTable td.input .working-time-row .wpcf7-form-control-wrap {
	display: inline-flex !important;
	max-width: none;
	width: auto;
}

/* 1行で横並び（ラベル・選択肢・「その他」入力が同じ行に） */
.page-staff-registration .entry-content .contactTable .input-row {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	gap: 0.5rem 0.75rem;
}
/* CF7が .input-row の直後に <br> を出す。直後が非表示の .input-sub のときだけその br を非表示にして余白を消す */
.page-staff-registration .entry-content .contactTable td.input p:has(> .input-row + br + .input-sub.input-row[style*="display:none"]) > .input-row + br,
.page-staff-registration .entry-content .contactTable td.input p:has(> .input-row + br + .input-sub.input-row[style*="display: none"]) > .input-row + br {
	display: none;
}
/* .input-row が複数並ぶ p 内の br は全て非表示（PCスキル・希望条件など。br のせいで余白が広がるため） */
.page-staff-registration .entry-content .contactTable td.input p:has(> .input-row + br + .input-row) > .input-row + br {
	display: none;
}
/* 上記の p 内では .input-row の間隔を 1rem に */
.page-staff-registration .entry-content .contactTable td.input p:has(> .input-row + br + .input-row) .input-row {
	margin-bottom: 1rem;
}
.page-staff-registration .entry-content .contactTable td.input p:has(> .input-row + br + .input-row) .input-row:last-child {
	margin-bottom: 0;
}
.page-staff-registration .entry-content .contactTable .input-sub.input-row {
	margin-top: 0.35rem;
	margin-bottom: var(--sr-field-gap);
}
/* .input-sub 内の先頭 br（CF7が挿入）も消して余白を防ぐ */
.page-staff-registration .entry-content .contactTable .input-sub.input-row > br:first-child {
	display: none;
}
.page-staff-registration .entry-content .contactTable .input-sub:not(.input-row) {
	margin-left: 0.5rem;
}
/* 家族：子ども「有」のときの ◯人 を横並びに */
.page-staff-registration .entry-content .contactTable #children-count-wrap.input-inline {
	display: inline-flex;
	align-items: center;
	gap: 0 0.25rem;
}
.page-staff-registration .entry-content .contactTable #children-count-wrap.input-inline .wpcf7-form-control-wrap,
.page-staff-registration .entry-content .contactTable #children-count-wrap.input-inline input {
	width: 4em;
	min-width: 3em;
}
/* 最寄り交通機関：常に2行固定（1行目: 駅名 / 2行目: まで徒歩◯分） */
.page-staff-registration .entry-content .contactTable #transit-detail {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	row-gap: 0.35rem;
}

.page-staff-registration .entry-content .contactTable #transit-detail br {
	display: none;
}

.page-staff-registration .entry-content .contactTable #transit-detail > .input-inline:first-of-type {
	flex: 0 0 100%;
	max-width: 100%;
}

.page-staff-registration .entry-content .contactTable #transit-detail > .input-inline:not(:first-child) {
	white-space: nowrap;
	flex-shrink: 0;
}

/* 最寄り交通機関：徒歩◯分を横並び、入力幅は子ども人数と同程度 */
.page-staff-registration .entry-content .contactTable .transit-minutes-wrap.input-inline {
	display: inline-flex;
	align-items: center;
	gap: 0 0.25rem;
	flex-shrink: 0;
}
.page-staff-registration .entry-content .contactTable .transit-minutes-wrap.input-inline .wpcf7-form-control-wrap,
.page-staff-registration .entry-content .contactTable .transit-minutes-wrap.input-inline input {
	width: 4em !important;
	min-width: 3em !important;
}

/* 「徒歩◯分」側だけ幅を確実に揃える（駅（停）側とは分離） */
.page-staff-registration .entry-content .contactTable input[name="transit-minutes"] {
	width: 4em !important;
	min-width: 3em !important;
}

.page-staff-registration .entry-content .contactTable input[name="transit-station"] {
	width: 12em;
	min-width: 10em;
}

/* 希望条件：通勤時間「希望時間」— 数字＋「分以内」を必ず1行、入力は狭め */
.page-staff-registration .entry-content .contactTable #commute_time-other-wrap.input-sub.input-row {
	flex-wrap: nowrap;
	align-items: center;
}
.page-staff-registration .entry-content .contactTable .commute-minutes-wrap.input-inline {
	display: inline-flex !important;
	flex-wrap: nowrap;
	align-items: center;
	gap: 0 0.35rem;
	white-space: nowrap;
	max-width: 100%;
}
.page-staff-registration .entry-content .contactTable #commute_time-other-wrap .commute-minutes-wrap .wpcf7-form-control-wrap {
	display: inline-flex !important;
	width: auto !important;
	max-width: none !important;
	min-width: 0 !important;
	flex: 0 0 auto;
}
.page-staff-registration .entry-content .contactTable #commute_time-other-wrap .commute-minutes-wrap input[name="commute_time-other"] {
	width: 3.25em !important;
	min-width: 3em !important;
	max-width: 4em !important;
	display: inline-block !important;
	box-sizing: border-box;
}
/* 勤務開始：希望日の日付入力幅を狭く */
.page-staff-registration .entry-content .contactTable .working-start-date-wrap.input-inline .wpcf7-form-control-wrap,
.page-staff-registration .entry-content .contactTable .working-start-date-wrap.input-inline input {
	width: 10em;
	min-width: 9em;
}
/* 「その他」系テキストを1行下でセル内フル幅にする共通行
 * 使用例: 語学のその他 / PCスキルの使用可能言語 / 勤務地のその他 / 登録業種のその他 など
 * マークアップは inc/cf7-form-staff-registration.html と同期すること
 */
.page-staff-registration .entry-content .contactTable .input-sub.sr-experience-other-row.input-row,
.page-staff-registration .entry-content .contactTable .input-sub.sr-wide-row.input-row {
	flex-direction: column;
	align-items: stretch;
	align-content: stretch;
	width: 100%;
	max-width: 100%;
	box-sizing: border-box;
}
.page-staff-registration .entry-content .contactTable .sr-experience-other-row .wpcf7-form-control-wrap,
.page-staff-registration .entry-content .contactTable .sr-wide-row .wpcf7-form-control-wrap {
	display: block !important;
	width: 100% !important;
	max-width: var(--sr-input-max) !important;
	min-width: 0 !important;
	box-sizing: border-box;
}
.page-staff-registration .entry-content .contactTable .sr-experience-other-row input,
.page-staff-registration .entry-content .contactTable .sr-wide-row input {
	width: 100% !important;
	max-width: 100% !important;
	min-width: 0 !important;
	box-sizing: border-box;
}
/* 追加入力（その他など）は横並び・適度な幅 */
.page-staff-registration .entry-content .contactTable .input-inline {
	display: inline-flex;
	align-items: center;
	flex-shrink: 0;
	margin-left: 0;
	vertical-align: middle;
}
.page-staff-registration .entry-content .contactTable .input-inline input,
.page-staff-registration .entry-content .contactTable .input-inline .wpcf7-form-control-wrap input {
	width: 12em;
	min-width: 10em;
	max-width: var(--sr-input-max);
	display: inline-block;
}
.page-staff-registration .entry-content .contactTable .input-sub.input-row .input-inline {
	margin-right: 0.5rem;
}
.page-staff-registration .entry-content .contactTable .input-sub.input-row .input-inline + .input-inline {
	margin-left: 0;
}
/* 勤務時間：を1行目、開始～終了を2行目に改行 */
.page-staff-registration .entry-content .contactTable .input-row.working-time-row {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	gap: 0 0.25rem;
}
.page-staff-registration .entry-content .contactTable .working-time-row .working-time-label {
	display: block;
	width: 100%;
	flex-basis: 100%;
	margin-bottom: 0.35rem;
}
/* td.input の .wpcf7-form-control-wrap { display:block; width:100% } を打ち消す */
.page-staff-registration .entry-content .contactTable td.input .working-time-row .wpcf7-form-control-wrap {
	display: inline-flex !important;
	width: 6.5em !important;
	min-width: 5em !important;
	max-width: none !important;
	align-items: center;
	flex-shrink: 0;
}
.page-staff-registration .entry-content .contactTable .working-time-row input[name="start_time"],
.page-staff-registration .entry-content .contactTable .working-time-row input[name="end_time"] {
	width: 100%;
	box-sizing: border-box;
	min-width: 0;
	display: block;
}
.page-staff-registration .entry-content .contactTable .input-row .wpcf7-form-control-wrap {
	display: inline-flex;
	align-items: center;
}

/* ========== 入力コントロール統一（テーブル・学歴・職務すべて同じ見た目） ========== */
.page-staff-registration .entry-content .contactTable input[type="text"],
.page-staff-registration .entry-content .contactTable input[type="email"],
.page-staff-registration .entry-content .contactTable input[type="tel"],
.page-staff-registration .entry-content .contactTable input[type="number"],
.page-staff-registration .entry-content .contactTable input[type="date"],
.page-staff-registration .entry-content .contactTable select,
.page-staff-registration .entry-content .contactTable textarea,
.page-staff-registration .entry-content .wpcf7 input[type="text"],
.page-staff-registration .entry-content .wpcf7 input[type="email"],
.page-staff-registration .entry-content .wpcf7 input[type="tel"],
.page-staff-registration .entry-content .wpcf7 input[type="number"],
.page-staff-registration .entry-content .wpcf7 input[type="date"],
.page-staff-registration .entry-content .wpcf7 select,
.page-staff-registration .entry-content .wpcf7 textarea {
	display: block;
	width: 100%;
	max-width: 100%;
	min-height: var(--sr-input-h);
	padding: var(--sr-input-padding);
	font-family: inherit;
	border: 1px solid var(--sr-border);
	border-radius: var(--sr-radius);
	background: var(--sr-bg);
	box-sizing: border-box;
	transition: border-color var(--sr-transition), box-shadow var(--sr-transition);
}
.page-staff-registration .entry-content .contactTable input:focus,
.page-staff-registration .entry-content .contactTable select:focus,
.page-staff-registration .entry-content .contactTable textarea:focus,
.page-staff-registration .entry-content .wpcf7 input:focus,
.page-staff-registration .entry-content .wpcf7 select:focus,
.page-staff-registration .entry-content .wpcf7 textarea:focus {
	outline: none;
	border-color: var(--sr-primary);
	box-shadow: var(--sr-focus-ring);
}

/* select のデフォルト矢印が消えるので、右側に下矢印を強制表示する */
.page-staff-registration .entry-content .contactTable select,
.page-staff-registration .entry-content .wpcf7 select {
	-webkit-appearance: none;
	appearance: none;
	background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='10' viewBox='0 0 16 10'%3E%3Cpath d='M2 2l6 6 6-6' fill='none' stroke='%231557b0' stroke-width='2.2' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");
	background-repeat: no-repeat;
	background-position: right 1rem center;
	background-size: 0.9rem auto;
	padding-right: calc(var(--sr-input-padding) + 2.2rem);
}
.page-staff-registration .entry-content .contactTable textarea,
.page-staff-registration .entry-content .wpcf7 textarea {
	min-height: 5.5em;
	resize: vertical;
}

/* 生年月日：入力フォームを小さくし、「生まれ」と1行で横並び */
.page-staff-registration .entry-content .contactTable .input-row-inline {
	display: flex !important;
	flex-wrap: nowrap !important;
	align-items: center;
	gap: 0 0.5rem;
}
.page-staff-registration .entry-content .contactTable .input-row-inline .wpcf7-form-control-wrap {
	display: block !important;
	flex: 0 0 11em !important;
	width: 11em !important;
	min-width: 0;
	max-width: 11em !important;
}
.page-staff-registration .entry-content .contactTable .input-row-inline input[type="date"],
.page-staff-registration .entry-content .contactTable td.input input#birth {
	width: 100% !important;
	max-width: 100% !important;
	min-width: 0;
	box-sizing: border-box;
}
.page-staff-registration .entry-content .contactTable .input-row-inline .input-suffix {
	flex: 0 0 auto;
	margin-left: 0.25rem;
	white-space: nowrap;
}

/* ========== ラジオ・チェックボックス（選択でラベルに色付き枠） ========== */
/* ネイティブの input は視覚的に隠すが、ラベルクリックで操作可能（script-common-form.js / script-hearing.js と互換） */
.page-staff-registration .entry-content .wpcf7-list-item input[type="radio"],
.page-staff-registration .entry-content .wpcf7-list-item input[type="checkbox"],
.page-staff-registration .entry-content .contactTable td.input input[type="radio"],
.page-staff-registration .entry-content .contactTable td.input input[type="checkbox"] {
	position: absolute;
	width: 1px;
	height: 1px;
	padding: 0;
	margin: -1px;
	overflow: hidden;
	clip: rect(0, 0, 0, 0);
	clip-path: inset(50%);
	white-space: nowrap;
	border: 0;
	opacity: 0;
}
.page-staff-registration .entry-content .wpcf7-list-item {
	display: inline-flex;
	align-items: center;
	margin: 0 1.5rem 1.5rem 0;
}
.page-staff-registration .entry-content .wpcf7-list-item label,
.page-staff-registration .entry-content .contactTable td.input label {
	display: inline-flex !important;
	align-items: center;
	justify-content: center;
	gap: 0.25rem;
	margin: 0 !important;
	padding: 0.35rem 0.6rem !important;
	min-width: 4.2em;
	box-sizing: border-box;
	font-size: 1.5rem;
	font-weight: 500;
	cursor: pointer;
	border: 1px solid var(--sr-border);
	border-radius: var(--sr-radius);
	background: var(--matching-color-bg);
	color: var(--matching-color-text);
	transition: border-color var(--sr-transition), background-color var(--sr-transition);
	user-select: none;
}
/* 選択時：ラベルに色付き枠（控えめに） */
.page-staff-registration .entry-content .wpcf7-list-item label:has(input:checked),
.page-staff-registration .entry-content .contactTable td.input label:has(input:checked),
.page-staff-registration .entry-content .wpcf7-list-item:has(input:checked) label {
	border-color: var(--sr-primary);
	background-color: var(--sr-primary-light);
	color: var(--matching-color-text);
}
.page-staff-registration .entry-content .wpcf7-list-item label:hover,
.page-staff-registration .entry-content .contactTable td.input label:hover {
	border-color: var(--sr-border-hover);
	background-color: var(--sr-surface);
}
.page-staff-registration .entry-content .wpcf7-list-item label:has(input:checked):hover,
.page-staff-registration .entry-content .contactTable td.input label:has(input:checked):hover,
.page-staff-registration .entry-content .wpcf7-list-item:has(input:checked) label:hover {
	background-color: var(--sr-primary-light);
}

@media (max-width: 640px) {
	.page-staff-registration .entry-content .contactTable th.title,
	.page-staff-registration .entry-content .contactTable td.input {
		display: block;
		width: 100%;
		border-right: 0;
		padding-left: 1rem;
		padding-right: 1rem;
	}
	.page-staff-registration .entry-content .contactTable th.title {
		border-bottom: 0;
		padding-bottom: 0.3rem;
	}
	.page-staff-registration .entry-content .contactTable td.input {
		padding-top: 0.35rem;
		padding-bottom: 1rem;
	}
	.page-staff-registration .entry-content .contactTable input[type="text"],
	.page-staff-registration .entry-content .contactTable input[type="email"],
	.page-staff-registration .entry-content .contactTable input[type="tel"],
	.page-staff-registration .entry-content .contactTable input[type="number"],
	.page-staff-registration .entry-content .contactTable input[type="date"],
	.page-staff-registration .entry-content .contactTable select,
	.page-staff-registration .entry-content .contactTable textarea {
		max-width: 100%;
	}
	/* 学歴・職務経歴ブロック：スマホで縦積み */
	.page-staff-registration .entry-content .career-wrap {
		flex-direction: column;
		align-items: stretch;
		gap: 0.35rem;
	}
	.page-staff-registration .entry-content .career-wrap > .title,
	.page-staff-registration .entry-content .career-wrap > p:first-child {
		flex: none;
		min-width: 0;
	}
	.page-staff-registration .entry-content .career-wrap > .career-period-wrap {
		flex: none;
		width: 100%;
		min-width: 0;
	}
	.page-staff-registration .entry-content .career-period-wrap {
		min-width: 0;
	}
	.page-staff-registration .entry-content .studies-wrap {
		flex-direction: column;
		align-items: flex-start;
	}
	.page-staff-registration .entry-content .studies-wrap input[type="text"] {
		width: 100%;
		min-width: 0;
		max-width: 100%;
	}
}

/* ========== CF7 共通（contactTable 外の wpcf7 要素） ========== */
.page-staff-registration .entry-content .wpcf7 {
	max-width: 100%;
}

.page-staff-registration .entry-content .wpcf7-form-control-wrap {
	display: block;
	margin-top: 0.1rem;
}
/* テキスト入力用ラベルのみ（.wpcf7-list-item 内の label は上で inline-flex 指定） */
.page-staff-registration .entry-content .wpcf7-form-control-wrap:not([class*="radio"]):not([class*="checkbox"]) > label {
	display: block;
	margin-top: 0.6rem;
}

/* 上で contactTable と wpcf7 の入力系を統一済み。ここは .wpcf7 直下のみの余白など */
.page-staff-registration .entry-content .wpcf7 textarea {
	min-height: 7em;
}

/* ========== フォーム下部ボタンエリア ========== */
.page-staff-registration .entry-content .btn-wrapper {
	display: flex;
	flex-wrap: wrap;
	justify-content: center;
	align-items: center;
	gap: var(--sr-field-gap);
	margin-top: var(--sr-section-gap);
	margin-bottom: var(--sr-section-gap);
	padding: var(--sr-field-gap) 0 calc(var(--sr-section-gap) - 0.25rem);
	border-top: 1px solid var(--sr-border);
}
/* 修正へ戻る・送信を横並び：高さ・ベースラインを揃える */
.page-staff-registration .entry-content .btn-wrapper.btn-actions-row {
	flex-direction: row;
	flex-wrap: wrap;
	justify-content: center;
	align-items: center;
	gap: 1rem 1.25rem;
}
.page-staff-registration .entry-content .btn-wrapper .submit,
.page-staff-registration .entry-content .btn-wrapper .confirmation-wrapper,
.page-staff-registration .entry-content .btn-wrapper .edit-wrapper,
.page-staff-registration .entry-content .btn-wrapper .submit-wrapper {
	display: block;
}
.page-staff-registration .entry-content .btn-wrapper.btn-actions-row > .submit {
	display: flex;
	align-items: center;
	flex: 0 1 auto;
}
.page-staff-registration .entry-content .btn-wrapper .submit.hide-before-after .confirmation-btn,
.page-staff-registration .entry-content .btn-wrapper .submit.is-disabled .confirmation-btn {
	opacity: 0.6;
	cursor: not-allowed;
}
.page-staff-registration .entry-content .btn-wrapper .submit .confirmation-wrapper.disabled {
	pointer-events: none;
}
.page-staff-registration .entry-content .btn-wrapper .submit-wrapper input {
	width: auto;
	min-width: 0;
}

.page-staff-registration .entry-content .contact-btn,
.page-staff-registration .entry-content button.contact-btn,
.page-staff-registration .entry-content input[type="submit"].contact-btn,
.page-staff-registration .entry-content input[type="button"].contact-btn {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	min-height: var(--matching-btn-min-height, 4rem);
	padding: var(--matching-btn-padding-y, 1rem) var(--matching-btn-padding-x, 1.8rem);
	font-size: var(--matching-btn-font-size, 1.2rem);
	font-weight: 600;
	font-family: inherit;
	line-height: 1.35;
	text-align: center;
	text-decoration: none;
	letter-spacing: 0.03em;
	border-radius: var(--sr-radius);
	border: var(--matching-btn-border-width, 2px) solid transparent;
	cursor: pointer;
	transition: background-color 0.2s ease, border-color 0.2s ease, box-shadow 0.25s ease, transform 0.2s ease;
	-webkit-appearance: none;
	appearance: none;
	box-sizing: border-box;
	flex-shrink: 0;
}
.page-staff-registration .entry-content .contact-btn:hover {
	text-decoration: none;
}
.page-staff-registration .entry-content .contact-btn:not([disabled]):hover {
	transform: translateY(-2px);
}
.page-staff-registration .entry-content .contact-btn:not([disabled]):active {
	transform: translateY(0);
}
.page-staff-registration .entry-content .contact-btn[disabled] {
	cursor: not-allowed;
	opacity: 0.6;
}

.page-staff-registration .entry-content .confirmation-btn,
.page-staff-registration .entry-content input[type="submit"].contact-btn {
	background-color: var(--sr-primary);
	color: #fff;
	border-color: var(--sr-primary);
	box-shadow: 0 1px 2px rgba(30, 86, 216, 0.2);
}
.page-staff-registration .entry-content .confirmation-btn:hover:not([disabled]),
.page-staff-registration .entry-content input[type="submit"].contact-btn:hover {
	background-color: var(--matching-color-primary-hover);
	border-color: var(--matching-color-primary-hover);
	color: #fff;
	box-shadow: 0 4px 12px rgba(30, 86, 216, 0.4);
}
.page-staff-registration .entry-content .confirmation-btn:not([disabled]):active,
.page-staff-registration .entry-content input[type="submit"].contact-btn:active {
	transform: translateY(0);
	box-shadow: 0 1px 3px rgba(30, 86, 216, 0.25);
}

.page-staff-registration .entry-content .edit-btn,
.page-staff-registration .entry-content button.contact-btn.edit-btn {
	background-color: var(--matching-color-bg);
	color: var(--matching-color-text);
	border-color: var(--sr-border);
}
.page-staff-registration .entry-content .edit-btn:hover {
	background-color: var(--sr-surface);
	border-color: var(--sr-border-hover);
	box-shadow: var(--matching-shadow-md);
}
.page-staff-registration .entry-content .edit-btn:active {
	transform: translateY(0);
	box-shadow: 0 1px 2px rgba(0, 0, 0, 0.06);
}

.page-staff-registration .entry-content .btn-add-block {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	min-height: var(--matching-btn-min-height, 4rem);
	padding: var(--matching-btn-padding-y, 1rem) var(--matching-btn-padding-x, 1.8rem);
	font-size: var(--matching-btn-font-size, 1.2rem);
	font-weight: 600;
	font-family: inherit;
	line-height: 1.35;
	text-align: center;
	letter-spacing: 0.02em;
	border-radius: var(--sr-radius);
	border: var(--matching-btn-border-width, 2px) solid var(--sr-border);
	background: var(--matching-color-bg);
	color: var(--matching-color-text);
	cursor: pointer;
	-webkit-appearance: none;
	appearance: none;
	box-sizing: border-box;
	flex-shrink: 0;
	transition: background-color var(--sr-transition), border-color var(--sr-transition);
}
.page-staff-registration .entry-content .btn-add-block:hover {
	background-color: var(--sr-surface);
	border-color: var(--sr-border-hover);
}

/* ========== 学歴ブロック（#studies-wrapper） ========== */
.page-staff-registration .entry-content #studies-wrapper {
	display: flex;
	flex-direction: column;
	gap: 3rem;
	margin-bottom: 2rem;
}
.page-staff-registration .entry-content .studies-block {
	padding: 1.25rem 1.5rem;
	background: var(--sr-surface-alt);
	border: 1px solid var(--sr-border);
	border-radius: var(--sr-radius);
}
.page-staff-registration .entry-content .studies-block + .btn-add-block {
	margin-top: 0.5rem;
}
.page-staff-registration .entry-content .studies-wrap {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	gap: 0.5rem 0.75rem;
}
.page-staff-registration .entry-content .studies-wrap .title {
	flex: 1 0 100%;
	font-weight: 600;
	font-size: 1.05rem;
	margin: 0.25rem 0 0;
}
.page-staff-registration .entry-content .studies-wrap .input {
	display: inline-flex;
	align-items: center;
	gap: 0.25rem;
	margin-bottom: 1rem;
}
.page-staff-registration .entry-content .studies-wrap .wpcf7-form-control-wrap {
	display: inline-flex;
	align-items: center;
	gap: 0.25rem;
}
.page-staff-registration .entry-content .studies-wrap input[type="number"] {
	width: 5em;
	min-width: 4em;
	display: inline-block;
}
.page-staff-registration .entry-content .studies-wrap input[type="text"] {
	min-width: 14em;
	max-width: 28em;
	display: inline-block;
}

/* ========== 職務経歴ブロック（#career-wrapper） ========== */
.page-staff-registration .entry-content #career-wrapper {
	display: flex;
	flex-direction: column;
	gap: 3rem;
	margin-bottom: 2rem;
}
.page-staff-registration .entry-content .career-block {
	padding: 1.25rem 1.5rem;
	background: var(--sr-surface-alt);
	border: 1px solid var(--sr-border);
	border-radius: var(--sr-radius);
}
.page-staff-registration .entry-content .career-block + .btn-add-block {
	margin-top: 0.5rem;
}
.page-staff-registration .entry-content .career-wrap {
	display: flex;
	flex-wrap: wrap;
	align-items: flex-start;
	gap: 0.5rem 0.75rem;
	margin-bottom: 1rem;
	padding-bottom: 1rem;
	border-bottom: 1px solid var(--sr-border);
}
.page-staff-registration .entry-content .career-wrap:last-child {
	margin-bottom: 0;
	padding-bottom: 0;
	border-bottom: 0;
}
/* ラベル1行・入力2行目で枠内に収める（CF7が入れる br は非表示） */
.page-staff-registration .entry-content .career-wrap > p:has(> .input) {
	margin: 0;
	width: 100%;
	min-width: 0;
}
.page-staff-registration .entry-content .career-wrap > p:has(> .input) .title {
	display: block;
	font-weight: 600;
	color: var(--matching-color-text);
	margin-bottom: 0.4rem;
}
.page-staff-registration .entry-content .career-wrap > p:has(> .input) .input {
	display: block;
	min-width: 0;
	width: 100%;
}
.page-staff-registration .entry-content .career-wrap > p:has(> .input) br {
	display: none;
}
.page-staff-registration .entry-content .career-wrap > .title {
	flex: 0 0 8.5rem;
	min-width: 7rem;
	font-weight: 600;
	color: var(--matching-color-text);
}
/* 勤務期間もラベル1行・入力2行目に統一 */
.page-staff-registration .entry-content .career-wrap:has(> .career-period-wrap) {
	flex-direction: column;
	align-items: flex-start;
	gap: 0.4rem;
}
.page-staff-registration .entry-content .career-wrap:has(> .career-period-wrap) > p:first-child {
	margin: 0;
	padding: 0;
	font-weight: 600;
	color: var(--matching-color-text);
	line-height: 1.5;
	min-width: 0;
}
.page-staff-registration .entry-content .career-wrap:has(> .career-period-wrap) > p:first-child .title {
	display: block;
	font-weight: inherit;
	color: inherit;
	line-height: inherit;
}
.page-staff-registration .entry-content .career-wrap > .career-period-wrap {
	flex: none;
	width: 100%;
	min-width: 0;
	align-self: stretch;
}
.page-staff-registration .entry-content .career-wrap > .input,
.page-staff-registration .entry-content .career-wrap .wpcf7-form-control-wrap {
	flex: 1 1 16rem;
	min-width: 0;
}
.page-staff-registration .entry-content .career-wrap input[type="text"],
.page-staff-registration .entry-content .career-wrap input[type="number"],
.page-staff-registration .entry-content .career-wrap textarea {
	max-width: 100%;
}
.page-staff-registration .entry-content .career-wrap textarea {
	min-height: 4.5em;
}
/* 勤務期間: 開始/終了は横並び、現在も在籍は終了の下に配置 */
.page-staff-registration .entry-content .career-wrap > .career-period-wrap {
	--career-period-label-w: 2.8em;
	display: grid;
	grid-template-columns: repeat(2, minmax(0, 1fr));
	gap: 0.5rem 1rem;
	align-items: start;
	min-width: 22em;
}
/* CF7がpを挟む出力に対応 */
.page-staff-registration .entry-content .career-wrap > .career-period-wrap > p {
	display: contents;
	margin: 0;
}
.page-staff-registration .entry-content .career-wrap > .career-period-wrap > p > br {
	display: none;
}
.page-staff-registration .entry-content .career-wrap > .career-period-wrap > .input,
.page-staff-registration .entry-content .career-wrap > .career-period-wrap > p > .input {
	min-width: 0;
}
/* 開始/終了のラベルと入力を2カラムで固定して重なり防止 */
.page-staff-registration .entry-content .career-wrap > .career-period-wrap > .input:nth-of-type(1),
.page-staff-registration .entry-content .career-wrap > .career-period-wrap > .input:nth-of-type(2),
.page-staff-registration .entry-content .career-wrap > .career-period-wrap > p > .input:nth-of-type(1),
.page-staff-registration .entry-content .career-wrap > .career-period-wrap > p > .input:nth-of-type(2) {
	display: grid;
	grid-template-columns: var(--career-period-label-w) minmax(0, 1fr);
	align-items: center;
	column-gap: 0.25rem;
	white-space: nowrap;
}
/* 現在も在籍は終了列（右列）の入力開始位置に合わせる */
.page-staff-registration .entry-content .career-wrap > .career-period-wrap > .input:has(input[name^="current"]),
.page-staff-registration .entry-content .career-wrap > .career-period-wrap > p > .input:has(input[name^="current"]) {
	grid-column: 2;
	display: inline-flex;
	padding-left: calc(var(--career-period-label-w) + 0.25rem);
	margin-top: 0.1rem;
	white-space: nowrap;
}
/* 在籍中チェックは開始/終了と同列で見やすく */
.page-staff-registration .entry-content .career-period-wrap .wpcf7-list-item {
	margin: 0;
}
.page-staff-registration .entry-content .career-period-wrap .wpcf7-list-item label {
	min-width: auto;
	padding: 0.3rem 0.7rem !important;
	font-size: 1.35rem;
	white-space: nowrap;
}
/* 勤務期間内の wpcf7 ラップは flex で伸ばさない（.career-wrap .wpcf7-form-control-wrap の打ち消し） */
.page-staff-registration .entry-content .career-period-wrap .wpcf7-form-control-wrap {
	display: inline-flex;
	align-items: center;
	flex: 0 0 auto;
}
.page-staff-registration .entry-content .career-wrap .Wrap input[type="number"],
.page-staff-registration .entry-content .career-period-wrap input[type="number"] {
	width: 4.5em;
	min-width: 3.5em;
	display: inline-block;
}
.page-staff-registration .entry-content .career-wrap input.duration {
	background: var(--sr-surface);
	cursor: default;
	width: 8em;
	min-width: 7em;
}
.page-staff-registration .entry-content .career-period-wrap input[name^="end_year"]:disabled,
.page-staff-registration .entry-content .career-period-wrap input[name^="end_month"]:disabled {
	background: var(--sr-surface);
	opacity: 0.75;
}

/* 勤務期間レイアウト最終調整:
 * 開始：  年  月　終了：  年  月
 * 　　　　　　　　現在も在籍
 */
.page-staff-registration .entry-content .career-wrap > .career-period-wrap {
	display: grid !important;
	grid-template-columns: 1fr 1fr !important;
	column-gap: 1.2rem;
	row-gap: 0.45rem;
	align-items: center;
}
.page-staff-registration .entry-content .career-wrap > .career-period-wrap > p {
	display: contents !important;
}
.page-staff-registration .entry-content .career-wrap > .career-period-wrap > p > br {
	display: none !important;
}
.page-staff-registration .entry-content .career-wrap > .career-period-wrap > .input,
.page-staff-registration .entry-content .career-wrap > .career-period-wrap > p > .input {
	display: inline-flex !important;
	align-items: center;
	gap: 0.25rem;
	white-space: nowrap;
	min-width: 0;
}
.page-staff-registration .entry-content .career-wrap > .career-period-wrap > .input:nth-of-type(1),
.page-staff-registration .entry-content .career-wrap > .career-period-wrap > p > .input:nth-of-type(1) {
	grid-column: 1;
}
.page-staff-registration .entry-content .career-wrap > .career-period-wrap > .input:nth-of-type(2),
.page-staff-registration .entry-content .career-wrap > .career-period-wrap > p > .input:nth-of-type(2) {
	grid-column: 2;
}
.page-staff-registration .entry-content .career-wrap > .career-period-wrap > .input:has(input[name^="current"]),
.page-staff-registration .entry-content .career-wrap > .career-period-wrap > p > .input:has(input[name^="current"]) {
	grid-column: 2;
	margin-top: 0.1rem;
	padding-left: 6.6rem;
}

/* ========== 取得資格ブロック（#qualification-wrapper） ========== */
.page-staff-registration .entry-content #qualification-wrapper {
	display: flex;
	flex-direction: column;
	gap: 1.5rem;
	margin-bottom: 1.5rem;
}
.page-staff-registration .entry-content .qualification-block {
	padding: 1.25rem 1.5rem;
	background: var(--sr-surface-alt);
	border: 1px solid var(--sr-border);
	border-radius: var(--sr-radius);
}
.page-staff-registration .entry-content .qualification-block + .btn-add-block {
	margin-top: 0.75rem;
}
.page-staff-registration .entry-content .qualification-wrap {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	gap: 0.5rem 0.75rem;
	margin-bottom: 0.75rem;
}
.page-staff-registration .entry-content .qualification-wrap:last-child {
	margin-bottom: 0;
}
.page-staff-registration .entry-content .qualification-wrap .title {
	font-weight: 600;
	color: var(--matching-color-text);
	white-space: nowrap;
}
.page-staff-registration .entry-content .qualification-wrap .input {
	display: inline-flex;
	align-items: center;
	gap: 0.35rem;
	min-width: 0;
}
.page-staff-registration .entry-content .qualification-wrap .input .wpcf7-form-control-wrap {
	display: inline-flex;
	align-items: center;
}
.page-staff-registration .entry-content .qualification-wrap input[type="number"] {
	width: 5em;
	min-width: 4em;
}
.page-staff-registration .entry-content .qualification-wrap input[type="text"] {
	min-width: 14em;
	max-width: 32em;
}

@media (max-width: 640px) {
	.page-staff-registration .entry-content .qualification-block {
		padding: 1rem 1.1rem;
	}
	.page-staff-registration .entry-content .qualification-wrap {
		flex-direction: column;
		align-items: flex-start;
	}
	.page-staff-registration .entry-content .qualification-wrap .input {
		width: 100%;
	}
	.page-staff-registration .entry-content .qualification-wrap input[type="text"] {
		width: 100%;
		min-width: 0;
		max-width: 100%;
	}
}

/* 項目ごとのバリデーションエラー（必須未入力など） */
.page-staff-registration .entry-content .wpcf7 .wpcf7-not-valid-tip {
	font-size: 1.35rem;
	font-weight: 600;
	color: #b91c1c;
	margin-top: 0.4rem;
	display: block;
}
.page-staff-registration .entry-content .wpcf7 .wpcf7-not-valid-tip::before {
	content: '※ ';
}

/* ========== 個人情報の取り扱いについて（#handling） ========== */
.page-staff-registration .entry-content .headling#handling {
	margin-top: var(--sr-section-gap);
	width: 100%;
}

.page-staff-registration .entry-content .headling#handling .frame_box {
	display: block;
	max-height: 21rem;
	overflow-y: auto;
	overflow-x: hidden;
	padding: var(--sr-inset-y) var(--sr-handling-pad-x) calc(var(--sr-inset-y) + 0.125rem);
	border: 1px solid var(--sr-border);
	border-radius: var(--sr-radius);
	background: var(--sr-surface-alt);
	box-shadow: var(--matching-shadow);
	-webkit-overflow-scrolling: touch;
	color: var(--sr-handling-text);
	font-size: var(--sr-prose-fs);
	line-height: var(--sr-prose-lh);
}

.page-staff-registration .entry-content .headling#handling .frame_box h1 {
	font-weight: 700;
	font-size: var(--sr-prose-title-fs);
	line-height: var(--sr-prose-title-lh);
	margin: 0 0 var(--sr-field-gap);
	padding-bottom: var(--sr-field-gap);
	color: var(--sr-handling-text);
	letter-spacing: 0.02em;
	border-bottom: 1px solid var(--sr-border);
}

.page-staff-registration .entry-content .headling#handling .frame_box .mb-20 {
	margin-bottom: var(--sr-field-gap);
}

.page-staff-registration .entry-content .headling#handling .frame_box ol {
	margin: 0 0 0.65rem;
	padding-left: var(--sr-handling-ol-indent);
	line-height: var(--sr-prose-lh);
	color: var(--sr-handling-text);
	list-style: decimal;
}

.page-staff-registration .entry-content .headling#handling .frame_box ol li {
	margin-bottom: 0.55rem;
	font-size: var(--sr-prose-fs);
}

.page-staff-registration .entry-content .headling#handling .frame_box ol li p {
	margin: 0.25rem 0 0;
	color: var(--sr-handling-text-sub);
	/* 1rem は html 62.5% だと約10pxになり过小になるため親（li）に合わせる */
	font-size: inherit;
	line-height: var(--sr-prose-lh);
}

.page-staff-registration .entry-content .headling#handling .frame_box ul {
	margin: 0.65rem 0 0;
	padding: 0 0 0 var(--sr-handling-ul-indent);
	list-style: none;
	color: var(--sr-handling-text-meta);
	/* お問い合わせ以下の本文を、ol 本文（--sr-prose-fs）と同じ字サイズ・行間に */
	font-size: var(--sr-prose-fs);
	line-height: var(--sr-prose-lh);
}

.page-staff-registration .entry-content .headling#handling .frame_box ul li {
	margin-bottom: 0.2rem;
	font-size: inherit;
}

.page-staff-registration .entry-content .headling#handling .frame_box ul li p {
	font-size: var(--sr-prose-fs);
}

.page-staff-registration .entry-content .headling#handling .frame_box ul li.square {
	font-weight: 600;
	color: var(--sr-handling-text);
	font-size: inherit;
	margin-top: 0.35rem;
	margin-bottom: 0.25rem;
}

.page-staff-registration .entry-content .headling#handling .frame_box .address .zipcode {
	display: inline;
	font-size: var(--sr-prose-fs);
}

/* ========== 個人情報同意（#check / .form-check） ========== */
.page-staff-registration .entry-content .form-group.form-check,
.page-staff-registration .entry-content .form-check {
	display: flex;
	align-items: center;
	justify-content: center;
	gap: 0.875rem;
	margin: var(--sr-section-gap) 0 0;
	padding: 1.125rem 1.375rem;
	background: var(--sr-surface-alt);
	border: 1px solid var(--sr-border);
	border-radius: var(--sr-radius);
}
.page-staff-registration .entry-content .form-group.form-check p,
.page-staff-registration .entry-content .form-check p.form-check-inner,
.page-staff-registration .entry-content .form-check > p {
	display: flex;
	align-items: center;
	justify-content: flex-start;
	gap: 0.875rem;
	margin: 0;
	flex-wrap: wrap;
	flex: 1 1 auto;
	min-width: 0;
	width: 100%;
}
.page-staff-registration .entry-content .form-group.form-check br,
.page-staff-registration .entry-content .form-check br {
	display: none;
}

.page-staff-registration .entry-content .form-check:has(#check:checked) {
	border-color: var(--sr-primary);
	background: var(--sr-primary-light);
}

.page-staff-registration .entry-content .form-check-input {
	width: 1.25rem;
	height: 1.25rem;
	min-width: 1.25rem;
	min-height: 1.25rem;
	margin-top: 0;
	accent-color: var(--sr-primary);
	cursor: pointer;
	flex-shrink: 0;
}

.page-staff-registration .entry-content .form-check-label {
	font-weight: 600;
	font-size: var(--sr-consent-label-fs);
	line-height: var(--sr-consent-label-lh);
	cursor: pointer;
	color: var(--sr-handling-text);
	flex: 0 1 auto;
	max-width: 100%;
	min-width: 0;
	text-align: center;
}

/* ========== 確認画面：回答の見た目を項目間で統一 ========== */
.page-staff-registration .entry-content .confirmation-screen {
	margin-bottom: 0;
}
.page-staff-registration .entry-content .confirmation-screen .confirmation-title {
	font-weight: 700;
	margin: 0 0 1.5rem;
	color: var(--matching-color-text);
	border-bottom: 3px solid var(--sr-primary);
	padding-bottom: 0.75rem;
	letter-spacing: 0.02em;
}
.page-staff-registration .entry-content .confirmation-screen .confirmation-title .title-ja {
	display: block;
	margin-top: 0.4rem;
	font-size: 1.15rem;
	font-weight: 600;
	opacity: 0.9;
	letter-spacing: 0.04em;
}
.page-staff-registration .entry-content .confirmation-screen .contactTable {
	box-shadow: 0 2px 12px rgba(0, 0, 0, 0.08);
}
.page-staff-registration .entry-content .confirmation-screen .contactTable th.title {
	width: 26%;
	min-width: 11rem;
	padding: 1rem 1.25rem;
	font-weight: 700;
	color: var(--matching-color-text);
	background: var(--sr-surface);
	border-right: 1px solid var(--sr-border);
	vertical-align: top;
	line-height: 1.5;
}
.page-staff-registration .entry-content .confirmation-screen .contactTable td.input {
	padding: 1rem 1.25rem;
	line-height: 1.55;
	background: var(--sr-bg);
	vertical-align: top;
}
.page-staff-registration .entry-content .confirmation-screen .contactTable tr {
	border-bottom-color: var(--sr-border);
}

/* すべての回答値：同じボックス（短文・中長文共通のベース） */
.page-staff-registration .entry-content .confirmation-screen .contactTable .answer {
	display: inline-block;
	max-width: 100%;
	padding: 0.5rem 0.85rem;
	margin: 0.15rem 0.2rem 0.15rem 0;
	box-sizing: border-box;
	font-weight: 500;
	font-size: 1rem;
	line-height: 1.5;
	color: var(--matching-color-text);
	word-break: break-word;
	vertical-align: middle;
	background: var(--sr-surface-alt);
	border: 1px solid var(--sr-border);
	border-radius: var(--sr-radius);
}

/* 複数行・HTML改行が入る項目だけ横幅100%のブロック（見た目は上と同じトーン） */
.page-staff-registration .entry-content .confirmation-screen .contactTable #confirm-qualification,
.page-staff-registration .entry-content .confirmation-screen .contactTable #confirm-pr,
.page-staff-registration .entry-content .confirmation-screen .contactTable #confirm-personality,
.page-staff-registration .entry-content .confirmation-screen .contactTable #confirm-suggested-other {
	display: block !important;
	width: 100%;
	max-width: 100%;
	margin: 0;
	white-space: pre-wrap;
	min-height: 2.5em;
}

.page-staff-registration .entry-content .confirmation-screen .contactTable #confirm-studies-wrapper,
.page-staff-registration .entry-content .confirmation-screen .contactTable #confirm-career-wrapper {
	display: flex;
	flex-direction: column;
	gap: 0.65rem;
}
.page-staff-registration .entry-content .confirmation-screen .contactTable #confirm-studies-wrapper .answer,
.page-staff-registration .entry-content .confirmation-screen .contactTable #confirm-career-wrapper .answer {
	display: block;
	width: 100%;
	max-width: 100%;
	margin: 0;
	line-height: 1.55;
}

/* 1セル内の複数行（ラベル＋値の並び）— 行間だけ揃える。値のボックスは上記と同一 */
.page-staff-registration .entry-content .confirmation-screen .contactTable td.input > .input-row,
.page-staff-registration .entry-content .confirmation-screen .contactTable td.input > .input-sub.input-row {
	display: block;
	margin: 0 0 0.55rem 0;
	line-height: 1.55;
}
.page-staff-registration .entry-content .confirmation-screen .contactTable td.input > .input-row:last-child,
.page-staff-registration .entry-content .confirmation-screen .contactTable td.input > .input-sub.input-row:last-child {
	margin-bottom: 0;
}
.page-staff-registration .entry-content .confirmation-screen .contactTable .input-row .input-sub.input-row {
	display: block;
	margin-top: 0.45rem;
	margin-bottom: 0;
	margin-left: 0;
	padding-left: 0;
}

.page-staff-registration .entry-content .confirmation-screen .contactTable .input-row.working-time-row {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	gap: 0.35rem 0.5rem;
}
.page-staff-registration .entry-content .confirmation-screen .contactTable .working-time-row .working-time-label {
	margin: 0;
	font-weight: 600;
	color: var(--matching-color-text);
}
.page-staff-registration .entry-content .confirmation-screen .contactTable .working-time-row .answer {
	margin: 0;
}

/* 最寄り等：インラインの「分」なども行高さを揃える */
.page-staff-registration .entry-content .confirmation-screen .contactTable .input-inline {
	vertical-align: middle;
	line-height: 1.5;
}

/* ========== CF7 送信結果・エラーメッセージ ========== */
.page-staff-registration .entry-content .wpcf7 .wpcf7-response-output {
	margin: 1.25rem 0 0;
	padding: 1rem 1.25rem 1rem 1.5rem;
	border-radius: var(--sr-radius);
	font-size: 1.5rem;
	font-weight: 500;
	line-height: 1.5;
	border: 2px solid transparent;
	box-sizing: border-box;
	text-align: center;
}
/* バリデーションエラー（入力不備） */
.page-staff-registration .entry-content .wpcf7 .wpcf7-validation-errors {
	border-color: #b45309;
	background: #fffbeb;
	color: #92400e;
	font-weight: 500;
}
/* 送信失敗（メール送信エラーなど） */
.page-staff-registration .entry-content .wpcf7 .wpcf7-mail-sent-ng {
	border-color: #b91c1c;
	background: #fef2f2;
	color: #991b1b;
	font-weight: 500;
}
/* 送信成功 */
.page-staff-registration .entry-content .wpcf7 .wpcf7-mail-sent-ok {
	border-color: #15803d;
	background: #f0fdf4;
	color: #166534;
	font-weight: 500;
}
