/**
 * JobBoard theme — premium, modern design system with full light/dark support.
 * Token-driven, no build step. Dark mode follows the system theme and can be
 * overridden manually via [data-jb-theme] on <html> (set by jobboard-ui.js).
 */

/* ============================================================= TOKENS ===== */
:root {
	color-scheme: light;

	--jb-bg: #ffffff;
	--jb-surface: #f8fafc;
	--jb-surface-2: #eef2f7;
	--jb-text: #0b1220;
	--jb-muted: #5b6b86;
	--jb-border: #e6e9f0;
	--jb-primary: #4f46e5;
	--jb-primary-soft: #eef0fe;
	--jb-primary-hover: #4338ca;
	--jb-on-primary: #ffffff;
	--jb-accent: #f59e0b;
	--jb-success: #16a34a;
	--jb-danger: #dc2626;

	--jb-shadow-sm: 0 1px 2px rgba(2, 6, 23, .06);
	--jb-shadow: 0 6px 24px -12px rgba(2, 6, 23, .22), 0 2px 6px -3px rgba(2, 6, 23, .08);
	--jb-shadow-lg: 0 24px 56px -22px rgba(2, 6, 23, .35);
	--jb-ring: 0 0 0 3px color-mix(in srgb, var(--jb-primary) 35%, transparent);

	--jb-radius: 16px;
	--jb-radius-sm: 12px;
	--jb-radius-pill: 999px;
	--jb-transition: 180ms cubic-bezier(.3, .7, .4, 1);
}

@media (prefers-color-scheme: dark) {
	:root:not([data-jb-theme="light"]) {
		color-scheme: dark;
		--jb-bg: #0b1220;
		--jb-surface: #111a2e;
		--jb-surface-2: #16203a;
		--jb-text: #e8ecf6;
		--jb-muted: #93a0bd;
		--jb-border: #243049;
		--jb-primary: #818cf8;
		--jb-primary-soft: #1b2340;
		--jb-primary-hover: #a5b4fc;
		--jb-on-primary: #0b1220;
		--jb-accent: #fbbf24;
		--jb-success: #34d399;
		--jb-danger: #f87171;
		--jb-shadow-sm: 0 1px 2px rgba(0, 0, 0, .5);
		--jb-shadow: 0 10px 30px -14px rgba(0, 0, 0, .7);
		--jb-shadow-lg: 0 28px 60px -22px rgba(0, 0, 0, .8);

		--wp--preset--color--base: #0b1220;
		--wp--preset--color--contrast: #e8ecf6;
		--wp--preset--color--surface: #111a2e;
		--wp--preset--color--surface-2: #16203a;
		--wp--preset--color--border: #243049;
		--wp--preset--color--muted: #93a0bd;
		--wp--preset--color--primary: #818cf8;
		--wp--preset--color--primary-hover: #a5b4fc;
		--wp--preset--color--accent: #fbbf24;
		--wp--preset--color--success: #34d399;
	}
}

/* Manual dark (toggle) — mirrors the dark token block. */
:root[data-jb-theme="dark"] {
	color-scheme: dark;
	--jb-bg: #0b1220;
	--jb-surface: #111a2e;
	--jb-surface-2: #16203a;
	--jb-text: #e8ecf6;
	--jb-muted: #93a0bd;
	--jb-border: #243049;
	--jb-primary: #818cf8;
	--jb-primary-soft: #1b2340;
	--jb-primary-hover: #a5b4fc;
	--jb-on-primary: #0b1220;
	--jb-accent: #fbbf24;
	--jb-success: #34d399;
	--jb-danger: #f87171;
	--jb-shadow-sm: 0 1px 2px rgba(0, 0, 0, .5);
	--jb-shadow: 0 10px 30px -14px rgba(0, 0, 0, .7);
	--jb-shadow-lg: 0 28px 60px -22px rgba(0, 0, 0, .8);

	--wp--preset--color--base: #0b1220;
	--wp--preset--color--contrast: #e8ecf6;
	--wp--preset--color--surface: #111a2e;
	--wp--preset--color--surface-2: #16203a;
	--wp--preset--color--border: #243049;
	--wp--preset--color--muted: #93a0bd;
	--wp--preset--color--primary: #818cf8;
	--wp--preset--color--primary-hover: #a5b4fc;
	--wp--preset--color--accent: #fbbf24;
	--wp--preset--color--success: #34d399;
}

