/* ── Reset / shared ────────────────────────────────────────────────────────── */
.wp-block-wp-career-board-job-single {
	max-width: 1100px;
	margin: 0 auto;
	padding: var(--wcb-space-2xl) var(--wcb-space-lg) var(--wcb-space-4xl);
	font-family: inherit;
	color: var(--wcb-contrast, #1e293b);
}

/* ── Buttons ─────────────────────────────────────────────────────────────── */
.wcb-btn {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: 0.4rem;
	padding: 0.7rem var(--wcb-space-2xl);
	border: none;
	border-radius: var(--wcb-radius-md);
	font-size: var(--wcb-text-md);
	font-weight: var(--wcb-font-semibold);
	font-family: inherit;
	cursor: pointer;
	text-decoration: none;
	transition: background 0.15s, opacity 0.15s;
	white-space: nowrap;
}
.wcb-btn--primary {
	background: var(--wcb-primary, #2563eb);
	color: var(--wcb-base, #fff);
}
.wcb-btn--primary:hover {
	background: var(--wcb-primary-dark, #1d4ed8);
	color: var(--wcb-base, #fff);
	text-decoration: none;
}
.wcb-btn--primary:disabled {
	opacity: 0.6;
	cursor: not-allowed;
}
.wcb-btn--full {
	width: 100%;
}

/* ── Badges ──────────────────────────────────────────────────────────────── */
.wcb-badge {
	display: inline-flex;
	align-items: center;
	padding: 0.2rem 0.65rem;
	border-radius: var(--wcb-radius-full);
	font-size: var(--wcb-text-sm);
	font-weight: var(--wcb-font-medium);
	line-height: 1.4;
	text-decoration: none;
	color: inherit;
}
.wcb-badge--featured  { background: var(--wcb-warning-bg); color: #92400e; }
.wcb-badge--remote    { background: var(--wcb-success-bg); color: var(--wcb-success); }
.wcb-badge--type      { background: var(--wcb-surface, #f1f5f9); color: var(--wcb-text-secondary); }
.wcb-badge--exp       { background: var(--wcb-surface, #f1f5f9); color: var(--wcb-text-secondary); }
.wcb-badge--salary    { background: var(--wcb-surface, #f1f5f9); color: var(--wcb-text-secondary); font-weight: var(--wcb-font-semibold); }
.wcb-badge--location  { background: var(--wcb-surface, #f1f5f9); color: var(--wcb-text-secondary); }
.wcb-badge--posted    { background: transparent; color: var(--wcb-text-tertiary); font-size: 0.8rem; padding: 0; }
.wcb-badge--sm { font-size: var(--wcb-text-xs); padding: 0.1rem 0.5rem; }

a.wcb-badge:hover { opacity: 0.8; }

.wcb-verified-badge {
	font-size: var(--wcb-text-xs);
	color: #0f766e;
	font-weight: var(--wcb-font-semibold);
	background: #ccfbf1;
	padding: 0.1rem 0.45rem;
	border-radius: var(--wcb-space-xs);
	margin-inline-start: 0.4rem;
}

/* ── Hero banner ─────────────────────────────────────────────────────────── */
.wcb-job-hero {
	display: grid;
	grid-template-columns: 1fr auto;
	grid-template-rows: auto auto;
	gap: var(--wcb-space-lg) var(--wcb-space-3xl);
	align-items: start;
	padding: var(--wcb-space-3xl);
	background: var(--wcb-base, #fff);
	border: 1px solid var(--wcb-border, #e2e8f0);
	border-radius: var(--wcb-radius-xl);
	margin-bottom: 1.75rem;
}

.wcb-job-hero-brand {
	grid-column: 1;
	grid-row: 1;
	display: flex;
	align-items: flex-start;
	gap: var(--wcb-space-lg);
	min-width: 0;
}

.wcb-company-avatar {
	width: 64px;
	height: 64px;
	flex-shrink: 0;
	background: var(--wcb-avatar-bg, #1e293b);
	color: var(--wcb-base, #fff);
	border-radius: var(--wcb-radius-xl);
	display: flex;
	align-items: center;
	justify-content: center;
	font-size: var(--wcb-text-xl);
	font-weight: var(--wcb-font-bold);
	letter-spacing: 0.02em;
}

.wcb-company-avatar--sm {
	width: 44px;
	height: 44px;
	border-radius: var(--wcb-radius-md);
	font-size: var(--wcb-text-base);
}

.wcb-hero-titles {
	flex: 1;
	min-width: 0;
}

.wcb-job-title {
	font-size: 1.625rem;
	font-weight: var(--wcb-font-bold);
	line-height: 1.25;
	margin: 0 0 0.3rem;
	color: var(--wcb-contrast, #0f172a);
}

.wcb-hero-company {
	font-size: 1rem;
	font-weight: var(--wcb-font-medium);
	color: var(--wcb-text-secondary);
	margin: 0;
}

.wcb-hero-company-link {
	color: var(--wcb-text-secondary);
	text-decoration: none;
	font-weight: var(--wcb-font-medium);
}

.wcb-hero-company-link:hover {
	color: var(--wcb-primary, #2563eb);
	text-decoration: underline;
}

.wcb-job-hero-meta {
	grid-column: 1;
	grid-row: 2;
	display: flex;
	flex-wrap: wrap;
	gap: var(--wcb-space-xs);
	align-items: center;
	min-width: 0;
}

.wcb-hero-cta {
	grid-column: 2;
	grid-row: 1 / 3;
	display: flex;
	flex-direction: column;
	align-items: flex-end;
	gap: 0.6rem;
	padding-top: 0.25rem;
}

.wcb-hero-cta .wcb-btn {
	min-width: 9rem;
}

.wcb-deadline-note {
	font-size: var(--wcb-text-sm);
	color: var(--wcb-text-tertiary);
	margin: 0;
	text-align: end;
}

/* ── Hero bookmark button ─────────────────────────────────────────────────── */
.wcb-bookmark-hero-btn {
	display: inline-flex;
	align-items: center;
	gap: 0.4rem;
	padding: 0.55rem var(--wcb-space-lg);
	border: 1.5px solid var(--wcb-border, #e2e8f0);
	border-radius: var(--wcb-radius-md);
	background: var(--wcb-base, #fff);
	color: var(--wcb-text-secondary);
	font-size: var(--wcb-text-base);
	font-weight: var(--wcb-font-medium);
	font-family: inherit;
	cursor: pointer;
	transition: border-color 0.15s, color 0.15s, background 0.15s;
	white-space: nowrap;
}

.wcb-bookmark-hero-btn:hover {
	border-color: var(--wcb-primary, #2563eb);
	color: var(--wcb-primary, #2563eb);
	background: #eff6ff;
}

.wcb-bookmark-hero-btn.wcb-bookmarked {
	border-color: var(--wcb-primary, #2563eb);
	color: var(--wcb-primary, #2563eb);
	background: var(--wcb-bg-subtle);
}

.wcb-bookmark-hero-btn:disabled {
	opacity: 0.7;
	cursor: not-allowed;
}

.wcb-applied-badge {
	display: none;
	font-size: var(--wcb-text-md);
	font-weight: var(--wcb-font-semibold);
	color: var(--wcb-success);
	background: #f0fdf4;
	border: 1px solid #bbf7d0;
	border-radius: var(--wcb-radius-md);
	padding: var(--wcb-space-sm) var(--wcb-space-lg);
	margin: 0;
	text-align: center;
}

.wcb-applied-badge.wcb-shown {
	display: block;
}

.wcb-applied-badge--center {
	text-align: center;
}

/* ── Two-column body ─────────────────────────────────────────────────────── */
.wcb-job-body {
	display: grid;
	grid-template-columns: 1fr 320px;
	gap: var(--wcb-space-2xl);
	align-items: start;
}

/* ── Main content ────────────────────────────────────────────────────────── */
.wcb-job-main {
	min-width: 0;
}

.wcb-section {
	background: var(--wcb-base, #fff);
	border: 1px solid var(--wcb-border, #e2e8f0);
	border-radius: var(--wcb-radius-xl);
	padding: 1.75rem;
	margin-bottom: var(--wcb-space-xl);
}

.wcb-section-heading {
	font-size: var(--wcb-text-lg);
	font-weight: var(--wcb-font-bold);
	color: var(--wcb-contrast, #0f172a);
	margin: 0 0 var(--wcb-space-xl);
	padding-bottom: var(--wcb-space-md);
	border-bottom: 1px solid var(--wcb-surface, #f1f5f9);
}

.wcb-section-heading-sm {
	font-size: var(--wcb-text-md);
	font-weight: var(--wcb-font-semibold);
	color: var(--wcb-contrast, #334155);
	margin: 0 0 var(--wcb-space-md);
}

.wcb-job-description {
	font-size: var(--wcb-text-md);
	line-height: 1.75;
	color: var(--wcb-contrast, #334155);
}

.wcb-job-description ul,
.wcb-job-description ol {
	padding-inline-start: var(--wcb-space-2xl);
	margin: var(--wcb-space-md) 0;
}

.wcb-job-description li {
	margin-bottom: 0.35rem;
}

.wcb-job-description strong {
	color: var(--wcb-contrast, #0f172a);
}

.wcb-tag-row {
	display: flex;
	flex-wrap: wrap;
	gap: var(--wcb-space-sm);
}

.wcb-tag {
	display: inline-block;
	padding: 0.25rem var(--wcb-space-md);
	background: var(--wcb-bg-subtle);
	border: 1px solid var(--wcb-border, #e2e8f0);
	border-radius: var(--wcb-radius-full);
	font-size: var(--wcb-text-sm);
	color: var(--wcb-text-secondary);
	text-decoration: none;
}

a.wcb-tag:hover {
	background: var(--wcb-surface, #f1f5f9);
	border-color: #cbd5e1;
}

/* ── Sidebar ─────────────────────────────────────────────────────────────── */
.wcb-job-sidebar {
	position: sticky;
	top: var(--wcb-space-3xl);
	display: flex;
	flex-direction: column;
	gap: var(--wcb-space-xl);
}

.wcb-sidebar-card {
	background: var(--wcb-base, #fff);
	border: 1px solid var(--wcb-border, #e2e8f0);
	border-radius: var(--wcb-radius-xl);
	padding: var(--wcb-space-2xl);
}

.wcb-card-title {
	font-size: var(--wcb-text-md);
	font-weight: var(--wcb-font-bold);
	color: var(--wcb-contrast, #0f172a);
	margin: 0 0 var(--wcb-space-lg);
	padding-bottom: 0.6rem;
	border-bottom: 1px solid var(--wcb-surface, #f1f5f9);
}

.wcb-detail-list {
	margin: 0 0 var(--wcb-space-xl);
	display: flex;
	flex-direction: column;
	gap: var(--wcb-space-md);
}

.wcb-detail-row {
	display: flex;
	justify-content: space-between;
	align-items: baseline;
	gap: var(--wcb-space-sm);
	font-size: var(--wcb-text-base);
}

.wcb-detail-row dt {
	color: var(--wcb-text-secondary);
	font-weight: var(--wcb-font-medium);
	flex-shrink: 0;
}

.wcb-detail-row dd {
	color: var(--wcb-contrast, #1e293b);
	font-weight: var(--wcb-font-medium);
	text-align: end;
	margin: 0;
}

.wcb-salary-highlight {
	color: var(--wcb-primary, #2563eb);
	font-weight: var(--wcb-font-bold) !important;
}

/* ── Company card ────────────────────────────────────────────────────────── */
.wcb-company-card-header {
	display: flex;
	align-items: center;
	gap: var(--wcb-space-md);
	margin-bottom: var(--wcb-space-md);
}

.wcb-company-card-name {
	font-size: var(--wcb-text-md);
	font-weight: var(--wcb-font-bold);
	color: var(--wcb-contrast, #0f172a);
	margin: 0;
	text-decoration: none;
	display: block;
}

a.wcb-company-card-name:hover {
	color: var(--wcb-primary, #2563eb);
	text-decoration: underline;
}

.wcb-company-bio {
	font-size: var(--wcb-text-base);
	line-height: 1.6;
	color: var(--wcb-text-secondary);
	margin: 0 0 var(--wcb-space-md);
}

.wcb-company-link {
	display: inline-flex;
	align-items: center;
	gap: 0.25rem;
	font-size: var(--wcb-text-base);
	color: var(--wcb-primary, #2563eb);
	text-decoration: none;
	font-weight: var(--wcb-font-medium);
}

.wcb-company-link:hover {
	text-decoration: underline;
}

/* ── Interactivity API — class-based visibility ──────────────────────────── */
.wcb-hidden { display: none !important; }

.wcb-panel-overlay,
.wcb-apply-panel {
	display: none;
}

.wcb-panel-overlay.wcb-open,
.wcb-apply-panel.wcb-open {
	display: block;
}

.wcb-apply-error {
	display: none;
	background: #fef2f2;
	border: 1px solid #fecaca;
	color: #b91c1c;
	padding: 0.65rem var(--wcb-space-lg);
	border-radius: var(--wcb-radius-md);
	font-size: var(--wcb-text-base);
	margin-bottom: var(--wcb-space-lg);
}

.wcb-apply-error.wcb-shown { display: block; }

.wcb-submitting-label {
	display: none;
}

.wcb-submitting-label.wcb-shown {
	display: inline;
}

/* ── Apply panel ─────────────────────────────────────────────────────────── */
.wcb-panel-overlay {
	position: fixed;
	inset: 0;
	background: rgba(15, 23, 42, 0.45);
	z-index: 9998;
	backdrop-filter: blur(2px);
}

.wcb-apply-panel {
	position: fixed;
	top: 0;
	right: 0;
	bottom: 0;
	width: min(520px, 100%);
	background: var(--wcb-base, #fff);
	z-index: 9999;
	overflow-y: auto;
	box-shadow: -8px 0 32px rgba(0, 0, 0, 0.12);
}

.wcb-apply-panel.wcb-open {
	animation: wcb-slide-in 0.25s ease-out;
}

@keyframes wcb-slide-in {
	from { transform: translateX(100%); }
	to   { transform: translateX(0); }
}

@media (prefers-reduced-motion: reduce) {
	.wcb-apply-panel { animation: none !important; transition: none !important; }
}

.wcb-panel-body {
	padding: 2.5rem var(--wcb-space-3xl);
}

.wcb-panel-close {
	position: absolute;
	top: var(--wcb-space-xl);
	right: var(--wcb-space-xl);
	background: var(--wcb-surface, #f1f5f9);
	border: none;
	width: var(--wcb-space-3xl);
	height: var(--wcb-space-3xl);
	border-radius: 50%;
	font-size: var(--wcb-text-xl);
	line-height: 1;
	padding: 0;
	cursor: pointer;
	color: var(--wcb-text-secondary);
	display: flex;
	align-items: center;
	justify-content: center;
}

.wcb-panel-close:hover {
	background: var(--wcb-border, #e2e8f0);
	color: var(--wcb-text-secondary);
}

.wcb-panel-title {
	font-size: 1.375rem;
	font-weight: var(--wcb-font-bold);
	color: var(--wcb-contrast, #0f172a);
	margin: 0 0 0.25rem;
}

.wcb-panel-subtitle {
	font-size: 1rem;
	color: var(--wcb-contrast, #334155);
	font-weight: var(--wcb-font-semibold);
	margin: 0 0 0.15rem;
}

.wcb-panel-company {
	font-size: var(--wcb-text-base);
	color: var(--wcb-text-secondary);
	margin: 0 0 var(--wcb-space-2xl);
}

.wcb-field-label {
	display: block;
	font-size: var(--wcb-text-base);
	font-weight: var(--wcb-font-semibold);
	color: #374151;
	margin-bottom: 0.4rem;
}

.wcb-field-hint {
	font-weight: var(--wcb-font-normal);
	color: var(--wcb-text-tertiary);
}

.wcb-cover-letter {
	width: 100%;
	padding: var(--wcb-space-md) var(--wcb-space-lg);
	border: 1.5px solid var(--wcb-border, #e2e8f0);
	border-radius: var(--wcb-radius-md);
	font-size: var(--wcb-text-md);
	font-family: inherit;
	line-height: 1.6;
	resize: vertical;
	color: var(--wcb-contrast, #1e293b);
	margin-bottom: var(--wcb-space-lg);
	transition: border-color 0.15s;
	box-sizing: border-box;
}

.wcb-cover-letter:focus {
	outline: none;
	border-color: var(--wcb-primary, #2563eb);
	box-shadow: var(--wcb-shadow-focus);
}

/* ── Apply panel — resume section ────────────────────────────────────────── */
.wcb-apply-resume-section {
	margin-block-end: var(--wcb-space-xl);
}

.wcb-apply-resume-select {
	display: block;
	width: 100%;
	padding: var(--wcb-space-sm) var(--wcb-space-md);
	border: 1px solid #d1d5db;
	border-radius: var(--wcb-radius-sm);
	font-size: var(--wcb-text-md);
	font-family: inherit;
	background: var(--wcb-base, #fff);
}

.wcb-apply-resume-select:focus {
	outline: 2px solid var(--wcb-primary, #2563eb);
	outline-offset: 2px;
}

.wcb-apply-resume-file {
	position: absolute;
	inset: 0;
	width: 100%;
	height: 100%;
	opacity: 0;
	cursor: pointer;
}

.wcb-upload-zone {
	display: flex;
	flex-direction: column;
	align-items: center;
	gap: 0.25rem;
	padding: var(--wcb-space-xl) var(--wcb-space-lg);
	border: 2px dashed #d1d5db;
	border-radius: var(--wcb-radius-md);
	text-align: center;
	cursor: pointer;
	position: relative;
	transition: border-color 0.15s, background 0.15s;
}

.wcb-upload-zone:hover {
	border-color: var(--wcb-primary, #2563eb);
	background: #eff6ff;
}

.wcb-upload-zone.wcb-has-file {
	border-color: #22c55e;
	background: #f0fdf4;
}

.wcb-upload-icon {
	font-size: var(--wcb-text-2xl);
	line-height: 1;
	color: var(--wcb-text-tertiary);
}

.wcb-upload-zone:hover .wcb-upload-icon {
	color: var(--wcb-primary, #2563eb);
}

.wcb-upload-zone.wcb-has-file .wcb-upload-icon {
	color: #22c55e;
}

.wcb-upload-text {
	font-size: var(--wcb-text-base);
	font-weight: var(--wcb-font-medium);
	color: #374151;
}

.wcb-upload-hint {
	font-size: var(--wcb-text-xs);
	color: var(--wcb-text-tertiary);
}

.wcb-upload-filename {
	font-size: var(--wcb-text-sm);
	font-weight: var(--wcb-font-semibold);
	color: #22c55e;
}

.wcb-upload-filename:empty {
	display: none;
}

/* ── Post-apply alert prompt ───────────────────────────────────────────── */
.wcb-post-apply-alert {
	margin-top: var(--wcb-space-sm);
}

.wcb-post-apply-alert.wcb-shown {
	display: block !important;
}

.wcb-post-apply-alert-done.wcb-shown {
	display: inline !important;
}

.wcb-post-apply-alert-btn {
	display: inline-flex;
	align-items: center;
	gap: 0.375rem;
	padding: 0.375rem var(--wcb-space-md);
	font-size: var(--wcb-text-sm);
	font-weight: var(--wcb-font-medium);
	font-family: inherit;
	color: var(--wcb-primary, #2563eb);
	background: #eff6ff;
	border: 1px solid var(--wcb-primary, #2563eb);
	border-radius: var(--wcb-radius-sm);
	cursor: pointer;
	transition: border-color 0.15s, color 0.15s, background-color 0.15s;
}

.wcb-post-apply-alert-btn:hover {
	background: var(--wcb-primary, #2563eb);
	color: var(--wcb-base, #fff);
}

.wcb-post-apply-alert-btn:disabled {
	opacity: 0.6;
	cursor: wait;
}

.wcb-post-apply-alert-done {
	font-size: var(--wcb-text-sm);
	color: #22c55e;
	font-weight: var(--wcb-font-medium);
}

.wcb-apply-no-resume {
	font-size: var(--wcb-text-base);
	color: var(--wcb-text-secondary);
	margin: 0;
}

.wcb-apply-no-resume a {
	color: var(--wcb-primary, #2563eb);
}

.wcb-apply-or-divider {
	text-align: center;
	font-size: var(--wcb-text-sm);
	color: var(--wcb-text-tertiary);
	margin: var(--wcb-space-lg) 0 var(--wcb-space-md);
}

/* ── Responsive ──────────────────────────────────────────────────────────── */
@media (max-width: 768px) {
	.wcb-job-hero {
		grid-template-columns: 1fr;
		grid-template-rows: auto auto auto;
	}

	.wcb-hero-cta {
		grid-column: 1;
		grid-row: 3;
		align-items: flex-start;
	}

	.wcb-hero-cta .wcb-btn {
		width: 100%;
	}

	.wcb-job-body {
		grid-template-columns: 1fr;
	}

	.wcb-job-sidebar {
		position: static;
	}

	.wcb-job-sidebar {
		order: -1;
	}
}

/* ── Share bar ──────────────────────────────────────────────────────────────── */
.wcb-share-bar {
	display: flex;
	align-items: center;
	gap: var(--wcb-space-xs);
	margin-top: var(--wcb-space-lg);
	padding-top: var(--wcb-space-lg);
	border-top: 1px solid var(--wcb-surface, #f1f5f9);
}

.wcb-share-label {
	font-size: 0.78rem;
	font-weight: var(--wcb-font-semibold);
	color: var(--wcb-text-tertiary);
	text-transform: uppercase;
	letter-spacing: 0.05em;
	margin-inline-end: 0.15rem;
}

.wcb-share-btn {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 30px;
	height: 30px;
	border-radius: var(--wcb-radius-sm);
	border: 1.5px solid var(--wcb-border, #e2e8f0);
	background: var(--wcb-base, #fff);
	color: var(--wcb-text-secondary);
	text-decoration: none;
	cursor: pointer;
	transition: border-color 0.12s, color 0.12s;
	padding: 0;
}

.wcb-share-btn:hover {
	border-color: var(--wcb-text-tertiary);
	color: var(--wcb-contrast, #0f172a);
}

/* ── Theme-agnostic sidebar + title suppression ─────────────────────────────── */
.wcb-job-page #secondary,
.wcb-job-page .widget-area,
.wcb-job-page aside.sidebar,
.wcb-job-page .sidebar-area,
.wcb-job-page .site-sidebar,
.wcb-job-page #sidebar { display: none !important; }

.wcb-job-page .entry-title,
.wcb-job-page .page-title,
.wcb-job-page h1.post-title,
.wcb-job-page .post-title,
.wcb-job-page .wp-block-post-title { display: none !important; }

/* ── Honeypot anti-spam ──────────────────────────────────────────────────── */
.wcb-hp-wrap {
	position: absolute;
	left: -9999px;
	overflow: hidden;
	width: 1px;
	height: 1px;
}
