/**
 * Careers — archive + single job
 *
 * Mirrors _src-html/careers.html and career-single.html. All sizing
 * uses theme tokens from global.css (--color-*, --radius-*, --font-*).
 * Page-prefixed classes; uses both `careers-` (archive) and `cs-` /
 * `job-` / `sj-` (single) namespaces matching the source mockups.
 */

/* ============================================================
   BREADCRUMB (shared across careers screens)
   ============================================================ */
.site-main--careers .breadcrumb {
	max-width: 1440px;
	margin: 0 auto;
	padding: 24px 100px;
}
.site-main--careers .breadcrumb-list {
	display: flex;
	align-items: center;
	gap: 8px;
}
.site-main--careers .breadcrumb-link {
	font-size: 16px;
	line-height: 22px;
	color: var(--color-grey-9);
	transition: color var(--transition-fast);
}
.site-main--careers .breadcrumb-link:hover { color: var(--color-primary-blue); }
.site-main--careers .breadcrumb-sep {
	width: 18px;
	height: 18px;
	flex-shrink: 0;
	color: var(--color-grey-6);
}
.site-main--careers .breadcrumb-current {
	font-size: 16px;
	line-height: 22px;
	color: var(--color-blue-n4);
}

/* ============================================================
   ARCHIVE — HERO
   ============================================================ */
.careers-hero-wrapper {
	max-width: 1440px;
	margin: 0 auto;
	padding: 0 100px;
}
.careers-hero {
	width: 100%;
	height: 580px;
	border-radius: var(--radius-xl);
	overflow: hidden;
	position: relative;
	display: flex;
	flex-direction: column;
	justify-content: flex-end;
	align-items: center;
	padding: 60px 170px;
}
.careers-hero-bg {
	position: absolute;
	inset: 0;
}
.careers-hero-bg img {
	width: 100%;
	height: 100%;
	object-fit: cover;
}
.careers-hero-bg::after {
	content: '';
	position: absolute;
	inset: 0;
	background: linear-gradient(to bottom, rgba(0, 0, 0, .4), rgba(0, 0, 0, .8));
}
.careers-hero-bg--placeholder {
	background: linear-gradient(135deg, var(--color-blue-1) 0%, var(--color-primary-blue) 60%, var(--color-blue-n3) 100%);
}
.careers-hero-bg--placeholder::after {
	background: linear-gradient(to bottom, rgba(0, 0, 0, .2), rgba(0, 0, 0, .5));
}
.careers-hero-content {
	position: relative;
	z-index: 1;
	text-align: center;
	width: 862px;
	max-width: 100%;
}
.careers-hero-sub {
	font-size: 18px;
	line-height: 24px;
	color: var(--color-grey-0);
	text-shadow: 0 4px 12px rgba(0, 0, 0, .12);
	margin-bottom: 12px;
}
.careers-hero-title {
	font-size: 72px;
	line-height: 80px;
	font-weight: var(--fw-semibold);
	color: var(--color-grey-0);
	text-shadow: 0 4px 12px rgba(0, 0, 0, .12);
	margin: 0;
}

/* ============================================================
   ARCHIVE — INTRO + BENEFITS
   ============================================================ */
.careers-info {
	max-width: 1440px;
	margin: 160px auto 0;
	padding: 0 100px;
}
.careers-intro {
	display: flex;
	flex-direction: column;
	align-items: center;
	gap: 32px;
	padding-top: 20px;
	max-width: 958px;
	margin: 0 auto;
}
.careers-intro-line {
	width: 3px;
	height: 80px;
	background: var(--color-primary-green);
	border-radius: 2px;
}
.careers-intro-text {
	font-size: 20px;
	line-height: 26px;
	color: var(--color-grey-9);
	text-align: center;
}
.careers-intro-text p { margin: 0 0 12px; }
.careers-intro-text p:last-child { margin-bottom: 0; }

