/* ONHYM Career Management Pro — Recruitment auth & apply pages */

.ocmp-auth-wrap,
.ocmp-apply-wrap {
	--ocmp-green: #0F766E;
	--ocmp-green-dark: #0B5953;
	--ocmp-green-soft: rgba(15,118,110,.08);
	--ocmp-blue: #003B73;
	--ocmp-blue-soft: rgba(0,59,115,.08);
	--ocmp-gold: #C7A23A;
	--ocmp-gold-dark: #A8881F;
	--ocmp-gold-soft: rgba(199,162,58,.14);
	--ocmp-red: #DC2626;
	--ocmp-red-soft: rgba(220,38,38,.10);
	--ocmp-ink: #1F2937;
	--ocmp-muted: #6B7280;
	--ocmp-border: #E5E7EB;
	--ocmp-bg: #F8FAFC;
	--ocmp-radius: 16px;
	--ocmp-shadow: 0 6px 18px rgba(15,23,42,.06);
	--ocmp-shadow-lg: 0 12px 36px rgba(15,23,42,.10);

	font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Helvetica, Arial, sans-serif;
	color: var(--ocmp-ink);
	max-width: 1240px;
	margin: 0 auto;
	padding: 16px 14px 60px;
	box-sizing: border-box;
}
.ocmp-auth-wrap *, .ocmp-auth-wrap *::before, .ocmp-auth-wrap *::after,
.ocmp-apply-wrap *, .ocmp-apply-wrap *::before, .ocmp-apply-wrap *::after { box-sizing: border-box; }