/* ============================================================== BASE ====== */
body { background: var(--jb-bg); color: var(--jb-text); -webkit-font-smoothing: antialiased; text-rendering: optimizeLegibility; }
a { text-underline-offset: 2px; }
img { max-width: 100%; height: auto; }

:where(a, button, input, select, summary, [tabindex]):focus-visible {
	outline: none;
	box-shadow: var(--jb-ring);
	border-radius: 6px;
}
html { scroll-behavior: smooth; }
@media (prefers-reduced-motion: reduce) {
	* { transition: none !important; animation: none !important; scroll-behavior: auto !important; }
}

.wp-element-button, .wp-block-button__link {
	border-radius: var(--jb-radius-sm);
	font-weight: 600;
	transition: transform var(--jb-transition), background var(--jb-transition), box-shadow var(--jb-transition);
}
.wp-element-button:hover, .wp-block-button__link:hover { transform: translateY(-1px); }

/* ===================================================== HEADER / FOOTER ==== */
.jb-site-header {
	position: sticky; top: 0; z-index: 100;
	background: color-mix(in srgb, var(--jb-bg) 85%, transparent);
	backdrop-filter: saturate(180%) blur(12px);
	-webkit-backdrop-filter: saturate(180%) blur(12px);
	border-bottom: 1px solid var(--jb-border);
}
.jb-site-header .wp-block-site-title a { text-decoration: none; color: var(--jb-text); }
.jb-site-header .wp-block-site-logo img { height: auto; }
/* Keep the dark-navy logo legible on the dark header (white chip behind it). */
:root[data-jb-theme="dark"] .jb-site-header .wp-block-site-logo img { background: #fff; border-radius: 8px; padding: 4px 8px; }
@media (prefers-color-scheme: dark) {
	:root:not([data-jb-theme="light"]) .jb-site-header .wp-block-site-logo img { background: #fff; border-radius: 8px; padding: 4px 8px; }
}
/* When a logo image is present, the wordmark covers the brand name — hide the
   redundant text title. Sites without a logo keep the text title. */
.jb-brand:has(.wp-block-site-logo img) .wp-block-site-title { display: none; }
.jb-site-footer { border-top: 1px solid var(--jb-border); background: var(--jb-surface); }

/* ---------------------------------------------------------- FOOTER ------ */
.jb-footer__cols { display: grid; gap: 2rem 2.5rem; grid-template-columns: 1fr; }
.jb-footer__cols > * { margin-block: 0; }
@media (min-width: 30rem) { .jb-footer__cols { grid-template-columns: repeat(2, 1fr); } }
@media (min-width: 64rem) { .jb-footer__cols { grid-template-columns: 1.5fr 1fr 1fr 1.3fr; } }
.jb-footcol { min-width: 0; }
.jb-footcol--brand { gap: 1rem; align-items: flex-start; }
.jb-footcol--brand .wp-block-site-tagline { margin: 0; color: var(--jb-muted); max-width: 34ch; }
.jb-site-footer .wp-block-site-logo img { height: auto; }
:root[data-jb-theme="dark"] .jb-site-footer .wp-block-site-logo img { background: #fff; border-radius: 8px; padding: 4px 8px; }
@media (prefers-color-scheme: dark) {
	:root:not([data-jb-theme="light"]) .jb-site-footer .wp-block-site-logo img { background: #fff; border-radius: 8px; padding: 4px 8px; }
}
.jb-footcol__title { font-size: .78rem !important; text-transform: uppercase; letter-spacing: .07em; font-weight: 700; color: var(--jb-muted); margin: 0 0 1rem; }

.jb-linklist { list-style: none; margin: 0; padding: 0; display: grid; gap: .6rem; }
.jb-linklist__link { color: var(--jb-text); text-decoration: none; font-size: .92rem; transition: color var(--jb-transition); }
.jb-linklist__link:hover { color: var(--jb-primary); }
.jb-linklist__count { color: var(--jb-muted); font-size: .8rem; margin-left: .35rem; }

.jb-site-footer .wp-block-navigation { gap: .6rem; }
.jb-site-footer .wp-block-navigation a { color: var(--jb-text); text-decoration: none; font-size: .92rem; }
.jb-site-footer .wp-block-navigation a:hover { color: var(--jb-primary); }

.jb-social { list-style: none; display: flex; flex-wrap: wrap; gap: .55rem; margin: .35rem 0 0; padding: 0; }
.jb-social a {
	display: inline-flex; align-items: center; justify-content: center;
	width: 40px; height: 40px; border-radius: 50%;
	border: 1px solid var(--jb-border); background: var(--jb-bg); color: var(--jb-muted);
	transition: transform var(--jb-transition), background var(--jb-transition), color var(--jb-transition), border-color var(--jb-transition);
}
.jb-social a:hover { color: var(--jb-on-primary); background: var(--jb-primary); border-color: transparent; transform: translateY(-2px); }
.jb-social svg { width: 18px; height: 18px; fill: currentColor; }

.jb-footer__bottom { margin-top: 2.75rem; padding-top: 1.5rem; border-top: 1px solid var(--jb-border); font-size: .85rem; color: var(--jb-muted); }
.jb-footer__bottom .wp-block-shortcode { margin: 0; }
.jb-totop { color: var(--jb-muted); text-decoration: none; font-weight: 600; transition: color var(--jb-transition); }
.jb-totop:hover { color: var(--jb-primary); }

.jb-theme-toggle {
	display: inline-flex; align-items: center; justify-content: center;
	width: 42px; height: 42px; border-radius: var(--jb-radius-pill);
	border: 1px solid var(--jb-border); background: var(--jb-surface);
	color: var(--jb-text); cursor: pointer; font-size: 1.1rem; line-height: 1;
	transition: background var(--jb-transition), transform var(--jb-transition);
}
.jb-theme-toggle:hover { transform: translateY(-1px); background: var(--jb-surface-2); }
.jb-theme-toggle .jb-theme-toggle__dark { display: none; }
:root[data-jb-theme="dark"] .jb-theme-toggle__dark { display: inline; }
:root[data-jb-theme="dark"] .jb-theme-toggle__light { display: none; }
@media (prefers-color-scheme: dark) {
	:root:not([data-jb-theme="light"]) .jb-theme-toggle__dark { display: inline; }
	:root:not([data-jb-theme="light"]) .jb-theme-toggle__light { display: none; }
}

/* ========================================================= DIRECTORY ====== */
.jb-directory { container-type: inline-size; }
.jb-directory__main { min-width: 0; }
@supports (container-type: inline-size) { .jb-directory__main { container-type: inline-size; } }

/* Two-column layout: sticky filter rail + results column (desktop). */
@media (min-width: 64rem) {
	.jb-directory--cols {
		display: grid; align-items: start;
		grid-template-columns: clamp(15rem, 21vw, 19rem) minmax(0, 1fr);
		gap: 2rem;
	}
	.jb-directory--cols .jb-directory__aside { position: sticky; top: 5.5rem; }
	.jb-directory--cols .jb-jobs { margin-top: 0; }
}

.jb-jobs {
	list-style: none; margin: 1.5rem 0 0; padding: 0;
	display: grid; gap: 1.25rem; grid-template-columns: 1fr;
}
@media (min-width: 40rem) { .jb-jobs { grid-template-columns: repeat(2, 1fr); } }
@media (min-width: 64rem) { .jb-jobs { grid-template-columns: repeat(3, 1fr); } }
@supports (container-type: inline-size) {
	@container (min-width: 34rem) { .jb-jobs { grid-template-columns: repeat(2, 1fr); } }
	@container (min-width: 60rem) { .jb-jobs { grid-template-columns: repeat(3, 1fr); } }
}

/* =========================================================== JOB CARD ===== */
.jb-job-card {
	position: relative; display: flex; flex-direction: column; gap: .85rem;
	padding: 1.4rem; background: var(--jb-surface);
	border: 1px solid var(--jb-border); border-radius: var(--jb-radius);
	box-shadow: var(--jb-shadow-sm);
	transition: transform var(--jb-transition), box-shadow var(--jb-transition), border-color var(--jb-transition);
}
.jb-job-card:hover, .jb-job-card:focus-within {
	transform: translateY(-4px); box-shadow: var(--jb-shadow);
	border-color: color-mix(in srgb, var(--jb-primary) 40%, var(--jb-border));
}
.jb-job-card--featured { border-color: color-mix(in srgb, var(--jb-accent) 55%, var(--jb-border)); }
.jb-job-card--featured::before {
	content: ""; position: absolute; inset: 0; border-radius: inherit; pointer-events: none;
	box-shadow: inset 0 0 0 1px color-mix(in srgb, var(--jb-accent) 45%, transparent);
}
.jb-job-card__head { display: grid; grid-template-columns: auto 1fr auto; gap: .85rem; align-items: start; }
.jb-job-card__logo {
	width: 52px; height: 52px; border-radius: 14px; object-fit: contain;
	background: var(--jb-bg); border: 1px solid var(--jb-border);
	display: inline-flex; align-items: center; justify-content: center;
	font-weight: 800; color: var(--jb-primary); font-size: 1.25rem;
}
.jb-job-card__title { margin: 0; font-size: 1.15rem; line-height: 1.3; font-weight: 700; letter-spacing: -.01em; }
.jb-job-card__title a { text-decoration: none; color: var(--jb-text); }
.jb-job-card__title a::after { content: ""; position: absolute; inset: 0; z-index: 0; }
.jb-job-card__company { margin: .15rem 0 0; color: var(--jb-muted); font-size: .9rem; font-weight: 500; }

/* ======================================================== PILLS / CHIPS === */
.jb-meta { list-style: none; margin: 0; padding: 0; display: flex; flex-wrap: wrap; gap: .4rem; }
.jb-pill, .jb-chip {
	display: inline-flex; align-items: center; gap: .35em;
	font-size: .8rem; font-weight: 500; line-height: 1.5;
	padding: .25rem .7rem; border-radius: var(--jb-radius-pill);
	background: var(--jb-surface-2); color: var(--jb-text);
	border: 1px solid transparent; white-space: nowrap;
}
.jb-pill--salary { color: var(--jb-success); background: color-mix(in srgb, var(--jb-success) 14%, var(--jb-bg)); font-weight: 700; }
.jb-pill--workmode { color: var(--jb-primary); background: var(--jb-primary-soft); }
.jb-chip { text-decoration: none; position: relative; z-index: 1; transition: background var(--jb-transition), color var(--jb-transition); }
.jb-chip:hover { background: var(--jb-primary); color: var(--jb-on-primary); }
.jb-chip--featured { background: color-mix(in srgb, var(--jb-accent) 18%, var(--jb-bg)); color: #92400e; font-weight: 700; }
:root[data-jb-theme="dark"] .jb-chip--featured { color: var(--jb-accent); }
@media (prefers-color-scheme: dark) {
	:root:not([data-jb-theme="light"]) .jb-chip--featured { color: var(--jb-accent); }
}
.jb-chip--more { background: transparent; border-color: var(--jb-border); color: var(--jb-muted); }

/* =========================================================== FILTERS ====== */
.jb-filters {
	display: grid; gap: .85rem; padding: 1.1rem 1.25rem;
	border-radius: var(--jb-radius); background: var(--jb-surface);
	border: 1px solid var(--jb-border);
}
.jb-filters__search { display: flex; gap: .5rem; flex-wrap: wrap; }
.jb-filters__input {
	flex: 1; min-width: 0; min-height: 48px; padding: .65rem 1rem;
	border: 1px solid var(--jb-border); border-radius: var(--jb-radius-sm);
	background: var(--jb-bg); color: var(--jb-text); font-size: 1rem;
}
.jb-filters__input::placeholder { color: var(--jb-muted); }
.jb-filters__submit { min-height: 48px; }
.jb-filters__more > summary { cursor: pointer; list-style: none; display: inline-flex; align-items: center; gap: .4rem; font-weight: 600; min-height: 44px; color: var(--jb-primary); }
.jb-filters__more > summary::-webkit-details-marker { display: none; }
.jb-filters__fields { display: grid; gap: .85rem; margin-top: .85rem; grid-template-columns: 1fr; }
.jb-field { display: grid; gap: .3rem; }
.jb-field__label { font-size: .8rem; font-weight: 500; color: var(--jb-muted); }
.jb-field select {
	min-height: 46px; padding: .4rem .7rem; border: 1px solid var(--jb-border);
	border-radius: var(--jb-radius-sm); background: var(--jb-bg); color: var(--jb-text); width: 100%;
}
.jb-filters__actions { display: flex; gap: .75rem; align-items: center; }
.jb-filters__reset { font-size: .85rem; color: var(--jb-muted); }
@media (min-width: 48rem) {
	.jb-filters__toggle { display: none; }
	/* Force fields visible from tablet up even without JS (details may be closed). */
	.jb-filters__more .jb-filters__fields { display: grid; grid-template-columns: repeat(auto-fit, minmax(11rem, 1fr)); align-items: end; }
}
/* Stacked, full-width controls when the filters sit in the desktop sidebar rail. */
@media (min-width: 64rem) {
	.jb-directory--cols .jb-filters { gap: 1rem; }
	.jb-directory--cols .jb-filters__search { flex-direction: column; align-items: stretch; }
	.jb-directory--cols .jb-filters__submit { width: 100%; }
	.jb-directory--cols .jb-filters__more .jb-filters__fields { grid-template-columns: 1fr; margin-top: .25rem; }
	.jb-directory--cols .jb-filters__actions { flex-direction: column; align-items: stretch; gap: .5rem; }
	.jb-directory--cols .jb-filters__actions .wp-element-button { width: 100%; }
	.jb-directory--cols .jb-filters__reset { display: block; text-align: center; }
}

/* ============================================================ TOOLBAR ====== */
.jb-toolbar { display: flex; flex-wrap: wrap; gap: .85rem; align-items: center; justify-content: space-between; margin-bottom: 1.25rem; }
.jb-toolbar__count { margin: 0; color: var(--jb-muted); font-size: .95rem; }
.jb-toolbar__count strong { color: var(--jb-text); }
.jb-toolbar__chips { list-style: none; display: flex; flex-wrap: wrap; gap: .45rem; margin: 0; padding: 0; align-items: center; }
.jb-chip--removable { cursor: pointer; text-decoration: none; }
.jb-chip--removable:hover { background: color-mix(in srgb, var(--jb-danger) 14%, var(--jb-bg)); color: var(--jb-danger); }
.jb-toolbar__clear { font-size: .85rem; color: var(--jb-muted); }
.jb-toolbar__sort { display: flex; align-items: center; gap: .45rem; }
.jb-toolbar__sort-label { font-size: .85rem; color: var(--jb-muted); }
.jb-toolbar__sort select { min-height: 42px; border: 1px solid var(--jb-border); border-radius: var(--jb-radius-sm); padding: 0 .6rem; background: var(--jb-bg); color: var(--jb-text); }

/* ========================================================= BREADCRUMBS ===== */
.jb-breadcrumbs { margin: 0 0 1.25rem; font-size: .85rem; color: var(--jb-muted); }
.jb-breadcrumbs__list { list-style: none; display: flex; flex-wrap: wrap; gap: .4rem; margin: 0; padding: 0; }
.jb-breadcrumbs__item + .jb-breadcrumbs__item::before { content: "›"; opacity: .5; margin-right: .4rem; }
.jb-breadcrumbs a { text-decoration: none; color: var(--jb-primary); }

/* ============================================================= BADGES ====== */
.jb-badge { display: inline-flex; align-items: center; gap: .3rem; font-size: .75rem; font-weight: 600; padding: .22rem .6rem; border-radius: var(--jb-radius-pill); }
.jb-badge--fresh { background: color-mix(in srgb, var(--jb-success) 14%, var(--jb-bg)); color: var(--jb-success); }
.jb-badge--urgent { background: color-mix(in srgb, var(--jb-accent) 18%, var(--jb-bg)); color: #b45309; }
:root[data-jb-theme="dark"] .jb-badge--urgent { color: var(--jb-accent); }
.jb-badge--closed { background: var(--jb-surface-2); color: var(--jb-muted); }
.jb-social-proof { font-size: .8rem; color: var(--jb-muted); }

/* ========================================================= SINGLE JOB ====== */
.jb-single { }
.jb-single__layout { display: grid; gap: 2rem; grid-template-columns: 1fr; align-items: start; }
.jb-single__main {
	background: var(--jb-surface); border: 1px solid var(--jb-border);
	border-radius: var(--jb-radius); padding: clamp(1.25rem, 4vw, 2.25rem); box-shadow: var(--jb-shadow-sm);
}
.jb-hero { display: grid; grid-template-columns: auto 1fr; gap: 1.1rem; align-items: center; }
.jb-hero__logo { width: 76px; height: 76px; border-radius: 18px; object-fit: contain; background: var(--jb-bg); border: 1px solid var(--jb-border); }
.jb-hero__title { margin: 0; font-size: clamp(1.6rem, 4vw, 2.25rem); font-weight: 800; letter-spacing: -.02em; }
.jb-hero__company { margin: .4rem 0 .65rem; color: var(--jb-muted); font-weight: 500; }
.jb-hero__company a { color: var(--jb-primary); text-decoration: none; }
.jb-hero__badges { display: flex; flex-wrap: wrap; gap: .45rem; margin: .7rem 0; align-items: center; }
.jb-hero__actions { display: flex; flex-wrap: wrap; gap: .65rem; align-items: center; margin-top: .8rem; }

.jb-keyfacts { background: var(--jb-bg); border: 1px solid var(--jb-border); border-radius: var(--jb-radius); padding: 1.1rem 1.3rem; margin: 1.5rem 0; }
.jb-keyfacts__title { font-size: .95rem; text-transform: uppercase; letter-spacing: .04em; color: var(--jb-muted); margin: 0 0 .7rem; }
.jb-keyfacts__list { margin: 0; display: grid; gap: .55rem; }
.jb-keyfacts__row { display: grid; grid-template-columns: 130px 1fr; gap: .5rem; }
.jb-keyfacts__row dt { font-weight: 600; margin: 0; color: var(--jb-muted); }
.jb-keyfacts__row dd { margin: 0; font-weight: 500; }

.jb-single__content { margin-top: 1.5rem; line-height: 1.7; }
.jb-single__content :where(h2, h3) { letter-spacing: -.01em; }
.jb-section { margin: 1.85rem 0; }
.jb-section__title { font-size: 1.25rem; font-weight: 700; margin: 0 0 .7rem; letter-spacing: -.01em; }
.jb-section__list { margin: 0; padding-left: 1.3rem; display: grid; gap: .45rem; }
.jb-section__list li::marker { color: var(--jb-primary); }
.jb-chips { list-style: none; margin: 0; padding: 0; display: flex; flex-wrap: wrap; gap: .45rem; }
.jb-facts { margin: 0; display: grid; gap: .45rem; }
.jb-facts__row { display: grid; grid-template-columns: 130px 1fr; gap: .5rem; }
.jb-facts__row dt { font-weight: 600; color: var(--jb-muted); }
.jb-single__tags { display: flex; flex-wrap: wrap; gap: .45rem; margin-top: 1.75rem; }

/* Sidebar apply card */
.jb-single__sidebar { display: grid; gap: 1rem; }
.jb-apply {
	background: var(--jb-surface); border: 1px solid var(--jb-border);
	border-radius: var(--jb-radius); padding: 1.4rem; box-shadow: var(--jb-shadow);
}
.jb-apply__btn {
	display: flex; align-items: center; justify-content: center;
	box-sizing: border-box; width: 100%; min-height: 52px; line-height: 1.2;
	padding: .65rem 1.25rem; border-radius: var(--jb-radius-sm);
	background: var(--jb-primary); color: var(--jb-on-primary); text-decoration: none;
	font-weight: 700; font-size: 1rem; box-shadow: var(--jb-shadow-sm);
	transition: transform var(--jb-transition), background var(--jb-transition);
}
.jb-apply__btn:hover { background: var(--jb-primary-hover); color: var(--jb-on-primary); transform: translateY(-1px); }
.jb-apply__deadline { margin: .8rem 0 0; font-size: .85rem; color: var(--jb-muted); text-align: center; }
.jb-apply .jb-save { margin-top: .8rem; width: 100%; justify-content: center; }
@media (min-width: 60rem) {
	.jb-single__layout { grid-template-columns: minmax(0, 1fr) 21rem; }
	.jb-single__sidebar { position: sticky; top: 88px; }
}

/* =========================================================== SAVE / SHARE = */
.jb-save {
	display: inline-flex; align-items: center; gap: .45rem; min-height: 46px; padding: 0 1rem;
	border: 1px solid var(--jb-border); border-radius: var(--jb-radius-sm);
	background: var(--jb-bg); color: var(--jb-text); cursor: pointer; font-weight: 600;
	position: relative; z-index: 2; transition: background var(--jb-transition), transform var(--jb-transition);
}
.jb-save:hover { background: var(--jb-surface-2); transform: translateY(-1px); }
.jb-save.is-saved { border-color: transparent; background: color-mix(in srgb, var(--jb-danger) 12%, var(--jb-bg)); color: var(--jb-danger); }
.jb-save.is-saved .jb-save__icon { font-weight: 700; }
.jb-save--icon { padding: 0; width: 46px; justify-content: center; }
.jb-save--icon .jb-save__label { position: absolute; width: 1px; height: 1px; overflow: hidden; clip: rect(0 0 0 0); white-space: nowrap; }

.jb-share { display: flex; flex-wrap: wrap; align-items: center; gap: .5rem; margin-top: 1.1rem; }
.jb-share__title { font-weight: 600; font-size: .85rem; color: var(--jb-muted); }
.jb-share__btn {
	min-height: 42px; display: inline-flex; align-items: center; padding: 0 .85rem;
	border: 1px solid var(--jb-border); border-radius: var(--jb-radius-sm);
	background: var(--jb-bg); color: var(--jb-text); text-decoration: none; cursor: pointer; font-size: .85rem; font-weight: 500;
	transition: background var(--jb-transition);
}
.jb-share__btn:hover { background: var(--jb-surface-2); }
.jb-share__status { font-size: .8rem; color: var(--jb-success); }

.jb-job-card__footer { display: flex; flex-wrap: wrap; align-items: center; gap: .5rem; margin-top: auto; padding-top: .6rem; }
.jb-job-card__footer .jb-save { margin-left: auto; }

/* ======================================================= COMPANY / RELATED = */
.jb-company { display: flex; gap: .9rem; align-items: center; margin: 2.5rem 0 1rem; padding: 1.2rem 1.35rem; background: var(--jb-surface); border: 1px solid var(--jb-border); border-radius: var(--jb-radius); }
.jb-company__logo { width: 56px; height: 56px; border-radius: 14px; object-fit: contain; background: var(--jb-bg); border: 1px solid var(--jb-border); }
.jb-company__name { margin: 0; font-weight: 700; }
.jb-company__site { color: var(--jb-primary); text-decoration: none; font-size: .9rem; }
.jb-related { margin-top: 2.75rem; }
.jb-related__title { font-size: 1.5rem; font-weight: 800; letter-spacing: -.02em; margin: 0 0 1.1rem; }

/* ======================================================== PAGINATION ====== */
.jb-pagination { display: flex; flex-wrap: wrap; gap: .45rem; justify-content: center; margin-top: 2.5rem; }
.jb-pagination .page-numbers {
	min-width: 46px; min-height: 46px; display: inline-flex; align-items: center; justify-content: center;
	padding: 0 .8rem; border: 1px solid var(--jb-border); border-radius: var(--jb-radius-sm);
	text-decoration: none; color: var(--jb-text); background: var(--jb-bg); font-weight: 600;
	transition: background var(--jb-transition);
}
.jb-pagination .page-numbers:hover { background: var(--jb-surface-2); }
.jb-pagination .current { background: var(--jb-primary); color: var(--jb-on-primary); border-color: transparent; }

/* ============================================================ EMPTY ======== */
.jb-empty { text-align: center; padding: clamp(2.5rem, 8vw, 4.5rem) 1rem; color: var(--jb-muted); }
.jb-empty__title { font-weight: 700; font-size: 1.25rem; color: var(--jb-text); margin-bottom: .35rem; }

/* ============================================================ NOTICES ====== */
.jb-notice { padding: 1rem 1.25rem; border: 1px dashed var(--jb-border); border-radius: var(--jb-radius-sm); background: var(--jb-surface); color: var(--jb-muted); }

/* ===================================================== MOBILE ACTION BAR === */
.jb-actionbar { display: none; }
@media (max-width: 47.99rem) {
	.jb-actionbar {
		display: flex; gap: .55rem; position: fixed; left: 0; right: 0; bottom: 0; z-index: 60;
		padding: .65rem .9rem; padding-bottom: calc(.65rem + env(safe-area-inset-bottom));
		background: color-mix(in srgb, var(--jb-bg) 92%, transparent);
		backdrop-filter: blur(12px); -webkit-backdrop-filter: blur(12px);
		border-top: 1px solid var(--jb-border);
	}
	.jb-actionbar__apply { flex: 1; text-align: center; min-height: 50px; line-height: 50px; border-radius: var(--jb-radius-sm); background: var(--jb-primary); color: var(--jb-on-primary); text-decoration: none; font-weight: 700; }
	.jb-single { padding-bottom: 84px; }
}

/* ====================================================== HOME / LANDING ===== */
.jb-hero-banner {
	text-align: center; border-radius: var(--jb-radius);
	background:
		radial-gradient(120% 120% at 50% -20%, color-mix(in srgb, var(--jb-primary) 22%, transparent), transparent 60%),
		linear-gradient(180deg, var(--jb-surface), var(--jb-bg));
	border: 1px solid var(--jb-border);
}
.jb-hero-banner .wp-block-heading { letter-spacing: -.03em; }
.jb-section--home { margin: clamp(2.5rem, 6vw, 4.5rem) 0; }
.jb-cta { border-radius: var(--jb-radius); background: var(--jb-surface); border: 1px solid var(--jb-border); }

.jb-herosearch {
	display: flex; gap: .5rem; max-width: 560px; margin: 1.75rem auto 0;
	background: var(--jb-bg); border: 1px solid var(--jb-border);
	border-radius: var(--jb-radius-pill); padding: .4rem .4rem .4rem 1.1rem;
	box-shadow: var(--jb-shadow);
}
.jb-herosearch__input { flex: 1; min-width: 0; border: 0; background: transparent; color: var(--jb-text); font-size: 1rem; outline: none; }
.jb-herosearch__input::placeholder { color: var(--jb-muted); }
.jb-herosearch__btn { border-radius: var(--jb-radius-pill); min-height: 46px; padding: 0 1.5rem; background: var(--jb-primary); color: var(--jb-on-primary); border: 0; font-weight: 700; cursor: pointer; }
.jb-herosearch__btn:hover { background: var(--jb-primary-hover); }
@media (max-width: 32rem) {
	.jb-herosearch { flex-direction: column; border-radius: var(--jb-radius); padding: .75rem; }
	.jb-herosearch__input { min-height: 44px; padding: 0 .5rem; }
}

/* =========================================================== CATEGORIES === */
.jb-cats { list-style: none; margin: 1.5rem 0 0; padding: 0; display: grid; gap: 1rem; grid-template-columns: repeat(2, 1fr); }
@media (min-width: 48rem) { .jb-cats { grid-template-columns: repeat(4, 1fr); } }
.jb-cat__link {
	display: flex; flex-direction: column; gap: .25rem; height: 100%;
	padding: 1.1rem 1.2rem; text-decoration: none; color: var(--jb-text);
	background: var(--jb-surface); border: 1px solid var(--jb-border); border-radius: var(--jb-radius);
	transition: transform var(--jb-transition), box-shadow var(--jb-transition), border-color var(--jb-transition);
}
.jb-cat__link:hover { transform: translateY(-3px); box-shadow: var(--jb-shadow); border-color: color-mix(in srgb, var(--jb-primary) 40%, var(--jb-border)); }
.jb-cat__name { font-weight: 700; letter-spacing: -.01em; }
.jb-cat__count { font-size: .85rem; color: var(--jb-muted); }

/* ============================================================ SAVED ======== */
.jb-saved__empty { color: var(--jb-muted); }

/* ====================================================== UNIFIED BUTTONS ==== */
/* One cohesive treatment for every button/control: rounded & soft. */
.wp-element-button,
.wp-block-button__link,
.jb-apply__btn,
.jb-filters__submit,
.jb-actionbar__apply {
	font-weight: 600;
	letter-spacing: 0;
	box-shadow: var(--jb-shadow-sm);
	transition: transform var(--jb-transition), box-shadow var(--jb-transition), background-color var(--jb-transition), color var(--jb-transition);
}
/* Default (un-coloured) buttons use the brand token — fixes white-on-light
   text in dark mode while respecting explicitly-coloured buttons. */
.wp-element-button:not(.has-background) { background-color: var(--jb-primary); }
.wp-element-button:not(.has-text-color) { color: var(--jb-on-primary); }
.wp-element-button:hover,
.wp-block-button__link:hover,
.jb-apply__btn:hover,
.jb-actionbar__apply:hover { transform: translateY(-2px); box-shadow: var(--jb-shadow); }
.wp-element-button:active,
.wp-block-button__link:active,
.jb-apply__btn:active { transform: translateY(0); box-shadow: var(--jb-shadow-sm); }

/* Secondary controls: lighter surface, same lift. */
.jb-save,
.jb-share__btn,
.jb-pagination .page-numbers,
.jb-filters__reset {
	transition: transform var(--jb-transition), background-color var(--jb-transition), box-shadow var(--jb-transition), border-color var(--jb-transition);
}
.jb-save:hover,
.jb-share__btn:hover,
.jb-pagination .page-numbers:hover { transform: translateY(-2px); box-shadow: var(--jb-shadow-sm); }
.jb-save:active,
.jb-share__btn:active,
.jb-pagination .page-numbers:active { transform: translateY(0); }

/* Hero search button stays a pill to match its rounded search bar. */
.jb-herosearch__btn { border-radius: var(--jb-radius-pill); box-shadow: none; }
.jb-herosearch__btn:hover { transform: none; box-shadow: none; background: var(--jb-primary-hover); }

/* Consistent control sizing for inputs/selects. */
.jb-filters__input,
.jb-field select,
.jb-toolbar__sort select { min-height: 48px; }

/* Border-box so min-height + padding never inflate control height. */
.jb-apply__btn, .jb-save, .jb-share__btn, .jb-filters__input, .jb-filters__submit,
.jb-field select, .jb-toolbar__sort select, .jb-pagination .page-numbers,
.jb-theme-toggle, .jb-herosearch__input, .jb-herosearch__btn, .jb-actionbar__apply { box-sizing: border-box; }