.careers-benefits-section {
	max-width: 1440px;
	margin: 80px auto 0;
	padding: 64px 100px;
	border-radius: var(--radius-xl);
	background:
		linear-gradient(90deg, rgba(255, 255, 255, .94) 0%, rgba(255, 255, 255, .9) 58%, rgba(255, 255, 255, .78) 100%),
		url('../images/careers/aachc-careers-benefits-background.webp') center / cover no-repeat;
	overflow: hidden;
}
.careers-benefits {
	display: flex;
	gap: 48px;
	align-items: flex-start;
}
.careers-benefits-img {
	width: 498px;
	height: 550px;
	border-radius: var(--radius-xl);
	overflow: hidden;
	flex-shrink: 0;
}
.careers-benefits-img img {
	width: 100%;
	height: 100%;
	object-fit: cover;
}
.careers-benefits-img--placeholder {
	background: linear-gradient(135deg, var(--color-grey-2), var(--color-grey-3));
}
.careers-benefits-content { flex: 1; }
.careers-benefits-title {
	font-size: 32px;
	line-height: 40px;
	font-weight: var(--fw-semibold);
	color: var(--color-blue-4);
	margin: 0 0 24px;
}
.benefit-item { margin-bottom: 16px; }
.benefit-item:last-child { margin-bottom: 0; }
.benefit-item-header {
	display: flex;
	align-items: center;
	gap: 12px;
	margin-bottom: 8px;
}
.benefit-dot {
	width: 6px;
	height: 6px;
	border-radius: 50%;
	background: var(--color-primary-blue);
	flex-shrink: 0;
}
.benefit-item-title {
	font-size: 20px;
	line-height: 26px;
	font-weight: var(--fw-medium);
	color: var(--color-grey-9);
	margin: 0;
}
.benefit-item-text {
	font-size: 18px;
	line-height: 24px;
	color: var(--color-grey-9);
	margin: 0;
}

/* ============================================================
   ARCHIVE — OPENINGS
   ============================================================ */
.openings {
	max-width: 1440px;
	margin: 160px auto 0;
	padding: 0 100px;
}
.openings-header {
	text-align: center;
	margin-bottom: 36px;
}
.openings-title {
	font-size: 32px;
	line-height: 40px;
	font-weight: var(--fw-semibold);
	color: var(--color-blue-4);
	margin: 0;
}
.openings-sub {
	font-size: 18px;
	line-height: 24px;
	color: var(--color-grey-9);
	margin: 16px 0 0;
}
.openings-grid {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(280px, 320px));
	gap: 24px;
	justify-content: center;
}
.openings-empty {
	max-width: 600px;
	margin: 0 auto;
	text-align: center;
	padding: 40px 24px;
	background: var(--color-grey-0);
	border-radius: var(--radius-lg);
	box-shadow: 0 4px 12px rgba(0, 0, 0, .02);
}
.openings-empty p {
	font-size: 18px;
	line-height: 24px;
	color: var(--color-grey-7);
	margin: 0;
}

.careers-pagination {
	display: flex;
	gap: 8px;
	justify-content: center;
	margin-top: 36px;
}
.careers-pagination .page-link-wrap a,
.careers-pagination .page-link-wrap span {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	min-width: 40px;
	height: 40px;
	padding: 0 12px;
	border-radius: var(--radius-lg);
	border: 1px solid var(--color-grey-3);
	background: var(--color-grey-0);
	font-size: 16px;
	font-weight: var(--fw-medium);
	color: var(--color-grey-9);
	text-decoration: none;
	transition: border-color var(--transition-fast), color var(--transition-fast);
}
.careers-pagination .page-link-wrap a:hover { border-color: var(--color-primary-blue); color: var(--color-primary-blue); }
.careers-pagination .page-link-wrap .current { background: var(--color-primary-blue); color: var(--color-grey-0); border-color: var(--color-primary-blue); }

/* ============================================================
   JOB CARD (archive + similar)
   ============================================================ */
