/*
 * BGN Careers — Frontend Styles
 *
 * Matches bringardner.com:
 *  - Navy primary (#0E2A47)
 *  - Red accent  (#C8102E) — same red as the homepage Free Case Review CTAs
 *  - Poppins typography
 *  - Generous container widths matching Elementor's default 1140px boxed layout
 *
 * Both colors are overridable from BGN_Careers → Settings.
 */

:root {
	--bgn-primary: #0E2A47;        /* navy */
	--bgn-primary-2: #163b62;      /* navy lighter (hover) */
	--bgn-accent: #C8102E;         /* red */
	--bgn-accent-2: #9a0c23;       /* red darker (hover) */
	--bgn-ink: #1a1a1a;
	--bgn-ink-2: #444;
	--bgn-muted: #6b7280;
	--bgn-line: #e5e7eb;
	--bgn-bg: #ffffff;
	--bgn-bg-alt: #f7f8fa;
	--bgn-bg-soft: #f1f4f8;
	--bgn-shadow: 0 6px 24px rgba(14, 42, 71, 0.08);
	--bgn-shadow-lg: 0 18px 48px rgba(14, 42, 71, 0.14);
	--bgn-radius: 14px;
	--bgn-radius-sm: 8px;
	--bgn-font: "Red Hat Display", "Helvetica Neue", Arial, sans-serif;
}

/* ====================================================================== */
/* Defensive overrides — defeat host theme rules that break text layout.   */
/* Some themes apply nuclear word-spacing or word-break to <p>/<h*>/<li>   */
/* (often as part of an "animated word reveal" effect or aggressive       */
/* responsive typography). These rules establish a clean rendering zone   */
/* inside our containers so paragraphs and headings flow naturally.       */
/* ====================================================================== */
.bgn-careers-wrapper p,
.bgn-careers-wrapper h1,
.bgn-careers-wrapper h2,
.bgn-careers-wrapper h3,
.bgn-careers-wrapper h4,
.bgn-careers-wrapper h5,
.bgn-careers-wrapper h6,
.bgn-careers-wrapper li,
.bgn-careers-wrapper a,
.bgn-careers-wrapper span,
.bgn-careers-wrapper label,
.bgn-careers-wrapper legend,
.bgn-single-main p,
.bgn-single-main h1,
.bgn-single-main h2,
.bgn-single-main h3,
.bgn-single-main h4,
.bgn-single-main h5,
.bgn-single-main h6,
.bgn-single-main li,
.bgn-single-main a,
.bgn-single-main span,
.bgn-single-main label,
.bgn-single-main legend,
.bgn-archive-main p,
.bgn-archive-main h1,
.bgn-archive-main h2,
.bgn-archive-main h3,
.bgn-archive-main h4,
.bgn-archive-main h5,
.bgn-archive-main h6,
.bgn-archive-main li,
.bgn-archive-main a,
.bgn-archive-main span,
.bgn-archive-main label,
.bgn-archive-main legend,
.bgn-apply p,
.bgn-apply h1,
.bgn-apply h2,
.bgn-apply h3,
.bgn-apply li,
.bgn-apply label,
.bgn-apply legend,
.bgn-apply span {
	word-spacing: normal !important;
	letter-spacing: normal !important;
	word-break: normal !important;
	overflow-wrap: break-word !important;
	white-space: normal !important;
	hyphens: manual;
}

/* Block-level text elements need block display + auto width too. */
/* Note: <li> is intentionally excluded — it's used for flex-based tags  */
/* and checklists which manage their own display value.                 */
.bgn-careers-wrapper p,
.bgn-careers-wrapper h1,
.bgn-careers-wrapper h2,
.bgn-careers-wrapper h3,
.bgn-careers-wrapper h4,
.bgn-single-main p,
.bgn-single-main h1,
.bgn-single-main h2,
.bgn-single-main h3,
.bgn-single-main h4,
.bgn-archive-main p,
.bgn-archive-main h1,
.bgn-archive-main h2,
.bgn-archive-main h3,
.bgn-archive-main h4,
.bgn-apply p,
.bgn-apply h1,
.bgn-apply h2,
.bgn-apply h3 {
	display: block !important;
	width: auto !important;
	max-width: 100% !important;
	min-width: 0 !important;
}

/* ---------- Reset / scoping ---------- */
.bgn-careers-wrapper,
.bgn-single-main,
.bgn-archive-main {
	font-family: var(--bgn-font) !important;
	color: var(--bgn-ink);
	line-height: 1.6;
}

.bgn-careers-wrapper *,
.bgn-single-main *,
.bgn-archive-main * {
	font-family: var(--bgn-font) !important;
	box-sizing: border-box;
}

.bgn-container {
	width: 100%;
	max-width: 1140px;
	margin: 0 auto;
	padding: 0 24px;
}

/* ---------- Typography helpers ---------- */
.bgn-eyebrow {
	display: inline-block;
	font-size: 12px;
	font-weight: 600;
	letter-spacing: 2.4px;
	text-transform: uppercase;
	color: var(--bgn-accent);
	margin-bottom: 12px;
}

.bgn-eyebrow--on-dark {
	color: rgba(255, 255, 255, 0.85);
}

.bgn-section-header {
	margin-bottom: 48px;
}

.bgn-section-header--center {
	text-align: center;
}

.bgn-section-title {
	font-size: clamp(28px, 4vw, 40px);
	font-weight: 700;
	color: var(--bgn-primary);
	margin: 0 0 12px;
	line-height: 1.15;
	letter-spacing: -0.02em;
}

.bgn-section-lede {
	font-size: 17px;
	color: var(--bgn-ink-2);
	max-width: 680px;
	margin: 0 auto;
}

/* ---------- Buttons ---------- */
.bgn-btn {
	display: inline-flex;
	align-items: center;
	gap: 10px;
	padding: 14px 28px;
	border-radius: var(--bgn-radius-sm);
	font-family: var(--bgn-font);
	font-size: 15px;
	font-weight: 600;
	letter-spacing: 0.3px;
	text-decoration: none;
	cursor: pointer;
	border: 2px solid transparent;
	transition: all 0.22s ease;
	line-height: 1;
	white-space: nowrap;
}

.bgn-btn--primary {
	background: var(--bgn-primary);
	color: #fff;
	border-color: var(--bgn-primary);
}

.bgn-btn--primary:hover,
.bgn-btn--primary:focus {
	background: var(--bgn-primary-2);
	border-color: var(--bgn-primary-2);
	color: #fff;
	transform: translateY(-1px);
	box-shadow: var(--bgn-shadow);
}

.bgn-btn--accent {
	background: var(--bgn-accent);
	color: #fff;
	border-color: var(--bgn-accent);
}

.bgn-btn--accent:hover,
.bgn-btn--accent:focus {
	background: var(--bgn-accent-2);
	border-color: var(--bgn-accent-2);
	color: #fff;
	transform: translateY(-1px);
	box-shadow: var(--bgn-shadow);
}

