﻿/* =========================================================
   Jobs: posting flow
   ========================================================= */

/* Submit job utility note */
.tra-submit-job-terms-note {
	margin: 0 0 0.75rem;
	font-size: 14px;
	line-height: 1.5;
	color: var(--tr-muted);
}

.tra-submit-job-terms-note a {
	font-weight: 600;
}

/* =========================================================
   Owned posting flow overrides
   ========================================================= */

.tr-posting-flow {
	width: 100%;
	max-width: var(--tr-max-form);
	margin: 0 auto 2rem;
	box-sizing: border-box;
}

.tr-posting-form {
	display: grid;
	gap: 0.9rem;
	padding: clamp(1rem, 2vw, 2rem);
	border: 1px solid var(--tr-border-soft);
	border-radius: 18px;
	background: #FFFFFF;
	box-shadow: var(--tr-shadow-lg);
}

.tr-posting-section,
.tr-posting-template-picker,
.tr-posting-complete {
	display: grid;
	gap: 0.9rem;
	padding: clamp(1rem, 2vw, 1.35rem);
	border: 1px solid rgba(0, 109, 119, 0.14);
	border-radius: 16px;
	background: linear-gradient(180deg, #FFFFFF 0%, #F8FCFC 100%);
	box-sizing: border-box;
}

.tr-posting-section__header {
	display: grid;
	gap: 0.3rem;
}

.tr-posting-section__title {
	margin: 0;
	font-size: clamp(1.1rem, 1.7vw, 1.35rem);
	line-height: 1.2;
}

.tr-posting-section__copy,
.tra-submit-job-template-picker__intro,
.tr-posting-complete__copy {
	margin: 0;
	color: var(--tr-muted);
	font-size: 0.94rem;
	line-height: var(--tr-leading);
}

.tr-posting-section__fields {
	display: grid;
	gap: 0;
}

.tr-posting-field {
	display: grid;
	grid-template-columns: minmax(0, 1fr);
	gap: 0.5rem;
	align-items: start;
	margin: 0;
	padding: 0.85rem 0;
	border: 0;
	border-bottom: 1px solid rgba(0, 43, 48, 0.08);
	background: transparent;
	box-shadow: none;
	overflow: visible;
}

.tr-posting-field:last-child {
	padding-bottom: 0.15rem;
	border-bottom: 0;
}

.tr-posting-field__label {
	display: block;
	width: 100%;
	max-width: 100%;
	margin: 0;
	color: var(--tr-text);
	font-weight: 750;
	line-height: 1.35;
}

.tr-posting-field__label small {
	display: block;
	margin-top: 0.2rem;
	color: var(--tr-muted);
	font-size: 0.85rem;
	font-weight: 500;
}

.tr-posting-field__control {
	min-width: 0;
	float: none;
	clear: none;
	width: 100%;
	max-width: 100%;
	overflow: visible;
	box-sizing: border-box;
}

.job-manager-form.tr-posting-form .tr-posting-field > .tr-posting-field__label,
.job-manager-form.tr-posting-form .tr-posting-field > .tr-posting-field__control,
.job-manager-form.tr-posting-form .tr-posting-field > div.field.tr-posting-field__control {
	float: none !important;
	clear: none !important;
	width: 100% !important;
	max-width: 100% !important;
	min-width: 0 !important;
	box-sizing: border-box !important;
}

.job-manager-form.tr-posting-form .tr-posting-field > .tr-posting-field__control > :is(input, select, textarea, .select2-container, .wp-editor-wrap) {
	width: 100% !important;
	max-width: 100% !important;
	box-sizing: border-box !important;
}

.tr-posting-field__control > :first-child {
	margin-top: 0;
}

.tr-posting-field__control > :last-child {
	margin-bottom: 0;
}

.tr-posting-form :is(input[type="text"], input[type="search"], input[type="email"], input[type="url"], input[type="number"], input[type="date"], select, textarea),
.tr-posting-template-picker :is(input[type="search"], select),
.tra-submit-job-template-picker__form :is(input[type="search"], select) {
	width: 100%;
	max-width: 100%;
	box-sizing: border-box;
	min-height: 52px;
	padding: 12px 16px;
	border: 1px solid rgba(0, 109, 119, 0.18);
	border-radius: 12px;
	background: #FFFFFF;
	color: var(--tr-text);
	box-shadow: inset 0 1px 0 rgba(0, 43, 48, 0.02);
	font-size: 15px;
	line-height: 1.45;
	font-family: var(--tr-font-sans);
}

.tr-posting-form textarea {
	min-height: 180px;
	resize: vertical;
}

.tr-posting-form select[multiple],
.tr-posting-template-picker select,
.tra-submit-job-template-picker__form select {
	min-height: 150px;
	padding: 8px 12px;
}

.tr-posting-form :is(input, select, textarea):focus,
.tr-posting-template-picker :is(input, select):focus,
.tra-submit-job-template-picker__form :is(input, select):focus {
	border-color: var(--tr-primary);
	box-shadow: var(--tr-focus);
	outline: none;
}

.tr-posting-form :is(.description, small.description, p.description, .job-manager-term-checklist-description) {
	display: block;
	margin: 0.4rem 0 0;
	color: var(--tr-muted);
	font-size: 14px;
	line-height: var(--tr-leading);
}

.tr-posting-editbar {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 0.75rem;
	padding: 0.8rem 0.95rem;
	border: 1px solid rgba(0, 109, 119, 0.14);
	border-radius: 14px;
	background: rgba(0, 109, 119, 0.035);
}

.tr-posting-editbar__copy {
	min-width: 0;
}

.tr-posting-editbar__meta {
	margin: 0;
	color: var(--tr-text);
	font-size: 0.95rem;
	font-weight: 750;
	line-height: 1.35;
	overflow-wrap: anywhere;
}

.tr-posting-editbar__link {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	flex: 0 0 auto;
	min-height: 38px;
	padding: 0.5rem 0.8rem;
	border: 1px solid rgba(0, 109, 119, 0.24);
	border-radius: 10px;
	background: #FFFFFF;
	color: var(--tr-primary);
	font-size: 0.88rem;
	font-weight: 750;
	text-decoration: none;
}

.tr-posting-editbar__link:hover,
.tr-posting-editbar__link:focus {
	border-color: var(--tr-primary);
	background: rgba(0, 109, 119, 0.06);
	color: var(--tr-primary-hover);
}

.tr-posting-form .account-sign-in strong {
	color: var(--tr-text);
}

.tr-posting-form .account-sign-in .button {
	min-height: 34px;
	margin: 0 0 0 auto;
	padding: 0.42rem 0.7rem;
	border: 1px solid rgba(0, 109, 119, 0.24);
	border-radius: 9px;
	background: #FFFFFF;
	color: var(--tr-primary);
	font-size: 0.84rem;
	font-weight: 750;
	box-shadow: none;
}

.tr-posting-field--type-checkbox .tr-posting-field__control {
	display: grid;
	grid-template-columns: 20px minmax(0, 1fr);
	gap: 0 0.75rem;
	align-items: center;
	padding: 0.9rem 1rem;
	border: 1px solid rgba(0, 109, 119, 0.14);
	border-radius: 12px;
	background: #FFFFFF;
	box-sizing: border-box;
	min-height: 54px;
}

.tr-posting-field--type-checkbox .tr-posting-field__control:has(input[type="checkbox"]:checked) {
	border-color: var(--tr-primary);
	background: rgba(0, 109, 119, 0.045);
	box-shadow: inset 0 0 0 1px rgba(0, 109, 119, 0.16);
}

.tr-posting-field--type-checkbox .tr-posting-field__control:hover,
.tr-posting-field--type-checkbox .tr-posting-field__control:focus-within {
	border-color: rgba(0, 109, 119, 0.4);
	background: rgba(0, 109, 119, 0.025);
}

.tr-posting-field--type-checkbox .tr-posting-field__control > input[type="checkbox"] {
	grid-column: 1;
	grid-row: 1;
	width: 16px !important;
	height: 16px;
	min-height: 16px !important;
	margin: 0;
	padding: 0;
	box-shadow: none;
	justify-self: center;
}

.tr-posting-field--type-checkbox .tr-posting-field__control > .description,
.tr-posting-field--type-checkbox .tr-posting-field__control > small.description {
	grid-column: 2;
	margin-top: 0;
	color: var(--tr-muted);
	font-size: 0.92rem;
	line-height: 1.45;
}

.tr-posting-form input[type="checkbox"],
.tr-posting-form input[type="radio"] {
	accent-color: var(--tr-primary);
}

.tr-posting-field--delivery-formats .job-manager-term-checklist,
.tr-posting-field--delivery-formats ul.job-manager-term-checklist,
.tr-posting-field--delivery-formats .term-checklist,
.tr-posting-field--delivery-formats .field > ul {
	display: grid;
	grid-template-columns: repeat(3, minmax(0, 1fr));
	gap: 0.75rem;
	list-style: none;
	margin: 0;
	padding: 0;
}

.tr-posting-field--delivery-formats .job-manager-term-checklist li,
.tr-posting-field--delivery-formats .field > ul > li {
	margin: 0;
	padding: 0;
	list-style: none;
}

.tr-posting-field--delivery-formats .job-manager-term-checklist li::before,
.tr-posting-field--delivery-formats .field > ul > li::before {
	display: none !important;
	content: none !important;
}

.tr-posting-field--delivery-formats label.selectit,
.tr-posting-field--delivery-formats .job-manager-term-checklist li label,
.tr-posting-field--delivery-formats .field > ul > li label {
	display: inline-flex;
	align-items: center;
	gap: 0.55rem;
	width: 100%;
	min-height: 48px;
	margin: 0;
	padding: 0.72rem 0.95rem;
	border: 1px solid var(--tr-border);
	border-radius: var(--tr-radius-pill);
	background: #FFFFFF;
	box-sizing: border-box;
	color: var(--tr-text);
	font-size: 14px;
	font-weight: 650;
	line-height: 1.3;
	cursor: pointer;
}

.tr-posting-field--delivery-formats label:hover,
.tr-posting-field--delivery-formats label:focus-within {
	border-color: rgba(0, 109, 119, 0.4);
	background-color: rgba(0, 109, 119, 0.03);
}

.tr-posting-field--delivery-formats input[type="checkbox"] {
	position: static;
	opacity: 1;
	pointer-events: auto;
	flex: 0 0 18px;
	width: 18px;
	height: 18px;
	margin: 0;
	padding: 0;
	box-shadow: none;
}

.tr-posting-field--delivery-formats .tr-posting-field__control::before,
.tr-posting-field--delivery-formats .tr-posting-field__control::after {
	display: none;
	content: none;
}

.tr-posting-field--job-category .select2-container {
	width: 100% !important;
	max-width: 100% !important;
}

.tr-posting-field--job-category .select2-selection--multiple {
	min-height: 52px !important;
	padding: 0.42rem 0.55rem !important;
	border: 1px solid rgba(0, 109, 119, 0.18) !important;
	border-radius: 12px !important;
	background: #FFFFFF !important;
	box-sizing: border-box !important;
	overflow: visible !important;
}

.tr-posting-field--job-category .select2-selection__rendered {
	display: flex !important;
	flex-wrap: wrap !important;
	align-items: center !important;
	gap: 0.35rem !important;
	width: 100% !important;
	max-width: 100% !important;
	margin: 0 !important;
	padding: 0 !important;
	box-sizing: border-box !important;
}

.tr-posting-field--job-category .select2-selection__choice {
	display: inline-flex !important;
	align-items: center !important;
	gap: 0.3rem;
	max-width: 100%;
	margin: 0 !important;
	padding: 0.32rem 0.58rem !important;
	border: 1px solid rgba(0, 109, 119, 0.18) !important;
	border-radius: 999px !important;
	background: rgba(0, 109, 119, 0.045) !important;
	color: var(--tr-text) !important;
	font-size: 0.86rem !important;
	font-weight: 650 !important;
	line-height: 1.2 !important;
	white-space: normal !important;
	overflow-wrap: anywhere;
}

.tr-posting-field--job-category .select2-selection__choice__remove {
	position: static !important;
	order: -1;
	margin: 0 !important;
	color: var(--tr-muted) !important;
	font-size: 1rem !important;
	line-height: 1 !important;
}

.tr-posting-field--job-category .select2-search--inline {
	flex: 1 1 160px;
	margin: 0 !important;
}

.tr-posting-field--job-category .select2-search__field {
	width: 100% !important;
	min-width: 140px !important;
	height: 32px !important;
	min-height: 32px !important;
	padding: 0.25rem 0.35rem !important;
	border: 0 !important;
	box-shadow: none !important;
}

.tr-posting-field--job-description .wp-editor-wrap,
.tr-posting-field--job-description .wp-editor-container,
.tr-posting-field--job-description .mce-tinymce {
	width: 100% !important;
	max-width: 100% !important;
	border-color: rgba(0, 109, 119, 0.16) !important;
	border-radius: 12px !important;
	box-sizing: border-box !important;
	overflow: hidden;
}

.tr-posting-field--job-description .mce-container,
.tr-posting-field--job-description .mce-container-body,
.tr-posting-field--job-description .mce-stack-layout,
.tr-posting-field--job-description .mce-flow-layout {
	max-width: 100% !important;
	box-sizing: border-box !important;
}

.tr-posting-field--job-description .mce-top-part,
.tr-posting-field--job-description .mce-toolbar-grp {
	background: #F7FCFD !important;
	border-color: rgba(0, 109, 119, 0.12) !important;
}

.tr-posting-field--job-description .mce-toolbar-grp {
	padding: 0.35rem 0.45rem !important;
}

.tr-posting-field--job-description .mce-toolbar,
.tr-posting-field--job-description .mce-flow-layout {
	display: flex !important;
	flex-wrap: wrap !important;
	align-items: center !important;
	gap: 0.2rem !important;
	width: auto !important;
}

.tr-posting-field--job-description .mce-flow-layout-item {
	display: inline-flex !important;
	margin: 0 0.12rem 0.12rem 0 !important;
	width: auto !important;
}

.tr-posting-field--job-description .mce-btn {
	border-radius: 8px !important;
	box-shadow: none !important;
	width: auto !important;
}

.tr-posting-field--job-description .mce-btn button {
	min-width: 30px !important;
	min-height: 30px !important;
	padding: 4px 6px !important;
	border: 0 !important;
	background: transparent !important;
	box-shadow: none !important;
}

.tr-posting-field--job-description .mce-edit-area iframe {
	min-height: 220px;
}

.tr-posting-actions {
	display: flex;
	flex-wrap: wrap;
	gap: 0.7rem;
	align-items: center;
	margin: 0 !important;
	padding: 0;
}

.tr-posting-action {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	min-height: 46px;
	max-width: 100%;
	box-sizing: border-box;
	text-align: center;
}

.tr-posting-actions .spinner {
	margin: 0 0 0 0.25rem;
}

.tra-submit-job-terms-note {
	margin: 0;
	font-size: 14px;
	line-height: 1.5;
	color: var(--tr-muted);
}

.tra-submit-job-terms-note a,
.tr-posting-form a {
	font-weight: 650;
}

.tr-posting-template-picker__form,
.tra-submit-job-template-picker__form {
	display: grid;
	grid-template-columns: minmax(0, 1fr) auto;
	align-items: end;
	gap: 0.65rem;
}

.tra-submit-job-template-picker__copy {
	display: grid;
	gap: 0.25rem;
}

.tra-submit-job-template-picker__eyebrow,
.tr-posting-complete__eyebrow {
	margin: 0;
	color: var(--tr-primary);
	font-size: 0.74rem;
	font-weight: 800;
	letter-spacing: 0.08em;
	text-transform: uppercase;
}

.tra-submit-job-template-picker__title {
	margin: 0;
	font-size: 1.1rem;
	line-height: 1.25;
}

.tra-submit-job-template-picker__search {
	grid-column: 1 / -1;
}

.tra-submit-job-template-picker__form select {
	grid-column: 1 / 2;
}

.tra-submit-job-template-picker__meta {
	grid-column: 1 / 2;
	margin: 0;
	color: var(--tr-muted);
	font-size: 0.84rem;
}

.tra-submit-job-template-picker__form button {
	grid-column: 2 / 3;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	min-height: 48px;
	padding: 0.68rem 1rem;
	border: 1px solid rgba(0, 109, 119, 0.22);
	border-radius: 11px;
	background: rgba(0, 109, 119, 0.06);
	color: var(--tr-primary);
	font-family: var(--tr-font-sans);
	font-size: 0.92rem;
	font-weight: 800;
	line-height: 1.2;
	box-shadow: none;
	cursor: pointer;
}

.tra-submit-job-template-picker__form button:hover,
.tra-submit-job-template-picker__form button:focus {
	border-color: var(--tr-primary);
	background: rgba(0, 109, 119, 0.1);
	color: var(--tr-primary-hover);
	outline: none;
}

.tra-submit-job-template-notice {
	margin-top: 0.85rem;
}

@media (max-width: 820px) {
	.tr-posting-form {
		padding: 1rem;
	}

	.tr-posting-field {
		grid-template-columns: minmax(0, 1fr);
		gap: 0.5rem;
	}

	.tr-posting-field--delivery-formats .job-manager-term-checklist,
	.tr-posting-field--delivery-formats ul.job-manager-term-checklist,
	.tr-posting-field--delivery-formats .term-checklist,
	.tr-posting-field--delivery-formats .field > ul {
		grid-template-columns: repeat(2, minmax(0, 1fr));
	}
}

@media (max-width: 640px) {
	.tr-posting-field,
	.tr-posting-template-picker__form,
	.tra-submit-job-template-picker__form {
		grid-template-columns: 1fr;
	}

	.tr-posting-field__label,
	.tr-posting-field__control,
	.tra-submit-job-template-picker__search,
	.tra-submit-job-template-picker__form select,
	.tra-submit-job-template-picker__meta,
	.tra-submit-job-template-picker__form button {
		grid-column: 1 / -1;
	}
}

@media (max-width: 560px) {
	.tr-posting-actions {
		display: grid;
		grid-template-columns: 1fr;
		gap: 0.55rem;
	}

	.tr-posting-action,
	.tr-posting-actions input[type="submit"],
	.tr-posting-actions button {
		width: 100%;
		min-width: 0;
	}

	.tr-posting-actions .spinner {
		justify-self: center;
		margin: 0.15rem 0 0;
	}

	.tr-posting-field--delivery-formats .job-manager-term-checklist,
	.tr-posting-field--delivery-formats ul.job-manager-term-checklist,
	.tr-posting-field--delivery-formats .term-checklist,
	.tr-posting-field--delivery-formats .field > ul {
		grid-template-columns: 1fr;
	}
}


/* Submit job preview: cleaner structure and stronger hierarchy */
#job_preview {
	display: grid;
	gap: 0;
	margin-top: 1rem;
	border: 1px solid rgba(0, 109, 119, 0.16);
	border-radius: 18px;
	background: linear-gradient(180deg, rgba(255, 255, 255, 0.98) 0%, rgba(246, 251, 252, 0.95) 100%);
	box-shadow: 0 12px 28px rgba(12, 31, 45, 0.08);
	overflow: hidden;
}

