/**
 * Careers Page — Monolith Aesthetic
 * Scoped to .page-template-careers / .page-template-careers-ja body class
 */

/* ═══════════════════════════════════════════════════════════════════════════
 * CSS Custom Properties (Design Tokens)
 * ═══════════════════════════════════════════════════════════════════════════ */
.exa-careers {
	--careers-bg: #131313;
	--careers-bg-alt: #1f1f1f;
	--careers-bg-card: #1b1b1b;
	--careers-bg-card-hover: #2a2a2a;
	--careers-fg: #e2e2e2;
	--careers-fg-soft: rgba(226, 226, 226, 0.78);
	--careers-fg-mute: rgba(226, 226, 226, 0.55);
	--careers-fg-faint: rgba(226, 226, 226, 0.40);
	--careers-line: rgba(255, 255, 255, 0.10);
	--careers-line-strong: rgba(255, 255, 255, 0.22);
	--careers-accent: #e60000;
	--careers-accent-hover: #b30000;
	--careers-accent-soft: rgba(230, 0, 0, 0.15);
	--careers-radius: 0.25rem;
	--careers-radius-lg: 0.5rem;
	--careers-radius-xl: 0.75rem;
	--careers-easing: cubic-bezier(0.4, 0, 0.2, 1);
	--careers-container: 1200px;
	--careers-container-narrow: 800px;
	--careers-section-py: 96px;
	--careers-section-py-sm: 56px;
	--careers-font: 'Montserrat', sans-serif;
	--careers-hero-overlay: 0.55;
	--careers-talent-overlay: 0.55;
}

/* ═══════════════════════════════════════════════════════════════════════════
 * Base / Reset
 * ═══════════════════════════════════════════════════════════════════════════ */
.exa-careers {
	background: var(--careers-bg);
	color: var(--careers-fg);
	font-family: var(--careers-font);
	line-height: 1.6;
	-webkit-font-smoothing: antialiased;
	-moz-osx-font-smoothing: grayscale;
}

.exa-careers *,
.exa-careers *::before,
.exa-careers *::after {
	box-sizing: border-box;
}

.exa-careers__container {
	max-width: var(--careers-container);
	margin: 0 auto;
	padding: 0 24px;
}

.exa-careers__container--narrow {
	max-width: var(--careers-container-narrow);
}

/* ═══════════════════════════════════════════════════════════════════════════
 * Typography
 * ═══════════════════════════════════════════════════════════════════════════ */
.exa-careers__section-subtitle {
	font-size: 0.75rem;
	font-weight: 600;
	letter-spacing: 0.15em;
	text-transform: uppercase;
	color: var(--careers-accent);
	margin-bottom: 0.75rem;
}

.exa-careers__section-title {
	font-size: clamp(1.75rem, 4vw, 2.5rem);
	font-weight: 700;
	line-height: 1.2;
	color: var(--careers-fg);
	margin: 0 0 1rem;
}

.exa-careers__section-desc {
	font-size: 1rem;
	color: var(--careers-fg-soft);
	max-width: 640px;
	margin: 0 auto;
}

.exa-careers__rich p {
	margin: 0 0 1em;
	color: var(--careers-fg-soft);
	line-height: 1.8;
}

.exa-careers__rich p:last-child {
	margin-bottom: 0;
}

.exa-careers__word--red {
	color: var(--careers-accent);
}

/* ═══════════════════════════════════════════════════════════════════════════
 * Hero Section
 * ═══════════════════════════════════════════════════════════════════════════ */
.exa-careers__hero {
	position: relative;
	min-height: 40vh;
	display: flex;
	align-items: center;
	justify-content: center;
	text-align: center;
	overflow: hidden;
}

.exa-careers__hero-bg {
	position: absolute;
	inset: 0;
	z-index: 0;
}

.exa-careers__hero-bg img {
	width: 100%;
	height: 100%;
	object-fit: cover;
}

.exa-careers__hero-overlay {
	position: absolute;
	inset: 0;
	background: linear-gradient(
		to bottom,
		rgba(19, 19, 19, calc(var(--careers-hero-overlay) * 0.6)) 0%,
		rgba(19, 19, 19, var(--careers-hero-overlay)) 50%,
		rgba(19, 19, 19, 1) 100%
	);
	z-index: 1;
}

.exa-careers__hero-content {
	position: relative;
	z-index: 2;
	padding: 120px 24px 80px;
	max-width: 800px;
}

