/* =========================================================
   Jobs: single job and application surfaces
   ========================================================= */

/* Prevent submit/edit layout from affecting application forms */
.application .job-manager-form fieldset,
.job_application .job-manager-form fieldset {
	display: block;
	grid-template-columns: none;
	border: 0;
	padding: 0;
	margin: 0 0 16px;
}


/* =========================================================
   Job tags
   ========================================================= */

.single_job_listing .job-listing-meta {
	display: flex;
	flex-wrap: wrap;
	gap: 10px;
	list-style: none;
	padding: 0;
	margin: 0 0 24px;
}

.single_job_listing .job-listing-meta li,
ul.job-listing-meta.meta li,
.job_tags {
	background-color: rgba(0, 109, 119, 0.045);
	color: var(--tr-muted);
	background-position-y: center;
	padding: 5px 9px;
	border: 1px solid rgba(0, 109, 119, 0.1);
	border-radius: 8px;
	display: inline-flex;
	align-items: center;
	font-weight: 500;
	margin: 0;
}

.single_job_listing .job-listing-meta li.job-type,
.single_job_listing .job-listing-meta li.salary,
ul.job-listing-meta.meta li.job-type,
ul.job-listing-meta.meta li.salary {
	color: var(--tr-primary);
	background-color: rgba(0, 109, 119, 0.06);
	border-color: rgba(0, 109, 119, 0.13);
}


/* =========================================================
   Job application forms
   ========================================================= */

.application,
.job_application {
	padding: 32px;
	margin-top: 32px;
	margin-bottom: 32px;
}

.application label,
.job_application label {
	display: block;
	width: 100%;
	float: none;
	text-align: left;
	font-weight: 600;
	color: var(--tr-text);
	margin: 0 0 8px;
	line-height: 1.4;
}

.application label small,
.job_application label small {
	font-weight: normal;
	color: var(--tr-muted);
	font-size: 13px;
	margin-left: 4px;
}

.application .field small.description,
.job_application .field small.description {
	display: block;
	margin-top: 8px;
	color: var(--tr-muted);
	font-size: 14px;
	line-height: 1.4;
}

form.apply_with_resume {
	margin-top: 32px;
	padding-top: 32px;
	border-top: 1px dashed var(--tr-border);
}

form.apply_with_resume p {
	margin-bottom: 20px;
}

.application .job-manager-form,
.job_application .job-manager-form,
.application form,
.job_application form {
	background: transparent;
	border: none;
	box-shadow: none;
	padding: 0;
	margin: 0;
}

.application .job-manager-form h2,
.job_application .job-manager-form h2 {
	margin-top: 0;
	margin-bottom: 24px;
	font-size: 20px;
}

.job-alert-link-wrapper,
a.job-alert-link {
	display: inline-block;
	margin-top: 16px;
	font-weight: 600;
	color: var(--tr-primary);
	text-decoration: none;
}

a.job-alert-link:hover,
a.job-alert-link:focus {
	color: var(--tr-primary-hover);
	text-decoration: underline;
}


/* =========================================================
   Breadcrumbs
   ========================================================= */

.tra-breadcrumbs {
	margin: 0 0 0.75rem;
}

.tra-breadcrumbs__list {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	gap: 0;
	list-style: none;
	margin: 0;
	padding: 0;
}

.tra-breadcrumbs__item + .tra-breadcrumbs__item::before {
	content: '›';
	padding: 0 0.35rem;
	color: var(--tr-muted);
	font-size: 0.85rem;
	opacity: 0.6;
}

.tra-breadcrumbs__link {
	font-size: 0.85rem;
	font-weight: 500;
	color: var(--tr-muted);
	text-decoration: none;
	transition: color 0.15s ease;
}

.tra-breadcrumbs__link:hover,
.tra-breadcrumbs__link:focus {
	color: var(--tr-primary);
	text-decoration: underline;
}

.tra-breadcrumbs__item--current span {
	font-size: 0.85rem;
	font-weight: 600;
	color: var(--tr-text);
}

/* On archive pages breadcrumbs sit inside the constrained group */
.tra-archive-intro ~ * .tra-breadcrumbs,
.alignfull .tra-breadcrumbs {
	margin-bottom: 0.5rem;
}

/* =========================================================
   Taxonomy archive pages (delivery format, categories)
   ========================================================= */

/* Intro description shown below the H1 on delivery format archives */
.tra-archive-intro p {
	max-width: 62ch;
	margin: 0.65rem 0 0;
	font-size: 1.05rem;
	line-height: var(--tr-leading);
	color: var(--tr-muted);
}