/* Current markup has two direct children: .tr-posting-preview__heading and
   .tr-posting-preview__actions. The previous rule named three grid areas
   (title/continue/edit) that no child claims, leaving an orphaned auto column
   that crushed the action buttons. Two-column layout matches the actual DOM. */
#job_preview .job_listing_preview_title {
	display: grid;
	grid-template-columns: minmax(0, 1fr) auto;
	align-items: center;
	gap: 0.85rem;
	padding: 0.9rem 1rem;
	border-bottom: 1px solid rgba(0, 109, 119, 0.12);
	background: rgba(241, 250, 251, 0.72);
}

#job_preview .job_listing_preview_title h2 {
	margin: 0;
	font-size: clamp(1.25rem, 2vw, 1.55rem);
	line-height: 1.2;
	min-width: 0;
	overflow-wrap: anywhere;
}

#job_preview .job_listing_preview_title .button {
	min-height: 42px;
	font-size: 0.92rem;
}

#job_preview .job_listing_preview {
	padding: clamp(1rem, 2vw, 1.35rem);
	background: transparent;
}

#job_preview .job_listing_preview > h1 {
	margin: 0 0 0.9rem;
	font-size: clamp(1.45rem, 2.2vw, 2rem);
	line-height: 1.15;
}

/* Outer element has both classes — cancel sidebar grid, max-width, and auto-margin from jobs-single.css */
#job_preview .job_listing_preview.single_job_listing {
	display: block;
	width: 100%;
	max-width: none;
	margin: 0;
}

