/**
 * Yoko Custom — WP Job Manager front-end theming.
 *
 * @package Yoko_Custom
 */

:root {
	--yoko-jm-radius-pill: 999px;
}

.job-manager-form .field input.input-text,
.job-manager-form .field input.input-autocomplete,
.job-manager-form .field input[type="text"],
.job-manager-form .field input[type="url"],
.job-manager-form .field input[type="email"],
.job-manager-form .field textarea.input-text,
.job-manager-form .field select,
.job_filters input[type="text"],
.job_filters input[type="search"],
.job_filters select {
	background: var(--wp--preset--color--core, #fff);
	color: var(--wp--preset--color--core-text, #494f64);
	font-family: var(--wp--preset--font-family--primary, inherit);
	font-size: var(--wp--preset--font-size--body-default, 1rem);
	border: 1px solid var(--wp--preset--color--core-border, #dcdcde);
	border-radius: var(--wp--preset--border-radius--small, 6px);
	padding: var(--wp--preset--spacing--20, 8px) var(--wp--preset--spacing--30, 12px);
}

.job-manager-form .field input.input-text:focus,
.job-manager-form .field input.input-autocomplete:focus,
.job-manager-form .field input[type="text"]:focus,
.job-manager-form .field input[type="url"]:focus,
.job-manager-form .field input[type="email"]:focus,
.job-manager-form .field textarea.input-text:focus,
.job-manager-form .field select:focus,
.job_filters input:focus,
.job_filters select:focus {
	border-color: var(--wp--preset--color--brand, #2345c1);
	outline: 2px solid var(--wp--preset--color--focus, #2345c1);
	outline-offset: 1px;
}

.job-manager-form .field input.input-autocomplete,
.job-manager-form .field input[type="text"],
.job-manager-form .field input[type="url"],
.job-manager-form .field input[type="email"] {
	width: 100%;
	box-sizing: border-box;
}

.job-manager-form fieldset label,
.job_filters label {
	color: var(--wp--preset--color--core-heading, #101a46);
	font-family: var(--wp--preset--font-family--primary, inherit);
}

.job-manager-form label small {
	color: var(--wp--preset--color--core-text, #6b7280);
}

.job-manager-form .required-field .required {
	color: #d63638;
}

.job-manager-form small.description {
	color: var(--wp--preset--color--core-text, #6b7280);
}

.job-manager-form .button,
.job_filters .search_submit input[type="submit"],
.single_job_listing .application_button.button,
.account-sign-in a.button,
#job_preview_submit_button.button {
	background: var(--wp--preset--color--brand, #2345c1);
	color: var(--wp--preset--color--core, #fff);
	font-family: var(--wp--preset--font-family--primary, inherit);
	font-size: var(--wp--preset--font-size--body-default, 1rem);
	border: 1px solid var(--wp--preset--color--brand, #2345c1);
	border-radius: var(--yoko-jm-radius-pill);
	padding: var(--wp--preset--spacing--20, 8px) var(--wp--preset--spacing--40, 24px);
	text-decoration: none;
}

.job-manager-form .button:hover,
.job-manager-form .button:focus,
.job_filters .search_submit input[type="submit"]:hover,
.job_filters .search_submit input[type="submit"]:focus,
.single_job_listing .application_button.button:hover,
.single_job_listing .application_button.button:focus,
.account-sign-in a.button:hover,
.account-sign-in a.button:focus,
#job_preview_submit_button.button:hover,
#job_preview_submit_button.button:focus {
	background: var(--wp--preset--color--contrast, #101a46);
	border-color: var(--wp--preset--color--contrast, #101a46);
	text-decoration: none;
}

.job-manager-form .button.secondary,
.job-manager-form .save_draft {
	background: var(--wp--preset--color--core-tint, #f3f4f7);
	color: var(--wp--preset--color--core-heading, #101a46);
	border: 1px solid var(--wp--preset--color--core-border, #dcdcde);
}

/* Job listing rows — qualified to beat WPJM's job-listings.css (0,3,4) without !important. */
ul.job_listings li.job_listing {
	border-bottom: 1px solid var(--wp--preset--color--core-border, #e0e0e0);
	padding: var(--wp--preset--spacing--30, 16px) 0;
}

ul.job_listings {
	border-top: 0;
}

ul.job_listings li.job_listing:first-child {
	border-top: 0;
}

ul.job_listings li.job_listing:last-child {
	border-bottom: 0;
}

ul.job_listings li.job_listing a,
ul.job_listings li.job_listing a:hover,
ul.job_listings li.job_listing a:focus,
ul.job_listings li.job_listing.job_position_featured a,
ul.job_listings li.job_listing.job_position_featured a:hover,
ul.job_listings li.job_listing.job_position_featured a:focus {
	background: transparent;
}

ul.job_listings li.job_listing.job_position_featured {
	background: #fefee5;
}

ul.job_listings li.job_listing a.jm-row {
	display: grid;
	grid-template-columns: minmax(0, 1fr) auto;
	grid-template-rows: auto auto;
	column-gap: var(--wp--preset--spacing--30, 16px);
	row-gap: 4px;
	align-items: center;
	overflow: visible;
}

ul.job_listings li.job_listing a.jm-row--no-logo {
	grid-template-columns: minmax(0, 1fr);
}

ul.job_listings li.job_listing a div.position {
	grid-column: 1;
	grid-row: 1;
	float: none;
	width: auto;
	padding: 0;
}

ul.job_listings li.job_listing a div.position h3 {
	margin: 0;
	padding: 0;
	font-size: var(--wp--preset--font-size--body-default, 1.125rem);
	font-weight: 700;
	line-height: 1.3;
	color: var(--wp--preset--color--core-heading, #101a46);
	font-family: var(--wp--preset--font-family--primary, inherit);
}

ul.job_listings li.job_listing a ul.meta {
	grid-column: 1;
	grid-row: 2;
	display: flex;
	flex-direction: column;
	flex-wrap: wrap;
	align-items: flex-start;
	gap: 4px var(--wp--preset--spacing--30, 16px);
	float: none;
	width: auto;
	margin: 0;
	padding: 0;
	list-style: none;
	color: var(--wp--preset--color--core-text, #494f64);
}

ul.job_listings li.job_listing a ul.meta > li {
	display: inline-flex;
	align-items: center;
	gap: 6px;
	float: none;
	width: auto;
	margin: 0;
}

ul.job_listings li.job_listing a ul.meta > li > .dashicons,
ul.job_listings li.job_listing a .position h3 .dashicons {
	font-size: 1em;
	width: 1em;
	height: 1em;
	line-height: 1;
	flex: 0 0 auto;
}

ul.job_listings li.job_listing a ul.meta > li > .dashicons {
	color: var(--wp--preset--color--brand, #2345c1);
}

ul.job_listings li.job_listing a .position h3 .jm-row__star {
	color: #f5b400;
	display: inline-block;
	vertical-align: middle;
	margin-right: 0.25em;
}

ul.job_listings li.job_listing a img.company_logo {
	grid-column: 2;
	grid-row: 1 / span 2;
	position: static;
	visibility: visible;
	width: auto;
	height: auto;
	max-width: 72px;
	max-height: 56px;
	object-fit: contain;
	align-self: center;
}

ul.job_listings .screen-reader-text {
	position: absolute;
	width: 1px;
	height: 1px;
	padding: 0;
	margin: -1px;
	overflow: hidden;
	clip: rect(0, 0, 0, 0);
	white-space: nowrap;
	border: 0;
}

li.job-type {
	display: inline-block;
	width: auto;
	background: var(--wp--preset--color--info, #cddbff);
	color: var(--wp--preset--color--contrast, #101a46);
	border-radius: var(--wp--preset--border-radius--minimal, 4px);
	padding: 2px var(--wp--preset--spacing--20, 8px);
}

li.job-type.full-time {
	background: var(--wp--preset--color--success, #eaf9cc);
}

li.job-type.part-time {
	background: var(--wp--preset--color--warning, #fde6c4);
}

ul.job_listings li.job_listing a .meta li.job-type,
.single_job_listing .meta li.job-type {
	display: inline-flex;
	width: auto;
	float: none;
}

/* Mobile rows: drop the logo and quiet the metadata so the title owns the hierarchy. */
@media (max-width: 767px) {

	ul.job_listings li.job_listing {
		padding: var(--wp--preset--spacing--30, 16px) 0;
	}

	ul.job_listings li.job_listing a.jm-row {
		grid-template-columns: minmax(0, 1fr);
		row-gap: 6px;
	}

	ul.job_listings li.job_listing a img.company_logo {
		display: none;
	}

	ul.job_listings li.job_listing a ul.meta {
		gap: 2px;
		color: var(--wp--preset--color--core-text, #494f64);
		font-size: var(--wp--preset--font-size--utility-meta, 0.875rem);
	}

	ul.job_listings li.job_listing a ul.meta > li.date {
		opacity: 0.7;
	}

	ul.job_listings li.job_listing a ul.meta > li.job-type {
		margin-top: var(--wp--preset--spacing--20, 8px);
	}
}

@media (min-width: 768px) {

	ul.job_listings li.job_listing a ul.meta {
		flex-direction: row;
		align-items: center;
	}

	ul.job_listings li.job_listing a img.company_logo {
		max-width: 120px;
		max-height: 80px;
	}
}

div.showing_jobs {
	display: flex;
	align-items: baseline;
	justify-content: space-between;
	gap: var(--wp--preset--spacing--20, 8px);
	color: var(--wp--preset--color--core-text, #494f64);
	font-size: var(--wp--preset--font-size--utility-meta, 0.875rem);
}

div.showing_jobs a.rss_link {
	color: var(--wp--preset--color--brand, #2345c1);
	text-decoration: none;
	white-space: nowrap;
}

div.showing_jobs a.rss_link:hover,
div.showing_jobs a.rss_link:focus {
	text-decoration: underline;
}

a.load_more_jobs {
	color: var(--wp--preset--color--brand, #2345c1);
}

.single_job_listing ul.job-listing-meta {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	gap: var(--wp--preset--spacing--20, 8px) var(--wp--preset--spacing--30, 16px);
	margin: 0 0 var(--wp--preset--spacing--30, 16px);
	padding: 0;
	list-style: none;
	font-size: var(--wp--preset--font-size--utility-meta, 0.875rem);
}

.single_job_listing ul.job-listing-meta li {
	margin: 0;
	color: var(--wp--preset--color--core-text, #494f64);
}

.single_job_listing ul.job-listing-meta li.date-posted {
	opacity: 0.7;
}

.single_job_listing .job-manager-info {
	background: var(--wp--preset--color--info, #cddbff);
	border-radius: var(--wp--preset--border-radius--small, 8px);
	padding: var(--wp--preset--spacing--30, 16px);
}

/* Logged-out dashboard: center the single combined prompt + Sign in button. */
#job-manager-job-dashboard .account-sign-in {
	display: flex;
	flex-direction: column;
	align-items: center;
	gap: var(--wp--preset--spacing--30, 16px);
	text-align: center;
}

.jm-dashboard-table .jm-dashboard-header {
	background: var(--wp--preset--color--core-tint, #f3f4f7);
}

.jm-dashboard-job {
	border-bottom: 1px solid var(--wp--preset--color--core-border, #e0e0e0);
}

.jm-dashboard a.jm-ui-button,
.jm-dashboard a.jm-dashboard-action.jm-ui-button--link {
	color: var(--wp--preset--color--brand, #2345c1);
}

.jm-dashboard a.jm-ui-button,
.jm-dashboard .jm-ui-button,
.jm-dashboard .jm-ui-button--outline {
	border-radius: var(--yoko-jm-radius-pill);
}

.jm-dashboard .job-dashboard-action-delete {
	color: #d63638;
}

.job-manager-form .select2-container .select2-selection,
.jm-form .select2-container .select2-selection,
.job_filters .select2-container .select2-selection {
	border: 1px solid var(--wp--preset--color--core-border, #dcdcde);
	border-radius: var(--wp--preset--border-radius--small, 6px);
}

.job-manager-form .select2-container .select2-selection--single,
.job_filters .select2-container .select2-selection--single {
	height: auto;
	min-height: 39px;
	display: flex;
	align-items: center;
	padding: 0 24px 0 var(--wp--preset--spacing--30, 12px);
	box-sizing: border-box;
}

.job-manager-form .select2-container .select2-selection--single .select2-selection__rendered,
.job_filters .select2-container .select2-selection--single .select2-selection__rendered {
	padding: 0;
	line-height: normal;
}

.job-manager-form .select2-container .select2-selection--single .select2-selection__arrow,
.job_filters .select2-container .select2-selection--single .select2-selection__arrow {
	top: 0;
	height: 100%;
}

/* WPJM alerts: equal border, kept inside the viewport, with left padding clearing the ::before icon. */
.job-manager-message,
.job-manager-error,
.job-manager-info {
	box-sizing: border-box;
	max-width: 100%;
	/* !important beats WPJM's `margin: 2em` and the theme's flex `margin: 0` on layout children. */
	margin: 0 0 var(--wp--preset--spacing--30, 16px) !important;
	padding: var(--wp--preset--spacing--30, 16px) var(--wp--preset--spacing--40, 24px) var(--wp--preset--spacing--30, 16px) 56px;
	border: 1px solid transparent;
	border-radius: var(--wp--preset--border-radius--small, 6px);
	overflow-wrap: break-word;
}

/* Doubled class matches WPJM's border-top-color hack so the border is one color on all sides. */
.job-manager-message.job-manager-message {
	background: var(--wp--preset--color--success, #eaf9cc);
	border-color: #46b450;
}

.job-manager-error.job-manager-error {
	background: var(--wp--preset--color--failure, #ffdcea);
	border-color: #d63638;
}

.job-manager-info.job-manager-info {
	background: var(--wp--preset--color--info, #cddbff);
	border-color: var(--wp--preset--color--brand, #2345c1);
}

.job-manager-pagination .page-numbers.current {
	background: var(--wp--preset--color--brand, #2345c1);
	color: var(--wp--preset--color--core, #fff);
}

.job_filters .search_jobs {
	display: flex;
	flex-direction: column;
	gap: var(--wp--preset--spacing--20, 8px);
}

.job_filters .search_jobs::before,
.job_filters .search_jobs::after {
	display: none;
}

.job_filters .search_jobs > div:empty {
	display: none;
}

.job_filters .search_jobs > * {
	float: none;
	width: auto;
	margin: 0;
	padding: 0;
}

.job_filters input[type="text"],
.job_filters input[type="search"],
.job_filters select,
.job_filters .search_submit input[type="submit"] {
	width: 100%;
	max-width: 100%;
	box-sizing: border-box;
}

.job_filters .search_jobs > div.search_keywords,
.job_filters .search_jobs > div.search_location,
.job_filters .search_jobs > div.search_categories,
.job_filters .search_jobs > div.search_submit {
	width: auto;
	float: none;
	padding: 0;
}

.job_filters .search_remote_position input[type="checkbox"] {
	margin: 0;
}

@media (min-width: 768px) {

	.job_filters .search_jobs {
		display: grid;
		grid-template-columns: repeat(3, 1fr) auto;
		column-gap: var(--wp--preset--spacing--30, 16px);
		row-gap: var(--wp--preset--spacing--20, 8px);
		align-items: end;
	}

	.job_filters .search_jobs > .search_keywords {
		grid-column: 1;
		grid-row: 1;
	}

	.job_filters .search_jobs > .search_categories {
		grid-column: 2;
		grid-row: 1;
	}

	.job_filters .search_jobs > .search_location {
		grid-column: 3;
		grid-row: 1;
	}

	.job_filters .search_jobs > .search_submit {
		grid-column: 4;
		grid-row: 1;
	}

	.job_filters .search_jobs > .search_submit input[type="submit"] {
		width: auto;
	}
}

/* Facets group by taxonomy: a label column beside a wrapping checkbox area, one row each. */
.job_filters ul.job_types {
	display: grid;
	grid-template-columns: auto 1fr;
	align-items: center;
	row-gap: var(--wp--preset--spacing--20, 8px);
	column-gap: var(--wp--preset--spacing--40, 24px);
	margin: 0;
	padding: var(--wp--preset--spacing--30, 16px);
	list-style: none;
}

.job_filters ul.job_types::before,
.job_filters ul.job_types::after {
	display: none;
}

/* Each group spills its label + items into the parent grid so labels stay aligned. */
.job_filters ul.job_types .yoko-facet-group {
	display: contents;
}

.job_filters ul.job_types .yoko-facet-group__label {
	font-weight: 700;
	white-space: nowrap;
}

.job_filters ul.job_types .yoko-facet-group__items {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	gap: 6px var(--wp--preset--spacing--40, 24px);
	min-width: 0;
}

.job_filters ul.job_types .yoko-facet-group__items label {
	display: flex;
	align-items: center;
	gap: 6px;
	margin: 0;
	font-size: var(--wp--preset--font-size--body-default, 1rem);
}

.job_filters ul.job_types .yoko-facet-group__items input[type="checkbox"] {
	flex: 0 0 auto;
	margin: 0;
}

.job_filters ul.job_types .yoko-facet-group--remote .search_remote_position {
	display: flex;
	align-items: center;
	gap: 6px;
	margin: 0;
	padding: 0;
	white-space: nowrap;
}

/* Stack the label above its checkboxes on narrow viewports. */
@media (max-width: 600px) {

	.job_filters ul.job_types {
		grid-template-columns: 1fr;
		row-gap: var(--wp--preset--spacing--30, 16px);
	}
}

ul.job_listings,
ul.job_listings li.job_listing {
	max-width: 100%;
}

/* Full-bleed the filter section while inner content stays in the content column. */
.job_filters {
	box-sizing: border-box;
	margin-left: calc(50% - 50vw);
	margin-right: calc(50% - 50vw);
	padding-left: calc(50vw - 50%);
	padding-right: calc(50vw - 50%);
	padding-top: var(--wp--preset--spacing--60);
}

.job_filters .search_jobs {
	padding: 0 0 var(--wp--preset--spacing--60);
}

@media (min-width: 1024px) {

	.job_filters {
		padding-top: calc(1.25 * var(--wp--preset--spacing--30, 16px));
	}

	.job_filters .search_jobs {
		padding-bottom: calc(1.75 * var(--wp--preset--spacing--30, 16px));
	}
}

.job_filters > ul.job_types,
.job_filters > .showing_jobs {
	box-sizing: border-box;
	margin-left: calc(50% - 50vw);
	margin-right: calc(50% - 50vw);
	padding-left: calc(50vw - 50%);
	padding-right: calc(50vw - 50%);
}

/* The page block sets an inline padding-top; !important is required to close the gap. */
.wp-block-group.has-global-padding:has(.job_filters) {
	padding-top: 0 !important;
}

.job-manager-form .field input[type="file"]::file-selector-button {
	background: var(--wp--preset--color--core-tint, #f3f4f7);
	color: var(--wp--preset--color--core-heading, #101a46);
	font-family: var(--wp--preset--font-family--primary, inherit);
	border: 1px solid var(--wp--preset--color--core-border, #dcdcde);
	border-radius: var(--yoko-jm-radius-pill);
	padding: var(--wp--preset--spacing--20, 8px) var(--wp--preset--spacing--30, 16px);
	margin-right: var(--wp--preset--spacing--30, 16px);
	cursor: pointer;
}

.single_job_listing .company {
	padding: 0 0 var(--wp--preset--spacing--40, 24px);
	border: 0;
	border-bottom: 1px solid var(--wp--preset--color--core-border, #dcdcde);
	border-radius: 0;
	box-shadow: none;
}

ul.job_listings li.no_job_listings_found {
	display: flex;
	flex-direction: column;
	align-items: center;
	text-align: center;
	gap: var(--wp--preset--spacing--30, 16px);
	max-width: 480px;
	margin: var(--wp--preset--spacing--60) auto;
	padding: var(--wp--preset--spacing--50, 24px);
	border: 0;
	color: var(--wp--preset--color--core-text, #494f64);
	font-size: var(--wp--preset--font-size--body-large, 1.125rem);
}

ul.job_listings li.no_job_listings_found::before {
	content: "\f179";
	font-family: dashicons;
	font-size: 48px;
	line-height: 1;
	color: var(--wp--preset--color--core-tint-1, #c0c9f7);
}

.single_job_listing .job-listing-meta li::before {
	color: var(--wp--preset--color--brand, #2345c1);
}

/* Fonteva credits buttons render outside .job-manager-form, so styled standalone. */
.yoko-fonteva-buy-more,
.yoko-fonteva-buy-more-link,
.job-manager-form .yoko-fonteva-buy-more-link {
	display: inline-block;
	background: var(--wp--preset--color--core-tint, #f3f4f7);
	color: var(--wp--preset--color--core-heading, #101a46);
	border: 1px solid var(--wp--preset--color--core-border, #dcdcde);
	border-radius: var(--yoko-jm-radius-pill);
	padding: var(--wp--preset--spacing--20, 8px) var(--wp--preset--spacing--30, 16px);
	font-family: var(--wp--preset--font-family--primary, inherit);
	font-size: var(--wp--preset--font-size--utility-meta, 0.875rem);
	line-height: 1.2;
	white-space: nowrap;
	text-decoration: none;
}

.yoko-fonteva-buy-more:hover,
.yoko-fonteva-buy-more:focus,
.yoko-fonteva-buy-more-link:hover,
.yoko-fonteva-buy-more-link:focus,
.job-manager-form .yoko-fonteva-buy-more-link:hover,
.job-manager-form .yoko-fonteva-buy-more-link:focus {
	background: var(--wp--preset--color--core-tint-3, #dbdeed);
	color: var(--wp--preset--color--core-heading, #101a46);
	border-color: var(--wp--preset--color--core-border, #dcdcde);
	text-decoration: none;
}

.yoko-fonteva-credits-toolbar .button {
	display: inline-block;
	background: transparent;
	color: var(--wp--preset--color--core-heading, #101a46);
	border: 1px solid var(--wp--preset--color--core-border, #dcdcde);
	border-radius: var(--yoko-jm-radius-pill);
	padding: var(--wp--preset--spacing--20, 8px) var(--wp--preset--spacing--30, 16px);
	font-family: var(--wp--preset--font-family--primary, inherit);
	font-size: var(--wp--preset--font-size--utility-meta, 0.875rem);
	line-height: 1.2;
	text-decoration: none;
}

.yoko-fonteva-credits-toolbar .button:hover,
.yoko-fonteva-credits-toolbar .button:focus {
	background: var(--wp--preset--color--core-tint, #f3f4f7);
	text-decoration: none;
}

/* Gap between filters and first listing — qualified to beat WPJM's `div.job_listings ul.job_listings { margin: 0 }`. */
div.job_listings ul.job_listings {
	margin-top: var(--wp--preset--spacing--50, 32px);
}

/* On mobile, run listings edge to edge (so featured backgrounds reach the viewport) and close the gap to the filters. */
@media (max-width: 767px) {

	div.job_listings ul.job_listings {
		margin-top: 0;
		margin-left: calc(50% - 50vw);
		margin-right: calc(50% - 50vw);
		max-width: none;
	}
}

/* Apply button rendered as an anchor needs button parity with the native input. */
.single_job_listing a.application_button.button {
	display: inline-block;
	text-decoration: none;
}

/* Single job listing: two-column layout with sticky info card. */
.yoko-jm-single__eyebrow {
	margin: 0 0 var(--wp--preset--spacing--40, 24px);
	font-size: var(--wp--preset--font-size--utility-meta, 0.875rem);
	font-weight: 600;
	letter-spacing: 0.04em;
	text-transform: uppercase;
}

.yoko-jm-single__eyebrow a {
	color: var(--wp--preset--color--brand, #2345c1);
	text-decoration: none;
}

.yoko-jm-single__eyebrow a:hover,
.yoko-jm-single__eyebrow a:focus {
	text-decoration: underline;
}

.yoko-jm-single__grid {
	display: grid;
	grid-template-columns: minmax(0, 1fr) clamp(280px, 28%, 340px);
	grid-template-areas:
		"company aside"
		"main    aside";
	gap: var(--wp--preset--spacing--40, 24px) var(--wp--preset--spacing--60, 40px);
	align-items: start;
}

.yoko-jm-single__company { grid-area: company; }
.yoko-jm-single__main    { grid-area: main; }
.yoko-jm-single__aside   { grid-area: aside; }

.yoko-jm-single .job_description {
	max-width: 80ch;
}

/* Break the two-column listing out of the narrow content column on wider screens. */
@media (min-width: 1024px) {
	.yoko-jm-single {
		width: min(1120px, 92vw);
		margin-left: calc(50% - min(560px, 46vw));
	}
}

/* Info card */
.yoko-jm-infocard {
	position: sticky;
	top: var(--wp--preset--spacing--40, 24px);
	display: flex;
	flex-direction: column;
	gap: var(--wp--preset--spacing--30, 16px);
	padding: var(--wp--preset--spacing--40, 24px);
	background: var(--wp--preset--color--core, #fff);
	border: 1px solid var(--wp--preset--color--core-border, rgba(16, 26, 70, 0.1));
	border-radius: 16px;
	box-shadow: 0 1px 2px rgba(16, 26, 70, 0.06), 0 8px 24px rgba(16, 26, 70, 0.06);
}

.yoko-jm-infocard__apply .application_button.button,
.yoko-jm-infocard__apply a.application_button.button {
	display: block;
	box-sizing: border-box;
	width: 100%;
	text-align: center;
}

.yoko-jm-apply .new-tab-icon {
	display: none;
}

/* Facts as label/value pairs */
.yoko-jm-facts {
	margin: 0;
	display: flex;
	flex-direction: column;
	gap: var(--wp--preset--spacing--30, 16px);
}

.yoko-jm-fact {
	display: flex;
	flex-direction: column;
	gap: 2px;
}

.yoko-jm-fact dt {
	margin: 0;
	font-size: 0.75rem;
	font-weight: 600;
	letter-spacing: 0.04em;
	text-transform: uppercase;
	color: var(--wp--preset--color--core-text, #494f64);
}

.yoko-jm-fact dd {
	margin: 0;
	font-size: var(--wp--preset--font-size--body-default, 1rem);
	color: var(--wp--preset--color--core-heading, #101a46);
}

.yoko-jm-fact dd a {
	color: var(--wp--preset--color--brand, #2345c1);
	text-decoration: none;
}

.yoko-jm-fact dd a:hover,
.yoko-jm-fact dd a:focus {
	text-decoration: underline;
}

/* Company block: framed logo beside the name, links in a row below it. */
.yoko-jm-single .company {
	display: flex;
	align-items: center;
	gap: var(--wp--preset--spacing--40, 24px);
	margin-bottom: 0;
}

.yoko-jm-single .company .company_logo {
	position: static;
	float: none;
	flex: 0 0 auto;
	box-sizing: border-box;
	width: 96px;
	height: 96px;
	margin: 0;
	padding: 0;
	border: 0;
	box-shadow: none;
	object-fit: contain;
}

.yoko-jm-single .company .company_header .name {
	margin: 0;
	padding: 0;
	font-size: var(--wp--preset--font-size--body-large, 1.125rem);
	text-transform: uppercase;
	letter-spacing: 0.02em;
	color: var(--wp--preset--color--core-heading, #101a46);
}

.yoko-jm-single .company .company_links {
	display: flex;
	flex-wrap: wrap;
	gap: var(--wp--preset--spacing--20, 8px) var(--wp--preset--spacing--40, 24px);
	margin: var(--wp--preset--spacing--20, 8px) 0 0;
}

.yoko-jm-single .company .company_links a {
	color: color-mix(in srgb, var(--wp--preset--color--brand, #2345c1) 65%, #fff);
	font-weight: 600;
	text-decoration: none;
}

.yoko-jm-single .company .company_links a:hover,
.yoko-jm-single .company .company_links a:focus {
	text-decoration: underline;
}

/* Core sets the icon font with !important; dashicons needs the same to win. */
.yoko-jm-single .company .company_links a::before {
	display: inline-block;
	width: 18px;
	height: 18px;
	margin: 0 4px 0 0;
	font-family: dashicons !important;
	font-size: 18px;
	line-height: 1.2;
	vertical-align: text-bottom;
	text-decoration: none;
}

.yoko-jm-single .company .company_links .website::before {
	content: "\f319";
}

.yoko-jm-single .company .company_links .company_twitter::before {
	content: "\f301";
}

.yoko-jm-single .company .company_links .company_facebook::before {
	content: "\f304";
}

.yoko-jm-single .company .new-tab-icon {
	display: none;
}

/* Tablet + mobile: single column, info card directly after the company. */
@media (max-width: 880px) {
	.yoko-jm-single__grid {
		grid-template-columns: 1fr;
		grid-template-areas:
			"company"
			"aside"
			"main";
		gap: var(--wp--preset--spacing--40, 24px);
	}

	.single_job_listing .company {
		padding-bottom: 0;
		border-bottom: 0;
	}

	.yoko-jm-single .company .company_links .company_links__label {
		position: absolute;
		width: 1px;
		height: 1px;
		overflow: hidden;
		clip-path: inset(50%);
		white-space: nowrap;
	}

	.yoko-jm-single .company .company_links a::before {
		margin: 0;
	}

	.yoko-jm-infocard {
		position: static;
	}

	.yoko-jm-single .job_description {
		max-width: none;
	}
}
