/* ONHYM Career Management Pro — public portal */
.ocmp-portal {
	--ocmp-green: #0F766E;
	--ocmp-green-dark: #0B5953;
	--ocmp-green-soft: rgba(15,118,110,.08);
	--ocmp-blue: #003B73;
	--ocmp-gold: #C7A23A;
	--ocmp-gold-soft: rgba(199,162,58,.14);
	--ocmp-red: #DC2626;
	--ocmp-red-soft: rgba(220,38,38,.12);
	--ocmp-orange: #EA8B0E;
	--ocmp-orange-soft: rgba(234,139,14,.14);
	--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 10px 30px 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: 12px;
	box-sizing: border-box;
}
.ocmp-portal *, .ocmp-portal *::before, .ocmp-portal *::after { box-sizing: border-box; }

/* ── KPI cards ─────────────────────────────────────────────────── */
.ocmp-kpis {
	display: grid;
	grid-template-columns: repeat(4, minmax(0, 1fr));
	gap: 18px;
	margin-bottom: 22px;
}
.ocmp-kpi {
	background: #fff;
	border-radius: var(--ocmp-radius);
	box-shadow: var(--ocmp-shadow);
	padding: 20px;
	display: flex;
	align-items: center;
	gap: 16px;
	border: 1px solid var(--ocmp-border);
	transition: transform .25s ease, box-shadow .25s ease;
}
.ocmp-kpi:hover {
	transform: translateY(-2px);
	box-shadow: var(--ocmp-shadow-lg);
}
.ocmp-kpi__icon {
	flex: 0 0 56px;
	width: 56px;
	height: 56px;
	border-radius: 14px;
	background: var(--ocmp-gold-soft);
	color: var(--ocmp-gold);
	display: flex;
	align-items: center;
	justify-content: center;
}
.ocmp-kpi:nth-child(1) .ocmp-kpi__icon { background: var(--ocmp-green-soft); color: var(--ocmp-green); }
.ocmp-kpi:nth-child(2) .ocmp-kpi__icon { background: rgba(0,59,115,.10);     color: var(--ocmp-blue); }
.ocmp-kpi:nth-child(3) .ocmp-kpi__icon { background: var(--ocmp-gold-soft);   color: var(--ocmp-gold); }
.ocmp-kpi:nth-child(4) .ocmp-kpi__icon { background: rgba(15,118,110,.10);   color: var(--ocmp-green); }
.ocmp-kpi__body { min-width: 0; }
.ocmp-kpi__value {
	font-size: 30px;
	font-weight: 800;
	color: var(--ocmp-green);
	line-height: 1.05;
}
.ocmp-kpi:nth-child(2) .ocmp-kpi__value { color: var(--ocmp-blue); }
.ocmp-kpi:nth-child(3) .ocmp-kpi__value { color: var(--ocmp-gold); }
.ocmp-kpi__label {
	margin-top: 4px;
	font-size: 14px;
	color: var(--ocmp-muted);
	font-weight: 500;
}