/* Inner nested .single_job_listing — strip chrome added by the live-page styles */
#job_preview .job_listing_preview .single_job_listing {
	display: block;
	width: 100%;
	max-width: none;
	margin: 0;
	padding: 0;
	border: 0;
	box-shadow: none;
	background: transparent;
}

#job_preview .job_listing_preview .job_description {
	margin-top: 1rem;
	padding-top: 0.85rem;
	border-top: 1px solid rgba(0, 109, 119, 0.12);
}

/* Stacking is handled by the .tr-posting-preview__header rule at the 780px
   breakpoint further down. The previous rule here named grid-template-areas
   (title/continue/edit) but the children don't carry matching grid-area
   declarations, so it just produced a broken 1fr 1fr layout that overrode
   our stack rule via ID specificity. Removed; the class-based 780px rule
   stacks correctly for both the original and current markup. */

/* =========================================================
   Job Package Selection
   ========================================================= */

/* Owned preview, package, and completion surfaces */
.tr-posting-preview,
.tr-posting-packages {
	border: 1px solid rgba(0, 109, 119, 0.16);
	border-radius: 18px;
	background: linear-gradient(180deg, rgba(255, 255, 255, 0.98) 0%, rgba(246, 251, 252, 0.95) 100%);
	box-shadow: 0 12px 28px rgba(12, 31, 45, 0.08);
	overflow: hidden;
}