.exa-careers__hero-subtitle {
	font-size: 0.875rem;
	font-weight: 600;
	letter-spacing: 0.2em;
	text-transform: uppercase;
	color: var(--careers-accent);
	margin-bottom: 1rem;
}

.exa-careers__hero-title {
	font-size: clamp(2.5rem, 6vw, 4rem);
	font-weight: 800;
	line-height: 1.1;
	color: #fff;
	margin: 0 0 1.5rem;
}

.exa-careers__hero-title .exa-careers__word--red {
	color: var(--careers-accent);
}

.exa-careers__hero-desc {
	font-size: 1.125rem;
	color: var(--careers-fg-soft);
	line-height: 1.7;
	margin: 0 0 2rem;
}

.exa-careers__hero-cta {
	display: inline-flex;
	flex-direction: row;
	align-items: center;
	gap: 8px;
	padding: 12px 28px;
	background: var(--careers-accent);
	border: none;
	border-radius: var(--careers-radius);
	color: #fff;
	font-family: var(--careers-font);
	font-size: 0.9375rem;
	font-weight: 600;
	text-decoration: none;
	transition: background 0.2s var(--careers-easing),
	            transform 0.2s var(--careers-easing);
	cursor: pointer;
}

.exa-careers__hero-cta:hover {
	background: var(--careers-accent-hover);
	transform: translateY(-2px);
}

.exa-careers__hero-cta .material-symbols-outlined {
	font-size: 20px;
	animation: careers-bounce 2s infinite;
}

@keyframes careers-bounce {
	0%, 20%, 50%, 80%, 100% { transform: translateY(0); }
	40% { transform: translateY(4px); }
	60% { transform: translateY(2px); }
}

/* ═══════════════════════════════════════════════════════════════════════════
 * Philosophy Section
 * ═══════════════════════════════════════════════════════════════════════════ */
.exa-careers__philosophy {
	padding: var(--careers-section-py) 0;
	text-align: center;
}

.exa-careers__philosophy-content {
	max-width: 720px;
	margin: 0 auto;
}

/* ═══════════════════════════════════════════════════════════════════════════
 * Values Section (Card Grid)
 * ═══════════════════════════════════════════════════════════════════════════ */
.exa-careers__values {
	padding: var(--careers-section-py) 0;
	background: var(--careers-bg-alt);
}

.exa-careers__values-header {
	text-align: center;
	margin-bottom: 48px;
}

.exa-careers__values-grid {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
	gap: 24px;
}

.exa-careers__value-card {
	background: var(--careers-bg-card);
	border: 1px solid var(--careers-line);
	border-radius: var(--careers-radius-lg);
	padding: 32px 24px;
	transition: border-color 0.25s var(--careers-easing),
	            transform 0.25s var(--careers-easing);
}

.exa-careers__value-card:hover {
	border-color: var(--careers-accent);
	transform: translateY(-4px);
}

.exa-careers__value-icon {
	width: 48px;
	height: 48px;
	display: flex;
	align-items: center;
	justify-content: center;
	background: var(--careers-accent-soft);
	border-radius: var(--careers-radius);
	margin-bottom: 16px;
}

.exa-careers__value-icon .material-symbols-outlined {
	font-size: 24px;
	color: var(--careers-accent);
}

.exa-careers__value-title {
	font-size: 1.125rem;
	font-weight: 600;
	color: var(--careers-fg);
	margin: 0 0 8px;
}

.exa-careers__value-desc {
	font-size: 0.9375rem;
	color: var(--careers-fg-mute);
	margin: 0;
	line-height: 1.6;
}

/* ═══════════════════════════════════════════════════════════════════════════
 * Benefits Section
 * ═══════════════════════════════════════════════════════════════════════════ */
.exa-careers__benefits {
	padding: var(--careers-section-py) 0;
}

.exa-careers__benefits-header {
	text-align: center;
	margin-bottom: 48px;
}

.exa-careers__benefits-grid {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
	gap: 32px;
}

.exa-careers__benefit-item {
	display: flex;
	gap: 16px;
	align-items: flex-start;
}

.exa-careers__benefit-icon {
	flex-shrink: 0;
	width: 40px;
	height: 40px;
	display: flex;
	align-items: center;
	justify-content: center;
	background: var(--careers-accent);
	border-radius: var(--careers-radius);
}

.exa-careers__benefit-icon .material-symbols-outlined {
	font-size: 20px;
	color: #fff;
}

