/* ============================================================
   MJU JOB PORTAL — toned-down deep-blue palette
   Sections:
	 1. Layout / utilities
	 2. Buttons & pills
	 3. Cards & grids (incl. .mju-job-card v3)
	 4. Homepage sections (hero, stats, top/expiring/latest, categories, states, quals, tags, CTA)
	 5. Single job
	 6. Archive list
	 7. Search
	 8. Footer
	 9. Responsive (mobile-first)
   ============================================================ */

body.mju-themed {
	margin: 0;
	padding: 0;
	font-family: var(--mju-font);
	color: var(--mju-text);
	background: var(--mju-bg);
	line-height: 1.55;
	-webkit-font-smoothing: antialiased;
}
body.mju-themed * { box-sizing: border-box; }
body.mju-themed img { max-width: 100%; height: auto; }
body.mju-themed a { color: var(--mju-primary); text-decoration: none; }
body.mju-themed a:hover { color: var(--mju-primary-dark); text-decoration: none; }
.mju-sr-only,
body.mju-themed .mju-sr-only {
	position: absolute; width: 1px; height: 1px; padding: 0; overflow: hidden; clip: rect(0,0,0,0); white-space: nowrap; border: 0;
}

.mju-container { max-width: 1200px; margin: 0 auto; padding: 0 16px; }

/* === 2. Buttons & pills === */
.mju-btn {
	display: inline-flex; align-items: center; justify-content: center; gap: 6px;
	font-family: var(--mju-font); font-weight: 600; line-height: 1; cursor: pointer;
	border-radius: var(--mju-radius); border: 1px solid transparent;
	text-decoration: none !important; transition: background .15s, color .15s, transform .05s, box-shadow .15s;
	min-height: 44px; padding: 10px 16px; font-size: .95rem;
}
.mju-btn:active { transform: translateY(1px); }
.mju-btn-sm { min-height: 36px; padding: 6px 12px; font-size: .85rem; }
.mju-btn-md { min-height: 44px; padding: 10px 18px; font-size: .95rem; }
.mju-btn-lg { min-height: 52px; padding: 14px 24px; font-size: 1.05rem; }
.mju-btn-block { width: 100%; padding: 12px 20px; font-size: 15px; font-weight: 600; }