.tr-posting-preview__header,
.tr-posting-packages .job_listing_packages_title {
	display: grid;
	grid-template-columns: minmax(0, 1fr) auto;
	gap: 0.85rem;
	align-items: center;
	padding: 1rem;
	border-bottom: 1px solid rgba(0, 109, 119, 0.12);
	background: rgba(241, 250, 251, 0.72);
}

.tr-posting-preview__heading {
	display: grid;
	gap: 0.25rem;
}

.tr-posting-preview__eyebrow {
	display: inline-flex;
	align-items: center;
	justify-self: start;
	margin: 0 0 0.35rem;
	padding: 0.18rem 0.6rem;
	border-radius: 100px;
	background: rgba(0, 109, 119, 0.1);
	color: var(--tr-primary);
	font-size: 0.72rem;
	font-weight: 800;
	letter-spacing: 0.08em;
	text-transform: uppercase;
}

.tr-posting-preview__header h2,
.tr-posting-packages .job_listing_packages_title h2 {
	margin: 0;
	font-size: clamp(1.2rem, 2vw, 1.55rem);
	line-height: 1.2;
}

.tr-posting-packages .job_listing_packages_title .button {
	min-height: 42px;
	font-size: 0.92rem;
}

.tr-posting-packages .job_listing_packages_title h2 {
	order: -1;
}