.job-card {
	background: var(--color-grey-0);
	border-radius: var(--radius-lg);
	box-shadow: 0 4px 12px rgba(0, 0, 0, .02);
	overflow: hidden;
	padding: 8px 8px 16px;
	display: flex;
	flex-direction: column;
}
.job-card-header {
	display: block;
	background: #CFE3F7;
	border-radius: 20px;
	padding: 12px;
	box-shadow: 0 4px 6px rgba(0, 0, 0, .01);
	margin-bottom: 16px;
	text-decoration: none;
	color: inherit;
	transition: background var(--transition-fast);
}
.job-card-header:hover { background: #BCD7F2; }
.job-card-date {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	height: 42px;
	padding: 8px 16px;
	border-radius: var(--radius-lg);
	background: #F9F9F9;
	box-shadow: 0 4px 6px rgba(0, 0, 0, .01);
	font-size: 16px;
	line-height: 22px;
	font-weight: var(--fw-medium);
	color: var(--color-grey-9);
	margin-bottom: 12px;
}
.job-card-name {
	font-size: 20px;
	line-height: 26px;
	font-weight: var(--fw-medium);
	color: var(--color-blue-4);
}
.job-card-body {
	padding: 0 12px;
	flex: 1;
	display: flex;
	flex-direction: column;
}
.job-tags {
	display: flex;
	gap: 4px;
	flex-wrap: wrap;
	margin-bottom: 12px;
}
.job-tag {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	padding: 8px 12px;
	border-radius: var(--radius-lg);
	border: .5px solid var(--color-grey-7);
	font-size: 14px;
	line-height: 18px;
	color: var(--color-grey-7);
}
.job-bullets {
	display: flex;
	flex-direction: column;
	gap: 8px;
	margin-bottom: 16px;
	flex: 1;
}
.job-bullet {
	display: flex;
	gap: 12px;
	align-items: flex-start;
}
.job-bullet-dot {
	width: 6px;
	height: 6px;
	border-radius: 50%;
	background: var(--color-primary-blue);
	flex-shrink: 0;
	margin-top: 8px;
}
.job-bullet-text {
	font-size: 16px;
	line-height: 22px;
	color: var(--color-grey-9);
	margin: 0;
}
.job-card-footer {
	padding: 0;
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 12px;
	margin-top: 8px;
}
.job-price {
	font-size: 18px;
	line-height: 24px;
	font-weight: var(--fw-semibold);
	color: var(--color-blue-4);
}
.job-btn {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: 8px;
	height: 44px;
	padding: 12px 20px;
	border-radius: var(--radius-xl);
	background: var(--color-primary-blue);
	color: var(--color-grey-0);
	font-size: 16px;
	line-height: 1;
	font-weight: var(--fw-semibold);
	border: none;
	cursor: pointer;
	transition: background var(--transition-fast);
	text-decoration: none;
}
.job-btn:hover { background: var(--color-blue-n3); }
.job-btn svg { width: 18px; height: 18px; }

/* ============================================================
   SINGLE — HERO
   ============================================================ */
.cs-hero-wrapper {
	max-width: 1440px;
	margin: 0 auto;
	padding: 0 100px;
}
.cs-hero {
	width: 100%;
	height: 360px;
	border-radius: var(--radius-xl);
	overflow: hidden;
	position: relative;
	display: flex;
	align-items: center;
	justify-content: center;
}
.cs-hero-bg {
	position: absolute;
	inset: 0;
}
.cs-hero-bg img {
	width: 100%;
	height: 100%;
	object-fit: cover;
}
.cs-hero-bg::after {
	content: '';
	position: absolute;
	inset: 0;
	background: linear-gradient(to bottom, rgba(0, 0, 0, .4), rgba(0, 0, 0, .8));
}
.cs-hero-bg--placeholder {
	background: linear-gradient(135deg, var(--color-blue-1), var(--color-primary-blue) 70%);
}
.cs-hero-bg--placeholder::after {
	background: linear-gradient(to bottom, rgba(0, 0, 0, .2), rgba(0, 0, 0, .5));
}
.cs-hero-title {
	position: relative;
	z-index: 1;
	font-size: 72px;
	line-height: 80px;
	font-weight: var(--fw-semibold);
	color: var(--color-grey-0);
	text-shadow: 0 4px 12px rgba(0, 0, 0, .12);
	text-align: center;
	margin: 0;
	padding: 0 24px;
}

/* ============================================================
   SINGLE — MAIN INFO (content + sticky sidebar)
   ============================================================ */
.cs-main {
	max-width: 1440px;
	margin: 80px auto 0;
	padding: 0 100px;
}
.cs-layout {
	display: flex;
	gap: 60px;
	align-items: flex-start;
}
.cs-content {
	flex: 1;
	min-width: 0;
}
.cs-body {
	font-size: 18px;
	line-height: 26px;
	color: var(--color-grey-9);
}
.cs-body p { margin: 0 0 16px; }
.cs-body h3 {
	font-size: 24px;
	line-height: 32px;
	font-weight: var(--fw-semibold);
	color: var(--color-grey-9);
	margin: 32px 0 12px;
}
.cs-body h3:first-child { margin-top: 0; }
.cs-body ul {
	list-style: none;
	padding: 0;
	margin: 0 0 16px;
	display: flex;
	flex-direction: column;
	gap: 8px;
}
.cs-body ul li {
	position: relative;
	padding-left: 28px;
	font-size: 18px;
	line-height: 26px;
	color: var(--color-grey-9);
}
.cs-body ul li::before {
	content: '';
	position: absolute;
	left: 0;
	top: 8px;
	width: 16px;
	height: 16px;
	background: url("data:image/svg+xml,%3Csvg viewBox='0 0 20 20' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M16.667 5L7.5 14.167L3.333 10' stroke='%230B4580' stroke-width='1.8' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E") center / contain no-repeat;
}
.cs-body a {
	color: var(--color-primary-blue);
	text-decoration: underline;
}

.cs-sidebar {
	width: 440px;
	flex-shrink: 0;
	position: sticky;
	top: 130px;
}
.cs-sidebar-card {
	background: var(--color-grey-0);
	border-radius: var(--radius-xl);
	box-shadow: 0 4px 12px rgba(0, 0, 0, .02);
	padding: 24px;
	display: flex;
	flex-direction: column;
	gap: 32px;
}
.cs-sidebar-row {
	display: flex;
	gap: 12px;
	align-items: center;
}
.cs-sidebar-icon {
	width: 54px;
	height: 54px;
	border-radius: var(--radius-full);
	border: 1px solid var(--color-grey-5);
	display: flex;
	align-items: center;
	justify-content: center;
	flex-shrink: 0;
}
.cs-sidebar-icon svg { width: 20px; height: 20px; }
.cs-sidebar-label {
	font-size: 18px;
	line-height: 26px;
	font-weight: var(--fw-semibold);
	color: var(--color-grey-9);
	word-break: break-word;
}
.cs-sidebar-label a { color: inherit; text-decoration: none; }
.cs-sidebar-label a:hover { color: var(--color-primary-blue); }
.cs-sidebar-sub {
	font-size: 16px;
	line-height: 22px;
	color: var(--color-grey-7);
	margin-top: 4px;
}
.cs-sidebar-salary-title {
	font-size: 24px;
	line-height: 30px;
	font-weight: var(--fw-semibold);
	color: var(--color-grey-9);
}
.cs-sidebar-salary-sub {
	font-size: 18px;
	line-height: 24px;
	color: var(--color-grey-7);
	margin-top: 4px;
}
.cs-sidebar-details {
	display: flex;
	flex-direction: column;
	gap: 20px;
}
.cs-sidebar-btn {
	display: flex;
	align-items: center;
	justify-content: center;
	height: 54px;
	padding: 16px 24px;
	border-radius: var(--radius-xl);
	background: var(--color-primary-blue);
	color: var(--color-grey-0);
	font-size: 17px;
	line-height: 1;
	font-weight: var(--fw-semibold);
	border: none;
	cursor: pointer;
	width: 100%;
	transition: background var(--transition-fast);
	text-decoration: none;
}
.cs-sidebar-btn:hover { background: var(--color-blue-n3); }

/* ============================================================
   SINGLE — BENEFITS OVERLAY
   ============================================================ */
.cs-benefits {
	margin-top: 160px;
	background: rgba(0, 0, 0, .6);
	position: relative;
	overflow: hidden;
}
.cs-benefits-bg {
	position: absolute;
	inset: 0;
	z-index: 0;
}
.cs-benefits-bg img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	opacity: .4;
}
.cs-benefits-inner {
	position: relative;
	z-index: 1;
	max-width: 1440px;
	margin: 0 auto;
	padding: 80px 100px;
	display: flex;
	flex-direction: column;
	gap: 36px;
}
.cs-benefits-header { max-width: 600px; }
.cs-benefits-title {
	font-size: 32px;
	line-height: 40px;
	font-weight: var(--fw-semibold);
	color: var(--color-grey-0);
	text-shadow: 0 4px 12px rgba(0, 0, 0, .12);
	margin: 0;
}
.cs-benefits-sub {
	font-size: 18px;
	line-height: 24px;
	color: var(--color-grey-1);
	margin: 16px 0 0;
	text-shadow: 0 4px 12px rgba(0, 0, 0, .12);
}
.cs-benefits-cards {
	display: grid;
	grid-template-columns: repeat(5, 1fr);
	gap: 24px;
}
.cs-benefit-card {
	background: var(--color-grey-0);
	border-radius: var(--radius-lg);
	padding: 24px;
	box-shadow: 0 4px 12px rgba(0, 0, 0, .02);
	display: flex;
	flex-direction: column;
	align-items: center;
	gap: 12px;
	min-width: 0;
}
.cs-benefit-icon {
	width: 54px;
	height: 54px;
	border-radius: var(--radius-full);
	border: 1px solid var(--color-grey-5);
	display: flex;
	align-items: center;
	justify-content: center;
}
.cs-benefit-icon svg { width: 20px; height: 20px; }
.cs-benefit-label {
	font-size: 18px;
	line-height: 24px;
	font-weight: var(--fw-semibold);
	color: var(--color-grey-9);
	text-align: center;
}