.bgn-btn--secondary {
	background: transparent;
	color: var(--bgn-primary);
	border-color: var(--bgn-primary);
}

.bgn-btn--secondary:hover,
.bgn-btn--secondary:focus {
	background: var(--bgn-primary);
	color: #fff;
}

.bgn-btn--ghost {
	background: transparent;
	color: var(--bgn-primary);
	border-color: var(--bgn-line);
}

.bgn-btn--ghost:hover,
.bgn-btn--ghost:focus {
	background: var(--bgn-bg-soft);
	color: var(--bgn-primary);
	border-color: var(--bgn-primary);
}

.bgn-btn--large {
	padding: 18px 36px;
	font-size: 16px;
}

.bgn-btn-arrow {
	transition: transform 0.22s ease;
	display: inline-block;
}

.bgn-btn:hover .bgn-btn-arrow,
.bgn-btn:focus .bgn-btn-arrow {
	transform: translateX(4px);
}

.bgn-cta-wrapper {
	margin-top: 24px;
}

.bgn-cta-wrapper--center {
	text-align: center;
}

/* ---------- HERO ---------- */
.bgn-hero {
	position: relative;
	background: linear-gradient(135deg, var(--bgn-primary) 0%, #122e54 60%, #0a2240 100%);
	color: #fff;
	padding: clamp(72px, 10vw, 140px) 0 clamp(80px, 11vw, 150px);
	overflow: hidden;
}

.bgn-hero__inner {
	position: relative;
	z-index: 2;
	max-width: 820px;
}

.bgn-hero__eyebrow {
	display: inline-block;
	font-size: 12px;
	font-weight: 600;
	letter-spacing: 2.6px;
	text-transform: uppercase;
	color: rgba(255, 255, 255, 0.85);
	margin-bottom: 18px;
}

.bgn-hero__title {
	font-size: clamp(38px, 6vw, 64px);
	font-weight: 700;
	margin: 0 0 24px;
	line-height: 1.05;
	letter-spacing: -0.025em;
	color: #fff;
}

.bgn-hero__subhead {
	font-size: clamp(16px, 1.45vw, 19px);
	color: rgba(255, 255, 255, 0.78);
	max-width: 680px;
	margin: 0 0 36px;
	line-height: 1.6;
	font-weight: 400;
	hyphens: manual !important;
}

/* Hero CTA — promoted from underlined link to outlined button. */
.bgn-hero__cta {
	display: inline-flex;
	align-items: center;
	gap: 10px;
	color: #fff;
	font-weight: 600;
	font-size: 14.5px;
	letter-spacing: 0.2px;
	text-decoration: none;
	background: transparent;
	border: 1.5px solid rgba(255, 255, 255, 0.4);
	padding: 12px 22px;
	border-radius: 6px;
	transition: background 0.22s ease, border-color 0.22s ease, transform 0.22s ease;
}

.bgn-hero__cta:hover,
.bgn-hero__cta:focus {
	color: #fff;
	background: rgba(255, 255, 255, 0.12);
	border-color: #fff;
	transform: translateY(-1px);
	text-decoration: none;
}

.bgn-hero__pattern {
	position: absolute;
	right: -100px;
	top: -50px;
	width: 480px;
	height: 480px;
	border-radius: 50%;
	background: radial-gradient(circle at 30% 30%, rgba(255, 255, 255, 0.06), transparent 65%);
	z-index: 1;
	pointer-events: none;
}

.bgn-hero::after {
	content: "";
	position: absolute;
	left: 0;
	bottom: 0;
	width: 100%;
	height: 4px;
	background: var(--bgn-accent);
	opacity: 0.85;
}

/* ---------- VALUES ---------- */
.bgn-values {
	padding: clamp(64px, 8vw, 100px) 0;
	background: var(--bgn-bg);
}

.bgn-values__grid {
	display: grid;
	grid-template-columns: repeat(4, 1fr);
	gap: 24px;
}

.bgn-value-card {
	padding: 32px 26px;
	background: var(--bgn-bg-alt);
	border-radius: var(--bgn-radius);
	border: 1px solid var(--bgn-line);
	transition: all 0.25s ease;
	position: relative;
	overflow: hidden;
}

.bgn-value-card::before {
	content: "";
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 3px;
	background: var(--bgn-accent);
	transform: scaleX(0);
	transform-origin: left;
	transition: transform 0.3s ease;
}

.bgn-value-card:hover {
	background: #fff;
	border-color: var(--bgn-primary);
	transform: translateY(-4px);
	box-shadow: var(--bgn-shadow);
}

.bgn-value-card:hover::before {
	transform: scaleX(1);
}

.bgn-value-card__icon {
	width: 52px;
	height: 52px;
	border-radius: 12px;
	background: var(--bgn-primary);
	color: var(--bgn-accent);
	display: inline-flex;
	align-items: center;
	justify-content: center;
	margin-bottom: 18px;
}

.bgn-value-card__icon svg {
	width: 26px;
	height: 26px;
}

.bgn-value-card__title {
	font-size: 18px;
	font-weight: 700;
	color: var(--bgn-primary);
	margin: 0 0 10px;
}

.bgn-value-card__body {
	font-size: 14.5px;
	color: var(--bgn-ink-2);
	margin: 0;
	line-height: 1.6;
}

/* ---------- OPENINGS / JOB CARDS (magazine layout) ---------- */
.bgn-openings {
	padding: clamp(64px, 8vw, 100px) 0;
	background: var(--bgn-bg-alt);
}

.bgn-eyebrow--decorative {
	color: var(--bgn-accent);
	font-style: normal;
	font-weight: 500;
	letter-spacing: 2.4px;
}

.bgn-jobs-grid {
	display: grid;
	grid-template-columns: 1fr;
	gap: 20px;
}

.bgn-job-card {
	position: relative;
	background: #fff;
	border-radius: 16px;
	padding: 36px;
	border: 1px solid var(--bgn-line);
	overflow: hidden;
	transition: transform 0.28s ease, box-shadow 0.28s ease, border-color 0.28s ease;
}

.bgn-job-card::before {
	content: "";
	position: absolute;
	left: 0;
	top: 0;
	bottom: 0;
	width: 3px;
	background: var(--bgn-accent);
	transform: scaleY(0);
	transform-origin: top;
	transition: transform 0.32s ease;
	border-radius: 16px 0 0 16px;
}

.bgn-job-card::after {
	content: "";
	position: absolute;
	right: -40px;
	top: -40px;
	width: 160px;
	height: 160px;
	background: radial-gradient(circle at center, rgba(201, 169, 97, 0.08) 0%, transparent 70%);
	border-radius: 50%;
	pointer-events: none;
	opacity: 0;
	transition: opacity 0.32s ease;
}

.bgn-job-card:hover {
	border-color: var(--bgn-primary);
	box-shadow: var(--bgn-shadow-lg);
	transform: translateY(-3px);
}

.bgn-job-card:hover::before { transform: scaleY(1); }
.bgn-job-card:hover::after  { opacity: 1; }

.bgn-job-card__num {
	position: absolute;
	top: 28px;
	right: 36px;
	font-family: Georgia, "Times New Roman", serif;
	font-style: italic;
	font-size: 13px;
	letter-spacing: 3px;
	color: var(--bgn-accent);
	opacity: 0.7;
	font-weight: 400;
}

.bgn-job-card__head {
	margin-bottom: 18px;
	padding-right: 80px; /* leaves room for the index in the corner */
}

.bgn-job-card__dept {
	display: inline-block;
	font-size: 11px;
	font-weight: 600;
	letter-spacing: 1.6px;
	text-transform: uppercase;
	color: var(--bgn-accent-2);
	background: rgba(201, 169, 97, 0.12);
	padding: 5px 12px;
	border-radius: 4px;
	margin-bottom: 12px;
}

.bgn-job-card__title {
	font-size: clamp(22px, 2.4vw, 28px);
	font-weight: 700;
	color: var(--bgn-primary);
	margin: 0;
	line-height: 1.18;
	letter-spacing: -0.018em;
}

.bgn-job-card__title a {
	color: inherit;
	text-decoration: none;
	transition: color 0.2s ease;
	background-image: linear-gradient(var(--bgn-accent), var(--bgn-accent));
	background-size: 0% 2px;
	background-repeat: no-repeat;
	background-position: 0 100%;
	transition: background-size 0.32s ease;
	padding-bottom: 2px;
}

.bgn-job-card__title a:hover {
	color: var(--bgn-primary);
	background-size: 100% 2px;
}

.bgn-job-card__summary {
	font-size: 15px;
	color: var(--bgn-ink-2);
	margin: 0 0 22px;
	line-height: 1.65;
	padding-left: 20px;
	border-left: 3px solid var(--bgn-accent);
	max-width: 56ch;
	font-style: italic;
}

.bgn-job-card__meta {
	list-style: none;
	padding: 0;
	margin: 0 0 26px;
	display: flex;
	flex-wrap: wrap;
	gap: 8px;
}

.bgn-job-card__meta li {
	display: inline-flex;
	align-items: center;
	gap: 6px;
	font-size: 12.5px;
	color: var(--bgn-primary-2);
	background: var(--bgn-bg-soft);
	padding: 6px 14px;
	border-radius: 100px;
	font-weight: 500;
}

.bgn-job-card__meta svg {
	color: var(--bgn-secondary);
	flex-shrink: 0;
}

.bgn-job-card__foot {
	display: flex;
	justify-content: space-between;
	align-items: center;
	padding-top: 22px;
	border-top: 1px solid var(--bgn-line);
	gap: 16px;
	flex-wrap: wrap;
}

.bgn-job-card__comp {
	font-size: 19px;
	font-weight: 600;
	color: var(--bgn-primary);
	line-height: 1.2;
}

.bgn-job-card__comp small {
	display: block;
	font-size: 11px;
	font-weight: 500;
	letter-spacing: 1.4px;
	text-transform: uppercase;
	color: var(--bgn-muted);
	margin-bottom: 4px;
}

.bgn-job-card__comp--placeholder {
	font-size: 14px;
	font-weight: 500;
	color: var(--bgn-muted);
	font-style: italic;
}

.bgn-job-card__comp--placeholder small {
	font-style: normal;
	color: var(--bgn-muted);
}

.bgn-job-card__actions {
	display: flex;
	gap: 10px;
}

.bgn-job-card__actions .bgn-btn {
	padding: 11px 22px;
	font-size: 14px;
}

/* ---------- EMPTY STATE ---------- */
.bgn-empty {
	background: #fff;
	border: 2px dashed var(--bgn-line);
	border-radius: var(--bgn-radius);
	padding: 56px 32px;
	text-align: center;
	color: var(--bgn-ink-2);
}

.bgn-empty svg {
	color: var(--bgn-muted);
	margin-bottom: 16px;
}

.bgn-empty h3 {
	font-size: 22px;
	color: var(--bgn-primary);
	margin: 0 0 12px;
}

.bgn-empty p {
	max-width: 540px;
	margin: 0 auto;
	font-size: 15.5px;
	line-height: 1.6;
}

.bgn-empty a {
	color: var(--bgn-accent-2);
	font-weight: 600;
}

/* ---------- WIZEHIRE ---------- */
.bgn-wizehire {
	padding: clamp(56px, 7vw, 90px) 0;
	background: var(--bgn-bg);
	border-top: 1px solid var(--bgn-line);
}

.bgn-wizehire__embed {
	max-width: 980px;
	margin: 0 auto 32px;
	padding: 24px;
	border-radius: var(--bgn-radius);
	background: var(--bgn-bg-alt);
	border: 1px solid var(--bgn-line);
}

.bgn-wizehire__embed iframe {
	width: 100%;
	min-height: 400px;
	border: 0;
}

/* ---------- GENERAL APP ---------- */
.bgn-general-app {
	padding: clamp(56px, 7vw, 90px) 0;
	background: linear-gradient(180deg, var(--bgn-bg-alt) 0%, var(--bgn-bg) 100%);
}

.bgn-general-app__card {
	display: grid;
	grid-template-columns: 80px 1fr;
	gap: 28px;
	align-items: center;
	background: #fff;
	border: 1px solid var(--bgn-line);
	border-left: 4px solid var(--bgn-accent);
	border-radius: var(--bgn-radius);
	padding: 36px 40px;
	box-shadow: var(--bgn-shadow);
}

.bgn-general-app__icon {
	width: 80px;
	height: 80px;
	background: var(--bgn-primary);
	color: var(--bgn-accent);
	border-radius: 50%;
	display: flex;
	align-items: center;
	justify-content: center;
	flex-shrink: 0;
}

.bgn-general-app__body h2 {
	font-size: 24px;
	color: var(--bgn-primary);
	margin: 0 0 8px;
	font-weight: 700;
}

.bgn-general-app__body p {
	font-size: 15.5px;
	color: var(--bgn-ink-2);
	margin: 0 0 18px;
	line-height: 1.65;
}

.bgn-general-app__body a:not(.bgn-btn) {
	color: var(--bgn-accent-2);
	font-weight: 600;
	text-decoration: underline;
}

/* ---------- EOE ---------- */
.bgn-eoe {
	padding: 24px 0 32px;
	background: var(--bgn-bg);
	text-align: center;
	border-top: 1px solid var(--bgn-line);
}

.bgn-eoe p {
	font-size: 13px;
	color: var(--bgn-muted);
	font-style: italic;
	margin: 0;
	letter-spacing: 0.3px;
}

/* ---------- SINGLE JOB PAGE ---------- */
.bgn-single-hero {
	position: relative;
	background: linear-gradient(135deg, var(--bgn-primary) 0%, #122e54 60%, #0a2240 100%);
	color: #fff;
	padding: 56px 0 64px;
	overflow: hidden;
}

.bgn-single-hero::after {
	content: "";
	position: absolute;
	left: 0;
	bottom: 0;
	width: 100%;
	height: 4px;
	background: var(--bgn-accent);
}

.bgn-breadcrumb {
	font-size: 13px;
	color: rgba(255, 255, 255, 0.7);
	margin-bottom: 24px;
	display: flex;
	align-items: center;
	gap: 8px;
	flex-wrap: wrap;
}

.bgn-breadcrumb a {
	color: rgba(255, 255, 255, 0.85);
	text-decoration: none;
	transition: color 0.2s ease;
}

.bgn-breadcrumb a:hover {
	color: var(--bgn-accent);
}

.bgn-breadcrumb__current {
	color: var(--bgn-accent);
}

.bgn-single-hero__inner {
	position: relative;
	z-index: 2;
	display: grid;
	grid-template-columns: 1fr auto;
	gap: 32px;
	align-items: end;
}

.bgn-single-hero__title {
	font-size: clamp(32px, 4.5vw, 48px);
	font-weight: 700;
	margin: 8px 0 18px;
	line-height: 1.1;
	letter-spacing: -0.02em;
	color: #fff;
}

.bgn-job-card__meta--hero li {
	color: rgba(255, 255, 255, 0.92);
	font-size: 14.5px;
}

.bgn-job-card__meta--hero svg {
	color: var(--bgn-accent);
}

/* ---------- SINGLE BODY ---------- */
.bgn-single-body {
	padding: 64px 0 80px;
	background: var(--bgn-bg);
}

.bgn-single-grid {
	display: grid;
	grid-template-columns: 1fr 320px;
	gap: 56px;
	align-items: start;
}

.bgn-single-content {
	min-width: 0;
}

.bgn-block {
	margin-bottom: 44px;
}

.bgn-block:last-child {
	margin-bottom: 0;
}

.bgn-block h2 {
	font-size: 24px;
	font-weight: 700;
	color: var(--bgn-primary);
	margin: 0 0 18px;
	padding-bottom: 14px;
	border-bottom: 2px solid var(--bgn-bg-soft);
	position: relative;
}

.bgn-block h2::after {
	content: "";
	position: absolute;
	left: 0;
	bottom: -2px;
	width: 56px;
	height: 2px;
	background: var(--bgn-accent);
}

.bgn-lede,
.bgn-lede p {
	font-size: 17px;
	color: var(--bgn-ink-2);
	line-height: 1.7;
	margin: 0;
}
.bgn-lede p + p { margin-top: 16px; }

.bgn-checklist {
	list-style: none !important;
	padding: 0 !important;
	margin: 0 !important;
	display: flex !important;
	flex-direction: column !important;
	gap: 12px !important;
}

.bgn-checklist li {
	display: flex !important;
	flex-direction: row !important;
	align-items: flex-start !important;
	gap: 12px !important;
	font-size: 15.5px;
	color: var(--bgn-ink-2);
	line-height: 1.55;
	width: 100% !important;
	min-width: 0;
	padding: 0 !important;
	margin: 0 !important;
}

.bgn-checklist li::before,
.bgn-checklist li::marker {
	content: none !important;
	display: none !important;
}

.bgn-checklist li > .bgn-check {
	flex: 0 0 22px !important;
}

.bgn-checklist li > .bgn-bullet-text {
	flex: 1 1 auto !important;
	min-width: 0 !important;
	display: block !important;
	width: auto !important;
}

.bgn-check {
	width: 22px;
	height: 22px;
	border-radius: 6px;
	background: rgba(14, 42, 71, 0.08);
	display: inline-flex;
	align-items: center;
	justify-content: center;
	flex-shrink: 0;
	margin-top: 1px;
	position: relative;
}

.bgn-check::after {
	content: "";
	width: 6px;
	height: 10px;
	border: solid var(--bgn-primary);
	border-width: 0 2px 2px 0;
	transform: rotate(45deg) translate(-1px, -1px);
}

.bgn-checklist--accent .bgn-check {
	background: rgba(200, 16, 46, 0.10);
}

.bgn-checklist--accent .bgn-check::after {
	border-color: var(--bgn-accent);
}

/* Group sub-headings within a responsibilities/qualifications list. */
.bgn-bullets__group {
	margin: 22px 0 10px;
	font-size: 15px;
	font-weight: 600;
	color: var(--bgn-primary);
	letter-spacing: 0.2px;
	text-transform: uppercase;
	border-left: 3px solid var(--bgn-accent);
	padding-left: 10px;
	line-height: 1.3;
}
.bgn-bullets__group:first-child { margin-top: 0; }

.bgn-block--apply {
	background: var(--bgn-bg-alt);
	padding: 32px;
	border-radius: var(--bgn-radius);
	border: 1px solid var(--bgn-line);
}

.bgn-block--apply h2 {
	border-bottom: none;
	padding-bottom: 0;
	margin-bottom: 12px;
}

.bgn-block--apply h2::after {
	display: none;
}

.bgn-block--apply p {
	font-size: 15.5px;
	color: var(--bgn-ink-2);
	margin: 0 0 22px;
	line-height: 1.65;
}

/* ---------- SIDEBAR ---------- */
.bgn-single-sidebar {
	position: sticky;
	top: 100px;
	display: grid;
	gap: 20px;
}

.bgn-sidebar-card {
	background: #fff;
	border: 1px solid var(--bgn-line);
	border-radius: var(--bgn-radius);
	padding: 24px;
	box-shadow: var(--bgn-shadow);
}

.bgn-sidebar-card h3 {
	font-size: 17px;
	color: var(--bgn-primary);
	margin: 0 0 12px;
	font-weight: 700;
}

.bgn-sidebar-card p {
	font-size: 14px;
	color: var(--bgn-ink-2);
	margin: 0 0 16px;
	line-height: 1.6;
}

.bgn-sidebar-meta {
	list-style: none;
	padding: 0;
	margin: 0;
	display: grid;
	gap: 10px;
}

.bgn-sidebar-meta li {
	display: flex;
	gap: 10px;
	align-items: flex-start;
	font-size: 13.5px;
	color: var(--bgn-ink-2);
}

.bgn-sidebar-meta svg {
	color: var(--bgn-accent);
	flex-shrink: 0;
	margin-top: 3px;
}

.bgn-sidebar-meta a {
	color: var(--bgn-ink-2);
	text-decoration: none;
}

.bgn-sidebar-meta a:hover {
	color: var(--bgn-primary);
}

.bgn-sidebar-jobs {
	list-style: none;
	padding: 0;
	margin: 0 0 16px;
	display: grid;
	gap: 8px;
}

.bgn-sidebar-jobs li a {
	display: block;
	padding: 12px 14px;
	background: var(--bgn-bg-alt);
	border-radius: var(--bgn-radius-sm);
	text-decoration: none;
	transition: all 0.2s ease;
}

.bgn-sidebar-jobs li a:hover {
	background: var(--bgn-primary);
	transform: translateX(2px);
}

.bgn-sidebar-jobs li a strong {
	display: block;
	color: var(--bgn-primary);
	font-size: 14.5px;
	font-weight: 600;
	margin-bottom: 2px;
}

.bgn-sidebar-jobs li a:hover strong {
	color: #fff;
}

.bgn-sidebar-jobs li a span {
	font-size: 12.5px;
	color: var(--bgn-muted);
}

.bgn-sidebar-jobs li a:hover span {
	color: rgba(255, 255, 255, 0.8);
}

.bgn-sidebar-link {
	display: inline-block;
	color: var(--bgn-accent-2);
	font-weight: 600;
	font-size: 14px;
	text-decoration: none;
}

.bgn-sidebar-link:hover {
	color: var(--bgn-primary);
}

/* ---------- RESPONSIVE ---------- */
@media (max-width: 980px) {
	.bgn-values__grid { grid-template-columns: repeat(2, 1fr); }
	.bgn-job-card { padding: 30px 26px; }
	.bgn-job-card__num { top: 22px; right: 22px; font-size: 12px; }
	.bgn-job-card__head { padding-right: 70px; }
	.bgn-job-card__foot {
		flex-direction: column;
		align-items: flex-start;
		gap: 18px;
	}
	.bgn-job-card__actions {
		width: 100%;
	}
	.bgn-job-card__actions .bgn-btn {
		flex: 1;
		justify-content: center;
		min-width: 130px;
	}
	.bgn-single-grid {
		grid-template-columns: 1fr;
		gap: 40px;
	}
	.bgn-single-sidebar { position: static; }
	.bgn-single-hero__inner {
		grid-template-columns: 1fr;
		align-items: start;
	}
}

@media (max-width: 640px) {
	.bgn-values__grid { grid-template-columns: 1fr; }
	.bgn-job-card { padding: 26px 22px; border-radius: 12px; }
	.bgn-job-card::before { border-radius: 12px 0 0 12px; }
	.bgn-job-card__num { display: none; }
	.bgn-job-card__head { padding-right: 0; }
	.bgn-job-card__title { font-size: 20px; }
	.bgn-job-card__summary {
		font-size: 14px;
		padding-left: 16px;
		margin-bottom: 18px;
	}
	.bgn-job-card__actions {
		flex-direction: column;
	}
	.bgn-job-card__actions .bgn-btn {
		width: 100%;
	}
	.bgn-job-card__comp { font-size: 17px; }
	.bgn-block--apply { padding: 24px; }
	.bgn-general-app__card {
		grid-template-columns: 1fr;
		text-align: center;
		padding: 28px 24px;
	}
	.bgn-general-app__icon { margin: 0 auto; }
	.bgn-block h2 { font-size: 20px; }
	.bgn-hero { padding: 64px 0 72px; }
	.bgn-single-hero { padding: 40px 0 48px; }
}

/* ====================================================================== */
/* Application form (Phase 2)                                              */
/* ====================================================================== */

.bgn-apply {
	background: var(--bgn-bg-soft);
	padding: clamp(48px, 7vw, 88px) 0 clamp(64px, 9vw, 100px);
	border-top: 1px solid var(--bgn-line);
}

.bgn-apply__card {
	max-width: 820px;
	margin: 0 auto;
	background: #fff;
	padding: clamp(28px, 4vw, 56px);
	border-radius: var(--bgn-radius);
	box-shadow: var(--bgn-shadow);
	border: 1px solid var(--bgn-line);
}

.bgn-apply__head {
	margin-bottom: 32px;
	padding-bottom: 24px;
	border-bottom: 1px solid var(--bgn-line);
}

.bgn-apply__title {
	font-size: clamp(24px, 3vw, 32px);
	font-weight: 700;
	color: var(--bgn-primary);
	margin: 8px 0 12px;
	line-height: 1.2;
	letter-spacing: -0.015em;
}

.bgn-apply__lede {
	color: var(--bgn-ink-2);
	font-size: 15.5px;
	margin: 0;
	line-height: 1.65;
}

/* Notices */
.bgn-notice {
	padding: 18px 22px;
	border-radius: 10px;
	margin-bottom: 24px;
	border-left: 4px solid;
	background: #fff;
}
.bgn-notice strong { display: block; margin-bottom: 4px; font-size: 15px; }
.bgn-notice p { margin: 0; font-size: 14.5px; line-height: 1.55; color: var(--bgn-ink-2); }
.bgn-notice--success {
	background: #f0f9f4;
	border-left-color: #15803d;
	color: #14532d;
}
.bgn-notice--success strong { color: #14532d; }
.bgn-notice--error {
	background: #fef2f2;
	border-left-color: var(--bgn-accent);
	color: #7f1d1d;
}
.bgn-notice--error strong { color: #7f1d1d; }

/* Form layout */
.bgn-form { display: flex; flex-direction: column; gap: 28px; }

.bgn-form__group {
	border: 1px solid var(--bgn-line);
	border-radius: 10px;
	padding: 22px 24px 24px;
	margin: 0;
	background: var(--bgn-bg-alt);
}

.bgn-form__group legend {
	font-size: 12px;
	font-weight: 700;
	letter-spacing: 1.4px;
	text-transform: uppercase;
	color: var(--bgn-primary);
	background: #fff;
	padding: 4px 10px;
	border: 1px solid var(--bgn-line);
	border-radius: 4px;
	margin-left: -2px;
}

.bgn-form__group-lede {
	color: var(--bgn-ink-2);
	font-size: 14px;
	line-height: 1.6;
	margin: 14px 0 18px;
	max-width: 640px;
}

.bgn-form__row { display: flex; flex-direction: column; gap: 18px; margin-top: 14px; }
.bgn-form__row:first-of-type { margin-top: 6px; }
.bgn-form__row--two { display: grid; grid-template-columns: 1fr 1fr; gap: 16px 20px; }
@media (max-width: 640px) {
	.bgn-form__row--two { grid-template-columns: 1fr; }
}

.bgn-form__field { display: flex; flex-direction: column; }
.bgn-form__label {
	font-size: 13px;
	font-weight: 600;
	color: var(--bgn-primary);
	margin-bottom: 6px;
	letter-spacing: 0.1px;
}
.bgn-req {
	color: var(--bgn-accent);
	font-weight: 700;
	margin-left: 2px;
}

.bgn-form__field input[type="text"],
.bgn-form__field input[type="email"],
.bgn-form__field input[type="tel"],
.bgn-form__field input[type="url"],
.bgn-form__field textarea {
	font-family: var(--bgn-font);
	font-size: 15px;
	color: var(--bgn-ink);
	background: #fff;
	border: 1px solid var(--bgn-line);
	border-radius: 8px;
	padding: 11px 14px;
	width: 100%;
	transition: border-color 0.18s ease, box-shadow 0.18s ease;
	line-height: 1.5;
}

.bgn-form__field input[type="file"] {
	font-family: var(--bgn-font);
	font-size: 13.5px;
	color: var(--bgn-ink-2);
	background: #fff;
	border: 1px dashed #b6c0cc;
	border-radius: 8px;
	padding: 10px 12px;
	width: 100%;
	cursor: pointer;
}
.bgn-form__field input[type="file"]::file-selector-button {
	font-family: var(--bgn-font);
	font-weight: 600;
	font-size: 13px;
	letter-spacing: 0.2px;
	background: var(--bgn-primary);
	color: #fff;
	border: 0;
	padding: 8px 14px;
	border-radius: 5px;
	cursor: pointer;
	margin-right: 12px;
}

.bgn-form__field textarea { resize: vertical; min-height: 110px; }

.bgn-form__field input:focus,
.bgn-form__field textarea:focus {
	outline: 0;
	border-color: var(--bgn-primary);
	box-shadow: 0 0 0 3px rgba(14, 42, 71, 0.10);
}

.bgn-form__hint {
	font-size: 12px;
	color: var(--bgn-muted);
	margin-top: 6px;
	line-height: 1.45;
}

/* Honeypot — visually hidden but still in the DOM. */
.bgn-form__hp {
	position: absolute;
	left: -10000px;
	top: auto;
	width: 1px;
	height: 1px;
	overflow: hidden;
}

/* Per-document writing-sample block (attorney form). */
.bgn-form__doc {
	background: #fff;
	border: 1px solid var(--bgn-line);
	border-radius: 8px;
	padding: 16px 18px 18px;
	margin-top: 14px;
}
.bgn-form__doc:first-of-type { margin-top: 6px; }

.bgn-form__doc-head { margin-bottom: 6px; }
.bgn-form__doc-title {
	display: block;
	color: var(--bgn-primary);
	font-size: 14.5px;
	font-weight: 700;
	margin-bottom: 4px;
}
.bgn-form__doc-help {
	display: block;
	color: var(--bgn-ink-2);
	font-size: 13px;
	line-height: 1.55;
	font-weight: 400;
}

/* Submit row */
.bgn-form__actions {
	display: flex;
	flex-direction: column;
	align-items: flex-start;
	gap: 14px;
	padding-top: 8px;
}
.bgn-form__legal {
	font-size: 12.5px;
	color: var(--bgn-muted);
	margin: 0;
	max-width: 560px;
	line-height: 1.55;
}

/* General-app intro block (revised since Phase 1) */
.bgn-general-app { background: #fff; padding: 0 0 0; }
.bgn-general-app__intro {
	max-width: 720px;
	margin: 0 auto 8px;
	text-align: center;
	padding: clamp(56px, 7vw, 80px) 0 0;
}
.bgn-general-app__intro h2 {
	font-size: clamp(26px, 3.4vw, 36px);
	color: var(--bgn-primary);
	font-weight: 700;
	margin: 18px 0 14px;
	line-height: 1.15;
	letter-spacing: -0.02em;
}
.bgn-general-app__intro p {
	color: var(--bgn-ink-2);
	font-size: 16.5px;
	line-height: 1.65;
	margin: 0 auto;
	max-width: 620px;
}
.bgn-general-app__icon {
	display: inline-flex;
	width: 64px;
	height: 64px;
	background: rgba(200, 16, 46, 0.08);
	color: var(--bgn-accent);
	border-radius: 50%;
	align-items: center;
	justify-content: center;
}

/* Optional CTA-style wrapper around an inline-form Apply block */
.bgn-block--apply-cta {
	background: linear-gradient(135deg, var(--bgn-primary) 0%, #163b62 100%);
	color: #fff;
	border-color: transparent;
}
.bgn-block--apply-cta h2 { color: #fff; }
.bgn-block--apply-cta p { color: rgba(255, 255, 255, 0.86); }

/* ====================================================================== */
/* v2.0 — Hero stat strip + modern job rows                                */
/* ====================================================================== */

/* Hero stat strip */
.bgn-hero-stats {
	display: grid;
	grid-template-columns: repeat(4, 1fr);
	gap: 0;
	margin: 56px 0 0;
	padding: 24px 0 0;
	border-top: 1px solid rgba(255, 255, 255, 0.18);
	max-width: 880px;
}
.bgn-hero-stats__item {
	padding: 0 18px;
	border-left: 1px solid rgba(255, 255, 255, 0.18);
}
.bgn-hero-stats__item:first-child { border-left: 0; padding-left: 0; }
.bgn-hero-stats__item dt {
	display: block;
	font-size: 11px;
	font-weight: 600;
	letter-spacing: 1.8px;
	text-transform: uppercase;
	color: rgba(255, 255, 255, 0.55);
	margin: 0 0 6px;
}
.bgn-hero-stats__item dd {
	margin: 0;
	font-size: 17px;
	font-weight: 600;
	color: #fff;
	letter-spacing: -0.005em;
	line-height: 1.3;
}
@media (max-width: 720px) {
	.bgn-hero-stats { grid-template-columns: repeat(2, 1fr); gap: 18px 0; }
	.bgn-hero-stats__item:nth-child(3) { border-left: 0; padding-left: 0; }
}
@media (max-width: 480px) {
	.bgn-hero-stats { grid-template-columns: 1fr; }
	.bgn-hero-stats__item { border-left: 0; padding-left: 0; padding-bottom: 14px; border-bottom: 1px solid rgba(255,255,255,0.12); }
	.bgn-hero-stats__item:last-child { border-bottom: 0; padding-bottom: 0; }
}

/* Job rows — replace the bgn-jobs-grid stacked cards with a sleek list */
.bgn-jobs-list {
	display: flex;
	flex-direction: column;
	gap: 12px;
	max-width: 1080px;
	margin: 0 auto;
}

.bgn-job-row {
	position: relative;
	display: grid;
	grid-template-columns: 1fr auto auto;
	align-items: center;
	gap: 28px;
	padding: 26px 30px;
	background: #fff;
	border: 1px solid var(--bgn-line);
	border-radius: var(--bgn-radius);
	transition: border-color 0.2s ease, transform 0.2s ease, box-shadow 0.2s ease;
}

.bgn-job-row:hover {
	border-color: var(--bgn-primary);
	transform: translateY(-2px);
	box-shadow: var(--bgn-shadow);
}

/* Whole-row click target sits behind the actual links so they still work */
.bgn-job-row__link {
	position: absolute;
	inset: 0;
	z-index: 1;
	border-radius: inherit;
	text-decoration: none;
}
.bgn-job-row__main, .bgn-job-row__meta, .bgn-job-row__cta { position: relative; z-index: 2; }

.bgn-job-row__main { min-width: 0; }
.bgn-job-row__dept {
	display: inline-block;
	font-size: 11px;
	font-weight: 700;
	letter-spacing: 1.4px;
	text-transform: uppercase;
	color: var(--bgn-accent);
	margin-bottom: 8px;
}
.bgn-job-row__title {
	font-size: 22px;
	font-weight: 700;
	color: var(--bgn-primary);
	margin: 0 0 6px;
	line-height: 1.2;
	letter-spacing: -0.015em;
}
.bgn-job-row__summary {
	color: var(--bgn-ink-2);
	font-size: 14.5px;
	margin: 0;
	line-height: 1.55;
	max-width: 540px;
}

.bgn-job-row__meta {
	display: flex;
	flex-direction: column;
	gap: 8px;
	min-width: 200px;
}

.bgn-tag {
	display: inline-flex !important;
	align-items: center !important;
	gap: 6px !important;
	padding: 5px 10px !important;
	background: var(--bgn-bg-soft);
	border: 1px solid var(--bgn-line);
	border-radius: 6px;
	font-size: 12.5px;
	font-weight: 500;
	color: var(--bgn-ink-2);
	white-space: nowrap;
	margin: 0 !important;
	list-style: none;
}
.bgn-tag svg { flex-shrink: 0; opacity: 0.7; }
.bgn-tag--type {
	background: rgba(14, 42, 71, 0.05);
	color: var(--bgn-primary);
	border-color: rgba(14, 42, 71, 0.12);
}
.bgn-tag--comp {
	background: rgba(200, 16, 46, 0.04);
	color: var(--bgn-accent);
	border-color: rgba(200, 16, 46, 0.18);
	font-weight: 600;
}

.bgn-job-row__cta { flex-shrink: 0; }
.bgn-job-row__cta .bgn-btn { padding: 12px 22px; font-size: 14px; }

@media (max-width: 900px) {
	.bgn-job-row {
		grid-template-columns: 1fr;
		gap: 16px;
		padding: 22px;
	}
	.bgn-job-row__meta { flex-direction: row; flex-wrap: wrap; min-width: 0; }
	.bgn-job-row__cta { justify-self: stretch; }
	.bgn-job-row__cta .bgn-btn { width: 100%; justify-content: center; }
}

/* ====================================================================== */
/* v2.0.2 — Callout box + Gutenberg post-content styles                    */
/* ====================================================================== */

/* Warning / info callouts inside post_content */
.bgn-callout {
	display: block;
	padding: 18px 22px;
	border-radius: 10px;
	margin: 24px 0;
	font-size: 15.5px;
	line-height: 1.6;
	background: #fff7f7;
	border-left: 4px solid var(--bgn-accent);
	color: #4a1414;
}
.bgn-callout strong {
	color: var(--bgn-accent);
	font-weight: 700;
}
.bgn-callout--warning {
	background: rgba(200, 16, 46, 0.06);
	border-left-color: var(--bgn-accent);
}

/* Headings and lists in the editor block (post_content) under a job */
.bgn-block--editor h3 {
	font-size: 20px;
	color: var(--bgn-primary);
	font-weight: 700;
	margin: 32px 0 12px;
	letter-spacing: -0.01em;
	padding-bottom: 0;
	border-bottom: 0;
}
.bgn-block--editor h3:first-child { margin-top: 8px; }
.bgn-block--editor h3::after { display: none; }

.bgn-block--editor ul,
.bgn-block--editor ol {
	margin: 0 0 18px;
	padding-left: 22px;
	color: var(--bgn-ink-2);
	line-height: 1.65;
	font-size: 15.5px;
}
.bgn-block--editor li {
	margin-bottom: 8px;
}
.bgn-block--editor p {
	color: var(--bgn-ink-2);
	font-size: 15.5px;
	line-height: 1.7;
	margin: 0 0 16px;
}

/* ====================================================================== */
/* v2.0.3 — Horizontal feature rows (replace narrow value cards)           */
/* ====================================================================== */

.bgn-features {
	display: grid;
	grid-template-columns: repeat(2, minmax(0, 1fr));
	gap: 28px 40px;
	margin-top: 8px;
}

.bgn-feature {
	display: flex;
	align-items: flex-start;
	gap: 18px;
	min-width: 0;
}

.bgn-feature__icon {
	flex: 0 0 48px;
	width: 48px;
	height: 48px;
	border-radius: 10px;
	background: rgba(14, 42, 71, 0.06);
	color: var(--bgn-accent);
	display: inline-flex !important;
	align-items: center;
	justify-content: center;
	margin-top: 2px;
}
.bgn-feature__icon svg { width: 22px; height: 22px; }

.bgn-feature__copy { flex: 1 1 auto; min-width: 0; }

.bgn-feature__title {
	font-size: 17px;
	font-weight: 700;
	color: var(--bgn-primary);
	margin: 0 0 6px;
	letter-spacing: -0.01em;
	line-height: 1.3;
}

.bgn-feature__body {
	font-size: 15px;
	color: var(--bgn-ink-2);
	line-height: 1.6;
	margin: 0;
}

@media (max-width: 720px) {
	.bgn-features { grid-template-columns: 1fr; gap: 22px; }
}

/* Tighten the values section — the old card layout had heavy padding */
.bgn-values {
	padding: clamp(56px, 7vw, 88px) 0 clamp(40px, 5vw, 60px);
}

/* Make Open Positions feel like the centerpiece of the page */
.bgn-openings {
	padding: clamp(48px, 6vw, 80px) 0 clamp(64px, 8vw, 100px) !important;
	background: var(--bgn-bg-alt);
}
.bgn-openings .bgn-section-title {
	font-size: clamp(32px, 4.2vw, 44px);
}

/* ====================================================================== */
/* v2.0.5 — Full careers page redesign                                     */
/* ====================================================================== */

/* --- HERO REDESIGN ---------------------------------------------------- */
.bgn-careers-wrapper .bgn-hero {
	padding: clamp(80px, 10vw, 132px) 0 clamp(72px, 9vw, 120px);
	background: linear-gradient(135deg, #0E2A47 0%, #0a2240 60%, #061830 100%);
	position: relative;
	overflow: hidden;
}

.bgn-careers-wrapper .bgn-hero__inner {
	position: relative;
	z-index: 2;
	max-width: 760px;
}

/* New CTA group — primary + secondary side by side */
.bgn-hero__ctas {
	display: flex;
	flex-wrap: wrap;
	gap: 14px;
	margin: 0 0 clamp(56px, 7vw, 88px);
}

.bgn-btn--ghost-on-dark {
	background: transparent;
	color: #fff;
	border-color: rgba(255, 255, 255, 0.32);
}
.bgn-btn--ghost-on-dark:hover,
.bgn-btn--ghost-on-dark:focus {
	background: rgba(255, 255, 255, 0.08);
	border-color: #fff;
	color: #fff;
	transform: translateY(-1px);
}

/* Hero meta — inline row, not boxes. */
.bgn-hero-meta {
	display: grid;
	grid-template-columns: repeat(4, minmax(0, 1fr));
	gap: 0;
	margin: 0;
	padding: 28px 0 0;
	border-top: 1px solid rgba(255, 255, 255, 0.14);
	max-width: 760px;
}
.bgn-hero-meta__item {
	padding: 0 22px 0 0;
	min-width: 0;
}
.bgn-hero-meta__item + .bgn-hero-meta__item {
	padding-left: 22px;
	border-left: 1px solid rgba(255, 255, 255, 0.14);
}
.bgn-hero-meta__item dt {
	display: block;
	font-size: 11px;
	font-weight: 600;
	letter-spacing: 1.6px;
	text-transform: uppercase;
	color: rgba(255, 255, 255, 0.5);
	margin: 0 0 8px;
}
.bgn-hero-meta__item dd {
	margin: 0;
	font-size: 16px;
	font-weight: 600;
	color: #fff;
	line-height: 1.35;
	letter-spacing: -0.005em;
}
@media (max-width: 820px) {
	.bgn-hero-meta { grid-template-columns: repeat(2, 1fr); gap: 24px 0; }
	.bgn-hero-meta__item:nth-child(odd) { border-left: 0; padding-left: 0; }
	.bgn-hero-meta__item { padding-right: 16px; }
}
@media (max-width: 480px) {
	.bgn-hero-meta { grid-template-columns: 1fr; gap: 0; }
	.bgn-hero-meta__item { border-left: 0 !important; padding: 14px 0 !important; border-bottom: 1px solid rgba(255, 255, 255, 0.10); }
	.bgn-hero-meta__item:last-child { border-bottom: 0; }
}

/* Hero pattern — large soft circle right side */
.bgn-careers-wrapper .bgn-hero__pattern {
	position: absolute;
	right: -120px;
	top: -100px;
	width: 540px;
	height: 540px;
	border-radius: 50%;
	background: radial-gradient(circle at 35% 35%, rgba(200, 16, 46, 0.08), transparent 65%);
	pointer-events: none;
	z-index: 1;
}

/* --- MISSION / ABOUT THE PRACTICE ------------------------------------- */
.bgn-mission {
	padding: clamp(64px, 8vw, 100px) 0;
	background: #fff;
}
.bgn-mission__grid {
	display: grid;
	grid-template-columns: 1.4fr 1fr;
	gap: clamp(36px, 6vw, 80px);
	align-items: start;
}
.bgn-mission__lede h2.bgn-mission__title {
	font-size: clamp(28px, 3.6vw, 40px);
	font-weight: 800;
	color: var(--bgn-primary);
	letter-spacing: -0.02em;
	line-height: 1.15;
	margin: 12px 0 24px;
	max-width: 520px;
}
.bgn-mission__lede p {
	font-size: 17px;
	line-height: 1.7;
	color: var(--bgn-ink-2);
	margin: 0 0 18px;
	max-width: 580px;
}
.bgn-mission__lede p:last-child { margin-bottom: 0; }

.bgn-mission__facts {
	background: var(--bgn-bg-alt);
	padding: 28px 28px 24px;
	border-radius: var(--bgn-radius);
	border: 1px solid var(--bgn-line);
	border-left: 3px solid var(--bgn-accent);
}
.bgn-fact {
	padding: 14px 0;
	border-bottom: 1px solid var(--bgn-line);
}
.bgn-fact:first-child { padding-top: 4px; }
.bgn-fact:last-child { border-bottom: 0; padding-bottom: 4px; }

.bgn-fact__label {
	display: block;
	font-size: 11px;
	font-weight: 700;
	letter-spacing: 1.4px;
	text-transform: uppercase;
	color: var(--bgn-accent);
	margin-bottom: 6px;
}
.bgn-fact__value {
	display: block;
	font-size: 15.5px;
	color: var(--bgn-primary);
	font-weight: 500;
	line-height: 1.5;
}

@media (max-width: 880px) {
	.bgn-mission__grid { grid-template-columns: 1fr; gap: 36px; }
}

/* --- HOW WE HIRE / PROCESS ------------------------------------------- */
.bgn-process {
	padding: clamp(64px, 8vw, 100px) 0;
	background: var(--bgn-bg-alt);
}
.bgn-process__steps {
	display: grid;
	grid-template-columns: repeat(4, minmax(0, 1fr));
	gap: 24px;
	list-style: none !important;
	padding: 0 !important;
	margin: 0;
	counter-reset: bgn-step;
}
.bgn-step {
	position: relative;
	background: #fff;
	padding: 32px 24px 28px;
	border-radius: var(--bgn-radius);
	border: 1px solid var(--bgn-line);
	transition: transform 0.25s ease, box-shadow 0.25s ease;
}
.bgn-step:hover {
	transform: translateY(-3px);
	box-shadow: var(--bgn-shadow);
	border-color: var(--bgn-primary);
}
.bgn-step__num {
	display: inline-block;
	font-size: 13px;
	font-weight: 800;
	letter-spacing: 2px;
	color: var(--bgn-accent);
	margin-bottom: 14px;
}
.bgn-step__title {
	font-size: 20px;
	font-weight: 700;
	color: var(--bgn-primary);
	margin: 0 0 10px;
	letter-spacing: -0.015em;
	line-height: 1.25;
}
.bgn-step__body {
	font-size: 14.5px;
	color: var(--bgn-ink-2);
	line-height: 1.6;
	margin: 0;
}
@media (max-width: 880px) { .bgn-process__steps { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 520px) { .bgn-process__steps { grid-template-columns: 1fr; } }

/* --- TYPOGRAPHIC POLISH FOR RED HAT DISPLAY --------------------------- */
/* Bold weights anchored at 800 for headings; body sits at 400/500 */
.bgn-careers-wrapper h1,
.bgn-careers-wrapper h2,
.bgn-single-main h1,
.bgn-single-main h2,
.bgn-archive-main h1,
.bgn-archive-main h2 {
	font-weight: 800 !important;
	letter-spacing: -0.02em;
}
.bgn-careers-wrapper h3,
.bgn-careers-wrapper h4,
.bgn-single-main h3,
.bgn-single-main h4 {
	font-weight: 700 !important;
}
.bgn-careers-wrapper p,
.bgn-single-main p,
.bgn-archive-main p,
.bgn-apply p {
	font-weight: 400 !important;
}