.tr-posting-packages ul.job_packages li.package-section {
	display: none;
}

.tr-posting-preview__actions {
	display: flex;
	flex-wrap: wrap;
	gap: 0.5rem;
	justify-content: flex-end;
	align-items: center;
}

.tr-posting-preview__actions .button {
	white-space: nowrap;
}

.tr-posting-preview__summary {
	display: flex;
	border-bottom: 1px solid rgba(0, 109, 119, 0.1);
	overflow-x: auto;
}

.tr-posting-preview__card {
	display: grid;
	gap: 0.2rem;
	flex: 1;
	min-width: 110px;
	padding: 0.85rem 1rem;
	border-right: 1px solid rgba(0, 109, 119, 0.1);
}

.tr-posting-preview__card:last-child {
	border-right: 0;
}

.tr-posting-complete__summary {
	display: grid;
	gap: 0.25rem;
	min-width: 0;
	padding: 0.8rem 0.9rem;
	border: 1px solid rgba(0, 109, 119, 0.12);
	border-radius: 12px;
	background: #FFFFFF;
}

.tr-posting-preview__card-label,
.tr-posting-complete__summary span {
	color: var(--tr-muted);
	font-size: 0.72rem;
	font-weight: 800;
	letter-spacing: 0.07em;
	text-transform: uppercase;
}