/* Add breathing room to the page edges on taxonomy archive pages.
   Mirrors the homepage shell gutter so content does not sit flush
   against the viewport on wide screens. */
body.tax-job_listing_category main > .wp-block-group.alignfull,
body.tax-job_delivery_format main > .wp-block-group.alignfull {
	padding-inline: var(--tr-shell-gutter);
	box-sizing: border-box;
}

/* =========================================================
   Single job listing
   ========================================================= */

.single_job_listing {
	max-width: var(--tr-max-content);
	margin: 0 auto;
	padding: 0 0 2rem;
}

/* Meta pills */
.single_job_listing .job-listing-meta {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	gap: 0.45rem;
	margin: 0 0 1rem;
	padding: 0;
	list-style: none;
}

.single_job_listing .job-listing-meta li,
ul.job-listing-meta.meta li {
	background-position-y: calc(50% - 1px);
	gap: 0.3rem;
	padding: 0.28rem 0.62rem;
	font-size: 0.84rem;
	font-weight: 500;
	border-radius: 8px;
	line-height: 1.4;
}

.single_job_listing .job-listing-meta li::before,
ul.job-listing-meta.meta li::before {
	position: relative;
	top: -1px;
}

.single_job_listing .job-listing-meta li label,
ul.job-listing-meta.meta li label {
	margin: 0 0.2rem 0 0;
	color: var(--tr-muted);
	font-weight: 600;
}

/* Job description typography */
.single_job_listing .job_description {
	font-size: 1rem;
	line-height: 1.75;
	color: var(--tr-text);
	margin-top: 0;
}

.single_job_listing .job_description p {
	margin: 0 0 0.85rem;
}

.single_job_listing .job_description p:last-child {
	margin-bottom: 0;
}

.single_job_listing .job_description h2,
.single_job_listing .job_description h3,
.single_job_listing .job_description h4 {
	margin: 1.35rem 0 0.45rem;
	line-height: 1.3;
	letter-spacing: -0.01em;
	color: var(--tr-text);
}

.single_job_listing .job_description h2 { font-size: 1.2rem; }
.single_job_listing .job_description h3 { font-size: 1.05rem; }
.single_job_listing .job_description h4 { font-size: 0.975rem; }

.single_job_listing .job_description ul,
.single_job_listing .job_description ol {
	padding-left: 1.4rem;
	margin: 0 0 0.85rem;
}

.single_job_listing .job_description li {
	margin: 0 0 0.3rem;
	line-height: var(--tr-leading);
}

.single_job_listing .job_description a {
	color: var(--tr-primary);
	text-decoration: underline;
}

/* Job tags (delivery format pills) */
.single_job_listing .job_tags {
	display: flex;
	flex-wrap: wrap;
	gap: 0.35rem;
	margin: 0.75rem 0 0;
	padding: 0;
	list-style: none;
}

/* Candidate requirements section */
.single_job_listing .tra-job-requirements {
	margin: 1.25rem 0 0;
	padding: 1.1rem 1.15rem;
	border: 1px solid rgba(0, 109, 119, 0.14);
	border-radius: 14px;
	background: #fff;
	box-shadow: 0 2px 8px rgba(0, 43, 48, 0.04);
}

.single_job_listing .tra-job-requirements__eyebrow {
	margin: 0 0 0.3rem;
	color: var(--tr-primary);
	font-size: 0.72rem;
	font-weight: 800;
	letter-spacing: 0.08em;
	text-transform: uppercase;
}

.single_job_listing .tra-job-requirements h2 {
	margin: 0 0 0.2rem;
	font-size: 1.05rem;
	line-height: 1.3;
	letter-spacing: -0.01em;
}

.single_job_listing .tra-job-requirements__intro {
	margin: 0 0 0.75rem;
	color: var(--tr-muted);
	font-size: 0.9rem;
	line-height: 1.5;
}

.single_job_listing .tra-job-requirements__list {
	display: grid;
	gap: 0.35rem;
	margin: 0 0 0.65rem;
	padding: 0 0 0 1.1rem;
	color: var(--tr-text);
	list-style: none;
}

.single_job_listing .tra-job-requirements__list li {
	position: relative;
	padding: 0;
	color: var(--tr-text);
	font-size: 0.875rem;
	font-weight: 700;
	line-height: 1.4;
}

.single_job_listing .tra-job-requirements__list li::before {
	position: absolute;
	top: 0.55em;
	left: -0.9rem;
	width: 0.32rem;
	height: 0.32rem;
	border-radius: 50%;
	background: var(--tr-primary);
	content: "";
}