.exa-careers__benefit-content {
	flex: 1;
}

.exa-careers__benefit-title {
	font-size: 1rem;
	font-weight: 600;
	color: var(--careers-fg);
	margin: 0 0 4px;
}

.exa-careers__benefit-desc {
	font-size: 0.875rem;
	color: var(--careers-fg-mute);
	margin: 0;
	line-height: 1.5;
}

/* ═══════════════════════════════════════════════════════════════════════════
 * Talent Community Section (Hero Banner)
 * ═══════════════════════════════════════════════════════════════════════════ */
.exa-careers__talent {
	position: relative;
	min-height: 50vh;
	display: flex;
	align-items: center;
	justify-content: center;
	text-align: center;
	overflow: hidden;
}

.exa-careers__talent-bg {
	position: absolute;
	inset: 0;
	z-index: 0;
}

.exa-careers__talent-bg img {
	width: 100%;
	height: 100%;
	object-fit: cover;
}

.exa-careers__talent-overlay {
	position: absolute;
	inset: 0;
	background: linear-gradient(
		to bottom,
		rgba(19, 19, 19, calc(var(--careers-talent-overlay) * 0.5)) 0%,
		rgba(19, 19, 19, var(--careers-talent-overlay)) 100%
	);
	z-index: 1;
}

.exa-careers__talent-content {
	position: relative;
	z-index: 2;
	padding: 80px 24px;
	max-width: 700px;
}

.exa-careers__talent-subtitle {
	font-size: 0.75rem;
	font-weight: 600;
	letter-spacing: 0.2em;
	text-transform: uppercase;
	color: var(--careers-accent);
	margin-bottom: 0.75rem;
}

.exa-careers__talent-title {
	font-size: clamp(2rem, 5vw, 3rem);
	font-weight: 700;
	line-height: 1.15;
	color: #fff;
	margin: 0 0 1.5rem;
}

.exa-careers__talent-title .exa-careers__word--red {
	color: var(--careers-accent);
}

.exa-careers__talent-cta {
	display: inline-flex;
	align-items: center;
	gap: 8px;
	padding: 12px 28px;
	background: var(--careers-accent);
	border: none;
	border-radius: var(--careers-radius);
	color: #fff;
	font-family: var(--careers-font);
	font-size: 0.9375rem;
	font-weight: 600;
	text-decoration: none;
	transition: background 0.2s var(--careers-easing),
	            transform 0.2s var(--careers-easing);
	cursor: pointer;
}

.exa-careers__talent-cta:hover {
	background: var(--careers-accent-hover);
	transform: translateY(-2px);
}

.exa-careers__talent-cta .material-symbols-outlined {
	font-size: 18px;
}

/* ═══════════════════════════════════════════════════════════════════════════
 * Job Openings Section
 * ═══════════════════════════════════════════════════════════════════════════ */
.exa-careers__openings {
	padding: var(--careers-section-py) 0;
	background: var(--careers-bg-alt);
}

.exa-careers__openings-header {
	text-align: center;
	margin-bottom: 48px;
}

.exa-careers__jobs-list {
	display: flex;
	flex-direction: column;
	gap: 16px;
	max-width: 900px;
	margin: 0 auto;
}

.exa-careers__job-card {
	background: var(--careers-bg-card);
	border: 1px solid var(--careers-line);
	border-radius: var(--careers-radius-lg);
	padding: 24px;
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	gap: 16px;
	transition: border-color 0.25s var(--careers-easing),
	            background 0.25s var(--careers-easing);
}

.exa-careers__job-card:hover {
	border-color: var(--careers-line-strong);
	background: var(--careers-bg-card-hover);
}

.exa-careers__job-info {
	flex: 1;
	min-width: 200px;
}

.exa-careers__job-types {
	display: flex;
	flex-wrap: wrap;
	gap: 6px;
	margin-bottom: 8px;
}

.exa-careers__job-type {
	display: inline-block;
	padding: 3px 10px;
	background: rgba(255, 255, 255, 0.12);
	border-radius: 9999px;
	font-size: 0.5625rem;
	font-weight: 700;
	letter-spacing: 0.04em;
	text-transform: uppercase;
	color: #fff;
}

.exa-careers__job-title {
	font-size: 1.375rem;
	font-weight: 600;
	color: var(--careers-fg);
	margin: 0 0 10px;
}

.exa-careers__job-meta {
	display: flex;
	flex-wrap: wrap;
	gap: 16px;
	font-size: 0.875rem;
	color: var(--careers-fg-mute);
}