.tr-posting-preview__card-value,
.tr-posting-complete__summary strong {
	min-width: 0;
	overflow-wrap: anywhere;
	color: var(--tr-text);
	font-weight: 600;
	line-height: 1.35;
}

.tr-posting-preview__listing,
.tr-posting-packages .job_listing_packages {
	min-width: 0;
	padding: clamp(1rem, 2vw, 1.35rem);
	box-sizing: border-box;
}

/* Safety: long descriptions and meta links should wrap rather than overflow
   the preview's overflow:hidden container at narrow widths. */
.tr-posting-preview__listing,
.tr-posting-preview__listing .single_job_listing,
.tr-posting-preview__listing .job_description,
.tr-posting-preview__listing .job_description p {
	min-width: 0;
	max-width: 100%;
	overflow-wrap: anywhere;
}

.tr-posting-preview__candidate-eyebrow {
	margin: 0 0 0.7rem;
	color: var(--tr-muted);
	font-size: 0.72rem;
	font-weight: 800;
	letter-spacing: 0.07em;
	text-transform: uppercase;
}

.tr-posting-packages ul.job_packages {
	display: grid;
	gap: 1rem;
	margin: 0;
	padding: 0;
	list-style: none;
}

.tr-posting-packages ul.job_packages li.package-section {
	margin: 0 0 0.2rem;
	padding: 0;
	color: var(--tr-text);
	font-size: 1.1rem;
	font-weight: 700;
	list-style: none;
}