/* ── Card / toolbar ────────────────────────────────────────────── */
.ocmp-card {
	background: #fff;
	border-radius: var(--ocmp-radius);
	box-shadow: var(--ocmp-shadow);
	border: 1px solid var(--ocmp-border);
	overflow: hidden;
}
.ocmp-toolbar {
	display: flex;
	flex-wrap: wrap;
	gap: 12px;
	align-items: center;
	padding: 18px;
	border-bottom: 1px solid var(--ocmp-border);
	background: linear-gradient(to bottom, #fff, #fbfdfd);
}
.ocmp-search {
	flex: 1 1 280px;
	position: relative;
	min-width: 220px;
}
.ocmp-search svg {
	position: absolute;
	left: 2px;
	top: 50%;
	transform: translateY(-50%);
	color: var(--ocmp-muted);
}
.ocmp-search input {
	width: 100%;
	padding: 11px 14px 11px 40px;
	border: 1px solid var(--ocmp-border);
	border-radius: 10px;
	font-size: 14px;
	background: #fff;
	color: var(--ocmp-ink);
	transition: border-color .2s, box-shadow .2s;
}
.ocmp-search input:focus {
	outline: none;
	border-color: var(--ocmp-green);
	box-shadow: 0 0 0 3px rgba(15,118,110,.18);
}
.ocmp-select {
	flex: 0 1 180px;
	min-width: 140px;
	padding: 10px 14px;
	border: 1px solid var(--ocmp-border);
	border-radius: 10px;
	font-size: 14px;
	background: #fff;
	color: var(--ocmp-ink);
	cursor: pointer;
	transition: border-color .2s;
}
.ocmp-select:focus { outline: none; border-color: var(--ocmp-green); box-shadow: 0 0 0 3px rgba(15,118,110,.18); }

.ocmp-btn {
	display: inline-flex;
	align-items: center;
	gap: 8px;
	padding: 10px 18px;
	border-radius: 10px;
	font-size: 14px;
	font-weight: 600;
	border: 1px solid transparent;
	cursor: pointer;
	transition: background .2s, transform .15s, box-shadow .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 6px 14px rgba(15,118,110,.30); }
.ocmp-btn--ghost {
	background: #fff;
	color: var(--ocmp-ink);
	border-color: var(--ocmp-border);
}
.ocmp-btn--ghost:hover { background: var(--ocmp-bg); }

/* ── Table ─────────────────────────────────────────────────────── */
.ocmp-table-wrap {
	overflow-x: auto;
	-webkit-overflow-scrolling: touch;
}
.ocmp-table {
	width: 100%;
	border-collapse: separate;
	border-spacing: 0;
	min-width: 760px;
}
.ocmp-table thead th {
	background: var(--ocmp-green);
	color: #fff;
	font-weight: 600;
	font-size: 13px;
	text-transform: uppercase;
	letter-spacing: .03em;
	padding: 14px 16px;
	text-align: left;
	border-bottom: 1px solid var(--ocmp-green-dark);
	position: sticky;
	top: 0;
	z-index: 1;
}
.ocmp-table thead th.ocmp-th-center { text-align: center; }
.ocmp-table tbody td {
	padding: 16px;
	font-size: 14px;
	border-bottom: 1px solid var(--ocmp-border);
	vertical-align: middle;
	color: var(--ocmp-ink);
}
.ocmp-table tbody tr:last-child td { border-bottom: 0; }
.ocmp-table tbody tr:hover { background: var(--ocmp-green-soft); }
.ocmp-cell-pos a {
	color: var(--ocmp-blue);
	font-weight: 600;
	text-decoration: none;
}
.ocmp-cell-pos a:hover { color: var(--ocmp-green); text-decoration: underline; }
.ocmp-pos-ref {
	display: block;
	font-size: 12px;
	color: var(--ocmp-muted);
	margin-top: 2px;
	font-weight: 400;
}
.ocmp-cell-target { color: var(--ocmp-muted); font-weight: 500; }
.ocmp-cell-deadline { color: var(--ocmp-ink); font-weight: 500; white-space: nowrap; }
.ocmp-cell-cands, .ocmp-cell-results { text-align: center; }
.ocmp-dash { color: var(--ocmp-muted); }

.ocmp-badge {
	display: inline-block;
	padding: 5px 12px;
	border-radius: 999px;
	font-size: 11px;
	font-weight: 700;
	letter-spacing: .04em;
}
.ocmp-badge--active   { background: var(--ocmp-green-soft);  color: var(--ocmp-green); }
.ocmp-badge--expired  { background: var(--ocmp-red-soft);    color: var(--ocmp-red); }
.ocmp-badge--upcoming { background: var(--ocmp-orange-soft); color: var(--ocmp-orange); }

.ocmp-icon-btn {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 36px;
	height: 36px;
	border-radius: 10px;
	color: #fff !important;
	text-decoration: none;
	transition: transform .15s, box-shadow .2s;
}
.ocmp-icon-btn:hover { transform: translateY(-1px); box-shadow: 0 6px 14px rgba(0,0,0,.18); }
.ocmp-icon-btn--gold  { background: var(--ocmp-gold); }
.ocmp-icon-btn--green { background: var(--ocmp-green); }
.ocmp-icon-btn svg {
	color: #fff !important;
	stroke: #fff !important;
	fill: none !important;
	display: block;
}

.ocmp-empty {
	padding: 32px;
	text-align: center;
	color: var(--ocmp-muted);
	font-size: 14px;
}

/* ── Footer / pagination ──────────────────────────────────────── */
.ocmp-footer {
	display: flex;
	justify-content: space-between;
	align-items: center;
	gap: 12px;
	padding: 14px 18px;
	border-top: 1px solid var(--ocmp-border);
	flex-wrap: wrap;
	background: #fbfdfd;
}
.ocmp-perpage {
	display: flex;
	align-items: center;
	gap: 14px;
	font-size: 13px;
	color: var(--ocmp-muted);
}
.ocmp-perpage select {
	margin-left: 6px;
	padding: 5px 8px;
	border-radius: 8px;
	border: 1px solid var(--ocmp-border);
	font-size: 13px;
}
.ocmp-pagination { display: flex; gap: 6px; flex-wrap: wrap; align-items: center; }
.ocmp-pagination .ocmp-page {
	display: inline-flex !important;
	align-items: center !important;
	justify-content: center !important;
	min-width: 40px;
	height: 40px;
	padding: 0 12px !important;
	margin: 0 !important;
	border-radius: 10px;
	border: 1px solid var(--ocmp-border);
	background: #fff;
	font-family: inherit;
	font-size: 14px;
	font-weight: 600;
	line-height: 1 !important;
	text-align: center;
	color: var(--ocmp-ink);
	cursor: pointer;
	box-shadow: none;
	text-shadow: none;
	transition: background .15s, border-color .15s, color .15s, transform .15s;
	-webkit-appearance: none;
	-moz-appearance: none;
	appearance: none;
	vertical-align: middle;
}
.ocmp-pagination .ocmp-page::before,
.ocmp-pagination .ocmp-page::after { content: none !important; }
.ocmp-pagination .ocmp-page:hover:not(:disabled) { background: var(--ocmp-green-soft); border-color: var(--ocmp-green); color: var(--ocmp-green); }
.ocmp-pagination .ocmp-page.is-active { background: var(--ocmp-green); color: #fff; border-color: var(--ocmp-green); }
.ocmp-pagination .ocmp-page:disabled { opacity: .45; cursor: not-allowed; background: var(--ocmp-bg); color: var(--ocmp-muted); }
.ocmp-pagination .ocmp-page-prev,
.ocmp-pagination .ocmp-page-next { font-size: 18px; font-weight: 700; }
.ocmp-pagination .ocmp-page-gap { border: none !important; background: transparent !important; cursor: default; color: var(--ocmp-muted); }

/* ── Modal ────────────────────────────────────────────────────── */
.ocmp-modal[hidden] { display: none !important; }
.ocmp-modal { position: fixed; inset: 0; z-index: 9999; display: none !important; align-items: center; justify-content: center; padding: 16px; }
.ocmp-modal__backdrop { position: absolute; inset: 0; background: rgba(15,23,42,.55); }
.ocmp-modal__panel {
	position: relative;
	background: #fff;
	border-radius: var(--ocmp-radius);
	box-shadow: var(--ocmp-shadow-lg);
	width: 100%;
	max-width: 520px;
	padding: 24px;
	max-height: 90vh;
	overflow: auto;
}
.ocmp-modal__close {
	position: absolute;
	top: 12px;
	right: 14px;
	width: 32px;
	height: 32px;
	border-radius: 8px;
	border: 0;
	background: var(--ocmp-bg);
	font-size: 22px;
	line-height: 1;
	cursor: pointer;
	color: var(--ocmp-muted);
}
.ocmp-modal__close:hover { background: var(--ocmp-red-soft); color: var(--ocmp-red); }
.ocmp-modal__title { margin: 0 0 4px; font-size: 20px; color: var(--ocmp-blue); }
.ocmp-modal__sub { margin: 0 0 18px; color: var(--ocmp-muted); font-size: 13px; }
.ocmp-modal form label { display: block; margin-bottom: 12px; font-size: 13px; color: var(--ocmp-ink); }
.ocmp-modal form label > span { display: block; margin-bottom: 4px; font-weight: 600; }
.ocmp-modal form input,
.ocmp-modal form textarea {
	width: 100%;
	padding: 10px 12px;
	border: 1px solid var(--ocmp-border);
	border-radius: 8px;
	font-size: 14px;
	font-family: inherit;
}
.ocmp-modal form input:focus,
.ocmp-modal form textarea:focus { outline: none; border-color: var(--ocmp-green); box-shadow: 0 0 0 3px rgba(15,118,110,.18); }
.ocmp-modal__actions { display: flex; justify-content: flex-end; gap: 10px; margin-top: 6px; }
.ocmp-modal__msg { margin-top: 12px; font-size: 13px; min-height: 18px; }
.ocmp-modal__msg.is-error   { color: var(--ocmp-red); }
.ocmp-modal__msg.is-success { color: var(--ocmp-green); }

/* ── Responsive ──────────────────────────────────────────────── */
@media (max-width: 1024px) {
	.ocmp-kpis { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 768px) {
	.ocmp-toolbar { padding: 14px; }
	.ocmp-search, .ocmp-select { flex-basis: 100%; }
	.ocmp-btn { width: 100%; justify-content: center; }
}
@media (max-width: 640px) {
	.ocmp-kpis { grid-template-columns: 1fr; gap: 12px; }
	.ocmp-kpi__value { font-size: 26px; }

	.ocmp-table { min-width: 0; }
	.ocmp-table thead { display: none; }
	.ocmp-table, .ocmp-table tbody, .ocmp-table tr, .ocmp-table td { display: block; width: 100%; }
	.ocmp-table tbody tr {
		background: #fff;
		border: 1px solid var(--ocmp-border);
		border-radius: 12px;
		margin-bottom: 12px;
		padding: 8px 4px;
	}
	.ocmp-table tbody tr:hover { background: #fff; }
	.ocmp-table tbody td {
		display: flex;
		justify-content: space-between;
		align-items: center;
		padding: 10px 14px;
		border-bottom: 1px dashed var(--ocmp-border);
		gap: 12px;
	}
	.ocmp-table tbody tr td:last-child { border-bottom: 0; }
	.ocmp-table tbody td::before {
		content: attr(data-label);
		font-size: 11px;
		font-weight: 700;
		color: var(--ocmp-muted);
		text-transform: uppercase;
		letter-spacing: .04em;
	}
	.ocmp-footer { flex-direction: column; align-items: stretch; }
	.ocmp-perpage { justify-content: space-between; }
	.ocmp-pagination { justify-content: center; }
}