.mju-btn-primary { background: var(--mju-primary); color: #fff; }
.mju-btn-primary:hover { background: var(--mju-primary-dark); color: #fff; }
.mju-btn-accent  { background: var(--mju-accent); color: #fff; }
.mju-btn-accent:hover { background: var(--mju-accent-dark); color: #fff; }
.mju-btn-apply   { background: var(--mju-accent); color: #fff; box-shadow: 0 1px 0 rgba(0,0,0,0.06); }
.mju-btn-apply:hover { background: var(--mju-accent-dark); color: #fff; }
.mju-btn-secondary { background: #fff; border-color: var(--mju-border); color: var(--mju-text); }
.mju-btn-secondary:hover { border-color: var(--mju-primary); color: var(--mju-primary); }
.mju-btn-ghost { background: transparent; border-color: var(--mju-border); color: var(--mju-text-soft); }
.mju-btn-ghost:hover { background: var(--mju-surface); border-color: var(--mju-primary); color: var(--mju-primary); }
.mju-btn-disabled { background: #ECECEC; color: #888; cursor: not-allowed; }
.mju-btn-disabled:hover { background: #ECECEC; color: #888; }

.mju-pill-row { list-style: none; padding: 0; margin: 8px 0; display: flex; flex-wrap: wrap; gap: 6px; }
.mju-pill {
	display: inline-flex; align-items: center; gap: 4px;
	padding: 3px 10px; font-size: .78rem; line-height: 1.4;
	background: var(--mju-surface); color: var(--mju-text-soft);
	border: 1px solid var(--mju-border); border-radius: 999px;
}
.mju-pill a { color: inherit; }
.mju-pill-org   { background: var(--mju-primary-soft); color: var(--mju-primary-dark); border-color: #C7D2E5; }
.mju-pill-state { background: #EAF1FB; color: #14346B; border-color: #C6D6EC; }
.mju-pill-type  { background: #E9F7EE; color: #0E6906; border-color: #C2E4CD; }
.mju-pill-soon  { background: #FEE2E2; color: var(--mju-urgency); border-color: #FCA5A5; font-weight: 600; }
.mju-pill-warn  { background: #FFF1DA; color: #B45309; border-color: #FAD9A6; }
.mju-pill-ok    { background: #E9F7EE; color: var(--mju-accent-dark); border-color: #C2E4CD; }
.mju-pill-closed { background: #ECECEC; color: #888; border-color: #d8d8d8; }

.mju-link { color: var(--mju-primary); font-weight: 600; display: inline-flex; align-items: center; gap: 4px; }
.mju-link:hover { color: var(--mju-primary-dark); }

/* === 3. Cards & grids === */
.mju-card {
	background: #fff; border: 1px solid var(--mju-border); border-radius: var(--mju-radius-lg);
	padding: 16px 18px; box-shadow: var(--mju-shadow-sm);
}
.mju-card h2 { font-size: 1.05rem; margin: 0 0 10px; display: flex; align-items: center; gap: 6px; color: var(--mju-primary); }
.mju-card__lead { margin: 0 0 10px; font-size: 1rem; }
.mju-card__lead strong { font-size: 1.4rem; color: var(--mju-primary); }

.mju-grid { display: grid; gap: 16px; grid-template-columns: 1fr; }
.mju-grid--cards { grid-template-columns: repeat(auto-fill, minmax(300px, 1fr)); }
.mju-grid--2col { grid-template-columns: repeat(2, minmax(0, 1fr)); }

/* === Job card v3 (centered, vertical stack, icon-text rows) === */
.mju-job-card--v3 {
	background: var(--mju-bg);
	border: 1px solid var(--mju-border);
	border-radius: 12px;
	padding: 24px 20px;
	text-align: center;
	display: flex;
	flex-direction: column;
	gap: 12px;
	min-width: 0;
	transition: transform .15s ease, box-shadow .15s ease, border-color .15s ease;
	box-shadow: var(--mju-shadow-sm);
}
.mju-job-card--v3:hover {
	transform: translateY(-2px);
	box-shadow: 0 8px 24px rgba(15, 44, 89, 0.10);
	border-color: var(--mju-primary);
}
.mju-job-card--v3.mju-job-card--expiring {
	background: var(--mju-saffron-soft);
	border-color: #F5D9A8;
}

.mju-job-card__avatar-wrap { display: flex; justify-content: center; }

/* Org avatar circle */
.mju-org-avatar {
	width: 48px; height: 48px; border-radius: 50%;
	display: inline-flex; align-items: center; justify-content: center;
	color: #fff; font-weight: 700; font-size: .82rem; letter-spacing: .02em;
	flex-shrink: 0; user-select: none; line-height: 1;
}
.mju-org-avatar--sm { width: 32px; height: 32px; font-size: .68rem; }
.mju-org-avatar--lg { width: 56px; height: 56px; font-size: 16px; font-weight: 700; }

.mju-job-card--v3 .mju-job-card__title {
	font-size: 16px;
	font-weight: 600;
	line-height: 1.35;
	color: var(--mju-text-muted);
	margin: 4px 0 0;
	display: -webkit-box;
	-webkit-line-clamp: 2;
	-webkit-box-orient: vertical;
	overflow: hidden;
}
.mju-job-card--v3 .mju-job-card__title a { color: inherit; text-decoration: none; }
.mju-job-card--v3 .mju-job-card__title a:hover { color: var(--mju-primary); }

.mju-job-card--v3 .mju-job-card__org {
	font-size: 22px;
	line-height: 1.25;
	color: var(--mju-primary);
	margin: 8px 0 0;
	font-weight: 800;
	letter-spacing: -0.2px;
}

.mju-job-card__meta {
	list-style: none; padding: 0; margin: 12px 0 4px;
	display: flex; flex-wrap: wrap; gap: 8px 16px;
	justify-content: center; align-items: center;
	font-size: 14px; color: var(--mju-text);
}
.mju-job-card__meta li {
	display: inline-flex; align-items: center; gap: 6px;
	flex: 0 1 auto; min-width: 0;
	max-width: 100%;
	overflow-wrap: break-word; word-break: break-word;
	line-height: 1.4;
	text-align: left;
}
.mju-job-card__meta li svg { width: 18px; height: 18px; flex-shrink: 0; color: var(--mju-primary); }
.mju-job-card__meta li strong { color: var(--mju-primary); font-weight: 700; }

.mju-job-card__cta { margin-top: 4px; }

.mju-empty { padding: 24px; text-align: center; color: var(--mju-text-muted); border: 1px dashed var(--mju-border); border-radius: var(--mju-radius); background: var(--mju-surface-alt); }

/* === 4. Homepage sections === */
.mju-section { padding: 32px 0; }
.mju-section--surface { background: var(--mju-surface); }
.mju-section--soon { padding-top: 24px; padding-bottom: 24px; }
.mju-section--top-jobs { background: var(--mju-bg); }
.mju-section--expiring { background: var(--mju-saffron-soft); }
.mju-section--latest { background: var(--mju-bg); }
.mju-section__head {
	display: flex; align-items: center; justify-content: space-between;
	margin-bottom: 16px; gap: 12px;
}
.mju-section__head h2 {
	margin: 0; font-size: 1.4rem; display: flex; align-items: center; gap: 8px;
	color: var(--mju-text); font-weight: 700;
}
.mju-section__head .mju-section__icon { font-size: 1.4rem; line-height: 1; }
.mju-section--expiring .mju-section__head h2 { color: var(--mju-urgency); }

/* Hero — clean white, restrained */
.mju-hero {
	background: var(--mju-bg);
	color: var(--mju-text);
	padding: 48px 0 56px;
	border-bottom: 1px solid var(--mju-border);
}
.mju-hero h1 {
	margin: 0 0 8px;
	font-size: 1.9rem;
	line-height: 1.2;
	color: var(--mju-primary);
	text-shadow: none;
	font-weight: 800;
	letter-spacing: -0.02em;
}
.mju-hero p {
	margin: 0 0 18px;
	color: var(--mju-text-muted);
	font-size: 1rem;
}
.mju-hero-stats {
	margin-top: 14px;
	display: flex; flex-wrap: wrap; gap: 8px 14px;
	color: var(--mju-text-muted);
	font-size: .9rem;
	align-items: baseline;
}
.mju-hero-stats strong { color: var(--mju-primary); font-weight: 700; }
.mju-hero-stats span { display: inline-flex; align-items: baseline; gap: 4px; }
@media (min-width: 720px) {
	.mju-hero h1 { font-size: 2.5rem; }
	.mju-hero p { font-size: 1.1rem; }
}

/* Stats strip */
.mju-stats { background: #fff; border-bottom: 1px solid var(--mju-border); }
.mju-stats__grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 16px; padding: 18px 16px; }
.mju-stat { display: flex; align-items: center; gap: 12px; }
.mju-stat__icon { width: 44px; height: 44px; border-radius: 50%; background: var(--mju-primary-soft); color: var(--mju-primary); display: inline-flex; align-items: center; justify-content: center; flex-shrink: 0; }
.mju-stat strong { display: block; font-size: 1.4rem; line-height: 1.1; color: var(--mju-text); }
.mju-stat span { font-size: .8rem; color: var(--mju-text-muted); }

/* Last-date-soon scroll (legacy, kept for safety) */
.mju-soon-scroll {
	display: flex; gap: 12px; overflow-x: auto; padding-bottom: 8px;
	scroll-snap-type: x mandatory; -webkit-overflow-scrolling: touch;
}
.mju-soon-scroll .mju-job-card { flex: 0 0 320px; scroll-snap-align: start; }

/* Top Jobs / Latest / Expiring grids on homepage */
.mju-home-jobs-grid {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
	gap: 20px;
}
@media (max-width: 480px) {
	.mju-home-jobs-grid { grid-template-columns: 1fr; gap: 16px; }
}

/* Expiring badge (homepage section accent) */
.mju-expiring-badge {
	display: inline-flex; align-items: center;
	background: var(--mju-urgency); color: #fff;
	padding: 2px 10px; border-radius: 999px;
	font-size: .76rem; font-weight: 600; line-height: 1.5;
}

/* Category cards */
.mju-cat-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(150px, 1fr)); gap: 12px; }
.mju-cat-card {
	display: flex; flex-direction: column; align-items: flex-start; gap: 4px;
	background: #fff; border: 1px solid var(--mju-border); border-radius: var(--mju-radius-lg);
	padding: 16px 14px; color: var(--mju-text); text-decoration: none !important;
	transition: border-color .15s, transform .05s, box-shadow .15s;
}
.mju-cat-card:hover { border-color: var(--mju-primary); transform: translateY(-1px); box-shadow: var(--mju-shadow); }
.mju-cat-card__icon { width: 38px; height: 38px; background: var(--mju-primary-soft); color: var(--mju-primary); border-radius: 8px; display: inline-flex; align-items: center; justify-content: center; }
.mju-cat-card__name { font-weight: 700; }
.mju-cat-card__count { font-size: .78rem; color: var(--mju-text-muted); }

/* State cards */
.mju-state-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(140px, 1fr)); gap: 10px; }
.mju-state-card {
	display: flex; align-items: center; justify-content: space-between;
	background: #fff; border: 1px solid var(--mju-border); border-radius: var(--mju-radius);
	padding: 12px 14px; color: var(--mju-text); font-weight: 600;
}
.mju-state-card:hover { border-color: var(--mju-primary); text-decoration: none; }
.mju-state-card__name { display: inline-flex; align-items: center; gap: 6px; }
.mju-state-card__count { background: var(--mju-primary-soft); color: var(--mju-primary); border-radius: 999px; padding: 1px 8px; font-size: .78rem; font-weight: 600; }

/* Qualification pills (homepage) */
.mju-pills-row { display: flex; flex-wrap: wrap; gap: 8px; }
.mju-qual-pill {
	display: inline-flex; align-items: center; gap: 6px;
	background: #fff; border: 1px solid var(--mju-border); border-radius: 999px;
	padding: 10px 16px; color: var(--mju-text); font-weight: 600;
}
.mju-qual-pill:hover { border-color: var(--mju-primary); color: var(--mju-primary); text-decoration: none; }

/* Two-col (admit + result) */
.mju-two-col { display: grid; grid-template-columns: 1fr 1fr; gap: 24px; }
.mju-list { list-style: none; padding: 0; margin: 0; }
.mju-list li { padding: 10px 0; border-bottom: 1px dashed var(--mju-border); display: flex; justify-content: space-between; gap: 8px; align-items: baseline; }
.mju-list li:last-child { border-bottom: 0; }
.mju-list small { color: var(--mju-text-muted); font-size: .78rem; flex-shrink: 0; }

/* Tag cloud */
.mju-tag-cloud { display: flex; flex-wrap: wrap; gap: 6px 8px; align-items: baseline; }
.mju-tag {
	background: #fff; border: 1px solid var(--mju-border); border-radius: 999px;
	padding: 4px 10px; color: var(--mju-text-soft); line-height: 1.6;
}
.mju-tag:hover { background: var(--mju-primary); color: #fff; border-color: var(--mju-primary); text-decoration: none; }

/* CTA */
.mju-section--cta { background: linear-gradient(135deg, #0F2C59 0%, #0A1F40 100%); color: #fff; }
.mju-cta { display: grid; grid-template-columns: 1fr 1fr; gap: 24px; align-items: center; }
.mju-cta h2 { color: #fff; margin: 0 0 4px; }
.mju-cta p { margin: 0; opacity: .9; }
.mju-cta__form { background: #fff; border-radius: var(--mju-radius); display: flex; align-items: center; gap: 6px; padding: 4px 4px 4px 12px; }
.mju-cta__icon { color: var(--mju-text-muted); }
.mju-cta__form input { flex: 1; min-width: 0; border: 0; padding: 12px 4px; font-size: 1rem; outline: none; background: transparent; color: var(--mju-text); }
.mju-cta__msg { display: block; padding-top: 8px; font-size: .85rem; color: #FFD9B0;}

/* === 5. Single job === */
.mju-crumb { font-size: .85rem; color: var(--mju-text-muted); padding: 18px 0 8px; display: flex; flex-wrap: wrap; gap: 6px; align-items: center; }
.mju-crumb a { color: var(--mju-text-soft); }
.mju-crumb__current { color: var(--mju-text); font-weight: 600; }

.mju-job__header { padding: 8px 0 16px; border-bottom: 1px solid var(--mju-border); margin-bottom: 18px; }
.mju-job__title { font-size: 1.6rem; line-height: 1.25; margin: 0 0 8px; color: var(--mju-text); }
.mju-job__meta { display: flex; align-items: center; justify-content: space-between; flex-wrap: wrap; gap: 10px; margin: 8px 0 14px; }
.mju-job__cta { display: flex; align-items: center; gap: 14px; flex-wrap: wrap; }
.mju-countdown { display: inline-flex; align-items: center; gap: 4px; font-weight: 600; color: var(--mju-warning); }
.mju-countdown.is-soon { color: var(--mju-urgency); }
.mju-countdown.is-closed { color: var(--mju-text-muted); }

.mju-share { display: inline-flex; gap: 6px; }
.mju-share__btn {
	width: 36px; height: 36px; border-radius: 50%;
	display: inline-flex; align-items: center; justify-content: center;
	background: var(--mju-surface); border: 1px solid var(--mju-border);
	color: var(--mju-text-soft); cursor: pointer;
}
.mju-share__btn:hover { background: var(--mju-primary); color: #fff; border-color: var(--mju-primary); text-decoration: none; }
.mju-share__copy.is-copied { background: var(--mju-success); color: #fff; border-color: var(--mju-success); }

.mju-job__grid { display: grid; gap: 14px; grid-template-columns: 1fr 1fr; }
.mju-card--dates, .mju-card--content, .mju-card--links { grid-column: 1 / -1; }
.mju-job__grid .mju-card { background: var(--mju-surface); border: 1px solid var(--mju-border); }
.mju-job__grid .mju-card h2 { color: var(--mju-primary); }

.mju-dates-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(150px, 1fr)); gap: 10px; margin: 0; }
.mju-date-cell { padding: 10px 12px; background: #fff; border-radius: var(--mju-radius); border: 1px solid var(--mju-border); }
.mju-date-cell.is-soon { background: #FEE2E2; border-color: #FCA5A5; }
.mju-date-cell dt { font-size: .78rem; color: var(--mju-text-muted); margin-bottom: 4px; }
.mju-date-cell dd { margin: 0; font-weight: 700; color: var(--mju-text); }
.mju-date-cell.is-soon dd { color: var(--mju-urgency); }
.mju-date-cell small { display: block; font-weight: 500; font-size: .75rem; opacity: .8; }

.mju-table { width: 100%; border-collapse: collapse; margin-top: 6px; font-size: .92rem; }
.mju-table th, .mju-table td { padding: 8px 10px; border-bottom: 1px solid var(--mju-border); text-align: left; }
.mju-table th { background: var(--mju-primary-soft); color: var(--mju-primary); font-weight: 700; }

.mju-kv { display: grid; grid-template-columns: max-content 1fr; gap: 6px 16px; margin: 0; }
.mju-kv dt { color: var(--mju-text-muted); font-weight: 500; }
.mju-kv dd { margin: 0; font-weight: 600; }

.mju-prose { line-height: 1.6; }
.mju-prose p { margin: 0 0 10px; }
.mju-prose ul, .mju-prose ol { margin: 0 0 10px 20px; }
.mju-prose a { color: var(--mju-primary); }

.mju-details { background: #fff; border: 1px solid var(--mju-border); border-radius: var(--mju-radius); padding: 8px 12px; margin-top: 8px; }
.mju-details summary { cursor: pointer; font-weight: 600; }

.mju-link-buttons { display: flex; flex-wrap: wrap; gap: 10px; }
.mju-related { padding: 32px 0; }
.mju-apply-sticky { position: fixed; left: 0; right: 0; bottom: 0; background: rgba(255,255,255,0.97); border-top: 1px solid var(--mju-border); padding: 10px 16px; box-shadow: 0 -2px 10px rgba(0,0,0,.08); z-index: 50; display: none; }
.mju-apply-sticky .mju-btn { width: 100%; }

/* === 6. Archive / list === */
.mju-archive-hero {
	background: var(--mju-bg);
	color: var(--mju-text);
	padding: 28px 0;
	border-bottom: 1px solid var(--mju-border);
}
.mju-archive-hero h1 { margin: 0 0 4px; font-size: 1.8rem; color: var(--mju-primary); }
.mju-archive-hero p { margin: 0; color: var(--mju-text-muted); }
.mju-archive-hero__count { font-size: .9rem; margin-top: 6px !important; color: var(--mju-text-muted); }
.mju-archive-hero__desc { margin-top: 8px; color: var(--mju-text-muted); }
.mju-archive { display: grid; grid-template-columns: 280px 1fr; gap: 24px; padding: 24px 16px; }
.mju-archive__main { min-width: 0; }
.mju-archive__toolbar { display: flex; justify-content: flex-end; margin-bottom: 14px; }
.mju-sort-form { display: inline-flex; align-items: center; gap: 8px; }
.mju-sort-form select { padding: 8px 10px; border: 1px solid var(--mju-border); border-radius: var(--mju-radius); background: #fff; color: var(--mju-text); font-size: .9rem; min-height: 40px; }
.mju-pagination { margin-top: 24px; text-align: center; }
.mju-pagination .page-numbers { display: inline-block; padding: 8px 14px; margin: 0 2px; border: 1px solid var(--mju-border); border-radius: var(--mju-radius); color: var(--mju-text); }
.mju-pagination .page-numbers:hover { border-color: var(--mju-primary); color: var(--mju-primary); }
.mju-pagination .page-numbers.current { background: var(--mju-primary); color: #fff; border-color: var(--mju-primary); }

/* Active filter chip on archive */
.mju-active-filter {
	display: inline-flex; align-items: center; gap: 4px;
	background: var(--mju-primary); color: #fff;
	padding: 3px 10px; border-radius: 999px; font-size: .8rem; font-weight: 600;
}

/* === 7. Search === */
.mju-search-form { display: flex; gap: 8px; margin-top: 14px; }
.mju-search-form input { flex: 1; padding: 12px 14px; border: 0; border-radius: var(--mju-radius); font-size: 1rem; }
.mju-search-results { padding: 24px 16px; }

/* === 8. Footer === */
.mju-footer { background: var(--mju-text); color: #CBD5E1; margin-top: 36px; padding: 32px 0 0; font-size: .9rem; }
.mju-footer h4, .mju-footer h5 { color: #fff; margin: 0 0 8px; }
.mju-footer__inner { display: grid; grid-template-columns: 1fr 2fr; gap: 24px; padding-bottom: 24px; }
.mju-footer__cols { display: grid; grid-template-columns: repeat(3, 1fr); gap: 18px; }
.mju-footer ul { list-style: none; padding: 0; margin: 0; }
.mju-footer li { padding: 3px 0; }
.mju-footer a { color: #CBD5E1; }
.mju-footer a:hover { color: var(--mju-saffron); }
.mju-footer__bottom { background: rgba(0,0,0,0.35); padding: 12px 0; }
.mju-footer__bottom small { color: #94A3B8; }

/* === 9. Responsive (mobile-first cleanups) === */
@media (max-width: 900px) {
	.mju-archive { grid-template-columns: 1fr; }
	.mju-job__grid { grid-template-columns: 1fr; }
	.mju-cta { grid-template-columns: 1fr; }
	.mju-two-col { grid-template-columns: 1fr; }
	.mju-footer__inner { grid-template-columns: 1fr; }
	.mju-footer__cols { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 600px) {
	.mju-stats__grid { grid-template-columns: repeat(3, minmax(0, 1fr)); gap: 8px; }
	.mju-stat { padding: 12px 6px !important; }
	.mju-stat__num { font-size: 1.4rem !important; }
	.mju-stat__label { font-size: 0.7rem !important; line-height: 1.2; }
	.mju-job__title { font-size: 1.3rem; }
	.mju-section { padding: 24px 0; }
	.mju-section__head { flex-direction: column; align-items: flex-start; }
	.mju-apply-sticky { display: block; }
	body.mju-themed { padding-bottom: 76px; }
	.mju-footer__cols { grid-template-columns: 1fr; }
	.mju-grid--cards { grid-template-columns: 1fr; }
}

/* Touch targets — Indian mobile audience priority */
@media (max-width: 768px) {
	.mju-btn-sm { min-height: 40px; }
	.mju-pill { padding: 4px 10px; font-size: .8rem; }
}

/* Hover (desktop) — apply to v3 cards already; keep legacy hover too */
@media (hover: hover) {
	.mju-job-card:hover {
		transform: translateY(-2px);
		box-shadow: var(--mju-shadow-hover);
		border-color: var(--mju-primary);
	}
}

/* ──────────────────────────────────────────────────────────────────
   mju-prose typography — humanised, readable single-job description
   ────────────────────────────────────────────────────────────────── */
.mju-prose {
  max-width: 70ch;
  margin: 24px auto;
  color: var(--mju-text);
  font-size: 16.5px;
  line-height: 1.75;
}
.mju-prose > * + * { margin-top: 1.1em; }
.mju-prose p { margin: 0 0 1.1em; }
.mju-prose h1, .mju-prose h2, .mju-prose h3, .mju-prose h4, .mju-prose h5 {
  color: var(--mju-primary);
  line-height: 1.3;
  margin: 1.6em 0 0.6em;
  font-weight: 700;
}
.mju-prose h2 { font-size: 22px; padding-bottom: 6px; border-bottom: 2px solid var(--mju-primary-soft); }
.mju-prose h3 { font-size: 19px; }
.mju-prose h4 { font-size: 17px; }
.mju-prose strong { color: var(--mju-text); font-weight: 700; }
.mju-prose em { font-style: italic; color: var(--mju-text-muted); }
.mju-prose a {
  color: var(--mju-primary);
  text-decoration: underline;
  text-decoration-thickness: 1px;
  text-underline-offset: 3px;
  word-break: break-word;
}
.mju-prose a:hover { color: var(--mju-primary-dark); text-decoration-thickness: 2px; }
.mju-prose ul, .mju-prose ol { padding-left: 1.4em; margin: 0 0 1.1em; }
.mju-prose li { margin: 0.4em 0; }
.mju-prose li::marker { color: var(--mju-primary); font-weight: 700; }
.mju-prose blockquote {
  border-left: 4px solid var(--mju-primary);
  background: var(--mju-surface);
  padding: 12px 18px;
  margin: 1.4em 0;
  color: var(--mju-text-muted);
  border-radius: 0 6px 6px 0;
}
.mju-prose hr {
  border: 0;
  border-top: 1px solid var(--mju-border);
  margin: 2em 0;
}
.mju-prose table {
  width: 100%;
  border-collapse: collapse;
  margin: 1.4em 0;
}
.mju-prose th, .mju-prose td {
  border: 1px solid var(--mju-border);
  padding: 10px 12px;
  text-align: left;
}
.mju-prose th { background: var(--mju-surface); color: var(--mju-primary); font-weight: 700; }
.mju-prose code {
  background: var(--mju-surface-alt);
  padding: 2px 6px;
  border-radius: 4px;
  font-size: 0.9em;
}
.mju-prose img { max-width: 100%; height: auto; border-radius: 8px; margin: 1em auto; display: block; }
.mju-prose p[style*="text-align: center"] { /* normalize legacy centered paragraphs from migrated content */ font-size: 16px; }
@media (max-width: 720px) {
  .mju-prose { font-size: 16px; line-height: 1.7; padding: 0 4px; }
  .mju-prose h2 { font-size: 20px; }
  .mju-prose h3 { font-size: 18px; }
}

/* Hide empty CTA wrappers (e.g. when apply is closed and the button returns ''
   leaving an empty .mju-job__cta div) */
.mju-job__cta:empty,
.mju-apply-sticky:empty {
  display: none !important;
}
.mju-job__cta:has(:not(.mju-countdown):empty) { /* fallback for older browsers */
  display: none;
}
/* Also hide the sticky-apply on mobile when the inner button is missing */
.mju-apply-sticky:not(:has(.mju-btn-apply)) {
  display: none;
}

/* Card CTA outline override — keeps "View Full Details" visually distinct
   from the green Apply button on single-job pages. Outlined navy by default,
   fills on hover. */
.mju-job-card--v3 .mju-job-card__cta {
  background: transparent;
  color: var(--mju-primary);
  border: 1.5px solid var(--mju-primary);
  font-weight: 700;
  letter-spacing: 0.2px;
  transition: background-color .15s ease, color .15s ease, transform .15s ease;
}
.mju-job-card--v3 .mju-job-card__cta:hover,
.mju-job-card--v3 .mju-job-card__cta:focus {
  background: var(--mju-primary);
  color: #fff;
  transform: translateY(-1px);
}
.mju-job-card--v3 .mju-job-card__cta svg {
  transition: transform .15s ease;
}
.mju-job-card--v3 .mju-job-card__cta:hover svg {
  transform: translateX(3px);
}

.mju-job-card__meta li > span { display: inline-block; max-width: 100%; overflow-wrap: anywhere; word-break: break-word; }
.mju-job-card__meta li > span { display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical; overflow: hidden; }

/* Org row — avatar + name inline ─────────────────────────────── */
.mju-job-card__org-row {
  display: flex; align-items: center; justify-content: center;
  gap: 10px; flex-wrap: nowrap;
  margin: 0 0 4px;
  text-align: left;
}
.mju-job-card__org-row .mju-org-avatar {
  flex-shrink: 0;
}
.mju-job-card--v3 .mju-job-card__org-row .mju-job-card__org {
  margin: 0;
  font-size: 19px;
  line-height: 1.2;
  text-align: left;
  word-break: break-word;
  overflow-wrap: anywhere;
}

/* Color contrast sweep ─────────────────────────────────────────── */
.mju-pill { border: 1px solid var(--mju-border); background: #fff; color: var(--mju-text); }
.mju-pill a { color: inherit; }
.mju-pill-state { background: #E6F4EC; color: #0E6906; border-color: #C2E4CD; }
.mju-pill-org   { background: #E6EBF3; color: #0F2C59; border-color: #C7D2E5; }
.mju-pill-type  { background: #F1F5F9; color: #475569; border-color: #CBD5E1; }
.mju-section--expiring { background: #FFF8E7; }   /* warmer cream — better than saffron tint */
.mju-section--expiring .mju-section__head h2 { color: #B91C1C; }  /* readable urgency red */
.mju-empty { color: var(--mju-text-muted); }
.mju-link, .mju-link a { color: var(--mju-primary); }
body.mju-themed .mju-card a { color: var(--mju-primary); }
.mju-cat-card, .mju-state-card, .mju-qual-pill { color: var(--mju-text); background: var(--mju-bg); }

/* Mobile filter drawer ─────────────────────────────────────────── */
.mju-filters-toggle { display: none; }
@media (max-width: 900px) {
  .mju-archive { display: block; }
  .mju-filters {
    position: fixed; top: 0; left: 0; right: 0; bottom: 0;
    width: 100vw; max-width: 360px;
    z-index: 1000;
    background: var(--mju-bg);
    transform: translateX(-110%); /* fully off-screen */
    transition: transform .25s ease, visibility .25s;
    visibility: hidden;
    overflow-y: auto; padding: 16px 16px 100px;
    box-shadow: 4px 0 24px rgba(0,0,0,0.15);
  }
  body.mju-filters-open .mju-filters { visibility: visible; }
  body.mju-filters-open .mju-filters { transform: translateX(0); }
  body.mju-filters-open { overflow: hidden; }
  .mju-filters::before {
    content: ""; position: sticky; top: 0; left: 0;
    display: block; height: 8px;
    background: linear-gradient(to bottom, var(--mju-bg), transparent);
    margin: -16px -16px 0;
  }
  .mju-filters-close {
    position: sticky; top: 8px;
    display: inline-flex; align-items: center; gap: 6px;
    margin: 0 0 12px auto;
    padding: 8px 14px; background: var(--mju-surface); border: 1px solid var(--mju-border);
    border-radius: 999px; font-size: 14px; cursor: pointer; color: var(--mju-text);
  }
  .mju-filters-toggle {
    display: inline-flex; align-items: center; gap: 8px;
    padding: 10px 16px; margin: 0 0 12px;
    background: var(--mju-bg); border: 1.5px solid var(--mju-primary);
    color: var(--mju-primary); border-radius: 999px;
    font-size: 14px; font-weight: 600; cursor: pointer;
  }
  .mju-filters-toggle:active { transform: scale(0.98); }
  .mju-filters-toggle__count {
    background: var(--mju-primary); color: #fff;
    border-radius: 999px; padding: 1px 8px; font-size: 12px;
  }
}

/* Archive hero — title left, filter button right ──────────────── */
.mju-archive-hero__row {
  display: flex; align-items: center; gap: 16px;
  flex-wrap: wrap;
}
.mju-archive-hero__left {
  flex: 1 1 auto; min-width: 0;
}
.mju-archive-hero__left h1 {
  margin: 0 0 4px;
  font-size: 1.4rem; line-height: 1.3;
  color: var(--mju-primary);
  word-break: break-word;
}
.mju-archive-hero__left p {
  margin: 0; color: var(--mju-text-muted); font-size: 0.92rem;
}
.mju-archive-hero__count {
  font-size: 0.85rem; color: var(--mju-text-muted); margin: 0;
}
@media (min-width: 720px) {
  .mju-archive-hero__left h1 { font-size: 1.8rem; }
}

/* Hide the filter toggle on desktop (≥901px), show on tablet/mobile */
.mju-filters-toggle {
  display: none;
  align-items: center; gap: 8px;
  padding: 10px 16px;
  background: var(--mju-bg);
  border: 1.5px solid var(--mju-primary);
  color: var(--mju-primary);
  border-radius: 999px;
  font-size: 14px; font-weight: 600; cursor: pointer;
  flex-shrink: 0;
  white-space: nowrap;
}
.mju-filters-toggle:hover { background: var(--mju-primary); color: #fff; }
@media (max-width: 900px) {
  .mju-filters-toggle { display: inline-flex; }
}

.mju-sort-form--hero select { max-width: 100px; }

/* ────────────────────────────────────────────────────────────────
   Archive hero actions: Filter (left) + Sort (right) — equal-sized pills
   ──────────────────────────────────────────────────────────────── */
:root {
  --mju-control-height: 42px;
  --mju-control-radius: 999px;
}
.mju-archive-hero__actions {
  display: inline-flex; align-items: center; gap: 16px;
  flex-wrap: nowrap;
}

/* Common base — both controls share these dimensions */
.mju-archive-hero__actions .mju-filters-toggle,
.mju-archive-hero__actions .mju-sort-form--hero {
  height: var(--mju-control-height);
  box-sizing: border-box;
  display: inline-flex;
  align-items: center;
  border-radius: var(--mju-control-radius);
  font-size: 14px;
  font-weight: 600;
  line-height: 1;
  background: #fff;
  margin: 0;
  padding: 0 18px;
  border: 1.5px solid var(--mju-border-strong, #CBD5E1);
  white-space: nowrap;
  cursor: pointer;
  transition: border-color .15s ease, background-color .15s ease, color .15s ease;
}

/* Filter pill — outlined navy, more visually prominent */
.mju-archive-hero__actions .mju-filters-toggle {
  border-color: var(--mju-primary);
  color: var(--mju-primary);
  gap: 8px;
}
.mju-archive-hero__actions .mju-filters-toggle:hover,
.mju-archive-hero__actions .mju-filters-toggle:focus {
  background: var(--mju-primary);
  color: #fff;
}

/* Sort pill — neutral outlined, content has Sort label + select */
.mju-sort-form--hero {
  gap: 8px;
  padding: 0 8px 0 16px;
}
.mju-sort-form--hero:hover { border-color: var(--mju-primary); }
.mju-sort-form__label {
  display: inline-flex; align-items: center; gap: 6px;
  color: var(--mju-text-muted);
  height: 100%;
}
.mju-sort-form__label svg { display: block; }

/* Select inside sort pill — fills the height, no inner padding fight */
.mju-sort-form--hero select {
  height: 100%;
  margin: 0;
  padding: 0 22px 0 4px;
  border: 0;
  background: transparent;
  background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='10' height='6' viewBox='0 0 10 6'><path d='M1 1l4 4 4-4' fill='none' stroke='%230F2C59' stroke-width='1.5'/></svg>");
  background-repeat: no-repeat;
  background-position: right 4px center;
  font-size: 14px;
  font-weight: 700;
  color: var(--mju-primary);
  cursor: pointer;
  appearance: none; -webkit-appearance: none;
  max-width: 150px;
  line-height: 1;
}
.mju-sort-form--hero select:focus {
  outline: 2px solid var(--mju-primary);
  outline-offset: 2px;
  border-radius: 6px;
}
.mju-sort-form--hero select option { color: var(--mju-text); }

/* Hero row layout: title fills, actions hug right */
.mju-archive-hero__row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
  flex-wrap: wrap;
}
.mju-archive-hero__left { flex: 1 1 60%; min-width: 0; }
.mju-archive-hero__actions { flex: 0 0 auto; }

/* Desktop ≥901px hide rule — superseded by definitive end-of-file block. */

/* Mobile ≤720px: actions wrap full-width, filter still left, sort still right */
@media (max-width: 720px) {
  :root { --mju-control-height: 40px; }
  .mju-archive-hero__row { flex-direction: column; align-items: stretch; }
  .mju-archive-hero__left h1 { font-size: 1.25rem; }
  /* Legacy ≤720px toolbar-layout overrides removed — see consolidated
     mobile centering block at end of file (single source of truth). */
  .mju-archive-hero__actions .mju-filters-toggle { padding: 0 14px; font-size: 13px; }
  .mju-sort-form--hero { padding: 0 6px 0 12px; font-size: 13px; }
  .mju-sort-form--hero select { font-size: 13px; max-width: 120px; }
}

@media (max-width: 380px) {
  .mju-sort-form--hero select { max-width: 90px; }
}

/* Active jobs count — inline pill next to H1 title */
.mju-archive-hero__left {
  display: flex; align-items: baseline; flex-wrap: wrap; gap: 10px;
}
.mju-archive-hero__left h1 { margin: 0 !important; }
.mju-archive-hero__left p {
  flex-basis: 100%; margin: 4px 0 0 !important;
}
.mju-archive-hero__count {
  display: inline-flex; align-items: center;
  padding: 4px 10px;
  background: var(--mju-primary-soft);
  color: var(--mju-primary);
  border-radius: 999px;
  font-size: 13px; font-weight: 600;
  white-space: nowrap;
  margin: 0 !important;
}
@media (max-width: 480px) {
  .mju-archive-hero__count { font-size: 12px; padding: 3px 8px; }
}

/* ────────────────────────────────────────────────────────────────
   Sort pill — definitive size/padding (overrides earlier rules)
   ──────────────────────────────────────────────────────────────── */
.mju-archive-hero__actions .mju-sort-form--hero {
  /* outer pill */
  height: var(--mju-control-height);
  padding: 0 12px 0 16px !important;
  border: 1.5px solid var(--mju-border-strong, #CBD5E1);
  border-radius: var(--mju-control-radius);
  background: #fff;
  display: inline-flex;
  align-items: center;
  gap: 6px;
  box-sizing: border-box;
  overflow: visible;
}
.mju-sort-form--hero .mju-sort-form__label {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  height: 100%;
  color: var(--mju-text-muted);
  font-size: 14px;
  font-weight: 600;
  flex-shrink: 0;
  line-height: 1;
}
.mju-sort-form--hero .mju-sort-form__label svg { width: 14px; height: 14px; flex-shrink: 0; }

/* The select — clean reset, sized to fit text + chevron without overlap */
.mju-sort-form--hero select {
  /* dimensions */
  height: calc(var(--mju-control-height) - 6px);
  min-width: 90px;
  max-width: 170px;
  /* spacing: enough room on right for the chevron */
  padding: 0 26px 0 4px !important;
  /* visuals */
  border: 0 !important;
  background: transparent !important;
  background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='10' height='6' viewBox='0 0 10 6'><path d='M1 1l4 4 4-4' fill='none' stroke='%230F2C59' stroke-width='1.5'/></svg>") !important;
  background-repeat: no-repeat !important;
  background-position: right 6px center !important;
  /* type */
  font: inherit;
  font-size: 14px;
  font-weight: 700;
  color: var(--mju-primary);
  line-height: 1;
  /* behavior */
  appearance: none !important; -webkit-appearance: none !important;
  cursor: pointer;
  outline: 0;
  /* Avoid wrap + clipping; let chosen value show fully */
  text-overflow: ellipsis;
  white-space: nowrap;
}
.mju-sort-form--hero select:focus-visible {
  outline: 2px solid var(--mju-primary);
  outline-offset: 2px;
  border-radius: 6px;
}

@media (max-width: 720px) {
  .mju-sort-form--hero { padding: 0 8px 0 12px !important; }
  .mju-sort-form--hero select { font-size: 13px; max-width: 120px; padding-right: 24px !important; }
}
@media (max-width: 380px) {
  .mju-sort-form--hero select { max-width: 90px; min-width: 70px; }
}

/* ────────────────────────────────────────────────────────────────
   Sort pill v2 — <details>-based custom dropdown, matched to filter pill
   ──────────────────────────────────────────────────────────────── */
.mju-sort-pill {
  position: relative;
  height: var(--mju-control-height);
  display: inline-flex;
  align-items: center;
}
.mju-sort-pill > summary {
  list-style: none; cursor: pointer;
  display: inline-flex; align-items: center; gap: 8px;
  height: var(--mju-control-height);
  padding: 0 14px 0 16px;
  border: 1.5px solid var(--mju-primary);  /* MATCH filter pill outline */
  border-radius: var(--mju-control-radius);
  background: #fff;
  font-size: 14px;
  font-weight: 600;
  color: var(--mju-primary);
  white-space: nowrap;
  transition: background-color .15s ease, color .15s ease;
}
.mju-sort-pill > summary::-webkit-details-marker { display: none; }
.mju-sort-pill > summary::marker { display: none; content: ''; }
.mju-sort-pill > summary:hover { background: var(--mju-primary); color: #fff; }
.mju-sort-pill > summary:hover .mju-sort-pill__label { color: rgba(255,255,255,0.85); }
.mju-sort-pill__label { color: var(--mju-text-muted); font-weight: 600; }
.mju-sort-pill__value { font-weight: 700; max-width: 140px; overflow: hidden; text-overflow: ellipsis; }
.mju-sort-pill__chev { transition: transform .15s ease; }
.mju-sort-pill[open] > summary .mju-sort-pill__chev { transform: rotate(180deg); }

/* Dropdown menu — appears RIGHT BELOW the pill, aligned right */
.mju-sort-pill__menu {
  position: absolute;
  top: calc(100% + 8px);
  right: 0;
  margin: 0; padding: 6px;
  list-style: none;
  background: #fff;
  border: 1px solid var(--mju-border);
  border-radius: 12px;
  box-shadow: 0 12px 32px rgba(15, 44, 89, 0.15);
  min-width: 200px;
  z-index: 50;
  animation: mjuSortFade .15s ease;
}
@keyframes mjuSortFade {
  from { opacity: 0; transform: translateY(-4px); }
  to   { opacity: 1; transform: translateY(0); }
}
.mju-sort-pill__menu li { margin: 0; }
.mju-sort-pill__menu a {
  display: flex; align-items: center; justify-content: space-between; gap: 12px;
  padding: 10px 12px;
  border-radius: 8px;
  color: var(--mju-text);
  text-decoration: none;
  font-size: 14px;
  font-weight: 500;
  white-space: nowrap;
}
.mju-sort-pill__menu a:hover { background: var(--mju-surface); }
.mju-sort-pill__menu a.is-active {
  background: var(--mju-primary-soft); color: var(--mju-primary); font-weight: 700;
}
.mju-sort-pill__menu a.is-active svg { color: var(--mju-primary); flex-shrink: 0; }

/* Mobile: full-width pill, dropdown anchors to right of viewport */
@media (max-width: 720px) {
  .mju-sort-pill > summary { font-size: 13px; padding: 0 12px; }
  .mju-sort-pill__value { max-width: 90px; }
  .mju-sort-pill__menu { min-width: 180px; }
}

/* ────────────────────────────────────────────────────────────────
   Sort v3 — button + sibling menu in normal flow (pushes content)
   ──────────────────────────────────────────────────────────────── */
.mju-sort { display: inline-flex; align-items: center; }
.mju-sort__trigger {
  display: inline-flex; align-items: center; gap: 8px;
  height: var(--mju-control-height);
  padding: 0 14px 0 16px;
  background: #fff;
  border: 1.5px solid var(--mju-primary);
  border-radius: var(--mju-control-radius);
  color: var(--mju-primary);
  font-size: 14px; font-weight: 600; line-height: 1;
  white-space: nowrap; cursor: pointer;
  transition: background-color .15s ease, color .15s ease;
}
.mju-sort__trigger:hover, .mju-sort__trigger[aria-expanded="true"] {
  background: var(--mju-primary); color: #fff;
}
.mju-sort__label { color: var(--mju-text-muted); font-weight: 600; }
.mju-sort__trigger:hover .mju-sort__label,
.mju-sort__trigger[aria-expanded="true"] .mju-sort__label { color: rgba(255,255,255,0.85); }
.mju-sort__value { font-weight: 700; max-width: 140px; overflow: hidden; text-overflow: ellipsis; }
.mju-sort__chev { transition: transform .18s ease; }
.mju-sort__trigger[aria-expanded="true"] .mju-sort__chev { transform: rotate(180deg); }

/* Menu — full-width within container, in NORMAL FLOW (pushes content down) */
.mju-sort-menu {
  margin: 12px auto 0;
  background: #fff;
  border: 1px solid var(--mju-border);
  border-radius: 12px;
  box-shadow: 0 6px 18px rgba(15, 44, 89, 0.08);
  overflow: hidden;
  animation: mjuSortDrop .18s ease;
}
@keyframes mjuSortDrop {
  from { opacity: 0; transform: translateY(-6px); max-height: 0; }
  to   { opacity: 1; transform: translateY(0); max-height: 300px; }
}
.mju-sort-menu[hidden] { display: none; }

.mju-sort-menu__item {
  display: flex; align-items: center; justify-content: space-between;
  padding: 14px 18px;
  color: var(--mju-text);
  text-decoration: none;
  font-size: 15px;
  font-weight: 500;
  border-bottom: 1px solid var(--mju-surface);
}
.mju-sort-menu__item:last-child { border-bottom: 0; }
.mju-sort-menu__item:hover { background: var(--mju-surface); }
.mju-sort-menu__item.is-active {
  background: var(--mju-primary-soft); color: var(--mju-primary); font-weight: 700;
}
.mju-sort-menu__item.is-active svg { color: var(--mju-primary); }

@media (max-width: 720px) {
  .mju-sort__trigger { font-size: 13px; padding: 0 12px; }
  .mju-sort__value { max-width: 90px; }
  .mju-sort-menu__item { padding: 12px 14px; font-size: 14px; }
}

/* ────────────────────────────────────────────────────────────────
   Toolbar children — keep filter + sort on a single line, never wrap.
   Wrapper layout itself is governed by the authoritative block below.
   ──────────────────────────────────────────────────────────────── */
.mju-sort { display: inline-flex !important; align-items: center !important; }

.mju-archive-hero__actions .mju-filters-toggle,
.mju-archive-hero__actions .mju-sort,
.mju-archive-hero__actions .mju-sort__trigger {
  flex-shrink: 0;
}

/* ─── Hero search — match brand outline (navy) ─────────────────── */





/* ─── Sort button desktop sizing — match filter/title proportions ── */
@media (min-width: 901px) {
  .mju-archive-hero__actions .mju-sort__trigger,
  .mju-archive-hero__actions .mju-filters-toggle {
    height: 44px;
    font-size: 14px;
    padding: 0 18px;
  }
  .mju-sort__value { max-width: 160px; }
}

/* ─── Single-job: card backgrounds plain white ─────────────────── */
.mju-job__grid .mju-card {
  background: #fff !important;
  border: 1px solid var(--mju-border) !important;
  box-shadow: none !important;
}
.mju-job__grid .mju-card h2 { color: var(--mju-primary); }

/* ─── Make ENTIRE card clickable (cards on archive + home) ─────── */
.mju-job-card--v3 { position: relative; }
.mju-job-card--v3 .mju-job-card__title a::after {
  content: ""; position: absolute; inset: 0; z-index: 1;
  border-radius: 12px;
}
.mju-job-card--v3 .mju-job-card__cta,
.mju-job-card--v3 a:not(.mju-job-card__title a) { position: relative; z-index: 2; }
.mju-job-card--v3:hover { cursor: pointer; }

/* ─── Trending tags — fix selected/click state (not full blue) ── */
.mju-tag-cloud a,
.tag-cloud-link {
  display: inline-block !important;
  background: var(--mju-surface) !important;
  color: var(--mju-text) !important;
  border: 1px solid var(--mju-border) !important;
  border-radius: 999px;
  padding: 6px 12px;
  margin: 4px;
  font-size: 13px !important;
  text-decoration: none !important;
  transition: background-color .15s ease, color .15s ease;
}
.mju-tag-cloud a:hover,
.tag-cloud-link:hover {
  background: var(--mju-primary-soft) !important;
  color: var(--mju-primary) !important;
  border-color: var(--mju-primary) !important;
}
.mju-tag-cloud a:focus,
.mju-tag-cloud a:active,
.tag-cloud-link:focus,
.tag-cloud-link:active {
  background: var(--mju-primary-soft) !important;
  color: var(--mju-primary) !important;
  outline: 2px solid var(--mju-primary);
  outline-offset: 2px;
}

/* ─── Mobile: compact breadcrumb + title + share on single-job ── */
@media (max-width: 720px) {
  .mju-crumb {
    font-size: 11px; line-height: 1.3;
    margin-bottom: 8px;
    overflow: hidden; text-overflow: ellipsis; white-space: nowrap;
  }
  .mju-crumb a, .mju-crumb__current { font-size: 11px; }
  .mju-crumb .mju-crumb__current { display: inline; }
  .mju-job__title { font-size: 1.15rem !important; line-height: 1.3 !important; margin: 0 0 6px; }
  .mju-job__pills { gap: 4px !important; margin-top: 2px; }
  .mju-job__pills .mju-pill { font-size: 11px; padding: 2px 8px; }
  .mju-job__meta {
    display: flex; flex-direction: row; align-items: center;
    gap: 8px; flex-wrap: wrap; margin: 6px 0;
  }
  .mju-share { gap: 4px; }
  .mju-share__btn { width: 32px; height: 32px; padding: 0; }
}

/* ─── Footer text contrast + Daily-Alerts heading ──────────────── */
.mju-footer, footer.mju-footer, .site-footer.mju-themed {
  background: var(--mju-text);
  color: #E2E8F0;
}
.mju-footer h2, .mju-footer h3, .mju-footer h4,
footer h2, footer h3, footer h4 {
  color: #fff;
}
.mju-footer p, .mju-footer li, .mju-footer a, footer p, footer li {
  color: #CBD5E1;
}
.mju-footer a:hover { color: #fff; }
.mju-footer__copyright { color: #94A3B8; font-size: 12px; }

/* ─── Footer layout (3-4 column) ───────────────────────────── */
.mju-footer__inner {
  display: grid; grid-template-columns: 1.4fr repeat(3, 1fr);
  gap: 32px;
  padding: 40px 16px;
}
.mju-footer__col h4 {
  font-size: 14px; font-weight: 700; margin: 0 0 12px;
  letter-spacing: 0.04em; text-transform: uppercase;
}
.mju-footer__col ul { list-style: none; padding: 0; margin: 0; }
.mju-footer__col li { margin: 6px 0; font-size: 14px; }
.mju-footer__col a { text-decoration: none; }
.mju-footer__tag { font-size: 14px; line-height: 1.6; max-width: 420px; }
.mju-footer__bottom {
  border-top: 1px solid #1E293B;
  padding: 16px 0;
  background: rgba(0,0,0,0.2);
}
.mju-footer__bottom .mju-container {
  display: flex; align-items: center; justify-content: space-between;
  flex-wrap: wrap; gap: 12px;
}
.mju-footer__nav a { color: #CBD5E1; }
@media (max-width: 720px) {
  .mju-footer__inner { grid-template-columns: 1fr; gap: 24px; padding: 28px 16px; }
  .mju-footer__bottom .mju-container { flex-direction: column; text-align: center; }
}

/* ─── Browse blocks (homepage) ─────────────────────────────────── */
.mju-section--browse { padding: 32px 0; }
.mju-section--browse + .mju-section--browse { padding-top: 8px; }

.mju-cat-grid {
  display: grid; gap: 12px;
  grid-template-columns: repeat(auto-fill, minmax(180px, 1fr));
}
.mju-cat-card {
  display: flex; align-items: center; gap: 10px;
  padding: 14px 16px;
  background: #fff;
  border: 1px solid var(--mju-border);
  border-radius: 10px;
  text-decoration: none;
  color: var(--mju-text);
  transition: border-color .15s ease, transform .15s ease;
}
.mju-cat-card:hover { border-color: var(--mju-primary); transform: translateY(-1px); }
.mju-cat-card__icon {
  width: 36px; height: 36px; border-radius: 8px;
  background: var(--mju-primary-soft); color: var(--mju-primary);
  display: inline-flex; align-items: center; justify-content: center;
  flex-shrink: 0;
}
.mju-cat-card__name { flex: 1; font-weight: 600; font-size: 14px; }
.mju-cat-card__count {
  background: var(--mju-primary-soft); color: var(--mju-primary);
  border-radius: 999px; padding: 2px 8px; font-size: 12px; font-weight: 700;
}

.mju-state-region { margin-bottom: 24px; }
.mju-state-region__title {
  font-size: 13px; font-weight: 700; text-transform: uppercase;
  letter-spacing: 0.06em; color: var(--mju-text-muted);
  margin: 0 0 10px;
}
.mju-state-grid {
  display: grid; gap: 8px;
  grid-template-columns: repeat(auto-fill, minmax(160px, 1fr));
}
.mju-state-card {
  display: flex; align-items: center; justify-content: space-between;
  padding: 10px 14px;
  background: #fff;
  border: 1px solid var(--mju-border);
  border-radius: 8px;
  text-decoration: none;
  color: var(--mju-text);
  font-size: 13px; font-weight: 500;
}
.mju-state-card:hover { border-color: var(--mju-primary); color: var(--mju-primary); }
.mju-state-card__count {
  background: var(--mju-primary-soft); color: var(--mju-primary);
  border-radius: 999px; padding: 1px 7px; font-size: 11px; font-weight: 700;
}

.mju-qual-grid { display: flex; flex-wrap: wrap; gap: 8px; }
.mju-qual-pill {
  display: inline-flex; align-items: center; gap: 6px;
  padding: 8px 14px;
  background: #fff;
  border: 1.5px solid var(--mju-border);
  border-radius: 999px;
  font-size: 14px; font-weight: 600;
  color: var(--mju-text);
  text-decoration: none;
}
.mju-qual-pill:hover { border-color: var(--mju-primary); color: var(--mju-primary); }
.mju-qual-pill svg { color: var(--mju-primary); }
.mju-qual-pill small { color: var(--mju-text-muted); font-weight: 600; font-size: 11px; }

.mju-hero h1 { color: var(--mju-primary); margin: 0 0 8px; }
.mju-hero p { color: var(--mju-text-muted); margin: 0 0 18px; }








/* ─── Hide any ads from ad-inserter throughout the site (no ads requested) */
.ai-viewport-0, .ai-viewport-1, .ai-viewport-2, .ai-viewport-3, .ai-viewport-others,
[id^="ai-"][class*="ad-inserter"],
.ai-inserter, .adsbygoogle {
  display: none !important;
}

/* Hide any leftover count badges if templates still emit them */
.mju-cat-card__count,
.mju-state-card__count,
.mju-qual-pill small { display: none !important; }

/* ============================================================
   FOOTER v2 (1.22.0) — Option C: navy ground + saffron top stripe
   + saffron underline pulse on links. Logo readable on dark bg.
   Higher specificity than legacy .mju-footer rules so we don't
   need !important and don't disturb other styles.
   ============================================================ */

body.mju-themed .mju-footer.mju-footer--v2 {
	background: var(--mju-primary);
	color: #E2E8F0;
	margin-top: 48px;
	padding: 0;
	font-size: 14px;
	line-height: 1.55;
	position: relative;
}
body.mju-themed .mju-footer.mju-footer--v2::before {
	content: "";
	display: block;
	height: 4px;
	width: 100%;
	background: var(--mju-saffron);
}

body.mju-themed .mju-footer.mju-footer--v2 .mju-footer__inner {
	display: grid;
	grid-template-columns: 1.4fr 1fr 1fr 1fr 1fr;
	gap: 28px;
	padding: 40px 16px 32px;
	max-width: 1200px;
	margin: 0 auto;
}
@media (max-width: 1100px) {
	body.mju-themed .mju-footer.mju-footer--v2 .mju-footer__inner {
		grid-template-columns: 1fr 1fr 1fr 1fr;
		gap: 24px;
	}
	body.mju-themed .mju-footer.mju-footer--v2 .mju-footer__brand {
		grid-column: 1 / -1;
	}
}

body.mju-themed .mju-footer.mju-footer--v2 .mju-footer__brand .mju-brand {
	display: inline-block;
	text-decoration: none;
	margin-bottom: 12px;
	line-height: 1;
}
body.mju-themed .mju-footer.mju-footer--v2 .mju-footer__brand .mju-brand__text {
	font-size: 22px;
	font-weight: 800;
	letter-spacing: -0.01em;
}
/* logo color flip for dark footer bg */
body.mju-themed .mju-footer.mju-footer--v2 .mju-footer__brand .mju-brand__primary {
	color: #F8FAFC;
}
body.mju-themed .mju-footer.mju-footer--v2 .mju-footer__brand .mju-brand__accent {
	color: var(--mju-saffron);
}

body.mju-themed .mju-footer.mju-footer--v2 .mju-footer__tag {
	color: #CBD5E1;
	font-size: 14px;
	line-height: 1.6;
	margin: 0;
	max-width: 360px;
}

body.mju-themed .mju-footer.mju-footer--v2 .mju-footer__col h4 {
	color: #F8FAFC;
	font-size: 13px;
	font-weight: 700;
	letter-spacing: 0.06em;
	text-transform: uppercase;
	margin: 0 0 14px;
	padding-bottom: 8px;
	border-bottom: 1px solid rgba(248, 250, 252, 0.12);
}

body.mju-themed .mju-footer.mju-footer--v2 .mju-footer__col ul {
	list-style: none;
	padding: 0;
	margin: 0;
}
body.mju-themed .mju-footer.mju-footer--v2 .mju-footer__col li {
	margin: 0;
	padding: 0;
	font-size: 14px;
	line-height: 1.4;
}
body.mju-themed .mju-footer.mju-footer--v2 .mju-footer__col li + li {
	margin-top: 8px;
}

body.mju-themed .mju-footer.mju-footer--v2 a {
	color: #E2E8F0;
	text-decoration: none;
	background-image: linear-gradient(var(--mju-saffron), var(--mju-saffron));
	background-repeat: no-repeat;
	background-position: 0 100%;
	background-size: 0% 1px;
	transition: background-size 0.18s ease, color 0.18s ease;
	padding-bottom: 1px;
}
body.mju-themed .mju-footer.mju-footer--v2 a:hover,
body.mju-themed .mju-footer.mju-footer--v2 a:focus-visible {
	color: var(--mju-saffron);
	background-size: 100% 1px;
}
body.mju-themed .mju-footer.mju-footer--v2 a:focus-visible {
	outline: 2px solid var(--mju-saffron);
	outline-offset: 2px;
	border-radius: 2px;
}
/* brand link should not get the underline pulse */
body.mju-themed .mju-footer.mju-footer--v2 .mju-footer__brand .mju-brand,
body.mju-themed .mju-footer.mju-footer--v2 .mju-footer__brand .mju-brand:hover {
	background-image: none;
	color: inherit;
}

body.mju-themed .mju-footer.mju-footer--v2 .mju-footer__bottom {
	background: rgba(0, 0, 0, 0.22);
	border-top: 1px solid rgba(248, 250, 252, 0.08);
	padding: 16px 0;
}
body.mju-themed .mju-footer.mju-footer--v2 .mju-footer__bottom-inner {
	display: flex;
	flex-wrap: wrap;
	gap: 12px 24px;
	align-items: center;
	justify-content: space-between;
	max-width: 1200px;
	margin: 0 auto;
	padding: 0 16px;
}
body.mju-themed .mju-footer.mju-footer--v2 .mju-footer__copyright {
	color: #94A3B8;
	font-size: 12.5px;
	margin: 0;
	line-height: 1.5;
}
body.mju-themed .mju-footer.mju-footer--v2 .mju-footer__nav {
	margin: 0;
	font-size: 13px;
	color: #94A3B8;
}
body.mju-themed .mju-footer.mju-footer--v2 .mju-footer__sep {
	color: #475569;
	margin: 0 6px;
}

@media (max-width: 960px) {
	body.mju-themed .mju-footer.mju-footer--v2 .mju-footer__inner {
		grid-template-columns: 1fr 1fr;
		gap: 28px;
		padding: 32px 16px 24px;
	}
	body.mju-themed .mju-footer.mju-footer--v2 .mju-footer__brand {
		grid-column: 1 / -1;
	}
}

@media (max-width: 600px) {
	body.mju-themed .mju-footer.mju-footer--v2 .mju-footer__inner {
		grid-template-columns: 1fr;
		gap: 24px;
	}
	body.mju-themed .mju-footer.mju-footer--v2 .mju-footer__bottom-inner {
		flex-direction: column;
		text-align: center;
	}
	body.mju-themed .mju-footer.mju-footer--v2 .mju-footer__tag {
		max-width: none;
	}
}

.mju-hero h1 { color: var(--mju-primary); margin: 0 0 8px; font-size: 1.8rem; line-height: 1.2; }
.mju-hero p  { color: var(--mju-text-muted); margin: 0 0 24px; font-size: 1rem; }

/* Mobile (≤640px): button collapses to icon-only, filters stack to 1 column */
@media (max-width: 640px) {
  .mju-hero h1 { font-size: 1.5rem; }
  .mju-hero p { font-size: 0.9rem; margin-bottom: 16px; }
}


/* ─── Hero search v1.23.0 — definitive clean rebuild (replaces all prior rules) ─── */
.mju-hero { padding: 36px 16px 32px; text-align: center; background: var(--mju-bg); }
.mju-hero h1 { color: var(--mju-primary); margin: 0 0 8px; font-size: 1.9rem; line-height: 1.2; }
.mju-hero p  { color: var(--mju-text-muted); margin: 0 0 24px; font-size: 1rem; }

.mju-hero__search { width: 100%; max-width: 720px; margin: 0 auto; }

/* Row 1: navy-outlined pill containing icon + input + Search button */
.mju-hero__search-row {
  display: flex;
  align-items: center;
  padding: 4px 4px 4px 14px;
  background: #fff;
  border: 1.5px solid var(--mju-primary);
  border-radius: var(--mju-control-radius, 999px);
  box-shadow: 0 1px 3px rgba(15, 44, 89, 0.06);
  box-sizing: border-box;
}
.mju-hero__search-icon {
  display: inline-flex; align-items: center; justify-content: center;
  flex-shrink: 0;
  color: var(--mju-text-muted);
  margin-right: 6px;
}
.mju-hero__search-icon svg { width: 18px; height: 18px; }

.mju-hero__search-row input[type="search"] {
  flex: 1 1 auto;
  min-width: 0;
  border: 0;
  outline: 0;
  background: transparent;
  padding: 12px 8px;
  font-size: 15px;
  color: var(--mju-text);
  line-height: 1.2;
  height: auto;
  margin: 0;
  -webkit-appearance: none;
  appearance: none;
}
.mju-hero__search-row input[type="search"]::placeholder { color: var(--mju-text-faint, #94A3B8); }
.mju-hero__search-row input[type="search"]::-webkit-search-cancel-button { display: none; }

/* Submit button — override .mju-btn-accent (which is global) with sufficient
   specificity. .mju-hero__search-row button[type=submit] beats .mju-btn-accent
   on selector weight (0,1,2 vs 0,1,0) so no !important needed. */
.mju-hero__search-row button[type="submit"] {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  flex-shrink: 0;
  padding: 11px 22px;
  margin: 0;
  border: 0;
  border-radius: var(--mju-control-radius, 999px);
  background: var(--mju-primary);
  color: #fff;
  font-size: 14px;
  font-weight: 700;
  cursor: pointer;
  line-height: 1;
  white-space: nowrap;
}
.mju-hero__search-row button[type="submit"]:hover { background: var(--mju-primary-dark); }
.mju-hero__search-row button[type="submit"] svg { width: 14px; height: 14px; }

/* Row 2: three pill dropdowns (state / qualification / organization) */
.mju-hero__filters {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 8px;
  margin-top: 10px;
}
.mju-hero__filters select {
  width: 100%;
  height: var(--mju-control-height, 42px);
  padding: 0 28px 0 14px;
  border: 1.5px solid var(--mju-border-strong, #CBD5E1);
  border-radius: var(--mju-control-radius, 999px);
  background: #fff
    url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='10' height='6' viewBox='0 0 10 6'><path d='M1 1l4 4 4-4' fill='none' stroke='%230F2C59' stroke-width='1.5'/></svg>")
    no-repeat right 10px center;
  font-size: 13px;
  color: var(--mju-text);
  cursor: pointer;
  box-sizing: border-box;
  appearance: none;
  -webkit-appearance: none;
  text-overflow: ellipsis;
}
.mju-hero__filters select:hover { border-color: var(--mju-primary); }
.mju-hero__filters select:focus { outline: 2px solid var(--mju-primary); outline-offset: 2px; }

/* Mobile: filters stack to 1 col, button shrinks slightly */
@media (max-width: 640px) {
  .mju-hero { padding: 28px 12px; }
  .mju-hero h1 { font-size: 1.4rem; }
  .mju-hero__search-row button[type="submit"] { padding: 10px 14px; font-size: 13px; }
  .mju-hero__filters { grid-template-columns: 1fr; }
}
@media (max-width: 380px) {
  .mju-hero__search-row button[type="submit"] svg { display: none; }
}

/* ─── Stats strip — center align with site (definitive) ───────── */
.mju-stats { background: #fff; padding: 24px 0; }
.mju-stats__grid {
  display: grid !important;
  grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
  gap: 24px !important;
  padding: 24px 16px !important;
  max-width: 1200px;
  margin: 0 auto;
  align-items: center;
  justify-items: center;
}
.mju-stat {
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center;
  gap: 14px;
  text-align: left;
}
.mju-stat strong { font-size: 1.6rem !important; font-weight: 800; color: var(--mju-primary) !important; }
.mju-stat span   { font-size: .85rem !important; color: var(--mju-text-muted) !important; }
@media (max-width: 720px) {
  .mju-stats__grid { grid-template-columns: repeat(3, minmax(0, 1fr)) !important; gap: 8px !important; padding: 12px 10px !important; }
  .mju-stat { justify-content: center; }
}

/* ─── CTA / Email Signup — readable text on navy bg ────────────── */
.mju-section--cta {
  background: linear-gradient(135deg, #0F2C59 0%, #0A1F40 100%) !important;
  color: #F8FAFC !important;
}
.mju-section--cta .mju-cta h2,
.mju-section--cta h2 {
  color: #FFFFFF !important;
  font-size: 1.5rem !important;
  margin: 0 0 6px !important;
  font-weight: 800;
}
.mju-section--cta .mju-cta p,
.mju-section--cta p {
  color: #CBD5E1 !important;
  opacity: 1 !important;
  margin: 0 !important;
}
.mju-section--cta .mju-cta__form button[type="submit"] {
  background: var(--mju-saffron) !important;
  color: #1A1A1A !important;
  border: 0 !important;
  font-weight: 700;
}
.mju-section--cta .mju-cta__form button[type="submit"]:hover {
  background: #E07B1F !important;
}

/* ─── Apply Now button on single-job: NAVY (not green) ─────────── */
.mju-job .mju-btn-apply,
.mju-apply-sticky .mju-btn-apply,
.mju-job__cta .mju-btn-apply {
  background: var(--mju-primary) !important;
  color: #fff !important;
  border: 0 !important;
}
.mju-job .mju-btn-apply:hover,
.mju-apply-sticky .mju-btn-apply:hover,
.mju-job__cta .mju-btn-apply:hover {
  background: var(--mju-primary-dark) !important;
}

/* ─── Search results page — search form pill outline (always visible) ─── */
.mju-search-form {
  display: inline-flex;
  align-items: center;
  width: 100%;
  max-width: 640px;
  margin: 16px auto 0;
  background: #fff;
  border: 1.5px solid var(--mju-primary);
  border-radius: 999px;
  padding: 4px 4px 4px 16px;
  box-sizing: border-box;
  box-shadow: 0 1px 3px rgba(15, 44, 89, 0.06);
}
.mju-search-form input[type="search"] {
  flex: 1 1 auto;
  min-width: 0;
  border: 0;
  outline: 0;
  background: transparent;
  padding: 12px 8px;
  font-size: 15px;
  color: var(--mju-text);
  margin: 0;
  height: auto;
}
.mju-search-form input[type="search"]::placeholder { color: var(--mju-text-faint); }
.mju-search-form button[type="submit"] {
  display: inline-flex;
  align-items: center;
  flex-shrink: 0;
  padding: 11px 22px;
  margin: 0;
  border: 0;
  border-radius: 999px;
  background: var(--mju-primary) !important;
  color: #fff !important;
  font-size: 14px;
  font-weight: 700;
  cursor: pointer;
  line-height: 1;
}
.mju-search-form button[type="submit"]:hover { background: var(--mju-primary-dark) !important; }
@media (max-width: 480px) {
  .mju-search-form { padding: 4px; }
  .mju-search-form button[type="submit"] { padding: 10px 14px; font-size: 13px; }
}

.mju-footer__nav-label { color: #FFFFFF; font-weight: 700; margin-right: 4px; }
.mju-footer__nav a { white-space: nowrap; }
@media (max-width: 720px) {
  .mju-footer__nav { display: flex; flex-wrap: wrap; justify-content: center; gap: 6px 10px; }
  .mju-footer__nav-label { width: 100%; text-align: center; margin-bottom: 4px; }
}

/* ─── Static page template (about/contact/privacy/etc.) ───────── */
.mju-page__hero {
  background: var(--mju-surface);
  padding: 36px 0 28px;
  border-bottom: 1px solid var(--mju-border);
}
.mju-page__crumb {
  font-size: 13px; color: var(--mju-text-muted);
  margin-bottom: 10px;
}
.mju-page__crumb a { color: var(--mju-text-muted); text-decoration: none; }
.mju-page__crumb a:hover { color: var(--mju-primary); }
.mju-page__crumb .mju-crumb__current { color: var(--mju-text); font-weight: 600; }
.mju-page__title {
  font-size: 2.1rem; line-height: 1.2;
  color: var(--mju-primary);
  margin: 0 0 8px;
  font-weight: 800;
}
.mju-page__lede {
  font-size: 1.05rem; color: var(--mju-text-muted);
  margin: 0; max-width: 70ch;
}
.mju-page__body {
  display: grid;
  grid-template-columns: minmax(0, 1fr);
  padding: 36px 0 56px;
}
.mju-page__content {
  /* extends mju-prose */
  background: #fff;
  border: 1px solid var(--mju-border);
  border-radius: 12px;
  padding: 32px 40px;
  max-width: 820px;
  margin: 0 auto;
}
.mju-page__content.mju-prose { max-width: none; }
.mju-page__content h2 {
  font-size: 1.5rem;
  margin-top: 1.8em;
}
.mju-page__content h2:first-child { margin-top: 0; }
.mju-page__content h3 { font-size: 1.2rem; }
.mju-page__meta {
  margin: 16px auto 0;
  max-width: 820px;
  text-align: right;
  font-size: 12px;
  color: var(--mju-text-faint);
}
.mju-page__pages {
  margin-top: 24px; padding-top: 16px;
  border-top: 1px solid var(--mju-border);
  font-size: 14px;
}

@media (max-width: 720px) {
  .mju-page__hero { padding: 24px 0 20px; }
  .mju-page__title { font-size: 1.5rem; }
  .mju-page__lede { font-size: 0.95rem; }
  .mju-page__body { padding: 24px 0 40px; }
  .mju-page__content { padding: 20px 18px; border-radius: 10px; }
  .mju-page__content h2 { font-size: 1.25rem; }
}

/* ─── Demo ad placeholders (design review only — replace with real AdSense later) ─ */
.mju-demo-ad {
  display: block;
  margin: 24px 0;
  padding: 0;
  background: repeating-linear-gradient( -45deg, #FAFAFA, #FAFAFA 10px, #F1F5F9 10px, #F1F5F9 20px );
  border: 2px dashed #94A3B8;
  border-radius: 10px;
  text-align: center;
  color: #64748B;
}
.mju-demo-ad__inner {
  display: flex; flex-direction: column; align-items: center; justify-content: center;
  gap: 4px;
  padding: 24px 12px;
  min-height: 90px;
}
.mju-demo-ad__label {
  font-weight: 800; font-size: 16px;
  letter-spacing: 0.15em;
  color: var(--mju-primary);
}
.mju-demo-ad__slot {
  font-family: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, monospace;
  font-size: 12px;
  color: var(--mju-text-muted);
  background: rgba(15,44,89,0.08);
  padding: 2px 8px;
  border-radius: 4px;
}
.mju-demo-ad__size {
  font-size: 11px;
  color: #94A3B8;
}

/* Variants by slot */
.mju-demo-ad--mid-content,
.mju-demo-ad--block-4 { min-height: 90px; }       /* 728x90 banner */
.mju-demo-ad--block-10 { min-height: 250px; }      /* 300x250 medium rectangle */
.mju-demo-ad--archive-grid-8,
.mju-demo-ad--archive-grid-16 {
  grid-column: 1 / -1;
  margin: 16px 0;
  min-height: 120px;
}
.mju-demo-ad--sidebar-sticky {
  position: sticky; top: 80px;
  min-height: 600px;
  margin: 0 0 24px;
}
.mju-demo-ad--sticky-mobile {
  position: fixed; left: 0; right: 0; bottom: 0;
  z-index: 90;
  margin: 0;
  border-radius: 0;
  border-left: 0; border-right: 0; border-bottom: 0;
  min-height: 60px;
  background: #fff !important;
}
.mju-demo-ad--sticky-mobile .mju-demo-ad__inner { padding: 12px; min-height: 60px; }
@media (min-width: 901px) { .mju-demo-ad--sticky-mobile { display: none; } }


/* ─── Above-fold ad slots — reserve space to prevent CLS ───
 * Mobile (default): 280px tall — Google picks 336×280 / 300×250 most often
 * Desktop (≥768px): 90px tall  — Google picks 970×90 / 728×90
 * No fixed width; let parent container drive width via full-width-responsive
 */
.mju-demo-ad--home-above-fold,
.mju-demo-ad--job-above-fold,
.mju-demo-ad--archive-above-fold,
.mju-demo-ad--tag-above-fold,
.mju-demo-ad--category-above-fold,
.mju-demo-ad--search-above-fold {
  max-width: 970px;
  margin: 16px 16px 24px;
  min-height: 280px; /* mobile reservation */
}
@media (min-width: 1002px) {
  .mju-demo-ad--home-above-fold,
  .mju-demo-ad--job-above-fold,
  .mju-demo-ad--archive-above-fold,
  .mju-demo-ad--tag-above-fold,
  .mju-demo-ad--category-above-fold,
  .mju-demo-ad--search-above-fold {
    margin-left: auto;
    margin-right: auto;
  }
}
.mju-demo-ad--home-above-fold .mju-demo-ad__inner,
.mju-demo-ad--job-above-fold .mju-demo-ad__inner,
.mju-demo-ad--archive-above-fold .mju-demo-ad__inner,
.mju-demo-ad--tag-above-fold .mju-demo-ad__inner,
.mju-demo-ad--category-above-fold .mju-demo-ad__inner,
.mju-demo-ad--search-above-fold .mju-demo-ad__inner {
  min-height: 280px;
}
@media (min-width: 768px) {
  .mju-demo-ad--home-above-fold,
  .mju-demo-ad--job-above-fold,
  .mju-demo-ad--archive-above-fold,
  .mju-demo-ad--tag-above-fold,
  .mju-demo-ad--category-above-fold,
  .mju-demo-ad--search-above-fold {
    min-height: 90px;
  }
  .mju-demo-ad--home-above-fold .mju-demo-ad__inner,
  .mju-demo-ad--job-above-fold .mju-demo-ad__inner,
  .mju-demo-ad--archive-above-fold .mju-demo-ad__inner,
  .mju-demo-ad--tag-above-fold .mju-demo-ad__inner,
  .mju-demo-ad--category-above-fold .mju-demo-ad__inner,
  .mju-demo-ad--search-above-fold .mju-demo-ad__inner {
    min-height: 90px;
    padding: 16px;
  }
}

/* ─── Quick-nav buttons (Meta-ad → vignette monetization flow) ───
 * Modern equivalent of legacy .bt-new — clickable internal nav grid
 */
.mju-nav-buttons {
  margin: 24px auto 32px;
  max-width: 970px;
  padding: 0 16px;
  box-sizing: border-box;
}
@media (max-width: 600px) {
  .mju-nav-buttons {
    padding: 0 14px;
  }
  .mju-nav-buttons__heading,
  .mju-nav-buttons__title {
    padding: 0;
  }
}
.mju-nav-buttons__heading {
  font-size: 22px;
  font-weight: 800;
  color: var(--mju-primary);
  margin: 0 0 16px;
}
.mju-nav-buttons__group {
  margin: 0 0 32px;
}
.mju-nav-buttons__group:last-child { margin-bottom: 32px; }
.mju-nav-buttons {
  /* outer block also gets equal breathing room top/bottom */
  margin: 32px auto 40px;
}
.mju-nav-buttons__title {
  display: flex;
  align-items: center;
  gap: 8px;
  font-size: 17px;
  font-weight: 700;
  color: var(--mju-primary);
  margin: 0 0 12px;
}
.mju-nav-buttons__icon { font-size: 20px; line-height: 1; }
.mju-nav-buttons__grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(180px, 1fr));
  gap: 10px;
}
.mju-bt-new {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 8px;
  padding: 12px 16px;
  background: linear-gradient(135deg, #FFFFFF 0%, #F8FAFC 100%);
  border: 2px solid var(--mju-primary);
  border-radius: var(--mju-control-radius);
  color: var(--mju-primary);
  font-weight: 700;
  font-size: 14px;
  text-decoration: none;
  transition: all 0.15s ease;
  min-height: 44px;
  box-shadow: 0 1px 2px rgba(15,44,89,0.05);
}
.mju-bt-new:hover,
.mju-bt-new:focus-visible {
  background: var(--mju-primary);
  color: #fff;
  transform: translateY(-1px);
  box-shadow: 0 4px 12px rgba(15,44,89,0.15);
  text-decoration: none;
  outline: none;
}
.mju-bt-new__label {
  flex: 1;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.mju-bt-new__count {
  background: rgba(15,44,89,0.08);
  color: var(--mju-primary);
  font-size: 11px;
  font-weight: 800;
  padding: 2px 8px;
  border-radius: 999px;
  min-width: 24px;
  text-align: center;
  flex-shrink: 0;
}
.mju-bt-new:hover .mju-bt-new__count,
.mju-bt-new:focus-visible .mju-bt-new__count {
  background: rgba(255,255,255,0.2);
  color: #fff;
}
@media (max-width: 600px) {
  .mju-nav-buttons__grid {
    grid-template-columns: repeat(2, 1fr);
    gap: 8px;
  }
  .mju-bt-new {
    padding: 10px 12px;
    font-size: 13px;
  }
}

/* Force mobile padding even if theme parent has narrower rules */
body .mju-nav-buttons,
.mju-nav-buttons.mju-nav-buttons {
  padding-left: 16px;
  padding-right: 16px;
  margin-bottom: 40px;
  box-sizing: border-box;
}


/* ─── Mobile overflow guard + nav-buttons tightening ─── */
html, body {
  overflow-x: hidden;
  max-width: 100vw;
}
@media (max-width: 600px) {
  .mju-nav-buttons {
    padding: 0 14px !important;
    margin-left: 0;
    margin-right: 0;
    width: 100%;
    max-width: 100vw;
  }
  .mju-nav-buttons__grid {
    grid-template-columns: 1fr 1fr;
    gap: 8px;
    width: 100%;
  }
  .mju-bt-new {
    min-width: 0;
    overflow: hidden;
  }
  .mju-bt-new__label {
    min-width: 0;
    flex: 1 1 auto;
  }
}
@media (max-width: 380px) {
  .mju-nav-buttons__grid {
    grid-template-columns: 1fr; /* single column on very narrow */
  }
  .mju-bt-new {
    font-size: 13px;
  }
}

/* ─── Hero with top + bottom divider lines (cleaner separation) ─── */
.mju-archive-hero {
  border-top: 1px solid var(--mju-border);
  border-bottom: 1px solid var(--mju-border);
  padding: 28px 0;
  margin: 0;
  background: var(--mju-surface, #FAFBFC);
}
.mju-archive-hero__row {
  /* single column now — toolbar moved out */
  display: block;
  text-align: center;
}
.mju-archive-hero__left {
  text-align: center;
  max-width: 720px;
  margin: 0 auto;
}
.mju-archive-hero__count {
  display: inline-block;
  margin-top: 8px;
  background: rgba(15,44,89,0.08);
  color: var(--mju-primary);
  padding: 4px 14px;
  border-radius: 999px;
  font-weight: 700;
  font-size: 0.85rem;
}

/* ─── Filter + Sort toolbar wrapper (above the cards grid) ───────
 * AUTHORITATIVE wrapper rule — geometry/spacing only.
 * Layout direction (justify-content) is set per-viewport in the
 * consolidated blocks at the bottom of this file. Do NOT re-add a
 * justify-content here; it caused the cascade conflict that split
 * the buttons left/right on mobile.
 * ──────────────────────────────────────────────────────────────── */
.mju-archive-hero__actions {
  display: flex !important;
  flex-direction: row !important;
  flex-wrap: nowrap !important;
  align-items: center !important;
  gap: 12px !important;
  width: 100% !important;
  max-width: 1200px;
  margin: 28px auto 14px !important;
  padding: 10px 16px 14px !important;
  background: transparent !important;
  border: 0 !important;
  border-bottom: 1px solid var(--mju-border) !important;
  border-radius: 0 !important;
  box-sizing: border-box !important;
}
/* (Old per-600px wrapper duplicate removed — folded into bottom block.) */


/* ─── FINAL hero centering + toolbar button/icon alignment ─── */
/* Hero copy fully centered + count badge inline-centered */
.mju-archive-hero,
.mju-archive-hero__row,
.mju-archive-hero__left {
  text-align: center !important;
}
.mju-archive-hero__row {
  display: block !important;
  max-width: 720px;
  margin-left: auto !important;
  margin-right: auto !important;
}
.mju-archive-hero__left {
  display: block !important;
  width: 100% !important;
  max-width: 720px;
  margin: 0 auto !important;
}
.mju-archive-hero__left h1 {
  text-align: center !important;
  margin: 0 0 8px !important;
}
.mju-archive-hero__left p,
.mju-archive-hero__desc {
  text-align: center !important;
}
.mju-archive-hero__count {
  display: inline-block !important;
  margin: 4px auto 8px !important;
  text-align: center !important;
}

/* Toolbar buttons — guarantee icons + text vertically centered, button heights matched */
.mju-archive-hero__actions .mju-filters-toggle,
.mju-archive-hero__actions .mju-sort__trigger {
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  gap: 8px !important;
  line-height: 1 !important;
  vertical-align: middle !important;
}
.mju-archive-hero__actions .mju-filters-toggle svg,
.mju-archive-hero__actions .mju-sort__trigger svg {
  flex-shrink: 0 !important;
  vertical-align: middle !important;
  display: inline-block !important;
}
/* Same icon size for both buttons so they look paired */
.mju-archive-hero__actions .mju-filters-toggle svg,
.mju-archive-hero__actions .mju-sort__trigger > svg:first-of-type {
  width: 16px !important;
  height: 16px !important;
}
.mju-archive-hero__actions .mju-sort__chev {
  width: 10px !important; height: 6px !important;
}

/* Mobile: keep centered + tight, single-line */
@media (max-width: 600px) {
  .mju-archive-hero {
    padding: 18px 16px !important;
  }
  .mju-archive-hero__left h1 {
    font-size: 1.15rem !important;
    line-height: 1.3 !important;
  }
  .mju-archive-hero__left p {
    font-size: 0.85rem !important;
    margin-top: 6px !important;
  }
  .mju-archive-hero__count {
    font-size: 0.78rem !important;
    padding: 3px 12px !important;
  }
}

/* ════════════════════════════════════════════════════════════════
   FINAL CASCADE — toolbar layout
   1) ≤900px  → buttons paired in CENTER, matched heights, icons aligned
   2) ≤600px  → smaller sizing tweaks (sizing only, layout inherited)
   3) ≥901px  → hide Filter button + flex-end Sort
   These three blocks are the SINGLE SOURCE OF TRUTH. The wrapper
   block above (`.mju-archive-hero__actions`) sets only geometry.
   ════════════════════════════════════════════════════════════════ */

/* (1) Mobile + tablet: center the paired buttons */
@media (max-width: 900px) {
  .mju-archive-hero__actions {
    justify-content: center !important;
    gap: 10px !important;
    padding: 6px 8px 10px !important;
    margin: 20px auto 12px !important;
  }
  .mju-archive-hero__actions .mju-filters-toggle,
  .mju-archive-hero__actions .mju-sort,
  .mju-archive-hero__actions .mju-sort__trigger {
    flex: 0 0 auto !important;
    width: auto !important;
    white-space: nowrap !important;
  }
  /* Matched heights so icons + text share a baseline */
  .mju-archive-hero__actions .mju-filters-toggle,
  .mju-archive-hero__actions .mju-sort__trigger {
    height: 38px !important;
    min-height: 38px !important;
    line-height: 1 !important;
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
  }
}

/* (2) Phone-only sizing — layout inherits from (1) */
@media (max-width: 600px) {
  .mju-archive-hero__actions .mju-filters-toggle,
  .mju-archive-hero__actions .mju-sort,
  .mju-archive-hero__actions .mju-sort__trigger {
    height: 34px !important;
    min-height: 34px !important;
    padding: 0 12px !important;
    font-size: 12.5px !important;
  }
  .mju-archive-hero__actions .mju-sort__label {
    display: none !important; /* drop "Sort:" label on phone to save space */
  }
  .mju-archive-hero__actions .mju-sort__value {
    max-width: 90px !important;
  }
}

/* (3) Desktop ≥901px — DEFINITIVE.
   Specificity bumped (extra `.mju-archive-hero__actions` qualifier
   already present). This block is the LAST in the file so it wins
   any !important tie via source order; no further overrides exist. */
@media (min-width: 901px) {
  .mju-archive-hero__actions {
    justify-content: flex-end !important;
  }
  .mju-archive-hero__actions .mju-filters-toggle,
  .mju-archive-hero__actions button.mju-filters-toggle {
    display: none !important;
    visibility: hidden !important;
  }
}


/* ════════════════════════════════════════════════════════════════
   BULLETPROOF FINAL — toolbar mobile centering via inline-block
   (Replaces flex-based centering. text-align:center is impossible to break.)
   ════════════════════════════════════════════════════════════════ */
@media (max-width: 900px) {
  /* Filter pinned LEFT, Sort pinned RIGHT, with edge margins. */
  .mju-archive-hero__actions,
  .mju-archive .mju-archive-hero__actions,
  .mju-archive__main .mju-archive-hero__actions,
  body .mju-archive-hero__actions {
    display: flex !important;
    flex-direction: row !important;
    justify-content: space-between !important;
    align-items: center !important;
    flex-wrap: nowrap !important;
    width: 100% !important;
    max-width: 100% !important;
    box-sizing: border-box !important;
    padding: 10px 16px 14px !important;
    margin: 20px 0 14px !important;
    background: transparent !important;
    border: 0 !important;
    border-bottom: 1px solid var(--mju-border) !important;
  }
  .mju-archive-hero__actions > .mju-filters-toggle {
    margin-right: auto !important; /* pin LEFT */
  }
  .mju-archive-hero__actions > .mju-sort {
    margin-left: auto !important;  /* pin RIGHT */
  }
  .mju-archive-hero__actions > .mju-filters-toggle,
  .mju-archive-hero__actions > .mju-sort {
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    height: 38px !important;
    min-height: 38px !important;
    line-height: 1 !important;
    font-size: 13px !important;
    width: auto !important;
    flex: 0 0 auto !important;
  }
  .mju-archive-hero__actions > .mju-sort > .mju-sort__trigger {
    display: inline-flex !important;
    align-items: center !important;
    height: 38px !important;
    min-height: 38px !important;
    line-height: 1 !important;
    font-size: 13px !important;
  }
}
@media (max-width: 600px) {
  .mju-archive-hero__actions > .mju-filters-toggle,
  .mju-archive-hero__actions > .mju-sort,
  .mju-archive-hero__actions > .mju-sort > .mju-sort__trigger {
    height: 36px !important;
    min-height: 36px !important;
    padding: 0 12px !important;
    font-size: 12.5px !important;
    margin: 0 4px !important;
  }
}

/* ════════════════════════════════════════════════════════════════
   FINAL — nav-buttons hover/focus/active text color (beats parent theme)
   Parent theme has `a:hover { color: <link-color> }` which overrides
   our white-on-navy hover. Force white on all interactive states.
   ════════════════════════════════════════════════════════════════ */
.mju-bt-new,
.mju-bt-new:link,
.mju-bt-new:visited {
  color: var(--mju-primary) !important;
}
.mju-bt-new:hover,
.mju-bt-new:focus,
.mju-bt-new:focus-visible,
.mju-bt-new:active,
a.mju-bt-new:hover,
a.mju-bt-new:focus,
a.mju-bt-new:active {
  color: #fff !important;
  background: var(--mju-primary) !important;
  text-decoration: none !important;
}
.mju-bt-new:hover .mju-bt-new__label,
.mju-bt-new:focus .mju-bt-new__label,
.mju-bt-new:active .mju-bt-new__label,
.mju-bt-new:hover .mju-bt-new__count,
.mju-bt-new:focus .mju-bt-new__count,
.mju-bt-new:active .mju-bt-new__count {
  color: #fff !important;
}

/* ════════════════════════════════════════════════════════════════
   NAV-BUTTONS — RESEARCH-BACKED HIGH-CTR DESIGN (test variant)
   - Orange #FF6B35 (Indeed/CXL data: warm filled CTAs +21–32% CTR)
   - Filled top-2 (decoy effect +17–24%), outlined rest
   - 56px mobile height (MIT touch-lab optimal)
   - → arrow (Wider Funnel test +26% CTR)
   - Verb+number label "View N New" (MarketingExperiments +31%)
   - Subtle pulse on top button, 5s then stops
   ════════════════════════════════════════════════════════════════ */
:root {
  --mju-cta: #FF6B35;          /* high-CTR action orange (research-backed) */
  --mju-cta-dark: #E5511D;     /* hover deeper orange */
  --mju-cta-light: #FFF5F0;
}

.mju-bt-new {
  display: flex !important;
  align-items: center !important;
  justify-content: space-between !important;
  gap: 10px !important;
  padding: 12px 14px !important;
  min-height: 56px !important;
  border-radius: 10px !important;
  text-decoration: none !important;
  font-weight: 700 !important;
  font-size: 14px !important;
  line-height: 1.2 !important;
  transition: transform .15s ease, box-shadow .15s ease, background .15s ease, border-color .15s ease;
  /* default: outlined orange */
  background: #fff !important;
  color: var(--mju-cta-dark) !important;
  border: 2px solid var(--mju-cta) !important;
  box-shadow: 0 1px 3px rgba(229,81,29,0.08) !important;
}

.mju-bt-new__main {
  display: flex !important;
  flex-direction: column !important;
  align-items: flex-start !important;
  gap: 2px !important;
  flex: 1 1 auto !important;
  min-width: 0 !important;
}
.mju-bt-new__label {
  font-weight: 800 !important;
  font-size: 14px !important;
  white-space: nowrap !important;
  overflow: hidden !important;
  text-overflow: ellipsis !important;
  color: inherit !important;
}
.mju-bt-new__count {
  font-size: 11px !important;
  font-weight: 700 !important;
  color: var(--mju-cta) !important;
  letter-spacing: 0.02em !important;
}
.mju-bt-new__arrow {
  font-size: 22px !important;
  font-weight: 700 !important;
  line-height: 1 !important;
  flex-shrink: 0 !important;
  transition: transform .15s ease !important;
  color: inherit !important;
}

/* FEATURED — top 2 buttons get filled treatment */
.mju-bt-new.is-featured {
  background: var(--mju-cta) !important;
  color: #fff !important;
  border-color: var(--mju-cta) !important;
  box-shadow: 0 4px 12px rgba(255,107,53,0.30) !important;
}
.mju-bt-new.is-featured .mju-bt-new__count {
  color: rgba(255,255,255,0.9) !important;
}

/* HOVER / FOCUS / ACTIVE — high-priority overrides (parent theme has a:hover blue) */
.mju-bt-new:hover,
.mju-bt-new:focus,
.mju-bt-new:focus-visible,
.mju-bt-new:active,
a.mju-bt-new:hover,
a.mju-bt-new:focus {
  background: var(--mju-cta-dark) !important;
  color: #fff !important;
  border-color: var(--mju-cta-dark) !important;
  text-decoration: none !important;
  transform: translateY(-2px) !important;
  box-shadow: 0 6px 18px rgba(229,81,29,0.40) !important;
}
.mju-bt-new:hover .mju-bt-new__count,
.mju-bt-new:focus .mju-bt-new__count,
.mju-bt-new:active .mju-bt-new__count {
  color: rgba(255,255,255,0.95) !important;
}
.mju-bt-new:hover .mju-bt-new__arrow {
  transform: translateX(4px) !important;
}

/* PULSE on the top button only — fires for ~6s then settles */
@keyframes mju-bt-pulse {
  0%, 100% { box-shadow: 0 4px 12px rgba(255,107,53,0.30); }
  50%      { box-shadow: 0 4px 24px rgba(255,107,53,0.65); }
}
.mju-bt-new.is-pulse {
  animation: mju-bt-pulse 1.6s ease-in-out 0s 4;
}

/* Mobile: bigger touch target, full-width grid */
@media (max-width: 600px) {
  .mju-nav-buttons__grid {
    grid-template-columns: 1fr 1fr !important;
    gap: 8px !important;
  }
  .mju-bt-new {
    min-height: 56px !important;
    padding: 10px 10px !important;
    font-size: 13px !important;
    gap: 6px !important;
  }
  .mju-bt-new__label {
    font-size: 13px !important;
  }
  .mju-bt-new__count {
    font-size: 10px !important;
  }
  .mju-bt-new__arrow {
    font-size: 18px !important;
  }
}
@media (max-width: 360px) {
  .mju-nav-buttons__grid {
    grid-template-columns: 1fr !important; /* fall back single col on very narrow */
  }
}


/* ─── Pair-matching: grid children fill cell height equally on all viewports ─── */
.mju-nav-buttons__grid {
  align-items: stretch !important;
  grid-auto-rows: 1fr !important;
}
.mju-bt-new {
  height: 100% !important;
  align-self: stretch !important;
}
.mju-bt-new__main {
  flex: 1 1 auto !important;
  justify-content: center !important;
}

/* ════════════════════════════════════════════════════════════════
   AD SLOTS — AdSense-compliant
   - "Advertisement" label rendered above slot (policy-allowed)
   - CLS-safe min-heights (mobile 280px, desktop 90px on leaderboards)
   - Skeleton shimmer until real ad loads (no fake CTAs / no ad-mimicry)
   - When AdSense <ins> mounts inside .mju-ad__inner, skeleton hides
   ════════════════════════════════════════════════════════════════ */

.mju-ad {
  display: block;
  margin: 18px auto 22px;
  padding: 0;
  text-align: center;
  max-width: 970px;
}
.mju-ad__label {
  display: block;
  font-size: 10px;
  font-weight: 600;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: #94A3B8;
  text-align: center;
  margin: 0 0 6px;
  user-select: none;
}
.mju-ad__inner {
  position: relative;
  background: #F8FAFC;
  border: 1px solid #E2E8F0;
  border-radius: 6px;
  overflow: hidden;
  min-height: 90px;
}
/* Skeleton shimmer (placeholder) — purely decorative, no ad mimicry */
.mju-ad__skeleton {
  position: absolute; inset: 0;
  background: linear-gradient(
    90deg,
    #F1F5F9 0%,
    #F8FAFC 50%,
    #F1F5F9 100%
  );
  background-size: 200% 100%;
  animation: mju-ad-shimmer 1.6s ease-in-out infinite;
  opacity: 0.7;
}
@keyframes mju-ad-shimmer {
  0%   { background-position: 200% 0; }
  100% { background-position: -200% 0; }
}
/* When real AdSense loads, hide skeleton */
.mju-ad__inner:has(ins.adsbygoogle) .mju-ad__skeleton,
.mju-ad__inner:has(iframe) .mju-ad__skeleton { display: none; }

/* Per-slot reservations (mobile-first; desktop reduces leaderboards to 90px) */
.mju-ad--home-above-fold .mju-ad__inner,
.mju-ad--archive-above-fold .mju-ad__inner,
.mju-ad--job-above-fold .mju-ad__inner,
.mju-ad--tag-above-fold .mju-ad__inner,
.mju-ad--category-above-fold .mju-ad__inner,
.mju-ad--search-above-fold .mju-ad__inner {
  min-height: 280px; /* mobile: Google often picks 336x280 / 300x250 */
}
.mju-ad--mid-content .mju-ad__inner,
.mju-ad--before-body .mju-ad__inner {
  min-height: 250px;
}
.mju-ad--archive-grid-8 .mju-ad__inner,
.mju-ad--archive-grid-16 .mju-ad__inner {
  min-height: 250px;
}
@media (min-width: 768px) {
  .mju-ad--home-above-fold .mju-ad__inner,
  .mju-ad--archive-above-fold .mju-ad__inner,
  .mju-ad--job-above-fold .mju-ad__inner,
  .mju-ad--tag-above-fold .mju-ad__inner,
  .mju-ad--category-above-fold .mju-ad__inner,
  .mju-ad--search-above-fold .mju-ad__inner {
    min-height: 90px; /* desktop: 970x90 / 728x90 leaderboard */
  }
}
.mju-ad--archive-grid-8,
.mju-ad--archive-grid-16 {
  grid-column: 1 / -1;
}
@media (max-width: 600px) {
  .mju-ad {
    margin: 16px 14px;
  }
}

/* Hide legacy mju-demo-ad styles entirely (replaced by mju-ad) */
.mju-demo-ad { display: none !important; }

/* ─── Filter + Sort: identical text size & weight on mobile/tablet ─── */
@media (max-width: 900px) {
  .mju-archive-hero__actions .mju-filters-toggle,
  .mju-archive-hero__actions .mju-filters-toggle > span,
  .mju-archive-hero__actions .mju-sort__trigger,
  .mju-archive-hero__actions .mju-sort__value {
    font-size: 13px !important;
    font-weight: 600 !important;
    line-height: 1 !important;
    letter-spacing: 0 !important;
  }
  /* Match icon sizes too — filter SVG was 18px, sort SVG was 14px */
  .mju-archive-hero__actions .mju-filters-toggle > svg,
  .mju-archive-hero__actions .mju-sort__trigger > svg:first-of-type {
    width: 16px !important;
    height: 16px !important;
    flex-shrink: 0 !important;
  }
  .mju-archive-hero__actions .mju-sort__chev {
    width: 10px !important;
    height: 6px !important;
  }
}
@media (max-width: 600px) {
  .mju-archive-hero__actions .mju-filters-toggle,
  .mju-archive-hero__actions .mju-filters-toggle > span,
  .mju-archive-hero__actions .mju-sort__trigger,
  .mju-archive-hero__actions .mju-sort__value {
    font-size: 12.5px !important;
  }
}


/* ─── Toolbar is NOW a sibling of .mju-archive (not inside __main) ─── */
.mju-archive-hero__actions {
  margin-top: 24px !important;
  margin-bottom: 0 !important; /* lets .mju-archive own the gap below */
}
@media (max-width: 600px) {
  .mju-archive-hero__actions {
    margin-top: 18px !important;
  }
}
.mju-archive {
  padding-top: 12px !important; /* reduced — toolbar's bottom border serves as separator */
}

/* ─── Search input focus styling — clean, no double outline ─── */
.mju-search,
.mju-search input,
.mju-search input[type="search"],
.mju-search-page input[type="search"],
input.mju-search-input,
.search-form input[type="search"] {
  outline: none !important;
}
.mju-search input:focus,
.mju-search input[type="search"]:focus,
.mju-search-page input[type="search"]:focus,
input.mju-search-input:focus,
.search-form input[type="search"]:focus {
  outline: none !important;
  border-color: var(--mju-cta) !important;
  box-shadow: 0 0 0 3px rgba(255,107,53,0.15) !important;
}
/* Kill any user-agent default inner ring (Safari/Chrome) */
.mju-search input::-webkit-search-decoration,
.mju-search input::-webkit-search-cancel-button,
.mju-search input::-webkit-search-results-button,
.mju-search input::-webkit-search-results-decoration {
  -webkit-appearance: none;
}

/* ─── DEFINITIVE outline override for all form inputs (parent theme has outlines) ─── */
input:focus,
input:focus-visible,
input:active,
textarea:focus,
textarea:focus-visible,
select:focus,
select:focus-visible,
input[type="text"]:focus,
input[type="email"]:focus,
input[type="search"]:focus,
input[type="search"]:focus-visible,
input[type="search"]:active,
input.mju-search-input:focus,
input.mju-search-input:focus-visible,
.mju-search input:focus,
.mju-search input:focus-visible,
.mju-search-page input:focus,
.search-form input:focus,
form input:focus {
  outline: 0 !important;
  outline-color: transparent !important;
  outline-style: none !important;
  outline-width: 0 !important;
  -webkit-tap-highlight-color: transparent !important;
}

/* Custom focus ring (replaces browser default) */
input[type="text"]:focus,
input[type="email"]:focus,
input[type="search"]:focus,
input.mju-search-input:focus,
.mju-search input:focus,
.mju-search-page input:focus,
.search-form input:focus {
  border-color: var(--mju-cta) !important;
  box-shadow: 0 0 0 3px rgba(255,107,53,0.15) !important;
}

/* Kill webkit extra inner border on autofill */
input:-webkit-autofill {
  box-shadow: 0 0 0 3px rgba(255,107,53,0.15), 0 0 0 1000px #fff inset !important;
  -webkit-text-fill-color: var(--mju-text);
}

/* ─── FINAL: zero visual focus indicator on search inputs ─── */
input[type="search"]:focus,
input[type="search"]:focus-visible,
input[type="search"]:active,
#mju-q:focus,
#mju-q:focus-visible,
#mju-q:active,
.mju-search input:focus,
.mju-search input:focus-visible,
.mju-search-page input:focus {
  outline: 0 !important;
  box-shadow: none !important;
  border-color: var(--mju-border) !important;
  -webkit-tap-highlight-color: transparent !important;
}

/* ─── In-grid archive ads (every 8 cards) — desktop fix ─── */
.mju-grid--cards .mju-ad,
.mju-ad--archive-grid-8,
.mju-ad--archive-grid-16,
.mju-ad--archive-grid-24 {
  grid-column: 1 / -1 !important;
  width: 100% !important;
  max-width: 100% !important;
  margin: 8px 0 !important;
}
.mju-grid--cards .mju-ad .mju-ad__inner,
.mju-ad--archive-grid-8 .mju-ad__inner,
.mju-ad--archive-grid-16 .mju-ad__inner,
.mju-ad--archive-grid-24 .mju-ad__inner {
  min-height: 90px;
  width: 100%;
}
@media (max-width: 768px) {
  .mju-grid--cards .mju-ad .mju-ad__inner,
  .mju-ad--archive-grid-8 .mju-ad__inner {
    min-height: 250px;
  }
}

/* ─── Single-job before-body / mid-content — wrap in card-style padding ─── */
.mju-job__main .mju-ad,
.mju-ad--before-body,
.mju-ad--mid-content {
  background: #fff;
  border: 1px solid var(--mju-border);
  border-radius: var(--mju-radius-lg);
  padding: 12px;
  margin: 16px 0 !important;
  max-width: none !important;
  width: auto !important;
  box-shadow: var(--mju-shadow-sm);
}
.mju-ad--before-body .mju-ad__inner,
.mju-ad--mid-content .mju-ad__inner {
  background: transparent;
  border: 0;
  min-height: 90px;
}
@media (max-width: 768px) {
  .mju-ad--before-body .mju-ad__inner,
  .mju-ad--mid-content .mju-ad__inner {
    min-height: 250px;
  }
}

/* ─── Single-job in-content ad — must escape narrow .mju-prose column ─── */
.mju-prose .mju-ad,
.mju-card--content .mju-ad,
.mju-job__main .mju-ad--mid-content,
.mju-job__main .mju-ad--before-body {
  /* Break out of any text-column constraints; fill the article width */
  width: 100% !important;
  max-width: 100% !important;
  margin-left: 0 !important;
  margin-right: 0 !important;
  display: block !important;
  /* Match before-body: white card style for visual cohesion */
  background: #fff;
  border: 1px solid var(--mju-border);
  border-radius: var(--mju-radius-lg);
  padding: 12px;
  box-shadow: var(--mju-shadow-sm);
}
.mju-prose .mju-ad .mju-ad__inner,
.mju-card--content .mju-ad .mju-ad__inner {
  width: 100% !important;
  background: transparent;
  border: 0;
  min-height: 90px;
}
@media (max-width: 768px) {
  .mju-prose .mju-ad .mju-ad__inner,
  .mju-card--content .mju-ad .mju-ad__inner {
    min-height: 250px;
  }
}
/* Force the ins.adsbygoogle inside ads to take full width */
.mju-ad__inner > ins.adsbygoogle {
  display: block !important;
  width: 100% !important;
  min-height: inherit !important;
}

/* ─── After-body ad — match card style (sits between Description and Important Dates) ─── */
.mju-ad--after-body {
  background: #fff !important;
  border: 1px solid var(--mju-border) !important;
  border-radius: var(--mju-radius-lg) !important;
  padding: 12px !important;
  margin: 16px 0 !important;
  max-width: 100% !important;
  width: 100% !important;
  box-shadow: var(--mju-shadow-sm) !important;
  box-sizing: border-box !important;
}
.mju-ad--after-body .mju-ad__inner {
  background: transparent !important;
  border: 0 !important;
  min-height: 90px !important;
  width: 100% !important;
}
@media (max-width: 768px) {
  .mju-ad--after-body .mju-ad__inner {
    min-height: 250px !important;
  }
}
.mju-ad--after-body ins.adsbygoogle {
  display: block !important;
  width: 100% !important;
  min-height: 90px !important;
}
@media (max-width: 768px) {
  .mju-ad--after-body ins.adsbygoogle {
    min-height: 250px !important;
  }
}

/* ─── After-body ad centering fix ─── */
.mju-ad--after-body {
  margin-left: auto !important;
  margin-right: auto !important;
  text-align: center !important;
}
.mju-ad--after-body .mju-ad__inner {
  margin-left: auto !important;
  margin-right: auto !important;
  text-align: center !important;
}
.mju-ad--after-body ins.adsbygoogle {
  margin-left: auto !important;
  margin-right: auto !important;
}
.mju-ad--after-body .mju-ad__label {
  text-align: center !important;
  margin-left: auto !important;
  margin-right: auto !important;
}

/* ─── After-body ad inside .mju-job__grid — span full row (was filling 1 col only) ─── */
.mju-job__grid .mju-ad--after-body,
.mju-job__grid .mju-ad {
  grid-column: 1 / -1 !important;
  width: 100% !important;
  max-width: 100% !important;
  margin: 16px 0 !important;
  box-sizing: border-box !important;
}

/* ════════════════════════════════════════════════════════════════
   404 / Not Found — recovery-focused layout
   ════════════════════════════════════════════════════════════════ */
.mju-404-hero {
  text-align: center;
  padding: 56px 16px 40px;
  background: var(--mju-surface, #FAFBFC);
  border-bottom: 1px solid var(--mju-border);
}
.mju-404__inner {
  max-width: 640px;
  margin: 0 auto;
}
.mju-404__icon {
  display: inline-flex;
  width: 80px; height: 80px;
  align-items: center; justify-content: center;
  background: var(--mju-cta-light, #FFF5F0);
  color: var(--mju-cta);
  border-radius: 50%;
  margin: 0 0 18px;
}
.mju-404__title {
  font-size: 2rem;
  font-weight: 800;
  color: var(--mju-primary);
  margin: 0 0 12px;
  line-height: 1.2;
}
.mju-404__lede {
  font-size: 1rem;
  color: var(--mju-text-soft);
  margin: 0 0 24px;
  line-height: 1.55;
}
.mju-404__search {
  display: flex;
  gap: 10px;
  align-items: stretch;
  max-width: 520px;
  margin: 0 auto;
}
.mju-404__search input[type="search"] {
  flex: 1;
  height: 48px;
  padding: 0 16px;
  border: 2px solid var(--mju-border);
  border-radius: 999px;
  font-size: 15px;
  background: #fff;
  color: var(--mju-text);
}
.mju-404__search input[type="search"]:focus {
  border-color: var(--mju-cta);
  outline: 0;
}
.mju-404__search .mju-btn-cta {
  height: 48px;
  padding: 0 22px;
  background: var(--mju-cta);
  color: #fff;
  border: 0;
  border-radius: 999px;
  font-weight: 700;
  display: inline-flex;
  align-items: center;
  gap: 6px;
  cursor: pointer;
  transition: background 0.15s ease, transform 0.15s ease;
}
.mju-404__search .mju-btn-cta:hover {
  background: var(--mju-cta-dark);
  transform: translateY(-1px);
}
.mju-404-recent {
  padding: 32px 16px 48px;
}
@media (max-width: 600px) {
  .mju-404-hero { padding: 40px 14px 28px; }
  .mju-404__title { font-size: 1.5rem; }
  .mju-404__lede { font-size: 0.95rem; }
  .mju-404__search { flex-direction: column; }
  .mju-404__search input[type="search"],
  .mju-404__search .mju-btn-cta { width: 100%; }
}

/* ════════════════════════════════════════════════════════════════
   Description body (mju-prose) — readable, on-brand list / step / FAQ styling
   Targets: How to Apply (ol), Selection Process / Preparation Tips / Documents Required (ul), FAQ (h3+p), tables.
   ════════════════════════════════════════════════════════════════ */

/* Section heading rhythm */
.mju-prose h2 {
  position: relative;
  font-size: 1.35rem;
  font-weight: 800;
  color: var(--mju-primary);
  margin: 2.2rem 0 0.85rem;
  padding-left: 14px;
  line-height: 1.3;
}
.mju-prose h2::before {
  content: "";
  position: absolute;
  left: 0; top: 0.35em; bottom: 0.35em;
  width: 4px;
  border-radius: 4px;
  background: var(--mju-cta);
}
.mju-prose h3 {
  font-size: 1.05rem;
  font-weight: 700;
  color: var(--mju-primary);
  margin: 1.3rem 0 0.5rem;
}
.mju-prose p { line-height: 1.6; margin: 0 0 0.8rem; color: var(--mju-text); }
.mju-prose strong { color: var(--mju-primary); font-weight: 700; }

/* Unordered lists — checkmark bullets */
.mju-prose ul {
  list-style: none;
  padding: 0;
  margin: 0.6rem 0 1rem;
}
.mju-prose ul > li {
  position: relative;
  padding: 8px 4px 8px 36px;
  margin: 0 0 4px;
  line-height: 1.55;
  border-radius: 6px;
  transition: background 0.15s ease;
}
.mju-prose ul > li:hover { background: var(--mju-cta-light, #FFF5F0); }
.mju-prose ul > li::before {
  content: "";
  position: absolute;
  left: 8px; top: 11px;
  width: 18px; height: 18px;
  border-radius: 50%;
  background: var(--mju-cta-light, #FFF5F0);
  display: inline-block;
}
.mju-prose ul > li::after {
  content: "✓";
  position: absolute;
  left: 11px; top: 11px;
  width: 12px; height: 12px;
  font-size: 12px;
  font-weight: 800;
  color: var(--mju-cta);
  line-height: 1;
}

/* Ordered lists — numbered circles (How to Apply steps) */
.mju-prose ol {
  list-style: none;
  padding: 0;
  margin: 0.6rem 0 1rem;
  counter-reset: mju-step;
}
.mju-prose ol > li {
  position: relative;
  padding: 12px 16px 12px 56px;
  margin: 0 0 10px;
  line-height: 1.55;
  background: #fff;
  border: 1px solid var(--mju-border);
  border-radius: 10px;
  counter-increment: mju-step;
  box-shadow: 0 1px 2px rgba(15,44,89,0.04);
}
.mju-prose ol > li::before {
  content: counter(mju-step);
  position: absolute;
  left: 14px; top: 12px;
  width: 30px; height: 30px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  background: var(--mju-cta);
  color: #fff;
  border-radius: 50%;
  font-weight: 800;
  font-size: 14px;
  font-family: var(--mju-font);
  line-height: 1;
  box-shadow: 0 2px 6px rgba(255,107,53,0.30);
}
.mju-prose ol > li a {
  color: var(--mju-cta-dark);
  font-weight: 600;
}
.mju-prose ol > li a:hover { color: var(--mju-cta); text-decoration: underline; }

/* Tables (Recruitment Overview, Vacancy Breakdown, Eligibility, Application Fee) */
.mju-prose table {
  width: 100%;
  border-collapse: collapse;
  margin: 0.6rem 0 1rem;
  font-size: 0.92rem;
  background: #fff;
  border: 1px solid var(--mju-border);
  border-radius: 10px;
  overflow: hidden;
  box-shadow: 0 1px 2px rgba(15,44,89,0.04);
}
.mju-prose thead th {
  background: var(--mju-primary);
  color: #fff;
  font-weight: 700;
  font-size: 0.88rem;
  text-align: left;
  padding: 10px 14px;
}
.mju-prose tbody td,
.mju-prose tbody th {
  padding: 10px 14px;
  border-bottom: 1px solid var(--mju-border);
  vertical-align: top;
  line-height: 1.45;
}
.mju-prose tbody tr:nth-child(even) td,
.mju-prose tbody tr:nth-child(even) th { background: var(--mju-surface, #F8FAFC); }
.mju-prose tbody tr:last-child td,
.mju-prose tbody tr:last-child th { border-bottom: 0; }
.mju-prose tbody th[scope="row"] {
  font-weight: 700;
  color: var(--mju-primary);
  background: var(--mju-surface, #F8FAFC);
  width: 35%;
}

/* FAQ — make question/answer feel like cards */
.mju-prose h2:has(+ h3) + h3,
.mju-prose h2 + h3 {
  margin-top: 1rem;
}
.mju-prose h3 + p {
  margin: 0 0 1.1rem;
  padding: 12px 16px;
  background: #fff;
  border-left: 3px solid var(--mju-cta);
  border-radius: 0 8px 8px 0;
  box-shadow: 0 1px 2px rgba(15,44,89,0.04);
}

/* "About <Org>" + lede + closer paragraphs — slight emphasis */
.mju-prose > p:first-of-type {
  font-size: 1.02rem;
  line-height: 1.7;
  color: var(--mju-text);
}

/* Mobile tweaks */
@media (max-width: 600px) {
  .mju-prose h2 { font-size: 1.18rem; margin-top: 1.6rem; }
  .mju-prose ol > li { padding: 10px 12px 10px 48px; }
  .mju-prose ol > li::before { left: 10px; top: 10px; width: 26px; height: 26px; font-size: 12px; }
  .mju-prose ul > li { padding-left: 30px; }
  .mju-prose ul > li::before { left: 4px; }
  .mju-prose ul > li::after { left: 7px; }
  .mju-prose table { font-size: 0.85rem; }
  .mju-prose thead th, .mju-prose tbody td, .mju-prose tbody th { padding: 8px 10px; }
}

/* "View More" link after homepage Latest Jobs grid — centered + on-brand. */
.mju-section__more {
  text-align: center;
  margin: 28px 0 4px;
}
.mju-btn-more {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  padding: 12px 24px;
  background: var(--mju-cta);
  color: #fff !important;
  border: 0;
  border-radius: 999px;
  font-weight: 700;
  font-size: 15px;
  text-decoration: none !important;
  box-shadow: 0 4px 12px rgba(255,107,53,0.30);
  transition: background 0.15s ease, transform 0.15s ease, box-shadow 0.15s ease;
}
.mju-btn-more:hover,
.mju-btn-more:focus-visible {
  background: var(--mju-cta-dark);
  color: #fff !important;
  transform: translateY(-2px);
  box-shadow: 0 6px 18px rgba(229,81,29,0.40);
  text-decoration: none !important;
}
.mju-btn-more svg {
  flex-shrink: 0;
  transition: transform 0.15s ease;
}
.mju-btn-more:hover svg { transform: translateX(4px); }