.tr-posting-package,
.tr-posting-packages ul.job_packages li.job-package {
	position: relative;
	display: grid;
	grid-template-columns: auto minmax(0, 1fr);
	gap: 0.25rem 0.8rem;
	align-items: start;
	margin: 0;
	padding: 1rem 1.1rem;
	border: 1px solid rgba(0, 109, 119, 0.18);
	border-radius: 14px;
	background: #FFFFFF;
	box-shadow: inset 0 1px 0 rgba(0, 43, 48, 0.02);
	font-size: 0.875rem;
	color: var(--tr-muted);
}

.tr-posting-packages ul.job_packages li.job-package:hover,
.tr-posting-packages ul.job_packages li.job-package:focus-within {
	border-color: rgba(0, 109, 119, 0.42);
	background: rgba(0, 109, 119, 0.025);
}

.tr-posting-packages ul.job_packages li.job-package:has(input[type="radio"]:checked) {
	border-color: var(--tr-primary);
	box-shadow: 0 0 0 1px var(--tr-primary);
}

.tr-posting-packages ul.job_packages li.job-package input[type="radio"] {
	grid-column: 1;
	grid-row: 1 / span 3;
	margin-top: 0.15rem;
	accent-color: var(--tr-primary);
}

.tr-posting-packages ul.job_packages li.job-package {
	cursor: pointer;
}

.tr-posting-packages ul.job_packages li.job-package label {
	grid-column: 2;
	grid-row: 1;
	margin: 0;
	color: var(--tr-text);
	font-size: 1rem;
	font-weight: 800;
	line-height: 1.3;
}

.tr-posting-packages ul.job_packages li.job-package label::after {
	content: '';
	position: absolute;
	inset: 0;
	border-radius: 14px;
}

.tr-posting-packages ul.job_packages li.job-package input[type="radio"] {
	position: relative;
	z-index: 1;
}

.tr-posting-packages ul.job_packages li.job-package > span {
	grid-column: 2;
	grid-row: 2;
	width: auto;
	margin: 0;
	color: var(--tr-primary);
	font-size: 0.9rem;
	font-weight: 700;
	line-height: 1.45;
}

.tr-posting-packages ul.job_packages li.job-package br {
	display: none;
}

.tr-posting-complete {
	max-width: 760px;
	margin-inline: auto;
}

.tr-posting-complete__body {
	display: grid;
	gap: 0.8rem;
}

.tr-posting-complete__title {
	margin: 0;
	font-size: clamp(1.5rem, 2.4vw, 2rem);
	line-height: 1.15;
}

.tr-posting-complete__actions {
	display: flex;
	flex-wrap: wrap;
	gap: 0.65rem;
	margin-top: 0.2rem;
}

@media (max-width: 780px) {
	/* Stack heading above buttons — the auto button column was crushing the
	   heading into many lines at tablet and large-phone widths.
	   The #job_preview selector matches the base rule's (1,1,0) specificity. */
	.tr-posting-preview__header,
	#job_preview .job_listing_preview_title,
	.tr-posting-packages .job_listing_packages_title {
		grid-template-columns: 1fr;
		grid-template-areas: none;
	}

	.tr-posting-preview__actions,
	.tr-posting-complete__actions {
		display: grid;
		grid-template-columns: 1fr;
		justify-content: stretch;
	}

	/* input[type="submit"] doesn't inherit width from its grid cell automatically */
	.tr-posting-preview__actions input[type="submit"],
	.tr-posting-preview__actions button,
	.tr-posting-preview__actions .button {
		width: 100%;
		min-width: 0;
		white-space: normal;
		box-sizing: border-box;
	}
}

@media (max-width: 640px) {
	.tr-posting-preview__summary {
		flex-direction: column;
	}

	.tr-posting-preview__card {
		border-right: 0;
		border-bottom: 1px solid rgba(0, 109, 119, 0.1);
	}

	.tr-posting-preview__card:last-child {
		border-bottom: 0;
	}
}