.exa-careers__job-meta-item {
	display: flex;
	align-items: center;
	gap: 4px;
}

.exa-careers__job-meta-item .material-symbols-outlined {
	font-size: 16px;
	color: var(--careers-fg-faint);
}

.exa-careers__job-desc {
	width: 100%;
	font-size: 0.9375rem;
	color: var(--careers-fg-soft);
	margin: 8px 0 0;
	line-height: 1.5;
}

.exa-careers__job-apply {
	flex-shrink: 0;
}

.exa-careers__job-btn {
	display: inline-flex;
	align-items: center;
	gap: 8px;
	padding: 10px 20px;
	background: var(--careers-accent);
	border: none;
	border-radius: var(--careers-radius);
	color: #fff;
	font-family: var(--careers-font);
	font-size: 0.875rem;
	font-weight: 600;
	text-decoration: none;
	transition: transform 0.2s var(--careers-easing),
	            box-shadow 0.2s var(--careers-easing);
	cursor: pointer;
}

.exa-careers__job-btn:hover {
	transform: translateY(-2px);
	box-shadow: 0 4px 12px rgba(255, 0, 0, 0.35);
}

.exa-careers__job-btn .material-symbols-outlined {
	font-size: 18px;
}

/* No openings state */
.exa-careers__no-openings {
	text-align: center;
	padding: 48px 24px;
	color: var(--careers-fg-mute);
}

/* ═══════════════════════════════════════════════════════════════════════════
 * CTA Section
 * ═══════════════════════════════════════════════════════════════════════════ */
.exa-careers__cta {
	padding: var(--careers-section-py) 0;
	text-align: center;
	border-top: 1px solid var(--careers-line);
}

.exa-careers__cta-content {
	max-width: 600px;
	margin: 0 auto;
}

.exa-careers__cta-title {
	font-size: clamp(1.5rem, 4vw, 2rem);
	font-weight: 700;
	color: var(--careers-fg);
	margin: 0 0 1rem;
}

.exa-careers__cta-desc {
	font-size: 1rem;
	color: var(--careers-fg-soft);
	margin: 0 0 2rem;
}

.exa-careers__cta-btn {
	display: inline-flex;
	align-items: center;
	gap: 8px;
	padding: 14px 32px;
	background: var(--careers-accent);
	border: none;
	border-radius: var(--careers-radius);
	color: #fff;
	font-family: var(--careers-font);
	font-size: 1rem;
	font-weight: 600;
	text-decoration: none;
	transition: background 0.2s var(--careers-easing),
	            transform 0.2s var(--careers-easing);
	cursor: pointer;
}

.exa-careers__cta-btn:hover {
	background: var(--careers-accent-hover);
	transform: translateY(-2px);
}

.exa-careers__cta-btn .material-symbols-outlined {
	font-size: 20px;
}

/* ═══════════════════════════════════════════════════════════════════════════
 * Responsive: Tablet
 * ═══════════════════════════════════════════════════════════════════════════ */
@media (max-width: 1024px) {
	.exa-careers {
		--careers-section-py: 72px;
	}

	.exa-careers__values-grid {
		grid-template-columns: repeat(2, 1fr);
	}

	.exa-careers__benefits-grid {
		grid-template-columns: repeat(2, 1fr);
	}

	.exa-careers__talent {
		min-height: 45vh;
	}
}

/* ═══════════════════════════════════════════════════════════════════════════
 * Responsive: Mobile
 * ═══════════════════════════════════════════════════════════════════════════ */
@media (max-width: 640px) {
	.exa-careers {
		--careers-section-py: 56px;
	}

	.exa-careers__container {
		padding: 0 16px;
	}

	.exa-careers__hero {
		min-height: 35vh;
	}

	.exa-careers__hero-content {
		padding: 100px 16px 60px;
	}

	.exa-careers__values-grid {
		grid-template-columns: 1fr;
	}

	.exa-careers__benefits-grid {
		grid-template-columns: 1fr;
	}

	.exa-careers__talent {
		min-height: 40vh;
	}

	.exa-careers__talent-content {
		padding: 56px 16px;
	}

	.exa-careers__job-card {
		flex-direction: column;
		align-items: stretch;
	}

	.exa-careers__job-apply {
		width: 100%;
	}

	.exa-careers__job-btn {
		width: 100%;
		justify-content: center;
	}
}