.single_job_listing .tra-job-requirements__facts {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
	gap: 0.55rem 0.85rem;
	margin: 0 0 0.75rem;
}

.single_job_listing .tra-job-requirements__fact {
	margin: 0;
	padding: 0.55rem 0.65rem;
	border: 1px solid rgba(0, 109, 119, 0.12);
	border-radius: 10px;
	background: rgba(0, 109, 119, 0.02);
}

.single_job_listing .tra-job-requirements__fact dt {
	margin: 0 0 0.2rem;
	font-size: var(--tr-text-xs);
	font-weight: 700;
	letter-spacing: 0.03em;
	text-transform: uppercase;
	color: var(--tr-muted);
}

.single_job_listing .tra-job-requirements__fact dd {
	margin: 0;
	font-size: 0.93rem;
	font-weight: 700;
	line-height: 1.35;
	color: var(--tr-text);
}

.single_job_listing .tra-job-requirements__note {
	margin: 0;
	color: var(--tr-muted);
	font-size: 0.83rem;
	line-height: 1.5;
}

/* Expired job notice */
.tra-expired-job-notice {
	margin: 0 0 1rem;
	padding: 14px 18px;
	border-radius: var(--tr-radius-md);
	border-left: 4px solid #D97706;
	background: #FFFBEB;
	box-shadow: var(--tr-shadow-sm);
}

.tra-expired-job-notice p {
	margin: 0;
	color: #78350F;
	font-size: 0.9rem;
	line-height: 1.5;
}

/* Similar jobs section (shown below expired job content) */
.tra-similar-jobs {
	margin: 1.25rem 0 0;
	padding: 1.1rem 1.15rem;
	border: 1px solid rgba(0, 109, 119, 0.14);
	border-radius: 14px;
	background: #fff;
	box-shadow: 0 2px 8px rgba(0, 43, 48, 0.04);
}

.tra-similar-jobs__heading {
	margin: 0 0 0.75rem;
	font-size: 1.05rem;
	font-weight: 700;
	line-height: 1.3;
	letter-spacing: -0.01em;
	color: var(--tr-text);
}

.tra-similar-jobs__list {
	margin: 0;
	padding: 0;
	list-style: none;
	display: flex;
	flex-direction: column;
	gap: 0.6rem;
}

.tra-similar-jobs__item {
	display: flex;
	align-items: baseline;
	gap: 0.5rem;
	flex-wrap: wrap;
}

.tra-similar-jobs__link {
	font-size: 0.95rem;
	font-weight: 600;
	color: var(--tr-primary);
	text-decoration: none;
	transition: color 0.15s ease;
}

.tra-similar-jobs__link:hover,
.tra-similar-jobs__link:focus {
	color: var(--tr-primary-hover);
	text-decoration: underline;
}

.tra-similar-jobs__location {
	font-size: 0.8rem;
	color: var(--tr-muted);
}

/* Sidebar eyebrow label */
.tra-job-sidebar__label {
	display: block;
	width: 100%;
	margin: 0 0 0.45rem;
	font-size: 0.72rem;
	font-weight: 800;
	letter-spacing: 0.07em;
	text-transform: uppercase;
	color: var(--tr-muted);
	overflow: hidden;
	text-overflow: ellipsis;
	white-space: nowrap;
}

