/* Custom HR Portal — frontend styles.
   Override the variables below in your theme to match brand colors. */
:root {
	--cthr-accent: #114c5f;
	--cthr-accent-light: #1e88a8;
	--cthr-accent-pale: #eaf4f7;
	--cthr-text: #0f2027;
	--cthr-muted: #5a6b72;
	--cthr-border: rgba(17, 76, 95, 0.12);
	--cthr-radius: 10px;
}

/* ---------- Filters ---------- */
.cthr-filters {
	display: grid;
	grid-template-columns: repeat(4, 1fr);
	gap: 10px;
	padding: 18px;
	background: var(--cthr-accent-pale);
	border: 1px solid var(--cthr-border);
	border-radius: var(--cthr-radius);
	margin-bottom: 28px;
}
.cthr-filters input[type="search"] { grid-column: 1 / -1; }
.cthr-filters input,
.cthr-filters select {
	padding: 10px 12px;
	border: 1px solid var(--cthr-border);
	border-radius: 6px;
	font: inherit;
	background: #fff;
	color: var(--cthr-text);
	width: 100%;
}
.cthr-filters input:focus,
.cthr-filters select:focus { outline: 2px solid var(--cthr-accent-light); outline-offset: 1px; }

/* ---------- Buttons ---------- */
.cthr-btn {
	display: inline-block;
	padding: 10px 22px;
	background: var(--cthr-accent);
	color: #fff;
	border: 1px solid var(--cthr-accent);
	border-radius: 6px;
	font-weight: 600;
	cursor: pointer;
	text-decoration: none;
	transition: background 0.2s ease;
}
.cthr-btn:hover { background: var(--cthr-accent-light); color: #fff; }
.cthr-btn-outline { background: transparent; color: var(--cthr-accent); }
.cthr-btn-outline:hover { background: var(--cthr-accent); color: #fff; }
.cthr-btn-lg { padding: 14px 34px; font-size: 1.05em; }

/* ---------- Job cards ---------- */
.cthr-results.is-loading { opacity: 0.45; pointer-events: none; }
.cthr-card {
	border: 1px solid var(--cthr-border);
	border-radius: var(--cthr-radius);
	padding: 22px 24px;
	margin-bottom: 16px;
	background: #fff;
	transition: box-shadow 0.2s ease, border-color 0.2s ease;
}
.cthr-card:hover { box-shadow: 0 6px 22px rgba(17, 76, 95, 0.1); border-color: var(--cthr-accent-light); }
.cthr-card.is-featured { border-left: 4px solid var(--cthr-accent); }
.cthr-card-head { display: flex; justify-content: space-between; align-items: flex-start; gap: 12px; flex-wrap: wrap; }
.cthr-card h3 { margin: 0 0 6px; font-size: 1.25em; }
.cthr-card h3 a { color: var(--cthr-text); text-decoration: none; }
.cthr-card h3 a:hover { color: var(--cthr-accent); }
.cthr-excerpt { color: var(--cthr-muted); margin: 10px 0 14px; }
.cthr-empty { padding: 32px; text-align: center; color: var(--cthr-muted); background: var(--cthr-accent-pale); border-radius: var(--cthr-radius); }

/* ---------- Badges & chips ---------- */
.cthr-badges { display: flex; gap: 6px; flex-wrap: wrap; }
.cthr-badge {
	font-size: 11px;
	font-weight: 700;
	letter-spacing: 0.04em;
	text-transform: uppercase;
	padding: 4px 10px;
	border-radius: 999px;
}
.cthr-badge-featured { background: var(--cthr-accent); color: #fff; }
.cthr-badge-urgent { background: #fdecea; color: #c0392b; }
.cthr-badge-remote { background: var(--cthr-accent-pale); color: var(--cthr-accent); }
.cthr-chip {
	display: inline-block;
	background: var(--cthr-accent-pale);
	color: var(--cthr-accent);
	padding: 5px 12px;
	border-radius: 999px;
	font-size: 0.85em;
	margin: 0 6px 6px 0;
}

/* ---------- Meta lists ---------- */
.cthr-meta { list-style: none; padding: 0; margin: 0 0 4px; display: flex; flex-wrap: wrap; gap: 4px 18px; color: var(--cthr-muted); font-size: 0.92em; }
.cthr-meta li::before { content: "•"; color: var(--cthr-accent-light); margin-right: 7px; }
.cthr-meta-large { font-size: 1em; margin: 0 0 16px; }
.cthr-list { padding-left: 20px; }
.cthr-list li { margin-bottom: 6px; }

/* ---------- Pagination ---------- */
.cthr-pagination { display: flex; gap: 6px; justify-content: center; margin-top: 22px; }
.cthr-page {
	min-width: 38px; padding: 8px 0;
	border: 1px solid var(--cthr-border); border-radius: 6px;
	background: #fff; cursor: pointer; font: inherit; color: var(--cthr-text);
}
.cthr-page.is-current, .cthr-page:hover { background: var(--cthr-accent); color: #fff; border-color: var(--cthr-accent); }

/* ---------- Apply form ---------- */
.cthr-apply {
	margin-top: 44px; padding: 30px;
	border: 1px solid var(--cthr-border); border-radius: var(--cthr-radius);
	background: linear-gradient(180deg, var(--cthr-accent-pale), #fff 140px);
}
.cthr-apply h2 { margin-top: 0; }
.cthr-form-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 4px 18px; }
.cthr-form-grid .cthr-full { grid-column: 1 / -1; }
.cthr-form-grid label { display: block; font-weight: 600; color: var(--cthr-text); }
.cthr-form-grid input, .cthr-form-grid textarea {
	width: 100%; margin-top: 5px;
	padding: 11px 12px;
	border: 1px solid var(--cthr-border); border-radius: 6px;
	font: inherit; background: #fff;
}
.cthr-form-grid input:focus, .cthr-form-grid textarea:focus { outline: 2px solid var(--cthr-accent-light); outline-offset: 1px; }
.cthr-hint { font-weight: 400; color: var(--cthr-muted); font-size: 0.87em; }
.cthr-consent { font-size: 0.9em; color: var(--cthr-muted); }
.cthr-hp { position: absolute !important; left: -9999px !important; height: 0; overflow: hidden; }
.cthr-form-msg { margin-top: 14px; font-weight: 600; }
.cthr-form-msg.is-error { color: #c0392b; }
.cthr-form-msg.is-success { color: #1e7e34; }
.cthr-closed-notice {
	background: #fdecea; color: #c0392b;
	padding: 14px 18px; border-radius: 8px; font-weight: 600;
}
.cthr-thankyou { text-align: center; }

/* ---------- Responsive ---------- */
@media (max-width: 768px) {
	.cthr-filters { grid-template-columns: 1fr 1fr; }
	.cthr-form-grid { grid-template-columns: 1fr; }
}
@media (max-width: 480px) {
	.cthr-filters { grid-template-columns: 1fr; }
}
@media (prefers-reduced-motion: reduce) {
	.cthr-card, .cthr-btn { transition: none; }
}