/* ============================================================
   SINGLE — APPLY FORM
   ============================================================ */
.cs-apply {
	max-width: 1440px;
	margin: 160px auto 0;
	padding: 0 100px;
}
.cs-apply-header {
	text-align: center;
	margin-bottom: 32px;
}
.cs-apply-title {
	font-size: 32px;
	line-height: 40px;
	font-weight: var(--fw-semibold);
	color: var(--color-blue-4);
	margin: 0;
}
.cs-apply-sub {
	font-size: 18px;
	line-height: 24px;
	color: var(--color-grey-9);
	margin: 16px auto 0;
	max-width: 600px;
}
.cs-apply-card {
	max-width: 694px;
	margin: 0 auto;
	background: var(--color-grey-0);
	border-radius: var(--radius-xl);
	box-shadow: 0 4px 12px rgba(0, 0, 0, .02);
	padding: 40px 32px;
	position: relative;
}
.cs-form-row {
	display: flex;
	gap: 24px;
	margin-bottom: 16px;
}
.cs-form-group {
	flex: 1;
	display: flex;
	flex-direction: column;
	gap: 8px;
	min-width: 0;
}
.cs-form-label {
	font-size: 18px;
	line-height: 24px;
	font-weight: var(--fw-bold);
	color: var(--color-grey-9);
}
.cs-form-input,
.cs-form-select {
	height: 55px;
	border: 1px solid var(--color-grey-5);
	border-radius: var(--radius-lg);
	padding: 16px 20px;
	font-size: 18px;
	line-height: 24px;
	color: var(--color-grey-9);
	background: transparent;
	outline: none;
	width: 100%;
	font-family: var(--font-primary);
	transition: border-color var(--transition-fast);
}
.cs-form-input::placeholder { color: var(--color-grey-6); }
.cs-form-input:focus,
.cs-form-select:focus { border-color: var(--color-primary-blue); }
.cs-form-input.has-error,
.cs-form-select.has-error,
.cs-form-textarea.has-error { border-color: #DC2626; }
.cs-form-select {
	appearance: none;
	-webkit-appearance: none;
	background-image: url("data:image/svg+xml,%3Csvg width='20' height='20' viewBox='0 0 20 20' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M5 7.5L10 12.5L15 7.5' stroke='%236C757D' stroke-width='1.5' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");
	background-repeat: no-repeat;
	background-position: right 20px center;
	cursor: pointer;
	padding-right: 56px;
}
.cs-form-select:not([data-touched]):invalid,
.cs-form-select option[disabled] { color: var(--color-grey-6); }
.cs-form-textarea {
	border: 1px solid var(--color-grey-5);
	border-radius: var(--radius-lg);
	padding: 16px 20px;
	font-size: 18px;
	line-height: 24px;
	color: var(--color-grey-9);
	background: transparent;
	outline: none;
	width: 100%;
	min-height: 110px;
	resize: vertical;
	font-family: var(--font-primary);
	transition: border-color var(--transition-fast);
	margin-bottom: 16px;
}
.cs-form-textarea::placeholder { color: var(--color-grey-6); }
.cs-form-textarea:focus { border-color: var(--color-primary-blue); }
.cs-form-attach {
	display: inline-flex;
	align-items: center;
	gap: 8px;
	cursor: pointer;
	margin-bottom: 4px;
	flex-wrap: wrap;
}
.cs-form-attach svg { width: 24px; height: 24px; flex-shrink: 0; }
.cs-form-attach-label {
	font-size: 17px;
	line-height: 1;
	font-weight: var(--fw-medium);
	color: var(--color-grey-9);
	border-bottom: 1px solid var(--color-grey-9);
	padding-bottom: 4px;
	max-width: 100%;
	overflow: hidden;
	text-overflow: ellipsis;
	white-space: nowrap;
}
.cs-form-attach.is-filled .cs-form-attach-label { color: var(--color-primary-blue); border-bottom-color: var(--color-primary-blue); }
.cs-form-attach.has-error .cs-form-attach-label { color: #DC2626; border-bottom-color: #DC2626; }
.cs-form-attach input[type="file"] { display: none; }
.cs-form-help {
	font-size: 14px;
	line-height: 20px;
	color: var(--color-grey-6);
	margin: 0 0 24px;
}
.field-error {
	font-size: 14px;
	color: #DC2626;
	margin-top: 4px;
}
.cs-apply-feedback {
	margin: 0 0 16px;
	font-size: 16px;
	line-height: 22px;
}
.cs-apply-feedback--error {
	color: #B91C1C;
	background: #FEE2E2;
	border-radius: var(--radius-lg);
	padding: 12px 16px;
}
.cs-apply-feedback--success {
	color: #047857;
	background: #D1FAE5;
	border-radius: var(--radius-lg);
	padding: 24px 20px;
	font-size: 18px;
	text-align: center;
}
.cs-form-submit {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	height: 54px;
	padding: 16px 24px;
	border-radius: var(--radius-xl);
	background: var(--color-primary-blue);
	color: var(--color-grey-0);
	font-size: 17px;
	line-height: 1;
	font-weight: var(--fw-semibold);
	border: none;
	cursor: pointer;
	transition: background var(--transition-fast);
}
.cs-form-submit:hover { background: var(--color-blue-n3); }
.cs-form-submit:disabled { opacity: .6; cursor: progress; }
.cs-form-submit.is-loading::after {
	content: '';
	display: inline-block;
	width: 14px;
	height: 14px;
	margin-left: 10px;
	border-radius: 50%;
	border: 2px solid rgba(255, 255, 255, .4);
	border-top-color: #fff;
	animation: aachc-spin .8s linear infinite;
}
@keyframes aachc-spin { to { transform: rotate(360deg); } }

/* ============================================================
   SINGLE — SIMILAR JOBS
   ============================================================ */
.cs-similar {
	max-width: 1440px;
	margin: 160px auto 0;
	padding: 0 100px;
}
.cs-similar-header {
	display: flex;
	align-items: flex-end;
	justify-content: space-between;
	gap: 32px;
	margin-bottom: 36px;
}
.cs-similar-title {
	font-size: 32px;
	line-height: 40px;
	font-weight: var(--fw-semibold);
	color: var(--color-blue-4);
	margin: 0;
}
.cs-similar-sub {
	font-size: 18px;
	line-height: 24px;
	color: var(--color-grey-9);
	margin: 16px 0 0;
	max-width: 600px;
}
.cs-similar-btn {
	display: inline-flex;
	align-items: center;
	gap: 12px;
	height: 54px;
	padding: 16px 24px;
	border-radius: var(--radius-xl);
	background: var(--color-primary-blue);
	color: var(--color-grey-0);
	font-size: 17px;
	line-height: 1;
	font-weight: var(--fw-semibold);
	border: none;
	cursor: pointer;
	white-space: nowrap;
	flex-shrink: 0;
	transition: background var(--transition-fast);
	text-decoration: none;
}
.cs-similar-btn:hover { background: var(--color-blue-n3); }
.cs-similar-btn svg { width: 18px; height: 18px; }
.cs-similar-grid {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
	gap: 24px;
}

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media (max-width: 1279px) {
	.site-main--careers .breadcrumb { padding: 24px 32px; }
	.careers-hero-wrapper,
	.careers-info,
	.careers-benefits-section,
	.openings,
	.cs-hero-wrapper,
	.cs-main,
	.cs-apply,
	.cs-similar { padding-left: 32px; padding-right: 32px; }
	.careers-hero { padding: 60px 80px; }
	.cs-benefits-inner { padding: 80px 32px; }
	.cs-sidebar { width: 380px; }
	.cs-benefits-cards { grid-template-columns: repeat(5, 1fr); }
}

@media (max-width: 991px) {
	.site-main--careers .breadcrumb { padding: 16px; }
	.careers-hero-wrapper { padding: 0 16px; }
	.careers-hero {
		height: 480px;
		padding: 32px 24px;
		border-radius: var(--radius-lg);
		align-items: center;
		justify-content: flex-end;
	}
	.careers-hero-content { width: 100%; }
	.careers-hero-sub { font-size: 16px; line-height: 22px; }
	.careers-hero-title { font-size: 40px; line-height: 46px; }

	.careers-info { padding: 0 16px; margin-top: 80px; }
	.careers-intro-text { font-size: 18px; line-height: 24px; }

	.careers-benefits-section { padding: 40px 16px; margin-top: 56px; border-radius: var(--radius-lg); }
	.careers-benefits { flex-direction: column; gap: 32px; }
	.careers-benefits-img { width: 100%; height: 320px; border-radius: var(--radius-lg); order: 2; }
	.careers-benefits-content { order: 1; }
	.careers-benefits-title { font-size: 24px; line-height: 30px; margin-bottom: 20px; }
	.benefit-item-title { font-size: 18px; line-height: 24px; }
	.benefit-item-text { font-size: 16px; line-height: 22px; }

	.openings { padding: 0 16px; margin-top: 80px; }
	.openings-title { font-size: 24px; line-height: 30px; }
	.openings-sub { font-size: 16px; line-height: 22px; }
	.openings-grid { grid-template-columns: 1fr; gap: 16px; }
	.job-card { width: 100%; }

	.cs-hero-wrapper { padding: 0 16px; }
	.cs-hero { height: 280px; border-radius: var(--radius-lg); }
	.cs-hero-title { font-size: 36px; line-height: 42px; }

	.cs-main { padding: 0 16px; margin-top: 56px; }
	.cs-layout { flex-direction: column; gap: 32px; }
	.cs-sidebar { width: 100%; position: static; }
	.cs-sidebar-card { border-radius: var(--radius-lg); }
	.cs-body { font-size: 16px; line-height: 24px; }
	.cs-body h3 { font-size: 20px; line-height: 26px; margin-top: 24px; }
	.cs-body ul li { font-size: 16px; line-height: 24px; }
	.cs-sidebar-btn { height: 48px; font-size: 16px; }

	.cs-benefits { margin-top: 72px; }
	.cs-benefits-inner { padding: 48px 16px; gap: 24px; }
	.cs-benefits-title { font-size: 24px; line-height: 30px; }
	.cs-benefits-sub { font-size: 16px; line-height: 22px; }
	.cs-benefits-cards { grid-template-columns: repeat(2, 1fr); gap: 16px; }
	.cs-benefit-card { padding: 20px; }
	.cs-benefit-label { font-size: 16px; line-height: 22px; }

	.cs-apply { padding: 0 16px; margin-top: 72px; }
	.cs-apply-title { font-size: 24px; line-height: 30px; }
	.cs-apply-sub { font-size: 16px; line-height: 22px; }
	.cs-apply-card { padding: 32px 20px; border-radius: var(--radius-lg); }
	.cs-form-row { flex-direction: column; gap: 16px; }
	.cs-form-label { font-size: 16px; line-height: 22px; }
	.cs-form-input,
	.cs-form-select { height: 55px; font-size: 16px; padding: 12px 16px; border-radius: 20px; padding-right: 48px; }
	.cs-form-select { background-position: right 16px center; }
	.cs-form-textarea { font-size: 16px; padding: 12px 16px; border-radius: 20px; }
	.cs-form-submit { width: 100%; height: 48px; font-size: 16px; }

	.cs-similar { padding: 0 16px; margin-top: 72px; }
	.cs-similar-header { flex-direction: column; align-items: flex-start; gap: 16px; }
	.cs-similar-title { font-size: 24px; line-height: 30px; }
	.cs-similar-sub { font-size: 16px; line-height: 22px; }
	.cs-similar-btn { height: 48px; font-size: 16px; width: 100%; justify-content: center; }
	.cs-similar-grid { grid-template-columns: 1fr; gap: 16px; }
}

@media (max-width: 575px) {
	.site-main--careers .breadcrumb { padding: 12px; }
	.careers-hero-wrapper,
	.careers-info,
	.careers-benefits-section,
	.openings,
	.cs-hero-wrapper,
	.cs-main,
	.cs-apply,
	.cs-similar { padding-left: 12px; padding-right: 12px; }
	.cs-benefits-cards { grid-template-columns: 1fr 1fr; }
	.cs-hero-title { font-size: 30px; line-height: 36px; }
}