/* Sidebar: agency card */
.single_job_listing .company.tra-agency-card,
.company.tra-agency-card {
	display: grid;
	grid-template-columns: minmax(0, 1fr);
	gap: 0.85rem;
	align-items: start;
	box-sizing: border-box;
	padding: 1.2rem;
	border: 1px solid rgba(0, 109, 119, 0.16);
	border-radius: 14px;
	background: linear-gradient(180deg, #FFFFFF 0%, #FBFEFE 100%);
	box-shadow: 0 8px 22px rgba(12, 31, 45, 0.07);
}

.single_job_listing .company.tra-agency-card .tra-agency-card__image,
.company.tra-agency-card .tra-agency-card__image {
	display: flex !important;
	align-items: center !important;
	justify-content: center !important;
	inline-size: 100% !important;
	min-inline-size: 0 !important;
	max-inline-size: 100% !important;
	block-size: 96px !important;
	min-block-size: 96px !important;
	max-block-size: 96px !important;
	box-sizing: border-box !important;
	overflow: hidden !important;
	padding: 0.65rem !important;
	border: 1px solid rgba(12, 122, 128, 0.16) !important;
	border-radius: 12px !important;
	background: #fff;
	box-shadow: 0 4px 12px rgba(12, 31, 45, 0.05);
}

.single_job_listing .company.tra-agency-card .tra-agency-card__image[style*="--tra-agency-logo-url"]::before,
.company.tra-agency-card .tra-agency-card__image[style*="--tra-agency-logo-url"]::before {
	content: "";
	display: block;
	inline-size: 100%;
	block-size: 100%;
	background-image: var(--tra-agency-logo-url);
	background-position: center;
	background-repeat: no-repeat;
	background-size: auto 118%;
}

.single_job_listing .company.tra-agency-card .tra-agency-card__logo,
.single_job_listing .company.tra-agency-card img.tra-agency-card__logo.wp-post-image,
.company.tra-agency-card .tra-agency-card__logo.wp-post-image,
.company.tra-agency-card .tra-agency-card__image img {
	display: block !important;
	inline-size: 100% !important;
	width: 100% !important;
	min-width: 0 !important;
	max-inline-size: 100% !important;
	max-width: 100% !important;
	block-size: 100% !important;
	height: 100% !important;
	min-height: 0 !important;
	max-block-size: 100% !important;
	max-height: 100% !important;
	object-fit: contain !important;
	border: 0 !important;
	border-radius: 0 !important;
	background: transparent !important;
}

.single_job_listing .company.tra-agency-card .tra-agency-card__content,
.company.tra-agency-card .tra-agency-card__content {
	display: grid;
	grid-column: 1;
	grid-template-columns: minmax(0, 1fr);
	align-content: start;
	min-width: 0;
}

.single_job_listing .company.tra-agency-card .tra-agency-card__name,
.company.tra-agency-card .tra-agency-card__name {
	display: grid;
	gap: 0.25rem;
	margin: 0;
	font-size: 1.08rem;
	line-height: 1.28;
	color: var(--tr-text);
}

.single_job_listing .company.tra-agency-card .tra-agency-card__locations,
.single_job_listing .company.tra-agency-card .tra-agency-card__specialisms,
.company.tra-agency-card .tra-agency-card__locations,
.company.tra-agency-card .tra-agency-card__specialisms {
	margin: 0.5rem 0 0;
	font-size: 0.86rem;
	color: var(--tr-muted);
	line-height: 1.4;
}

.single_job_listing .company.tra-agency-card .tra-agency-card__specialisms strong,
.company.tra-agency-card .tra-agency-card__specialisms strong {
	color: var(--tr-text);
	font-weight: 700;
}

.single_job_listing .company.tra-agency-card .tra-agency-card__summary,
.company.tra-agency-card .tra-agency-card__summary {
	grid-column: 1 / -1;
	margin: 0.75rem 0 0;
	font-size: 0.9rem;
	line-height: 1.58;
	color: var(--tr-muted);
}

.single_job_listing .company.tra-agency-card .tra-agency-card__actions,
.company.tra-agency-card .tra-agency-card__actions {
	grid-column: 1 / -1;
	display: grid;
	gap: 0.6rem;
	margin: 1rem 0 0;
}

.single_job_listing .company.tra-agency-card p:last-child,
.company.tra-agency-card p:last-child {
	margin-bottom: 0;
}

.single_job_listing .company.tra-agency-card .tra-agency-card__button,
.company.tra-agency-card .tra-agency-card__button {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 100%;
	box-sizing: border-box;
	min-height: 42px;
	padding: 0.55rem 0.95rem;
	border: 1px solid rgba(0, 109, 119, 0.28);
	border-radius: 10px;
	font-size: 0.875rem;
	font-weight: 700;
	text-decoration: none;
	color: var(--tr-primary);
	background: rgba(0, 109, 119, 0.04);
	transition: background 0.16s ease, border-color 0.16s ease, transform 0.16s ease;
}

.single_job_listing .company.tra-agency-card .tra-agency-card__button--website,
.company.tra-agency-card .tra-agency-card__button--website {
	color: #FFFFFF;
	background: var(--tr-primary);
	border-color: var(--tr-primary);
	box-shadow: 0 8px 16px rgba(0, 109, 119, 0.14);
}

.single_job_listing .company.tra-agency-card .tra-agency-card__button:hover,
.single_job_listing .company.tra-agency-card .tra-agency-card__button:focus,
.company.tra-agency-card .tra-agency-card__button:hover,
.company.tra-agency-card .tra-agency-card__button:focus {
	background: rgba(0, 109, 119, 0.06);
	border-color: var(--tr-primary);
	transform: translateY(-1px);
}

.single_job_listing .company.tra-agency-card .tra-agency-card__button--website:hover,
.single_job_listing .company.tra-agency-card .tra-agency-card__button--website:focus,
.company.tra-agency-card .tra-agency-card__button--website:hover,
.company.tra-agency-card .tra-agency-card__button--website:focus {
	color: #FFFFFF;
	background: var(--tr-primary-hover);
	border-color: var(--tr-primary-hover);
}

/* Sidebar: apply wrapper */
.single_job_listing .tr-job-apply,
.single_job_listing .tra-external-application-wrapper {
	padding: 1.1rem 1.15rem;
	border-radius: 14px;
	border: 1px solid rgba(0, 109, 119, 0.14);
	background: #fff;
	box-shadow: 0 2px 8px rgba(0, 43, 48, 0.05);
}

.single_job_listing .tr-job-apply__button,
.single_job_listing .tra-external-application-wrapper__button {
	display: flex;
	width: 100%;
	justify-content: center;
	min-height: 48px;
	padding: 0.68rem 1.2rem;
	border-radius: 10px;
	background-color: var(--tr-primary);
	color: #fff;
	border-color: var(--tr-primary);
	font-weight: 700;
	font-size: 0.975rem;
	font-family: var(--tr-font-sans);
	letter-spacing: 0;
	transition: background-color 0.16s ease, transform 0.12s ease;
}

.single_job_listing .tr-job-apply__button:hover,
.single_job_listing .tr-job-apply__button:focus,
.single_job_listing .tra-external-application-wrapper__button:hover,
.single_job_listing .tra-external-application-wrapper__button:focus {
	background-color: var(--tr-primary-hover);
	border-color: var(--tr-primary-hover);
	color: #fff;
	transform: translateY(-1px);
}

.single_job_listing .tr-job-apply__note,
.single_job_listing .tra-external-application-wrapper__note {
	margin: 0.6rem 0 0;
	font-size: 0.83rem;
	line-height: 1.5;
	color: var(--tr-muted);
	text-align: center;
}

/* Alert link: subtle text-style link */
.single_job_listing .tr-job-alert,
.single_job_listing .job-manager-single-alert-link {
	margin: 0;
	text-align: center;
}

.single_job_listing .tr-job-alert__link,
.single_job_listing .job-manager-single-alert-link a {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	padding: 0.42rem 0.65rem;
	border-radius: 8px;
	font-size: 0.85rem;
	font-weight: 600;
	color: var(--tr-muted);
	text-decoration: none;
	transition: color 0.15s ease, background 0.15s ease;
	border: none;
}

.single_job_listing .tr-job-alert__link:hover,
.single_job_listing .tr-job-alert__link:focus,
.single_job_listing .job-manager-single-alert-link a:hover,
.single_job_listing .job-manager-single-alert-link a:focus {
	color: var(--tr-primary);
	background: rgba(0, 109, 119, 0.05);
}

/* Bookmarking intentionally disabled */
.single_job_listing .wp-job-manager-bookmarks-form,
.single_job_listing .job-manager-bookmark-wrapper,
.single_job_listing .job-manager-bookmark-form,
.submit-bookmark-button {
	display: none !important;
}

/* WP Job Manager default application box — replaced by our apply button */
.application,
.job_application {
	display: none !important;
}

/* Two-column layout (>=768px) */
@media (min-width: 768px) {
	.single_job_listing {
		display: grid;
		grid-template-columns: 1fr 300px;
		column-gap: 2.5rem;
		align-items: start;
	}

	/* Breadcrumbs: row 1, full width. Collapses to zero height if absent. */
	.single_job_listing > .tra-breadcrumbs {
		grid-column: 1 / -1;
		grid-row: 1;
		margin-bottom: 0.25rem;
	}

	/* Expired notice: row 2, full width. Collapses to zero height on live jobs. */
	.single_job_listing > .tra-expired-job-notice {
		grid-column: 1 / -1;
		grid-row: 2;
	}

	/* Meta pills: row 3, full width */
	.single_job_listing > .job-listing-meta {
		grid-column: 1 / -1;
		grid-row: 3;
	}

	/* Left column */
	.single_job_listing > .job_description {
		grid-column: 1;
		grid-row: 4;
		margin-top: 0.5rem;
	}

	.single_job_listing > .tra-job-requirements {
		grid-column: 1;
		grid-row: 5;
	}

	/* Similar jobs: row 6, left column. Collapses to zero height on live jobs. */
	.single_job_listing > .tra-similar-jobs {
		grid-column: 1;
		grid-row: 6;
	}

	/* Right sidebar: sticky as a single unit, spans rows 4–7 */
	.single_job_listing > .tra-job-sidebar {
		grid-column: 2;
		grid-row: 4 / 7;
		align-self: start;
		position: sticky;
		top: 1.5rem;
		display: flex;
		flex-direction: column;
		gap: 0.75rem;
		min-width: 0;
		width: 100%;
	}

	/* Alert link below sidebar */
	.single_job_listing > .tr-job-alert,
	.single_job_listing > .job-manager-single-alert-link {
		grid-column: 2;
		grid-row: 7;
		margin-top: 0.25rem;
	}

	.single_job_listing .tr-job-alert__link,
	.single_job_listing .job-manager-single-alert-link a {
		display: flex;
		width: 100%;
		box-sizing: border-box;
	}
}

/* Mobile adjustments (<=640px) */
@media (max-width: 640px) {
	.single_job_listing .company.tra-agency-card,
		.single_job_listing .tra-job-requirements,
		.single_job_listing .tra-similar-jobs,
		.single_job_listing .tr-job-apply,
		.single_job_listing .tra-external-application-wrapper {
		padding: 0.9rem 1rem;
	}

	.single_job_listing .tr-job-apply__button,
	.single_job_listing .tra-external-application-wrapper__button {
		font-size: 1rem;
	}
}


/* =========================================================
   Application mobile polish
   ========================================================= */

@media (max-width: 640px) {
    .tr-check-email,
    .application,
    .job_application {
        padding: 20px;
    }

    .application input[type="submit"],
    .application button,
    .job_application input[type="submit"],
    .job_application button {
        width: 100%;
        min-width: 0;
    }
}


/* =========================================================
   Candidate apply gate
   ========================================================= */

/* Candidate apply gate */
.tra-apply-gate-page {
	max-width: var(--tr-max-form);
	margin: 0 auto;
	padding: clamp(1rem, 3vw, 2rem) 0 2.5rem;
}

.tra-apply-gate {
	max-width: 920px;
	margin: 0 auto;
}

.tra-apply-gate__card {
	padding: clamp(1rem, 2.6vw, 1.6rem);
	border: 1px solid rgba(0, 109, 119, 0.14);
	border-radius: 18px;
	background:
		radial-gradient(circle at top right, rgba(167, 215, 206, 0.16), transparent 34%),
		linear-gradient(180deg, rgba(255, 255, 255, 0.98) 0%, rgba(246, 251, 252, 0.96) 100%);
	box-shadow: 0 14px 32px rgba(12, 31, 45, 0.09);
}

.tra-apply-gate__eyebrow {
	margin: 0 0 0.45rem;
	color: var(--tr-primary);
	font-size: var(--tr-text-xs);
	font-weight: 800;
	letter-spacing: 0.08em;
	text-transform: uppercase;
}

.tra-apply-gate h1 {
	margin: 0 0 0.55rem;
	font-size: clamp(2rem, 3vw, 2.75rem);
	line-height: 1.12;
}

.tra-apply-gate__intro {
	max-width: 68ch;
	margin: 0 0 1rem;
	color: var(--tr-muted);
	font-size: 1.04rem;
	line-height: 1.55;
}

.tra-apply-gate__actions {
	display: flex;
	flex-wrap: wrap;
	gap: 0.7rem;
	margin-top: 1rem;
}

.tra-apply-gate--requirements-blocked .tra-apply-gate__card {
	border-color: rgba(192, 93, 47, 0.24);
	background:
		radial-gradient(circle at top right, rgba(244, 187, 128, 0.18), transparent 34%),
		linear-gradient(180deg, rgba(255, 255, 255, 0.98) 0%, rgba(255, 250, 244, 0.96) 100%);
}

.tra-apply-gate__requirements-list {
	display: grid;
	gap: 0.55rem;
	margin: 1rem 0;
	padding: 0;
	list-style: none;
}

.tra-apply-gate__requirements-list li {
	position: relative;
	padding: 0.72rem 0.9rem 0.72rem 2.25rem;
	border: 1px solid rgba(192, 93, 47, 0.18);
	border-radius: 14px;
	background: rgba(255, 255, 255, 0.76);
	color: var(--tr-text);
	font-weight: 700;
	line-height: 1.45;
}

.tra-apply-gate__requirements-list li::before {
	content: "!";
	position: absolute;
	top: 0.75rem;
	left: 0.85rem;
	display: inline-grid;
	place-items: center;
	width: 1rem;
	height: 1rem;
	border-radius: 999px;
	background: rgba(192, 93, 47, 0.14);
	color: #9B3F1D;
	font-size: 0.72rem;
	font-weight: 900;
	line-height: 1;
}

.tra-apply-gate__form {
	display: grid;
	gap: 0.95rem;
	margin-top: 1.1rem;
}

.tra-apply-gate__form > .tr-journey-action {
	display: inline-flex;
	justify-self: start;
	width: auto;
	max-width: max-content;
}

.tra-apply-gate__form p {
	margin: 0;
}

.tra-apply-gate__field {
	margin: 0;
}

.tra-apply-gate__grid {
	display: grid;
	grid-template-columns: repeat(2, minmax(0, 1fr));
	gap: 0.9rem 1rem;
}

.tra-apply-gate__field-label {
	margin: 0 0 0.4rem;
	font-weight: 800;
	color: var(--tr-text);
}

.tra-apply-gate__form label:not(.tra-apply-gate__checkbox):not(.tra-choice-pill) {
	display: block;
	margin: 0 0 0.38rem;
	font-weight: 800;
	color: var(--tr-text);
}

.tra-apply-gate__form :is(input[type="text"], input[type="email"], input[type="number"], input[type="date"], textarea, select) {
	width: 100%;
	max-width: 100%;
	box-sizing: border-box;
	padding: 12px 14px;
	border: 1px solid rgba(0, 109, 119, 0.2);
	border-radius: 12px;
	background: #FFFFFF;
	color: var(--tr-text);
	font: inherit;
}

.tra-apply-gate__form textarea {
	min-height: 140px;
	resize: vertical;
}

.tra-apply-gate__form select[multiple] {
	min-height: 190px;
}

.tra-apply-gate__form :is(input, textarea, select):focus {
	border-color: var(--tr-primary);
	box-shadow: var(--tr-focus);
	outline: none;
}

.tra-apply-gate__form small {
	display: block;
	margin-top: 0.35rem;
	color: var(--tr-muted);
	line-height: 1.45;
}

.tra-checkbox-grid {
	display: grid;
	gap: 0.8rem;
	margin-top: 0.55rem;
}

.tra-choice-group {
	display: grid;
	gap: 0.4rem;
}

.tra-choice-group__title {
	margin: 0;
	color: var(--tr-primary);
	font-size: 0.75rem;
	font-weight: 800;
	letter-spacing: 0.07em;
	text-transform: uppercase;
}

.tra-choice-group__options {
	display: flex;
	flex-wrap: wrap;
	gap: 0.6rem;
	align-items: stretch;
}

.tra-choice-pill {
	position: relative;
	display: flex;
	align-items: center;
	gap: 0.55rem;
	flex: 1 1 210px;
	min-height: 44px;
	inline-size: auto;
	max-inline-size: 100%;
	min-inline-size: 170px;
	padding: 0.56rem 0.75rem;
	border: 1px solid rgba(0, 109, 119, 0.18);
	border-radius: 12px;
	background: rgba(255, 255, 255, 0.93);
	box-shadow: 0 2px 8px rgba(7, 28, 42, 0.04);
	cursor: pointer;
	font-size: 0.94rem;
	font-weight: 700;
	line-height: 1.25;
	box-sizing: border-box;
	overflow: visible;
	transition: border-color 150ms ease, background-color 150ms ease, box-shadow 150ms ease, color 150ms ease, transform 150ms ease;
	margin: 0;
}

.tra-choice-pill input {
	position: absolute;
	inline-size: 1px;
	block-size: 1px;
	margin: 0;
	padding: 0;
	border: 0;
	overflow: hidden;
	white-space: nowrap;
	clip-path: inset(50%);
}

.tra-choice-pill__indicator {
	position: relative;
	display: inline-block;
	flex: 0 0 18px;
	inline-size: 18px;
	block-size: 18px;
	border: 1.5px solid rgba(0, 109, 119, 0.48);
	border-radius: 4px;
	background: #FFFFFF;
	transition: border-color 150ms ease, background-color 150ms ease, box-shadow 150ms ease;
}

.tra-choice-pill__indicator::after {
	content: "\2713";
	position: absolute;
	inset: 0;
	display: grid;
	place-items: center;
	color: #FFFFFF;
	font-size: 0.72rem;
	font-weight: 800;
	opacity: 0;
	transform: scale(0.75);
	transition: opacity 150ms ease, transform 150ms ease;
}

.tra-choice-pill__label {
	display: inline-block;
	min-width: 0;
	overflow-wrap: anywhere;
	white-space: normal;
	letter-spacing: normal;
	word-spacing: 0.04em;
}

.tra-choice-pill:hover,
.tra-choice-pill:focus-within {
	border-color: rgba(0, 109, 119, 0.36);
	box-shadow: 0 10px 22px rgba(7, 28, 42, 0.08);
	transform: translateY(-1px);
}

.tra-choice-pill:has(input[type="checkbox"]:checked) {
	border-color: rgba(0, 109, 119, 0.52);
	background: linear-gradient(140deg, rgba(0, 109, 119, 0.18), rgba(255, 255, 255, 0.95));
	color: var(--tr-primary-hover);
	box-shadow: 0 12px 24px rgba(0, 109, 119, 0.12);
}

.tra-choice-pill:has(input[type="checkbox"]:checked) .tra-choice-pill__indicator {
	border-color: var(--tr-primary);
	background: var(--tr-primary);
	box-shadow: inset 0 0 0 1px rgba(255, 255, 255, 0.22);
}

.tra-choice-pill:has(input[type="checkbox"]:checked) .tra-choice-pill__indicator::after {
	opacity: 1;
	transform: scale(1);
}

.tra-choice-pill input:focus-visible + .tra-choice-pill__indicator {
	outline: 2px solid rgba(0, 109, 119, 0.28);
	outline-offset: 2px;
}

.tra-degree-repeater {
	display: grid;
	gap: 0.75rem;
}

.tra-degree-repeater__row {
	display: grid;
	gap: 0.75rem;
	padding: 0.8rem;
	border: 1px solid rgba(0, 109, 119, 0.12);
	border-radius: 12px;
	background: rgba(255, 255, 255, 0.72);
}

.tra-degree-repeater__row[hidden] {
	display: none !important;
}

/* Reduce the block theme's default top padding on single job listing pages */
body.single-job_listing .entry-content.wp-block-post-content {
	padding-top: clamp(1rem, 2.5vw, 1.75rem);
}

.tra-degree-repeater__add {
	justify-self: start;
	min-height: 40px;
	padding: 0.5rem 0.8rem;
	border: 1px solid rgba(0, 109, 119, 0.26);
	border-radius: 10px;
	background: rgba(0, 109, 119, 0.08);
	color: var(--tr-primary);
	font-weight: 800;
	cursor: pointer;
}

.tra-degree-repeater__add:hover,
.tra-degree-repeater__add:focus {
	background: rgba(0, 109, 119, 0.14);
	color: var(--tr-primary-hover);
}

.tra-apply-gate__fieldset {
	display: grid;
	gap: 0.95rem;
	margin: 0;
	padding: 1rem;
	border: 1px solid rgba(0, 109, 119, 0.14);
	border-radius: 14px;
	background: rgba(255, 255, 255, 0.72);
}

.tra-apply-gate__fieldset legend {
	margin-bottom: 0.1rem;
	padding: 0 0.35rem;
	color: var(--tr-primary);
	font-weight: 800;
	letter-spacing: 0.04em;
	text-transform: uppercase;
}

.tra-apply-gate__checkbox {
	display: flex;
	align-items: flex-start;
	gap: 0.55rem;
	margin-top: 0.8rem;
	color: var(--tr-text);
	font-weight: 700;
	line-height: 1.45;
}

.tra-apply-gate__checkbox input {
	flex: 0 0 auto;
	margin-top: 0.22rem;
	accent-color: var(--tr-primary);
}

.tra-apply-gate .tra-notice {
	margin: 1rem 0;
}

.tra-apply-gate--redirecting .tra-apply-gate__card {
	text-align: center;
}

.tra-apply-gate--redirecting .tra-apply-gate__intro {
	margin-left: auto;
	margin-right: auto;
}


/* =========================================================
   Candidate apply gate mobile polish
   ========================================================= */

@media (max-width: 700px) {
	.tra-apply-gate-page {
		padding-inline: 1rem;
	}

	.tra-apply-gate__grid {
		grid-template-columns: 1fr;
	}

	.tra-apply-gate .tr-journey-action {
		width: 100%;
		justify-content: center;
	}

	.tra-apply-gate__form > .tr-journey-action {
		width: 100%;
		max-width: 100%;
		justify-self: stretch;
	}

	.tra-checkbox-grid {
		gap: 0.6rem;
	}

	.tra-choice-group__options {
		gap: 0.36rem;
	}

	.tra-choice-pill {
		flex-basis: 100%;
		min-inline-size: 0;
		width: 100%;
		justify-content: flex-start;
		border-radius: 12px;
	}
}