/* ── Hero ─────────────────────────────────────────────────────── */
.ocmp-auth__hero {
	background: linear-gradient(135deg, #003B73 0%, #0F766E 100%);
	border-radius: 20px;
	color: #fff;
	padding: 48px 36px;
	margin-bottom: 28px;
	box-shadow: var(--ocmp-shadow-lg);
	position: relative;
	overflow: hidden;
}
.ocmp-auth__hero::before {
	content: "";
	position: absolute;
	top: -40px;
	right: -40px;
	width: 220px;
	height: 220px;
	background: radial-gradient(circle, rgba(199,162,58,.35) 0%, rgba(199,162,58,0) 70%);
	pointer-events: none;
}
.ocmp-auth__hero::after {
	content: "";
	position: absolute;
	bottom: -60px;
	left: -40px;
	width: 260px;
	height: 260px;
	background: radial-gradient(circle, rgba(255,255,255,.08) 0%, rgba(255,255,255,0) 70%);
	pointer-events: none;
}
.ocmp-auth__hero--compact { padding: 32px 28px; margin-bottom: 22px; }
.ocmp-auth__hero-inner { position: relative; z-index: 1; max-width: 760px; }
.ocmp-eyebrow {
	display: inline-block;
	padding: 4px 10px;
	border-radius: 999px;
	background: rgba(255,255,255,.18);
	font-size: 12px;
	font-weight: 700;
	letter-spacing: .08em;
	text-transform: uppercase;
	margin-bottom: 12px;
}
.ocmp-auth__hero-title {
	margin: 0 0 8px;
	font-size: 34px;
	font-weight: 800;
	line-height: 1.15;
	color: #fff;
}
.ocmp-auth__hero-lede {
	margin: 0;
	font-size: 16px;
	color: rgba(255,255,255,.92);
	max-width: 640px;
}

/* ── Card primitives ──────────────────────────────────────────── */
.ocmp-card {
	background: #fff;
	border-radius: var(--ocmp-radius);
	box-shadow: var(--ocmp-shadow);
	border: 1px solid var(--ocmp-border);
}
.ocmp-card--pad { padding: 26px; }

/* ── Grid layout ──────────────────────────────────────────────── */
.ocmp-auth__grid {
	display: grid;
	grid-template-columns: 340px 1fr;
	gap: 24px;
	align-items: start;
}
.ocmp-auth__grid > .ocmp-auth__cards.is-wide { grid-column: 1 / -1; max-width: 460px; margin: 0 auto; }
.ocmp-auth__cards {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 20px;
}
/* When only the Sign In card is rendered, center it in a single column. */
.ocmp-auth__cards:has(.ocmp-signin):not(:has(.ocmp-auth-card--alt)) {
	grid-template-columns: 1fr;
	max-width: 460px;
	margin: 0 auto;
}
.ocmp-auth__cards > .ocmp-auth-card { min-width: 0; }
.ocmp-auth__job { display: flex; flex-direction: column; gap: 20px; }

/* ── Job summary card ─────────────────────────────────────────── */
.ocmp-job-card__label {
	display: inline-block;
	padding: 4px 10px;
	border-radius: 999px;
	background: var(--ocmp-gold-soft);
	color: var(--ocmp-gold-dark);
	font-size: 11px;
	font-weight: 700;
	letter-spacing: .08em;
	text-transform: uppercase;
	margin-bottom: 12px;
}
.ocmp-job-card__title {
	margin: 0 0 16px;
	font-size: 22px;
	font-weight: 700;
	color: var(--ocmp-blue);
	line-height: 1.25;
}
.ocmp-job-card__meta {
	list-style: none;
	margin: 0;
	padding: 0;
	display: flex;
	flex-direction: column;
	gap: 10px;
}
.ocmp-job-card__meta li {
	display: flex;
	align-items: center;
	gap: 10px;
	font-size: 14px;
	color: var(--ocmp-ink);
}
.ocmp-job-card__meta li svg { flex: 0 0 16px; color: var(--ocmp-green); }
.ocmp-job-card__meta li strong { color: var(--ocmp-muted); font-weight: 600; }

/* ── Benefits panel ──────────────────────────────────────────── */
.ocmp-benefits h3 { margin: 0 0 14px; font-size: 16px; color: var(--ocmp-blue); }
.ocmp-benefits ul,
.ocmp-auth-card__list { list-style: none; margin: 0; padding: 0; display: flex; flex-direction: column; gap: 10px; }
.ocmp-benefits li,
.ocmp-auth-card__list li {
	display: flex; align-items: center; gap: 10px; font-size: 14px; color: var(--ocmp-ink);
}
.ocmp-check {
	display: inline-flex; align-items: center; justify-content: center;
	width: 22px; height: 22px; border-radius: 999px;
	background: var(--ocmp-green-soft); color: var(--ocmp-green);
	font-weight: 800; font-size: 13px; flex-shrink: 0;
}

/* ── Auth cards ──────────────────────────────────────────────── */
.ocmp-auth-card { display: flex; flex-direction: column; }
.ocmp-auth-card__head {
	display: flex; align-items: center; gap: 14px; margin-bottom: 22px;
}
.ocmp-auth-card__head h2 { margin: 0; font-size: 20px; color: var(--ocmp-blue); }
.ocmp-auth-card__head p { margin: 4px 0 0; color: var(--ocmp-muted); font-size: 13px; }
.ocmp-auth-card__icon {
	display: inline-flex; align-items: center; justify-content: center;
	width: 48px; height: 48px; border-radius: 14px; flex-shrink: 0;
}
.ocmp-auth-card__icon--green { background: var(--ocmp-green-soft); color: var(--ocmp-green); }
.ocmp-auth-card__icon--gold  { background: var(--ocmp-gold-soft);  color: var(--ocmp-gold-dark); }
.ocmp-auth-card--alt { background: linear-gradient(180deg, #fff 0%, #fbf8ef 100%); }
.ocmp-auth-card--alt .ocmp-auth-card__list { margin-bottom: 22px; }

/* ── Form primitives ─────────────────────────────────────────── */
.ocmp-form { display: flex; flex-direction: column; gap: 14px; }
.ocmp-form__grid {
	display: grid; grid-template-columns: 1fr 1fr; gap: 14px;
}
.ocmp-field { display: flex; flex-direction: column; gap: 6px; }
.ocmp-field > span { font-size: 13px; font-weight: 600; color: var(--ocmp-ink); }
.ocmp-field input,
.ocmp-field textarea {
	width: 100%; padding: 11px 14px;
	border: 1px solid var(--ocmp-border); border-radius: 10px;
	font-size: 14px; font-family: inherit; background: #fff; color: var(--ocmp-ink);
	transition: border-color .2s, box-shadow .2s;
}
.ocmp-field input:focus,
.ocmp-field textarea:focus {
	outline: none;
	border-color: var(--ocmp-green);
	box-shadow: 0 0 0 3px rgba(15,118,110,.18);
}
.ocmp-form__row {
	display: flex; align-items: center; justify-content: space-between;
	gap: 12px; flex-wrap: wrap; font-size: 13px;
}
.ocmp-check-inline { display: inline-flex; align-items: center; gap: 8px; color: var(--ocmp-ink); cursor: pointer; }
.ocmp-check-inline input { accent-color: var(--ocmp-green); }
.ocmp-form__alt { margin: 4px 0 0; text-align: center; font-size: 13px; color: var(--ocmp-muted); }
.ocmp-form__hint { margin: 0; font-size: 12px; color: var(--ocmp-muted); }
.ocmp-form__msg {
	min-height: 18px;
	margin-top: 6px;
	font-size: 13px;
	text-align: center;
}
.ocmp-form__msg.is-error   { color: var(--ocmp-red); }
.ocmp-form__msg.is-success { color: var(--ocmp-green); }

/* ── Buttons (auth scope) ────────────────────────────────────── */
.ocmp-auth-wrap .ocmp-btn,
.ocmp-apply-wrap .ocmp-btn {
	display: inline-flex; align-items: center; justify-content: center; gap: 8px;
	padding: 12px 22px; border-radius: 10px;
	font-size: 14px; font-weight: 600; font-family: inherit;
	border: 1px solid transparent; cursor: pointer; text-decoration: none;
	transition: background .2s, transform .15s, box-shadow .2s, border-color .2s, color .2s;
}
.ocmp-btn--primary { background: var(--ocmp-green); color: #fff; }
.ocmp-btn--primary:hover { background: var(--ocmp-green-dark); transform: translateY(-1px); box-shadow: 0 8px 18px rgba(15,118,110,.30); color: #fff; }
.ocmp-btn--gold { background: var(--ocmp-gold); color: #fff; }
.ocmp-btn--gold:hover { background: var(--ocmp-gold-dark); transform: translateY(-1px); box-shadow: 0 8px 18px rgba(199,162,58,.32); color: #fff; }
.ocmp-btn--ghost { background: #fff; color: var(--ocmp-ink); border-color: var(--ocmp-border); }
.ocmp-btn--ghost:hover { background: var(--ocmp-bg); color: var(--ocmp-blue); border-color: var(--ocmp-blue); }
.ocmp-btn--block { width: 100%; margin-top: 4px; }
.ocmp-btn[disabled],
.ocmp-btn.is-loading { opacity: .65; cursor: not-allowed; transform: none; box-shadow: none; }

.ocmp-link { color: var(--ocmp-green); text-decoration: none; font-weight: 600; }
.ocmp-link:hover { color: var(--ocmp-green-dark); text-decoration: underline; }
.ocmp-link--block { display: block; margin-top: 14px; padding: 10px 14px; background: var(--ocmp-green-soft); border-radius: 10px; text-align: center; }
.ocmp-link--block:hover { background: var(--ocmp-green); color: #fff; text-decoration: none; }

.ocmp-muted { color: var(--ocmp-muted); font-size: 13px; }

/* ── Apply page layout ───────────────────────────────────────── */
.ocmp-apply__grid {
	display: grid;
	grid-template-columns: 320px 1fr;
	gap: 24px;
	align-items: start;
}
.ocmp-apply__side { display: flex; flex-direction: column; gap: 20px; position: sticky; top: 20px; }
.ocmp-apply__main { display: flex; flex-direction: column; gap: 20px; min-width: 0; }
.ocmp-help-card strong { display: block; font-size: 15px; color: var(--ocmp-blue); margin-bottom: 6px; }
.ocmp-help-card p { margin: 0 0 12px; font-size: 13px; color: var(--ocmp-muted); }

.ocmp-job-desc h2,
.ocmp-apply-form h2 { margin: 0 0 12px; font-size: 20px; color: var(--ocmp-blue); }
.ocmp-job-desc__body { color: var(--ocmp-ink); line-height: 1.6; font-size: 15px; }
.ocmp-job-desc__body p { margin: 0 0 12px; }

.ocmp-apply-form { display: flex; flex-direction: column; gap: 16px; }
.ocmp-apply-form__actions {
	display: flex; justify-content: flex-end; gap: 10px; flex-wrap: wrap;
	border-top: 1px solid var(--ocmp-border); padding-top: 16px;
}

/* ── Upload tiles ────────────────────────────────────────────── */
.ocmp-upload-grid {
	border: none; padding: 0; margin: 0;
	display: grid; grid-template-columns: 1fr 1fr; gap: 14px;
}
.ocmp-upload-grid > legend {
	width: 100%; padding: 0 0 6px;
	font-size: 13px; font-weight: 700; color: var(--ocmp-blue);
	text-transform: uppercase; letter-spacing: .04em;
}
.ocmp-upload {
	display: flex; flex-direction: column; gap: 6px;
	border: 1px dashed var(--ocmp-border); border-radius: 12px;
	padding: 16px; background: var(--ocmp-bg);
	cursor: pointer; transition: border-color .2s, background .2s;
}
.ocmp-upload:hover { border-color: var(--ocmp-green); background: var(--ocmp-green-soft); }
.ocmp-upload--wide { grid-column: 1 / -1; }
.ocmp-upload__title { font-size: 13px; font-weight: 700; color: var(--ocmp-ink); }
.ocmp-upload__hint  { font-size: 12px; color: var(--ocmp-muted); word-break: break-word; }
.ocmp-upload input[type="file"] {
	font-size: 12px; padding: 6px 0; border: 0; background: transparent;
}
.ocmp-upload.is-filled { border-color: var(--ocmp-green); border-style: solid; background: #fff; }
.ocmp-upload.is-filled .ocmp-upload__hint { color: var(--ocmp-green); font-weight: 600; }

/* ── Success state ───────────────────────────────────────────── */
.ocmp-success h2 { margin: 0 0 12px; color: var(--ocmp-green); }
.ocmp-success p { margin: 0 0 10px; font-size: 15px; color: var(--ocmp-ink); }

/* ── Responsive ──────────────────────────────────────────────── */
@media (max-width: 1024px) {
	.ocmp-auth__grid { grid-template-columns: 1fr; }
	.ocmp-apply__grid { grid-template-columns: 1fr; }
	.ocmp-apply__side { position: static; }
}
@media (max-width: 720px) {
	.ocmp-auth__cards { grid-template-columns: 1fr; }
	.ocmp-form__grid { grid-template-columns: 1fr; }
	.ocmp-upload-grid { grid-template-columns: 1fr; }
	.ocmp-auth__hero { padding: 32px 22px; }
	.ocmp-auth__hero-title { font-size: 26px; }
	.ocmp-card--pad { padding: 20px; }
}

/* ── Sign-In card (image-matched design) ─────────────────────── */
.ocmp-signin { padding: 32px 30px; }
.ocmp-signin__head {
	display: flex; align-items: flex-start; gap: 16px; margin-bottom: 24px;
}
.ocmp-signin__icon {
	display: inline-flex; align-items: center; justify-content: center;
	width: 52px; height: 52px; border-radius: 999px;
	background: #F1F4F4; color: var(--ocmp-green);
	flex-shrink: 0;
}
.ocmp-signin__title { min-width: 0; flex: 1; }
.ocmp-signin__title h2 {
	margin: 0; font-size: 28px; font-weight: 800; color: #0B5953; line-height: 1.1;
}
.ocmp-signin__underline {
	display: block; width: 56px; height: 3px; border-radius: 2px;
	background: var(--ocmp-gold); margin: 8px 0 12px;
}
.ocmp-signin__title p {
	margin: 0; color: var(--ocmp-muted); font-size: 14px; line-height: 1.5;
}

/* Inputs with leading icon + optional trailing toggle */
.ocmp-field--icon > span:first-child { color: var(--ocmp-ink); font-weight: 700; font-size: 13px; }
.ocmp-input {
	position: relative; display: flex; align-items: center;
	border: 1px solid #0f766e; border-radius: 10px;
	background: #fff; transition: border-color .2s, box-shadow .2s;
	overflow: hidden;
}
.ocmp-input:focus-within {
	border-color: var(--ocmp-green);
	box-shadow: 0 0 0 3px rgba(15,118,110,.15);
}
.ocmp-input__icon {
	display: inline-flex; align-items: center; justify-content: center;
	width: 44px; flex-shrink: 0; color: var(--ocmp-muted);
}
.ocmp-input input {
	flex: 1; min-width: 0;
	padding: 12px 14px 12px 0;
	border: 0 !important; outline: none !important;
	background: transparent; font-family: inherit; font-size: 14px;
	color: var(--ocmp-ink);
	box-shadow: none !important;
}
.ocmp-input input::placeholder { color: #9CA3AF; }
.ocmp-input__toggle {
	-webkit-appearance: none;
	appearance: none;
	display: inline-flex; align-items: center; justify-content: center;
	width: 42px; height: 42px; padding: 0;
	border: 0 !important;
	border-radius: 0 !important;
	background: transparent !important;
	box-shadow: none !important;
	color: var(--ocmp-muted);
	cursor: pointer; flex-shrink: 0;
	outline: none;
	line-height: 1;
}
.ocmp-input__toggle svg { pointer-events: none; }
.ocmp-input__toggle:hover { color: var(--ocmp-green); background: transparent !important; }
.ocmp-input__toggle:focus-visible { outline: 2px solid var(--ocmp-green); outline-offset: -2px; }

/* Remember me solo (no forgot link inline) */
.ocmp-check-inline--solo { padding: 4px 0; font-size: 14px; color: var(--ocmp-ink); }

/* Sign In button with trailing arrow */
.ocmp-btn--arrow { gap: 12px; padding: 14px 22px; font-size: 15px; }
.ocmp-btn--arrow svg { transition: transform .2s; }
.ocmp-btn--arrow:hover svg { transform: translateX(3px); }

/* Forgot password centered link */
.ocmp-signin__forgot {
	margin: 14px 0 0; text-align: center; font-size: 14px;
}
.ocmp-signin__forgot .ocmp-link { font-weight: 700; }

/* OR divider */
.ocmp-divider {
	position: relative;
	margin: 7px 0;
	text-align: center;
	color: var(--ocmp-muted);
}
.ocmp-divider::before {
	content: "";
	position: absolute;
	top: 50%; left: 0; right: 0;
	height: 1px;
	background: var(--ocmp-border);
}
.ocmp-divider span {
	position: relative; display: inline-flex; align-items: center; justify-content: center;
	width: 44px; height: 44px; border-radius: 999px;
	background: #fff; border: 1px solid var(--ocmp-border);
	font-size: 12px; font-weight: 700; letter-spacing: .04em;
	color: var(--ocmp-muted);
}

/* Create-account CTA below sign in */
.ocmp-signin__cta { text-align: center; }
.ocmp-signin__cta-title {
	margin: 0 0 4px; font-size: 16px; font-weight: 700; color: var(--ocmp-ink);
}
.ocmp-signin__cta-text {
	margin: 0 0 16px; font-size: 13px; color: var(--ocmp-muted);
}

/* Outline button variant for Create Account */
.ocmp-btn--outline {
	background: #fff;
	color: var(--ocmp-green);
	border-color: var(--ocmp-green);
	font-weight: 700;
}
.ocmp-btn--outline:hover {
	background: var(--ocmp-green);
	color: #fff;
	transform: translateY(-1px);
	box-shadow: 0 8px 18px rgba(15,118,110,.20);
}
.ocmp-btn--outline:hover svg { color: #fff; }

@media (max-width: 480px) {
	.ocmp-signin { padding: 26px 22px; }
	.ocmp-signin__title h2 { font-size: 24px; }
}

/* ═══════════════════════════════════════════════════════════════
   REGISTER PAGE
   ═══════════════════════════════════════════════════════════════ */

/* ── Step indicator ──────────────────────────────────────────── */
.ocmp-register-wrap { padding-top: 28px; }
.ocmp-steps {
	display: flex; align-items: center; justify-content: center;
	gap: 0; margin-bottom: 36px;
}
.ocmp-steps__item {
	display: flex; flex-direction: column; align-items: center; gap: 8px;
	position: relative;
}
.ocmp-steps__num {
	display: inline-flex; align-items: center; justify-content: center;
	width: 38px; height: 38px; border-radius: 999px;
	border: 2px solid var(--ocmp-border);
	background: #fff; color: var(--ocmp-muted);
	font-size: 15px; font-weight: 700; transition: all .25s;
}
.ocmp-steps__item.is-active .ocmp-steps__num {
	background: var(--ocmp-green); border-color: var(--ocmp-green);
	color: #fff; box-shadow: 0 0 0 4px rgba(15,118,110,.15);
}
.ocmp-steps__label {
	font-size: 12px; font-weight: 600; color: var(--ocmp-muted);
	white-space: nowrap; transition: color .25s;
}
.ocmp-steps__item.is-active .ocmp-steps__label { color: var(--ocmp-green); }
.ocmp-steps__connector {
	flex: 1 0 60px; height: 2px;
	background: var(--ocmp-border); margin-bottom: 28px;
	max-width: 100px;
}

/* ── Two-column layout ───────────────────────────────────────── */
.ocmp-register__layout {
	display: grid;
	grid-template-columns: 1fr 340px;
	gap: 32px;
	align-items: start;
}

/* ── Form column ─────────────────────────────────────────────── */
.ocmp-register__title {
	margin: 0 0 6px; font-size: 30px; font-weight: 800; color: var(--ocmp-blue);
}
.ocmp-register__sub {
	margin: 0 0 28px; color: var(--ocmp-muted); font-size: 15px;
}

/* Form grid & fields */
.ocmp-rform { display: flex; flex-direction: column; gap: 16px; }
.ocmp-rform__row { display: grid; grid-template-columns: 1fr 1fr; gap: 16px; }
.ocmp-rfield { display: flex; flex-direction: column; gap: 7px; }
.ocmp-rfield > span:first-child { font-size: 13px; font-weight: 700; color: var(--ocmp-ink); }
.ocmp-rfield input,
.ocmp-rinput input {
	width: 100%; padding: 12px 14px;
	border: 1px solid var(--ocmp-border); border-radius: 10px;
	font-size: 14px; font-family: inherit; background: #fff; color: var(--ocmp-ink);
	transition: border-color .2s, box-shadow .2s;
}
.ocmp-rfield input:focus,
.ocmp-rinput input:focus {
	outline: none;
	border-color: var(--ocmp-green);
	box-shadow: 0 0 0 3px rgba(15,118,110,.15);
}
.ocmp-rfield input::placeholder,
.ocmp-rinput input::placeholder { color: #9CA3AF; }

/* Password input with eye toggle */
.ocmp-rinput {
	display: flex; align-items: center;
	border: 1px solid var(--ocmp-border); border-radius: 10px;
	background: #fff; overflow: hidden;
	transition: border-color .2s, box-shadow .2s;
}
.ocmp-rinput:focus-within {
	border-color: var(--ocmp-green);
	box-shadow: 0 0 0 3px rgba(15,118,110,.15);
}
.ocmp-rinput input {
	border: 0 !important; box-shadow: none !important;
	border-radius: 0 !important; flex: 1;
}
.ocmp-rinput__eye {
	display: inline-flex; align-items: center; justify-content: center;
	width: 42px; flex-shrink: 0;
	border: 0; background: transparent; color: var(--ocmp-muted); cursor: pointer;
}
.ocmp-rinput__eye:hover { color: var(--ocmp-green); }

/* Phone with country prefix */
.ocmp-phone-wrap {
	display: flex; align-items: stretch;
	border: 1px solid var(--ocmp-border); border-radius: 10px;
	background: #fff; overflow: hidden;
	transition: border-color .2s, box-shadow .2s;
}
.ocmp-phone-wrap:focus-within {
	border-color: var(--ocmp-green);
	box-shadow: 0 0 0 3px rgba(15,118,110,.15);
}
.ocmp-phone-prefix {
	display: inline-flex; align-items: center; gap: 7px;
	padding: 0 12px; background: #F3F4F6; border-right: 1px solid var(--ocmp-border);
	font-size: 14px; font-weight: 600; color: var(--ocmp-ink); white-space: nowrap;
	flex-shrink: 0;
}
.ocmp-phone-prefix img { border-radius: 2px; }
.ocmp-phone-wrap input {
	flex: 1; border: 0 !important; box-shadow: none !important;
	border-radius: 0 !important; outline: none !important;
	padding: 12px 14px; font-size: 14px; font-family: inherit;
	background: transparent; color: var(--ocmp-ink);
}
.ocmp-phone-wrap input::placeholder { color: #9CA3AF; }

/* Terms checkbox */
.ocmp-terms {
	display: flex; align-items: flex-start; gap: 10px;
	font-size: 14px; color: var(--ocmp-ink); cursor: pointer;
	padding: 4px 0;
}
.ocmp-terms input[type="checkbox"] {
	width: 18px; height: 18px; flex-shrink: 0; margin-top: 2px;
	accent-color: var(--ocmp-green); cursor: pointer;
}

/* Large primary button */
.ocmp-btn--lg { padding: 14px 22px; font-size: 15px; font-weight: 700; }

.ocmp-rform__signin {
	text-align: center; font-size: 14px; color: var(--ocmp-muted); margin: 8px 0 0;
}

/* ── Benefits sidebar ────────────────────────────────────────── */
.ocmp-register__benefits { position: sticky; top: 20px; }
.ocmp-benefits__title {
	margin: 0 0 20px; font-size: 18px; font-weight: 700; color: var(--ocmp-blue);
}
.ocmp-benefits__list {
	list-style: none; margin: 0; padding: 0;
	display: flex; flex-direction: column; gap: 18px;
}
.ocmp-benefits__list li {
	display: flex; align-items: flex-start; gap: 14px;
}
.ocmp-benefits__icon {
	display: inline-flex; align-items: center; justify-content: center;
	width: 40px; height: 40px; border-radius: 10px; flex-shrink: 0;
	background: var(--ocmp-green-soft); color: var(--ocmp-green);
}
.ocmp-benefits__list strong { display: block; font-size: 14px; color: var(--ocmp-ink); margin-bottom: 3px; }
.ocmp-benefits__list p { margin: 0; font-size: 13px; color: var(--ocmp-muted); line-height: 1.4; }

/* ── Register responsive ─────────────────────────────────────── */
@media (max-width: 1024px) {
	.ocmp-register__layout { grid-template-columns: 1fr; }
	.ocmp-register__benefits { position: static; }
}
@media (max-width: 640px) {
	.ocmp-rform__row { grid-template-columns: 1fr; }
	.ocmp-steps__connector { max-width: 40px; flex-basis: 40px; }
	.ocmp-register__title { font-size: 24px; }
}
@media (max-width: 400px) {
	.ocmp-steps__label { display: none; }
	.ocmp-steps__connector { flex-basis: 28px; max-width: 28px; }
}

/* ───────────────────────────────────────────────────────────────
   Candidate Dashboard
   ─────────────────────────────────────────────────────────────── */

/* Outer centering wrapper */
.ocmp-dash-outer {
    max-width: 1520px;
    margin: 40px auto 56px;
    padding: 0 24px;
    box-sizing: border-box;
}

.ocmp-dash {
    display: grid;
    grid-template-columns: 260px 1fr;
    background: #ffffff;
    border-radius: 28px;
    box-shadow: 0 20px 60px rgba(0,0,0,.10), 0 2px 8px rgba(0,0,0,.05);
    overflow: hidden;
    min-height: 680px;
    color: var(--ocmp-ink);
    font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "Helvetica Neue", Arial, sans-serif;
}

/* Sidebar ------------------------------------------------------ */
.ocmp-dash__sidebar {
    background: linear-gradient(180deg, #0B5953 0%, #0F766E 100%);
    color: #fff;
    padding: 28px 18px;
    position: sticky;
    top: 0;
    align-self: start;
    min-height: 800px;
    box-shadow: 2px 0 8px rgba(0,0,0,.08);
    border-radius: 28px 0 0 28px;
}

.ocmp-dash__brand {
    padding: 0 6px 24px;
    border-bottom: 1px solid rgba(255, 255, 255, .12);
    margin-bottom: 18px;
}
.ocmp-dash__logo {
    font-size: 22px;
    font-weight: 800;
    letter-spacing: 1.2px;
    color: #fff;
}
.ocmp-dash__brand-sub {
    margin-top: 4px;
    font-size: 12px;
    color: rgba(255, 255, 255, .7);
    letter-spacing: .4px;
    text-transform: uppercase;
}

.ocmp-dash__nav {
    display: flex;
    flex-direction: column;
    gap: 4px;
}
.ocmp-dash__nav-item {
    display: flex;
    align-items: center;
    gap: 12px;
    padding: 11px 12px;
    border-radius: 10px;
    color: #ffffff !important;
    font-size: 14px;
    font-weight: 500;
    text-decoration: none !important;
    transition: background .15s ease, color .15s ease;
}
.ocmp-dash__nav-item svg {
    width: 18px;
    height: 18px;
    flex-shrink: 0;
    flex-shrink: 0;
    color: #ffffff;
}
.ocmp-dash__nav-item span {
    color: #ffffff;
}
.ocmp-dash__nav-item:hover {
    background: rgba(255,255,255,.10);
    color: #ffffff !important;
}
.ocmp-dash__nav-item.is-active {
    background: rgba(255,255,255,.18);
    color: #ffffff !important;
    box-shadow: inset 3px 0 0 var(--ocmp-gold);
}
.ocmp-dash__nav-item--logout {
    margin-top: 18px;
    opacity: .85;
}
.ocmp-dash__nav-item--logout:hover { opacity: 1; }

/* Main --------------------------------------------------------- */
.ocmp-dash__main {
    padding: 36px 40px 52px;
    min-width: 0;
    background: #F8F9FA;
    border-radius: 0 28px 28px 0;
}

.ocmp-dash__header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 24px;
    margin-bottom: 28px;
    flex-wrap: wrap;
}
.ocmp-dash__title {
    margin: 0;
    font-size: 28px;
    font-weight: 700;
    color: var(--ocmp-ink);
    line-height: 1.2;
}
.ocmp-dash__subtitle {
    margin: 6px 0 0;
    color: var(--ocmp-muted);
    font-size: 14px;
}

/* Stats -------------------------------------------------------- */
.ocmp-dash__stats {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 18px;
    margin-bottom: 28px;
}
.ocmp-stat {
    background: #fff;
    border: 1px solid var(--ocmp-border);
    border-radius: 18px;
    padding: 20px;
    display: flex;
    align-items: center;
    gap: 16px;
    box-shadow: 0 2px 8px rgba(15,23,42,.06);
    transition: transform .15s ease, box-shadow .15s ease;
}
.ocmp-stat:hover {
    transform: translateY(-2px);
    box-shadow: 0 6px 18px rgba(15, 23, 42, .08);
}
.ocmp-stat__icon {
    width: 48px;
    height: 48px;
    border-radius: 12px;
    display: flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
}
.ocmp-stat__icon svg { width: 22px; height: 22px; }
.ocmp-stat--green  .ocmp-stat__icon { background: #E6F6F3; color: var(--ocmp-green); }
.ocmp-stat--orange .ocmp-stat__icon { background: #FFF1E5; color: #E07A19; }
.ocmp-stat--teal   .ocmp-stat__icon { background: #E2F4F2; color: #0E8F86; }
.ocmp-stat--red    .ocmp-stat__icon { background: #FDECEC; color: #D24545; }
.ocmp-stat__label {
    font-size: 13px;
    color: var(--ocmp-muted);
    margin-bottom: 4px;
}
.ocmp-stat__value {
    font-size: 26px;
    font-weight: 700;
    color: var(--ocmp-ink);
    line-height: 1.1;
}
.ocmp-stat__hint {
    font-size: 12px;
    color: var(--ocmp-muted);
    margin-top: 2px;
}

/* Grid: applications + aside ---------------------------------- */
.ocmp-dash__grid {
    display: grid;
    grid-template-columns: minmax(0, 1fr) 340px;
    gap: 22px;
    align-items: start;
}

/* Card --------------------------------------------------------- */
.ocmp-card {
    background: #fff;
    border: 1px solid var(--ocmp-border);
    border-radius: var(--ocmp-radius);
    padding: 22px;
    box-shadow: 0 1px 2px rgba(15, 23, 42, .04);
}
.ocmp-card__head {
    display: flex;
    align-items: center;
    justify-content: space-between;
    margin-bottom: 14px;
}
.ocmp-card__title {
    margin: 0;
    font-size: 18px;
    font-weight: 700;
    color: var(--ocmp-ink);
}
.ocmp-card__link {
    font-size: 13px;
    color: var(--ocmp-green);
    text-decoration: none;
    font-weight: 600;
}
.ocmp-card__link:hover { text-decoration: underline; }

/* Table -------------------------------------------------------- */
.ocmp-table-wrap { overflow-x: auto; }
.ocmp-table {
    width: 100%;
    border-collapse: collapse;
    font-size: 14px;
}
.ocmp-table thead th {
    text-align: left;
    padding: 10px 12px;
    font-size: 12px;
    text-transform: uppercase;
    letter-spacing: .4px;
    color: var(--ocmp-muted);
    font-weight: 600;
    border-bottom: 1px solid var(--ocmp-border);
    background: #FAFBFC;
}
.ocmp-table tbody td {
    padding: 14px 12px;
    border-bottom: 1px solid #F1F3F5;
    vertical-align: middle;
}
.ocmp-table tbody tr:last-child td { border-bottom: 0; }
.ocmp-table__primary {
    font-weight: 600;
    color: var(--ocmp-ink);
}
.ocmp-table__sub {
    font-size: 12px;
    color: var(--ocmp-muted);
    margin-top: 2px;
}
.ocmp-table__next { color: var(--ocmp-muted); }
.ocmp-table__action { text-align: right; }

/* Status badges ----------------------------------------------- */
.ocmp-badge {
    display: inline-block;
    padding: 4px 10px;
    border-radius: 999px;
    font-size: 12px;
    font-weight: 600;
    line-height: 1.4;
}
.ocmp-badge--pending              { background: #F1F3F5; color: #475467; }
.ocmp-badge--under_review         { background: #FFF1E5; color: #E07A19; }
.ocmp-badge--shortlisted          { background: #EDE9FE; color: #5B21B6; }
.ocmp-badge--interview            { background: #E7F0FA; color: #1E5BB8; }
.ocmp-badge--interview_scheduled  { background: #E7F0FA; color: #1E5BB8; }
.ocmp-badge--accepted             { background: #E6F6E9; color: #1E7C36; }
.ocmp-badge--rejected             { background: #FDECEC; color: #D24545; }

/* Buttons additions ------------------------------------------- */
.ocmp-btn--sm {
    padding: 6px 14px;
    font-size: 13px;
    border-radius: 8px;
}
.ocmp-btn--lg svg { margin-right: 4px; }

/* Empty state ------------------------------------------------- */
.ocmp-empty {
    text-align: center;
    padding: 36px 20px;
    color: var(--ocmp-muted);
}
.ocmp-empty svg { color: #CBD5DD; margin-bottom: 8px; }
.ocmp-empty p { margin: 6px 0 16px; font-size: 14px; }

/* Aside (messages + help) ------------------------------------- */
.ocmp-dash__aside {
    display: flex;
    flex-direction: column;
    gap: 18px;
}
.ocmp-msg-list {
    list-style: none;
    margin: 0;
    padding: 0;
    display: flex;
    flex-direction: column;
    gap: 12px;
}
.ocmp-msg {
    display: flex;
    gap: 12px;
    padding: 12px;
    border-radius: 10px;
    background: #FAFBFC;
    border: 1px solid #F1F3F5;
}
.ocmp-msg__dot {
    width: 10px;
    height: 10px;
    border-radius: 50%;
    margin-top: 6px;
    flex-shrink: 0;
}
.ocmp-msg__dot--blue  { background: #1E5BB8; }
.ocmp-msg__dot--green { background: var(--ocmp-green); }
.ocmp-msg__dot--gold  { background: var(--ocmp-gold); }
.ocmp-msg__title {
    font-size: 13px;
    font-weight: 600;
    color: var(--ocmp-ink);
    margin-bottom: 2px;
}
.ocmp-msg__text {
    font-size: 12px;
    color: var(--ocmp-muted);
    line-height: 1.4;
}

/* Help card --------------------------------------------------- */
.ocmp-help {
    text-align: center;
    background: linear-gradient(160deg, #F0FAF8 0%, #FFFFFF 100%);
    border: 1px solid #DAEDE9;
}
.ocmp-help__icon {
    width: 52px;
    height: 52px;
    border-radius: 50%;
    background: #fff;
    color: var(--ocmp-green);
    display: inline-flex;
    align-items: center;
    justify-content: center;
    margin-bottom: 10px;
    box-shadow: 0 2px 6px rgba(15, 118, 110, .15);
}
.ocmp-help__icon svg { width: 26px; height: 26px; }
.ocmp-help__title {
    margin: 4px 0 6px;
    font-size: 16px;
    font-weight: 700;
    color: var(--ocmp-ink);
}
.ocmp-help__text {
    margin: 0 0 14px;
    font-size: 13px;
    color: var(--ocmp-muted);
    line-height: 1.5;
}

/* Responsive --------------------------------------------------- */
@media (max-width: 1200px) {
    .ocmp-dash__grid { grid-template-columns: 1fr; }
    .ocmp-dash__stats { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 900px) {
    .ocmp-dash-outer { margin: 20px auto 36px; padding: 0 16px; }
    .ocmp-dash { grid-template-columns: 1fr; border-radius: 20px; }
    .ocmp-dash__sidebar {
        position: relative;
        min-height: auto;
        padding: 18px;
        border-radius: 20px 20px 0 0;
    }
    .ocmp-dash__nav {
        flex-direction: row;
        overflow-x: auto;
        gap: 6px;
    }
    .ocmp-dash__nav-item { white-space: nowrap; }
    .ocmp-dash__nav-item.is-active { box-shadow: inset 0 -3px 0 var(--ocmp-gold); }
    .ocmp-dash__brand { display: none; }
    .ocmp-dash__main { padding: 22px 20px 36px; border-radius: 0 0 20px 20px; }
}
@media (max-width: 600px) {
    .ocmp-dash-outer { margin: 12px auto 28px; padding: 0 12px; }
    .ocmp-dash { border-radius: 16px; }
    .ocmp-dash__stats { grid-template-columns: 1fr 1fr; }
    .ocmp-dash__header { flex-direction: column; align-items: flex-start; }
    .ocmp-dash__title { font-size: 22px; }
}
@media (max-width: 400px) {
    .ocmp-dash__stats { grid-template-columns: 1fr; }
}

/* ─────────────────────────────────────────────────────────────
 * Plain .ocmp-input (no leading icon): give input proper padding
 * ───────────────────────────────────────────────────────────── */
.ocmp-input > input:first-child { padding-left: 14px; }

/* ─────────────────────────────────────────────────────────────
 * Modern Morocco phone input
 * ───────────────────────────────────────────────────────────── */
.ocmp-phone {
    display: inline-flex; align-items: stretch; width: 100%;
    border: 1px solid var(--ocmp-border); border-radius: 12px;
    background: #fff; overflow: hidden;
    transition: border-color .2s, box-shadow .2s;
    min-height: 48px;
}
.ocmp-phone:focus-within {
    border-color: var(--ocmp-green);
    box-shadow: 0 0 0 3px rgba(15,118,110,.15);
}
.ocmp-phone__flag {
    display: inline-flex; align-items: center; justify-content: center;
    padding: 0 10px 0 12px; flex-shrink: 0;
}
.ocmp-phone__flag svg {
    border-radius: 3px; box-shadow: 0 0 0 1px rgba(0,0,0,.08);
}
.ocmp-phone__code {
    display: inline-flex; align-items: center;
    padding: 0 10px 0 4px; flex-shrink: 0;
    font-size: 14px; font-weight: 600; color: var(--ocmp-ink);
    border-right: 1px solid var(--ocmp-border);
}
.ocmp-phone input {
    flex: 1; min-width: 0;
    padding: 12px 14px; border: 0 !important; outline: none !important;
    box-shadow: none !important; background: transparent;
    font-size: 14px; font-family: inherit; color: var(--ocmp-ink);
}
.ocmp-phone input::placeholder { color: #9CA3AF; }

/* ─────────────────────────────────────────────────────────────
 * Password strength meter
 * ───────────────────────────────────────────────────────────── */
.ocmp-pw-meter { margin-top: 6px; display: flex; align-items: center; gap: 10px; }
.ocmp-pw-meter__bar {
    flex: 1; height: 5px; border-radius: 999px;
    background: #E5E7EB; overflow: hidden;
}
.ocmp-pw-meter__bar > span {
    display: block; height: 100%; width: 0;
    background: #EF4444; transition: width .25s ease, background .25s ease;
}
.ocmp-pw-meter__label {
    font-size: 12px; font-weight: 700; color: var(--ocmp-muted);
    min-width: 56px; text-align: right;
}
.ocmp-pw-meter.is-weak   .ocmp-pw-meter__bar > span { background: #EF4444; }
.ocmp-pw-meter.is-weak   .ocmp-pw-meter__label     { color: #EF4444; }
.ocmp-pw-meter.is-medium .ocmp-pw-meter__bar > span { background: var(--ocmp-gold); }
.ocmp-pw-meter.is-medium .ocmp-pw-meter__label     { color: var(--ocmp-gold); }
.ocmp-pw-meter.is-strong .ocmp-pw-meter__bar > span { background: var(--ocmp-green); }
.ocmp-pw-meter.is-strong .ocmp-pw-meter__label     { color: var(--ocmp-green); }

/* ─────────────────────────────────────────────────────────────
 * Dashboard tab panels + forms + progress + checklist + docs
 * ───────────────────────────────────────────────────────────── */
.ocmp-dash__panel { display: none; }
.ocmp-dash__panel.is-active { display: block; }

.ocmp-dash__grid--narrow { grid-template-columns: minmax(0, 1fr) 320px; }
@media (max-width: 1100px) {
    .ocmp-dash__grid--narrow { grid-template-columns: 1fr; }
}

.ocmp-form { display: flex; flex-direction: column; gap: 14px; padding: 4px 2px 2px; }
.ocmp-form__row { display: grid; grid-template-columns: 1fr 1fr; gap: 14px; }
@media (max-width: 640px) { .ocmp-form__row { grid-template-columns: 1fr; } }
.ocmp-form__field { display: flex; flex-direction: column; gap: 6px; }
.ocmp-form__field > span:first-child { font-size: 13px; font-weight: 700; color: var(--ocmp-ink); }
.ocmp-form__field > input,
.ocmp-form__field > textarea {
    width: 100%; padding: 12px 14px; min-height: 48px;
    border: 1px solid var(--ocmp-border); border-radius: 12px;
    font-size: 14px; font-family: inherit; background: #fff; color: var(--ocmp-ink);
    transition: border-color .2s, box-shadow .2s;
}
.ocmp-form__field > input:focus,
.ocmp-form__field > textarea:focus {
    outline: none;
    border-color: var(--ocmp-green);
    box-shadow: 0 0 0 3px rgba(15,118,110,.15);
}
.ocmp-form__msg { font-size: 13px; font-weight: 600; }
.ocmp-form__msg.is-error   { color: #B91C1C; }
.ocmp-form__msg.is-success { color: var(--ocmp-green); }
.ocmp-form__actions { display: flex; gap: 10px; justify-content: flex-end; padding-top: 6px; }

/* Progress bar */
.ocmp-progress { padding: 4px 2px 12px; }
.ocmp-progress__bar {
    height: 8px; background: #E5E7EB; border-radius: 999px; overflow: hidden;
}
.ocmp-progress__bar > span {
    display: block; height: 100%;
    background: linear-gradient(90deg, var(--ocmp-green), var(--ocmp-gold));
    border-radius: 999px; transition: width .3s ease;
}
.ocmp-progress__label {
    margin-top: 8px; font-size: 13px; color: var(--ocmp-muted);
}
.ocmp-progress__label strong { color: var(--ocmp-ink); font-weight: 800; }

/* Checklist */
.ocmp-checklist { list-style: none; margin: 0; padding: 0; display: flex; flex-direction: column; gap: 8px; }
.ocmp-checklist li {
    display: flex; align-items: center; gap: 10px;
    font-size: 14px; color: var(--ocmp-muted);
}
.ocmp-checklist li > span:first-child {
    display: inline-flex; align-items: center; justify-content: center;
    width: 22px; height: 22px; border-radius: 999px;
    background: #F3F4F6; color: var(--ocmp-muted);
    font-size: 13px; font-weight: 800; flex-shrink: 0;
}
.ocmp-checklist li.is-done { color: var(--ocmp-ink); }
.ocmp-checklist li.is-done > span:first-child {
    background: rgba(15,118,110,.12); color: var(--ocmp-green);
}

/* Documents list */
.ocmp-docs { list-style: none; margin: 0; padding: 0; display: flex; flex-direction: column; gap: 10px; }
.ocmp-doc {
    display: flex; align-items: center; gap: 14px;
    padding: 12px 14px; border: 1px solid var(--ocmp-border); border-radius: 12px;
    background: #fff;
    transition: border-color .2s, box-shadow .2s;
}
.ocmp-doc:hover { border-color: var(--ocmp-green); box-shadow: 0 4px 12px rgba(15,118,110,.08); }
.ocmp-doc__ext {
    display: inline-flex; align-items: center; justify-content: center;
    width: 48px; height: 48px; border-radius: 10px;
    background: rgba(15,118,110,.1); color: var(--ocmp-green);
    font-size: 11px; font-weight: 800; letter-spacing: .03em; flex-shrink: 0;
}
.ocmp-doc__body { flex: 1; min-width: 0; }
.ocmp-doc__title { font-weight: 700; color: var(--ocmp-ink); font-size: 14px; }
.ocmp-doc__sub { font-size: 12px; color: var(--ocmp-muted); margin-top: 2px; }

/* Email preferences */
.ocmp-pref { list-style: none; margin: 0; padding: 0; display: flex; flex-direction: column; gap: 10px; }
.ocmp-pref li { padding: 0; }
.ocmp-pref label {
    display: flex; align-items: center; gap: 10px;
    padding: 10px 12px; border: 1px solid var(--ocmp-border); border-radius: 10px;
    background: #fff; font-size: 14px; color: var(--ocmp-ink); cursor: pointer;
}
.ocmp-pref input[type="checkbox"] {
    width: 18px; height: 18px; flex-shrink: 0; accent-color: var(--ocmp-green);
}
.ocmp-pref input[type="checkbox"][disabled] + span { color: var(--ocmp-muted); }

/* Messages full list */
.ocmp-msg-list--full .ocmp-msg { padding: 14px 12px; border-bottom: 1px solid var(--ocmp-border); }
.ocmp-msg-list--full .ocmp-msg:last-child { border-bottom: 0; }
.ocmp-msg__meta { font-size: 12px; color: var(--ocmp-muted); margin-top: 4px; }

/* Empty hint */
.ocmp-empty__hint { color: var(--ocmp-muted); font-size: 13px; margin: 4px 0 12px; }

/* Table extras for applications panel */
.ocmp-table__primary { font-weight: 700; color: var(--ocmp-ink); }
.ocmp-table__sub { font-size: 12px; color: var(--ocmp-muted); margin-top: 2px; }
.ocmp-table__action { text-align: right; }
.ocmp-table__next { color: var(--ocmp-muted); font-size: 13px; }

/* Card link in header */
.ocmp-card__link {
    font-size: 13px; font-weight: 700; color: var(--ocmp-green);
    text-decoration: none;
}
.ocmp-card__link:hover { color: var(--ocmp-green-dark); text-decoration: underline; }

/* ═══════════════════════════════════════════════════════════
   APPLY v2  — Multi-step recruitment workflow
   Hero · Stepper · Sidebar · 4 panels · Drag-drop uploads
   ═══════════════════════════════════════════════════════════ */

.ocmp-apply2 {
    --ap-green: #0F766E;
    --ap-green-d: #0B5953;
    --ap-orange: #F58220;
    --ap-ink: #0f172a;
    --ap-muted: #64748b;
    --ap-line: #e5e7eb;
    --ap-bg: #f8fafc;
    --ap-radius: 24px;
    --ap-card-shadow: 0 2px 12px rgba(15,23,42,.06);
    /* background: var(--ap-bg); */
    max-width: 1240px;
    margin: 32px auto 60px;
    padding: 0 20px;
    font-family: inherit;
    color: var(--ap-ink);
}

/* ── HERO ─────────────────────────────────────────────── */
.ocmp-apply2__hero {
    background: linear-gradient(59deg, rgba(11, 89, 83, .92), rgb(255 255 255 / 0%)), url(https://preprodonhym.maltem.ma/wp-content/uploads/2026/06/ChatGPT-Image-Jun-9-2026-06_39_32-PM-e1781026836584.png) center / cover no-repeat;
    border-radius: var(--ap-radius);
    color: #fff;
    margin-bottom: 28px;
    overflow: hidden;
    position: relative;
}
.ocmp-apply2__hero-inner {
    padding: 36px 40px 32px;
    max-width: 720px;
}
.ocmp-apply2__hero-pill {
    display: inline-block;
    background: #c9a227;
    color: #fff;
    font-size: 11px;
    font-weight: 700;
    letter-spacing: .14em;
    text-transform: uppercase;
    padding: 6px 14px;
    border-radius: 20px;
    margin-bottom: 16px;
}
.ocmp-apply2__hero-title {
    font-size: 34px;
    font-weight: 700;
    color: #fff;
    margin: 0 0 12px;
    line-height: 1.15;
}
.ocmp-apply2__hero-dept {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    color: #c9a227;
    font-size: 14px;
    font-weight: 600;
    margin: 0 0 14px;
}
.ocmp-apply2__hero-meta {
    display: flex;
    flex-wrap: wrap;
    gap: 18px;
    font-size: 13.5px;
    color: rgba(255,255,255,.92);
}
.ocmp-apply2__hero-meta span {
    display: inline-flex;
    align-items: center;
    gap: 6px;
}
.ocmp-apply2__hero-meta span + span::before {
    content: '·';
    margin-right: 14px;
    opacity: .6;
}
.ocmp-apply2__hero-meta span:first-child::before { content: none; margin: 0; }

/* ── STEPPER ──────────────────────────────────────────── */
.ocmp-apply2__stepper {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 0;
    padding: 0 8px;
    margin-bottom: 32px;
    position: relative;
}
.ocmp-step {
    position: relative;
    flex: 1;
    display: flex;
    flex-direction: column;
    align-items: center;
    text-align: center;
    z-index: 1;
}
.ocmp-step__circle {
    width: 36px;
    height: 36px;
    border-radius: 50%;
    background: #fff;
    border: 2px solid #cbd5e1;
    color: #94a3b8;
    display: flex;
    align-items: center;
    justify-content: center;
    font-weight: 700;
    font-size: 14px;
    transition: all .2s;
    position: relative;
    z-index: 2;
}
.ocmp-step__check { display: none; }
.ocmp-step__label {
    font-size: 12.5px;
    font-weight: 500;
    color: #94a3b8;
    margin-top: 8px;
    transition: color .2s;
}
.ocmp-step__line {
    position: absolute;
    top: 17px;
    left: calc(50% + 18px);
    right: calc(-50% + 18px);
    height: 2px;
    background: #e2e8f0;
    z-index: 0;
}
/* States */
.ocmp-step.is-current .ocmp-step__circle {
    background: var(--ap-green);
    border-color: var(--ap-green);
    color: #fff;
    box-shadow: 0 0 0 4px rgba(15,118,110,.12);
}
.ocmp-step.is-current .ocmp-step__label { color: var(--ap-green); font-weight: 700; }
.ocmp-step.is-done .ocmp-step__circle {
    background: var(--ap-green);
    border-color: var(--ap-green);
    color: #fff;
}
.ocmp-step.is-done .ocmp-step__num { display: none; }
.ocmp-step.is-done .ocmp-step__check { display: block; }
.ocmp-step.is-done .ocmp-step__label { color: var(--ap-green); }
.ocmp-step.is-done .ocmp-step__line { background: var(--ap-green); }

/* ── LAYOUT ──────────────────────────────────────────── */
.ocmp-apply2__layout {
    display: grid;
    grid-template-columns: 260px 1fr;
    gap: 24px;
    align-items: flex-start;
}

/* ── SIDEBAR ─────────────────────────────────────────── */
.ocmp-apply2__side {
    display: flex;
    flex-direction: column;
    gap: 16px;
    position: sticky;
    top: 20px;
}
.ocmp-apply2__sidecard {
    background: #fff;
    border: 1px solid var(--ap-line);
    border-radius: 16px;
    padding: 18px;
    box-shadow: var(--ap-card-shadow);
}
.ocmp-apply2__sidecard-head {
    display: flex;
    align-items: center;
    gap: 8px;
    margin-bottom: 14px;
}
.ocmp-apply2__sidecard-icon {
    width: 30px;
    height: 30px;
    border-radius: 8px;
    background: #f0fdfa;
    color: var(--ap-green);
    display: flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
}
.ocmp-apply2__sidecard-head strong { font-size: 14px; color: var(--ap-ink); }
.ocmp-apply2__summary {
    margin: 0;
    display: flex;
    flex-direction: column;
    gap: 12px;
}
.ocmp-apply2__summary dt {
    display: flex;
    align-items: center;
    gap: 6px;
    font-size: 11.5px;
    font-weight: 600;
    color: var(--ap-muted);
    text-transform: uppercase;
    letter-spacing: .05em;
    margin: 0 0 2px;
}
.ocmp-apply2__summary dt svg { color: var(--ap-green); flex-shrink: 0; }
.ocmp-apply2__summary dd {
    margin: 0;
    font-size: 13.5px;
    font-weight: 600;
    color: var(--ap-ink);
    padding-left: 20px;
    line-height: 1.4;
}
.ocmp-apply2__side-lede {
    font-size: 12.5px;
    color: var(--ap-muted);
    margin: 0 0 10px;
    line-height: 1.5;
}
.ocmp-apply2__side-link {
    display: flex !important;
    align-items: center;
    gap: 6px;
    font-size: 13px;
    color: var(--ap-green) !important;
    text-decoration: none !important;
    padding: 4px 0;
}
.ocmp-apply2__side-link:hover { color: var(--ap-green-d) !important; }
.ocmp-apply2__sidecard--help { background: #fff; }
.ocmp-apply2__sidecard--secure {
    background: #f0fdf4;
    border-color: #bbf7d0;
}
.ocmp-apply2__sidecard--secure .ocmp-apply2__sidecard-icon {
    background: #dcfce7;
    color: #166534;
}

/* ── MAIN PANELS ─────────────────────────────────────── */
.ocmp-apply2__main {
    background: #fff;
    border-radius: var(--ap-radius);
    box-shadow: var(--ap-card-shadow);
    overflow: hidden;
}
.ocmp-apply2__form { display: block; }
.ocmp-apply2__panel { display: none; padding: 32px 36px 28px; }
.ocmp-apply2__panel.is-active { display: block; animation: ocmpFadeIn .25s ease; }
@keyframes ocmpFadeIn { from { opacity:0; transform: translateY(6px); } to { opacity:1; transform:none; } }

.ocmp-apply2__panel-head { margin-bottom: 24px; }
.ocmp-apply2__panel-head h2 {
    font-size: 20px;
    font-weight: 700;
    color: var(--ap-green);
    margin: 0 0 6px;
}
.ocmp-apply2__panel-head p {
    font-size: 13.5px;
    color: var(--ap-muted);
    margin: 0;
}
.ocmp-apply2__subhead {
    font-size: 16px;
    font-weight: 700;
    color: var(--ap-green);
    margin: 24px 0 14px;
    padding-bottom: 8px;
    border-bottom: 1px solid var(--ap-line);
}

/* ── FORM FIELDS ─────────────────────────────────────── */
.ocmp-apply2__grid2 {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 16px;
}
.ocmp-apply2__field {
    display: flex;
    flex-direction: column;
    gap: 6px;
}
.ocmp-apply2__field--full { grid-column: 1 / -1; }
.ocmp-apply2__field > span {
    font-size: 12.5px;
    font-weight: 600;
    color: var(--ap-ink);
}
.ocmp-apply2__field > span em {
    color: var(--ap-orange);
    font-style: normal;
}
.ocmp-apply2__field > span small {
    color: var(--ap-muted);
    font-weight: 400;
    margin-left: 4px;
}
.ocmp-apply2__field input,
.ocmp-apply2__field select,
.ocmp-apply2__field textarea,
.ocmp-apply2__q-body input[type="text"],
.ocmp-apply2__q-body input[type="date"],
.ocmp-apply2__q-body textarea,
.ocmp-apply2__q-body select {
    width: 100%;
    padding: 11px 14px;
    border: 1px solid var(--ap-line);
    border-radius: 10px;
    font-size: 14px;
    font-family: inherit;
    color: var(--ap-ink);
    background: #fff;
    transition: border-color .15s, box-shadow .15s;
    box-sizing: border-box;
}
.ocmp-apply2__field input:focus,
.ocmp-apply2__field select:focus,
.ocmp-apply2__field textarea:focus,
.ocmp-apply2__q-body input:focus,
.ocmp-apply2__q-body textarea:focus,
.ocmp-apply2__q-body select:focus {
    border-color: var(--ap-green);
    outline: none;
    box-shadow: 0 0 0 3px rgba(15,118,110,.12);
}
.ocmp-apply2__field input::placeholder,
.ocmp-apply2__field textarea::placeholder { color: #94a3b8; }
.ocmp-apply2__field input.is-invalid,
.ocmp-apply2__field select.is-invalid,
.ocmp-apply2__field textarea.is-invalid {
    border-color: #dc2626;
    box-shadow: 0 0 0 3px rgba(220,38,38,.10);
}

/* Phone */
.ocmp-apply2__phone {
    display: flex;
    align-items: stretch;
    border: 1px solid var(--ap-line);
    border-radius: 10px;
    overflow: hidden;
    background: #fff;
}
.ocmp-apply2__phone-flag {
    display: flex;
    align-items: center;
    padding: 0 8px 0 12px;
    background: #f8fafc;
    border-right: 1px solid var(--ap-line);
}
.ocmp-apply2__phone-code {
    display: flex;
    align-items: center;
    padding: 0 10px;
    font-size: 13.5px;
    font-weight: 600;
    color: var(--ap-ink);
    background: #f8fafc;
    border-right: 1px solid var(--ap-line);
}
.ocmp-apply2__phone input {
    flex: 1;
    border: none !important;
    border-radius: 0 !important;
    box-shadow: none !important;
    padding: 11px 12px;
}

/* Input w/ leading icon (LinkedIn) */
.ocmp-apply2__input-icon {
    position: relative;
}
.ocmp-apply2__input-icon > svg {
    position: absolute;
    left: 12px;
    top: 50%;
    transform: translateY(-50%);
    color: #0a66c2;
    pointer-events: none;
}
.ocmp-apply2__input-icon input { padding-left: 38px; }

/* ── DOCUMENTS: dropzone ─────────────────────────────── */
.ocmp-apply2__doc {
    background: #fff;
    border: 1px solid var(--ap-line);
    border-radius: 14px;
    padding: 16px 18px;
    margin-bottom: 16px;
}
.ocmp-apply2__doc-head {
    display: flex;
    align-items: center;
    gap: 6px;
    margin-bottom: 12px;
    font-size: 14px;
}
.ocmp-apply2__doc-num {
    font-weight: 700;
    color: var(--ap-green);
}
.ocmp-apply2__doc-title { font-weight: 600; color: var(--ap-ink); }
.ocmp-apply2__doc-req { color: var(--ap-orange); font-size: 12px; font-weight: 600; }
.ocmp-apply2__doc-opt { color: var(--ap-muted); font-size: 12px; }

.ocmp-apply2__dropzone {
    border: 2px dashed #cbd5e1;
    border-radius: 12px;
    padding: 22px 18px;
    text-align: center;
    background: #f8fafc;
    transition: border-color .15s, background .15s;
    cursor: pointer;
}
.ocmp-apply2__dropzone:hover,
.ocmp-apply2__dropzone.is-drag {
    border-color: var(--ap-green);
    background: #f0fdfa;
}
.ocmp-apply2__dropzone-icon { color: var(--ap-green); margin-bottom: 6px; }
.ocmp-apply2__dropzone-txt { font-size: 13.5px; color: var(--ap-ink); margin: 0 0 4px; font-weight: 500; }
.ocmp-apply2__dropzone-or { font-size: 12px; color: var(--ap-muted); margin: 0 0 8px; }
.ocmp-apply2__dropzone-btn { padding: 7px 18px !important; font-size: 13px !important; }
.ocmp-apply2__dropzone-hint { font-size: 11.5px; color: var(--ap-muted); margin: 8px 0 0; }

.ocmp-apply2__filelist {
    list-style: none;
    margin: 12px 0 0;
    padding: 0;
    display: flex;
    flex-direction: column;
    gap: 8px;
}
.ocmp-apply2__filelist:empty { display: none; }
.ocmp-apply2__file {
    display: flex;
    align-items: center;
    gap: 10px;
    background: #f8fafc;
    border: 1px solid var(--ap-line);
    border-radius: 10px;
    padding: 10px 12px;
}
.ocmp-apply2__file-icon {
    width: 28px; height: 28px;
    border-radius: 6px;
    background: #fee2e2;
    color: #dc2626;
    display: flex; align-items: center; justify-content: center;
    font-size: 10px; font-weight: 700; flex-shrink: 0;
}
.ocmp-apply2__file-icon.is-doc { background: #dbeafe; color: #2563eb; }
.ocmp-apply2__file-icon.is-zip { background: #fef3c7; color: #d97706; }
.ocmp-apply2__file-meta { flex: 1; min-width: 0; }
.ocmp-apply2__file-name { font-size: 13px; font-weight: 600; color: var(--ap-ink); white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.ocmp-apply2__file-size { font-size: 11.5px; color: var(--ap-muted); }
.ocmp-apply2__file-check {
    width: 22px; height: 22px;
    border-radius: 50%;
    background: var(--ap-green);
    color: #fff;
    display: flex; align-items: center; justify-content: center;
    font-size: 12px; font-weight: 700; flex-shrink: 0;
}
.ocmp-apply2__file-rm {
    background: transparent !important;
    border: none !important;
    color: var(--ap-muted) !important;
    cursor: pointer;
    padding: 4px !important;
    border-radius: 6px !important;
    box-shadow: none !important;
    -webkit-appearance: none;
}
.ocmp-apply2__file-rm:hover { color: #dc2626 !important; background: #fef2f2 !important; }

.ocmp-apply2__notice {
    display: flex;
    align-items: center;
    gap: 8px;
    background: #f0fdf4;
    border: 1px solid #bbf7d0;
    border-radius: 10px;
    padding: 10px 14px;
    font-size: 12.5px;
    color: #166534;
    margin: 14px 0 0;
}
.ocmp-apply2__notice svg { color: #16a34a; flex-shrink: 0; }

/* ── SCREENING QUESTIONS ─────────────────────────────── */
.ocmp-apply2__q {
    background: #fff;
    border: 1px solid var(--ap-line);
    border-radius: 14px;
    padding: 16px 18px;
    margin-bottom: 14px;
}
.ocmp-apply2__q-head {
    display: flex;
    align-items: center;
    gap: 8px;
    margin-bottom: 14px;
}
.ocmp-apply2__q-num {
    width: 22px; height: 22px;
    border-radius: 6px;
    background: var(--ap-green);
    color: #fff;
    display: flex; align-items: center; justify-content: center;
    font-size: 12px; font-weight: 700; flex-shrink: 0;
}
.ocmp-apply2__q-label { font-size: 14px; font-weight: 600; color: var(--ap-ink); }
.ocmp-apply2__q-label em { color: var(--ap-orange); font-style: normal; }
.ocmp-apply2__q-body {}
.ocmp-apply2__radios, .ocmp-apply2__checks {
    display: flex; flex-wrap: wrap; gap: 8px 16px;
}
.ocmp-apply2__radio, .ocmp-apply2__check {
    display: inline-flex; align-items: center; gap: 6px;
    font-size: 13.5px;
    color: var(--ap-ink);
    cursor: pointer;
    padding: 4px 0;
}
.ocmp-apply2__radio input, .ocmp-apply2__check input {
    accent-color: var(--ap-green);
    width: 16px; height: 16px;
    cursor: pointer;
}
.ocmp-apply2__counter {
    font-size: 11.5px;
    color: var(--ap-muted);
    text-align: right;
    margin-top: 4px;
}

/* ── REVIEW ──────────────────────────────────────────── */
.ocmp-apply2__review-card {
    background: #fff;
    border: 1px solid var(--ap-line);
    border-radius: 14px;
    padding: 18px 20px;
    margin-bottom: 14px;
}
.ocmp-apply2__review-head {
    display: flex;
    align-items: center;
    gap: 10px;
    margin-bottom: 14px;
}
.ocmp-apply2__review-icon {
    width: 32px; height: 32px;
    border-radius: 8px;
    background: #f0fdfa;
    color: var(--ap-green);
    display: flex; align-items: center; justify-content: center;
    flex-shrink: 0;
}
.ocmp-apply2__review-head h3 {
    flex: 1;
    font-size: 15px;
    font-weight: 700;
    color: var(--ap-ink);
    margin: 0;
}
.ocmp-apply2__edit-btn {
    padding: 6px 12px !important;
    font-size: 12.5px !important;
    color: #fff !important;
    background: var(--ap-green) !important;
    border: 1px solid var(--ap-green) !important;
    border-radius: 8px !important;
    display: inline-flex !important;
    align-items: center;
    gap: 5px;
}
.ocmp-apply2__edit-btn svg { color: #fff; stroke: #fff; }
.ocmp-apply2__review-body {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 12px 24px;
    font-size: 13.5px;
}
.ocmp-apply2__review-body p { margin: 0; }
.ocmp-apply2__review-body .rv-row { display: flex; flex-direction: column; gap: 2px; }
.ocmp-apply2__review-body .rv-key { font-size: 11.5px; font-weight: 600; color: var(--ap-muted); text-transform: uppercase; letter-spacing: .05em; }
.ocmp-apply2__review-body .rv-val { font-size: 13.5px; color: var(--ap-ink); font-weight: 500; word-break: break-word; }
.ocmp-apply2__review-body .rv-full { grid-column: 1 / -1; }
.ocmp-apply2__review-body .rv-doc {
    display: flex; align-items: center; gap: 10px;
    padding: 8px 10px;
    border: 1px solid var(--ap-line); border-radius: 8px;
    background: #f8fafc;
}
.ocmp-apply2__review-body .rv-doc-icon {
    width: 28px; height: 28px; border-radius: 6px;
    background: #fee2e2; color: #dc2626;
    display: flex; align-items: center; justify-content: center;
    font-size: 10px; font-weight: 700; flex-shrink: 0;
}
.ocmp-apply2__review-body .rv-empty { color: var(--ap-muted); font-style: italic; font-size: 13px; }

/* Certify */
.ocmp-apply2__certify {
    display: flex;
    gap: 12px;
    background: #f0fdfa;
    border: 1px solid #99f6e4;
    border-radius: 12px;
    padding: 14px 16px;
    margin: 18px 0;
    cursor: pointer;
}
.ocmp-apply2__certify input[type="checkbox"] {
    width: 18px; height: 18px;
    accent-color: var(--ap-green);
    margin-top: 2px;
    flex-shrink: 0;
}
.ocmp-apply2__certify span { display: flex; flex-direction: column; gap: 4px; }
.ocmp-apply2__certify strong { font-size: 13.5px; color: var(--ap-ink); font-weight: 600; }
.ocmp-apply2__certify small { font-size: 12.5px; color: var(--ap-muted); }

/* ── FOOTERS / BUTTONS ───────────────────────────────── */
.ocmp-apply2__panel-foot {
    display: flex;
    align-items: center;
    justify-content: space-between;
    margin-top: 28px;
    padding-top: 20px;
    border-top: 1px solid var(--ap-line);
    gap: 12px;
    flex-wrap: wrap;
}
.ocmp-apply2__panel-foot-right {
    display: flex;
    gap: 10px;
    flex-wrap: wrap;
}
.ocmp-apply2__panel-foot .ocmp-jbtn {
    display: inline-flex !important;
    align-items: center;
    gap: 8px;
    padding: 10px 18px !important;
    font-size: 14px !important;
}
.ocmp-apply2__panel-foot .ocmp-jbtn--primary {
    background: #c9a227 !important;
    color: #fff !important;
    border: none !important;
}
.ocmp-apply2__panel-foot .ocmp-jbtn--primary:hover { background: #c9a227 !important; }

.ocmp-apply2__msg {
    margin: 12px 0;
    font-size: 13.5px;
}
.ocmp-apply2__msg.is-error {
    background: #fef2f2;
    border: 1px solid #fecaca;
    color: #991b1b;
    padding: 10px 14px;
    border-radius: 8px;
}
.ocmp-apply2__msg.is-success {
    background: #f0fdf4;
    border: 1px solid #bbf7d0;
    color: #166534;
    padding: 10px 14px;
    border-radius: 8px;
}

.ocmp-apply2__foot-note {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 6px;
    font-size: 11.5px;
    color: var(--ap-muted);
    margin: 14px 0 0;
}
.ocmp-apply2__foot-note svg { color: #16a34a; }

/* ── DECORATIVE FOOTER CTA ───────────────────────────── */
.ocmp-apply2__cta {
    margin-top: 28px;
    background: linear-gradient(135deg, #f0fdfa 0%, #ecfeff 100%);
    border-radius: 16px;
    padding: 20px 28px;
    display: flex;
    align-items: center;
}
.ocmp-apply2__cta > div {
    display: flex;
    align-items: center;
    gap: 14px;
}
.ocmp-apply2__cta-icon {
    width: 42px; height: 42px;
    border-radius: 10px;
    background: #fff;
    color: var(--ap-green);
    display: flex; align-items: center; justify-content: center;
    flex-shrink: 0;
    box-shadow: 0 2px 6px rgba(0,0,0,.05);
}
.ocmp-apply2__cta strong { display: block; font-size: 14px; color: var(--ap-green); font-weight: 700; margin-bottom: 2px; }
.ocmp-apply2__cta p { margin: 0; font-size: 12.5px; color: var(--ap-muted); }

/* ── SUCCESS SCREEN (already submitted) ──────────────── */
.ocmp-apply2__success {
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 60px 20px;
}
.ocmp-apply2__success-card {
    background: #fff;
    border-radius: var(--ap-radius);
    box-shadow: var(--ap-card-shadow);
    text-align: center;
    padding: 48px 36px;
    max-width: 500px;
}
.ocmp-apply2__success-icon {
    width: 76px; height: 76px;
    border-radius: 50%;
    background: #dcfce7;
    color: #16a34a;
    display: flex; align-items: center; justify-content: center;
    margin: 0 auto 18px;
}
.ocmp-apply2__success-card h2 {
    font-size: 22px;
    color: var(--ap-green);
    margin: 0 0 10px;
}
.ocmp-apply2__success-card p { font-size: 14px; color: var(--ap-muted); margin: 0 0 8px; }
.ocmp-apply2__success-actions { margin-top: 22px; }

/* ── RESPONSIVE ──────────────────────────────────────── */
@media (max-width: 1024px) {
    .ocmp-apply2__layout { grid-template-columns: 1fr; }
    .ocmp-apply2__side { position: static; }
}
@media (max-width: 720px) {
    .ocmp-apply2 { padding: 0 12px; margin-top: 16px; }
    .ocmp-apply2__hero-inner { padding: 24px 22px; }
    .ocmp-apply2__hero-title { font-size: 24px; }
    .ocmp-apply2__panel { padding: 22px 18px; }
    .ocmp-apply2__grid2 { grid-template-columns: 1fr; }
    .ocmp-apply2__review-body { grid-template-columns: 1fr; }
    .ocmp-step__label { font-size: 11px; }
    .ocmp-step__line { display: none; }
    .ocmp-apply2__stepper { padding: 0; gap: 4px; }
    .ocmp-apply2__panel-foot { flex-direction: column-reverse; align-items: stretch; }
    .ocmp-apply2__panel-foot-right { justify-content: stretch; }
    .ocmp-apply2__panel-foot .ocmp-jbtn { flex: 1; justify-content: center; }
}

/* ── Stat card: extra colours ─────────────────────────────────── */
.ocmp-stat--blue {
    --sc: #1E5BB8;
    background: linear-gradient(135deg, #EBF2FC 0%, #D6E6F9 100%);
    border-top: 3px solid var(--sc);
}
.ocmp-stat--blue .ocmp-stat__icon { background: rgba(30,91,184,.12); color: var(--sc); }
.ocmp-stat--blue .ocmp-stat__value { color: var(--sc); }
.ocmp-stat--accepted {
    --sc: #1E7C36;
    background: linear-gradient(135deg, #E6F6E9 0%, #CBEDD2 100%);
    border-top: 3px solid var(--sc);
}
.ocmp-stat--accepted .ocmp-stat__icon { background: rgba(30,124,54,.12); color: var(--sc); }
.ocmp-stat--accepted .ocmp-stat__value { color: var(--sc); }

/* Clickable stat cards */
.ocmp-stat[tabindex] { transition: box-shadow .15s; }
.ocmp-stat[tabindex]:hover,
.ocmp-stat[tabindex]:focus-visible { box-shadow: 0 4px 16px rgba(0,0,0,.15); outline: 2px solid var(--ocmp-green); outline-offset: 2px; }

/* ── Status pipeline strip ────────────────────────────────────── */
.ocmp-pipeline {
    display: grid;
    grid-template-columns: repeat(6, 1fr);
    gap: 0;
    border: 1px solid var(--ocmp-border, #E5E7EB);
    border-radius: 14px;
    overflow: hidden;
    margin-bottom: 28px;
}
.ocmp-pipeline__item {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: 4px;
    padding: 16px 8px;
    background: #F9FAFB;
    border-right: 1px solid var(--ocmp-border, #E5E7EB);
    text-align: center;
    position: relative;
    transition: background .15s;
}
.ocmp-pipeline__item:last-child { border-right: none; }

.ocmp-pipeline__icon { color: #9CA3AF; line-height: 1; }
.ocmp-pipeline__count {
    font-size: 22px;
    font-weight: 700;
    color: #9CA3AF;
    line-height: 1;
}
.ocmp-pipeline__label {
    font-size: 11px;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: .04em;
    color: #9CA3AF;
    white-space: nowrap;
}

/* Active (has items) states per status */
.ocmp-pipeline__item--pending.has-items             { background: #F8FAFC; }
.ocmp-pipeline__item--pending.has-items .ocmp-pipeline__icon,
.ocmp-pipeline__item--pending.has-items .ocmp-pipeline__count,
.ocmp-pipeline__item--pending.has-items .ocmp-pipeline__label { color: #475467; }

.ocmp-pipeline__item--under_review.has-items        { background: #FFF8F1; }
.ocmp-pipeline__item--under_review.has-items .ocmp-pipeline__icon,
.ocmp-pipeline__item--under_review.has-items .ocmp-pipeline__count,
.ocmp-pipeline__item--under_review.has-items .ocmp-pipeline__label { color: #E07A19; }

.ocmp-pipeline__item--shortlisted.has-items         { background: #F5F0FE; }
.ocmp-pipeline__item--shortlisted.has-items .ocmp-pipeline__icon,
.ocmp-pipeline__item--shortlisted.has-items .ocmp-pipeline__count,
.ocmp-pipeline__item--shortlisted.has-items .ocmp-pipeline__label { color: #5B21B6; }

.ocmp-pipeline__item--interview_scheduled.has-items { background: #EBF2FC; }
.ocmp-pipeline__item--interview_scheduled.has-items .ocmp-pipeline__icon,
.ocmp-pipeline__item--interview_scheduled.has-items .ocmp-pipeline__count,
.ocmp-pipeline__item--interview_scheduled.has-items .ocmp-pipeline__label { color: #1E5BB8; }

.ocmp-pipeline__item--accepted.has-items            { background: #E9F7ED; }
.ocmp-pipeline__item--accepted.has-items .ocmp-pipeline__icon,
.ocmp-pipeline__item--accepted.has-items .ocmp-pipeline__count,
.ocmp-pipeline__item--accepted.has-items .ocmp-pipeline__label { color: #1E7C36; }

.ocmp-pipeline__item--rejected.has-items            { background: #FEF2F2; }
.ocmp-pipeline__item--rejected.has-items .ocmp-pipeline__icon,
.ocmp-pipeline__item--rejected.has-items .ocmp-pipeline__count,
.ocmp-pipeline__item--rejected.has-items .ocmp-pipeline__label { color: #D24545; }

@media (max-width: 860px) {
    .ocmp-pipeline { grid-template-columns: repeat(3, 1fr); }
    .ocmp-pipeline__item:nth-child(3) { border-right: none; }
    .ocmp-pipeline__item:nth-child(3n) { border-right: none; }
    .ocmp-pipeline__item:nth-child(-n+3) { border-bottom: 1px solid var(--ocmp-border, #E5E7EB); }
}
@media (max-width: 520px) {
    .ocmp-pipeline { grid-template-columns: repeat(2, 1fr); }
    .ocmp-pipeline__item:nth-child(3n) { border-right: 1px solid var(--ocmp-border, #E5E7EB); }
    .ocmp-pipeline__item:nth-child(2n) { border-right: none; }
    .ocmp-pipeline__item:nth-child(-n+4) { border-bottom: 1px solid var(--ocmp-border, #E5E7EB); }
}

/* ── Auth job context banner ──────────────────────────────────── */
.ocmp-auth__job-banner {
width: 37%;
    margin-left: 381px;
    background: linear-gradient(135deg, #0B5953 0%, #0F766E 60%, #1a9d93 100%);
    color: #fff;
    padding: 15px 15px;
    margin-bottom: 28px;
    border-radius: 14px;
    margin-top: -102px;
}
.ocmp-auth__job-banner-inner {
    display: flex;
    align-items: flex-start;
    gap: 14px;
    max-width: 680px;
    margin: 0 auto;
}
.ocmp-auth__job-banner-icon {
    flex-shrink: 0;
    width: 40px;
    height: 40px;
    border-radius: 10px;
    background: rgba(255,255,255,.2);
    display: flex;
    align-items: center;
    justify-content: center;
}
.ocmp-auth__job-banner-label {
    font-size: 11px;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: .06em;
    opacity: .75;
    margin: 0 0 2px;
}
.ocmp-auth__job-banner-title {
    font-size: 17px;
    font-weight: 700;
    margin: 0 0 4px;
    display: flex;
    align-items: center;
    flex-wrap: wrap;
    gap: 8px;
}
.ocmp-auth__job-banner-ref {
    display: inline-block;
    font-size: 11px;
    font-weight: 600;
    background: rgba(255,255,255,.2);
    border-radius: 999px;
    padding: 2px 10px;
}
.ocmp-auth__job-banner-meta {
    font-size: 13px;
    opacity: .85;
    margin: 0;
}
@media (max-width: 600px) {
    .ocmp-auth__job-banner { padding: 14px 16px; }
    .ocmp-auth__job-banner-title { font-size: 15px; }
}

/* ── Dashboard stat grid: 6 columns ──────────────────────────── */
@media (min-width: 1100px) {
    .ocmp-dash__stats { grid-template-columns: repeat(6, 1fr); }
}
@media (min-width: 700px) and (max-width: 1099px) {
    .ocmp-dash__stats { grid-template-columns: repeat(3, 1fr); }
}
@media (max-width: 699px) {
    .ocmp-dash__stats { grid-template-columns: repeat(2, 1fr); }
}
