:root {
	--gj-bg: #f3efe7;
	--gj-surface: #fffdf8;
	--gj-surface-strong: #fff8ee;
	--gj-border: #d8c8b3;
	--gj-text: #1d242b;
	--gj-muted: #5d6772;
	--gj-accent: #ad2f18;
	--gj-accent-dark: #7d1f10;
	--gj-ink-soft: #efe4d5;
	--gj-shadow: 0 24px 60px rgba(40, 26, 14, 0.08);
}

.gj-app {
	color: var(--gj-text);
}

.gj-hero {
	display: grid;
	grid-template-columns: minmax(0, 1.7fr) minmax(280px, 0.8fr);
	gap: 1.5rem;
	padding: 2rem;
	border-radius: 28px;
	background:
		radial-gradient(circle at top right, rgba(173, 47, 24, 0.14), transparent 32%),
		linear-gradient(135deg, #fffdf8 0%, #f5ece1 100%);
	box-shadow: var(--gj-shadow);
}

.gj-kicker,
.gj-card-kicker {
	margin: 0 0 0.5rem;
	font-size: 0.82rem;
	font-weight: 700;
	letter-spacing: 0.08em;
	text-transform: uppercase;
	color: var(--gj-accent);
}

.gj-hero h1,
.gj-profile h2,
.gj-section h2,
.gj-filters h2,
.gj-job-card h3 {
	font-family: Georgia, "Times New Roman", serif;
	letter-spacing: -0.02em;
}

.gj-hero h1 {
	margin: 0 0 0.85rem;
	font-size: clamp(2.3rem, 4vw, 4.4rem);
	line-height: 0.95;
}

.gj-lead,
.gj-profile-card p,
.gj-section__meta,
.gj-excerpt,
.gj-meta,
.gj-notice {
	color: var(--gj-muted);
}

.gj-hero__stats {
	display: grid;
	gap: 1rem;
}

.gj-stat-card,
.gj-profile-card,
.gj-filter-card,
.gj-job-card,
.gj-admin-card {
	padding: 1.35rem;
	border: 1px solid var(--gj-border);
	border-radius: 22px;
	background: var(--gj-surface);
	box-shadow: 0 12px 30px rgba(40, 26, 14, 0.05);
}

.gj-stat-card strong {
	display: block;
	margin-top: 0.5rem;
	font-size: 2rem;
}

.gj-profile,
.gj-filters,
.gj-section {
	margin-top: 1.5rem;
}

.gj-auth-grid,
.gj-filter-grid,
.gj-card-grid,
.gj-admin-grid {
	display: grid;
	gap: 1rem;
}

.gj-auth-grid,
.gj-admin-grid {
	grid-template-columns: repeat(2, minmax(0, 1fr));
}

.gj-filter-card__header,
.gj-section__header {
	display: flex;
	align-items: end;
	justify-content: space-between;
	gap: 1rem;
	margin-bottom: 1rem;
}

.gj-filter-grid {
	grid-template-columns: repeat(3, minmax(0, 1fr));
}

.gj-filter-grid__search {
	grid-column: span 1;
}

.gj-profile-card,
.gj-filter-card label {
	display: grid;
	gap: 0.55rem;
}

.gj-profile-card--active {
	grid-template-columns: minmax(0, 1fr) auto;
	align-items: center;
	background: linear-gradient(135deg, var(--gj-surface) 0%, var(--gj-surface-strong) 100%);
}

.gj-profile-actions {
	display: flex;
	gap: 0.75rem;
}

.gj-profile input,
.gj-filter-card select,
.gj-filter-card input {
	width: 100%;
	padding: 0.85rem 0.95rem;
	border: 1px solid var(--gj-border);
	border-radius: 14px;
	background: #fff;
	color: var(--gj-text);
	font: inherit;
}

.gj-button,
.gj-favorite-button {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	padding: 0.8rem 1rem;
	border-radius: 999px;
	border: 1px solid transparent;
	font-weight: 700;
	text-decoration: none;
	cursor: pointer;
	transition: transform 0.18s ease, background-color 0.18s ease, border-color 0.18s ease;
}

.gj-button:hover,
.gj-favorite-button:hover {
	transform: translateY(-1px);
}

.gj-button--primary {
	background: var(--gj-accent);
	color: #fff;
}

.gj-button--primary:hover {
	background: var(--gj-accent-dark);
}

.gj-button--secondary,
.gj-favorite-button,
.gj-favorite-button--link {
	background: var(--gj-ink-soft);
	border-color: var(--gj-border);
	color: var(--gj-text);
}

.gj-favorite-button.is-active {
	background: #1f4a36;
	border-color: #1f4a36;
	color: #fff;
}

.gj-section__meta {
	margin: 0;
	max-width: 38ch;
	text-align: right;
}

.gj-card-grid {
	grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
}

.gj-job-card {
	display: grid;
	gap: 0.85rem;
	border-radius: 24px;
	background:
		linear-gradient(180deg, rgba(255, 248, 238, 0.7), rgba(255, 253, 248, 1)),
		#fff;
}

.gj-job-card__top,
.gj-job-card__footer {
	display: flex;
	justify-content: space-between;
	gap: 1rem;
	align-items: start;
}

.gj-job-card h3 {
	margin: 0;
	font-size: 1.45rem;
	line-height: 1.05;
}

.gj-company {
	margin: 0;
	font-weight: 700;
	font-size: 1rem;
}

.gj-meta,
.gj-excerpt,
.gj-favorite-status,
.gj-score {
	margin: 0;
	font-size: 0.95rem;
}

.gj-chip-row {
	display: flex;
	flex-wrap: wrap;
	gap: 0.5rem;
}

.gj-chip {
	padding: 0.35rem 0.7rem;
	border-radius: 999px;
	background: var(--gj-ink-soft);
	border: 1px solid var(--gj-border);
	font-size: 0.82rem;
	font-weight: 700;
}

.gj-score {
	font-weight: 700;
	color: var(--gj-accent);
}

.gj-empty,
.gj-notice {
	padding: 1rem 1.15rem;
	border-radius: 16px;
	border: 1px dashed var(--gj-border);
	background: rgba(255, 248, 238, 0.72);
}

.gj-notice {
	margin-top: 1rem;
	border-style: solid;
}

.gj-notice--error {
	border-color: #c96e5f;
	background: #fff2ee;
	color: #7e2f24;
}

.gj-notice--success {
	border-color: #87a18d;
	background: #eef7f0;
	color: #264b2e;
}

.gj-admin-grid {
	margin: 1rem 0;
}

@media (max-width: 900px) {
	.gj-hero,
	.gj-auth-grid,
	.gj-admin-grid,
	.gj-filter-grid,
	.gj-profile-card--active,
	.gj-section__header,
	.gj-job-card__top,
	.gj-job-card__footer {
		grid-template-columns: 1fr;
		flex-direction: column;
		align-items: stretch;
	}

	.gj-section__meta {
		text-align: left;
	}
}

@media (max-width: 640px) {
	.gj-hero,
	.gj-profile-card,
	.gj-filter-card,
	.gj-job-card {
		padding: 1.1rem;
		border-radius: 20px;
	}

	.gj-hero h1 {
		font-size: 2.4rem;
	}
}
