/* ═══════════════════════════════════════════════════════════════════════
   careers.css — public Careers at /careers.

   Block: .gg-cr  (CaReers)

   Sections:
     1. Body wrapper + ambient
     2. Atoms (eyebrow, buttons, breadcrumb)
     3. Hero — centered with stat strip
     4. Perks (4-up grid, 8 cards)
     5. Open roles — tab filter + list rows (full-row click, salary band)
     6. Process — 5-step vertical with giant ghost numerals
     7. Inclusion dark feature
     8. Talent-network email capture
   ═══════════════════════════════════════════════════════════════════════ */

/* ── Body / wrapper ──────────────────────────────────────────────────── */
.gg-cr-body{ background: var(--gg-off-white, #FAFAFA); }
.gg-cr-body::before{
	content: ""; position: fixed; inset: 0;
	background:
		radial-gradient(1100px 460px at 6% -10%, rgba(237,41,56,.06), transparent 70%),
		radial-gradient(900px 420px at 110% 12%, rgba(245,158,11,.05), transparent 75%);
	pointer-events: none; z-index: 0;
}
.gg-cr{ width: 100%; padding: 20px 28px 32px; position: relative; z-index: 1; display: flex; flex-direction: column; gap: clamp(22px, 2.6vw, 36px); }
@media (max-width: 700px){ .gg-cr{ padding: 14px 14px 48px; } }

/* ── Atoms ───────────────────────────────────────────────────────────── */
.gg-cr__eyebrow{
	display: inline-flex; align-items: center; gap: 7px;
	font-family: var(--gg-font-head);
	font-size: var(--gg-text-2xs, 11px);
	font-weight: 700;
	color: var(--gg-red, #ED2938);
	letter-spacing: .14em; text-transform: uppercase;
	margin-bottom: 4px;
}
.gg-cr__eyebrow i{ font-size: 13px; }
.gg-cr__eyebrow--light{ color: rgba(255,255,255,.82); }
.gg-cr__eyebrow--light i{ color: #fff; }

.gg-cr__btn{
	display: inline-flex; align-items: center; justify-content: center; gap: 8px;
	padding: 12px 22px;
	border-radius: 12px;
	font-family: var(--gg-font-head);
	font-size: 12px; font-weight: 800;
	letter-spacing: .04em; text-transform: uppercase;
	white-space: nowrap;
	border: 1.5px solid transparent;
	cursor: pointer;
	transition: all 220ms ease;
}
.gg-cr__btn i{ font-size: 13px; transition: transform 220ms ease; }
.gg-cr__btn--primary{
	background: linear-gradient(135deg, var(--gg-red, #ED2938), var(--gg-red-deep, #B91C28));
	color: #fff;
	box-shadow: 0 10px 26px -10px rgba(237,41,56,.6), inset 0 1px 0 rgba(255,255,255,.18);
}
.gg-cr__btn--primary:hover{ filter: brightness(1.05); transform: translateY(-1px); color: #fff; }
.gg-cr__btn--primary:hover i{ transform: translateX(2px); }
.gg-cr__btn--dark{ background: var(--gg-black, #0A0A0A); color: #fff; }
.gg-cr__btn--dark:hover{ background: var(--gg-black-soft, #141414); transform: translateY(-1px); color: #fff; }

/* ── Breadcrumb ──────────────────────────────────────────────────────── */
.gg-cr__crumbs{ margin: 0; }
.gg-cr__crumbs-list{
	list-style: none; padding: 0; margin: 0;
	display: flex; flex-wrap: wrap; align-items: center; gap: 8px;
	font-family: var(--gg-font-head);
	font-size: var(--gg-text-xs, 12px);
	font-weight: 600;
	color: var(--gg-gray-500, #6B7280);
}
.gg-cr__crumbs-list li{ display: inline-flex; align-items: center; gap: 8px; }
.gg-cr__crumbs-list li:not(:last-child)::after{ content: "/"; color: var(--gg-gray-300, #D1D5DB); font-weight: 500; }
.gg-cr__crumbs-list a{ color: var(--gg-gray-500, #6B7280); transition: color 180ms ease; }
.gg-cr__crumbs-list a:hover{ color: var(--gg-red-deep, #B91C28); }
.gg-cr__crumbs-list span[aria-current]{ color: var(--gg-gray-800, #1F2937); }

/* ── Hero ────────────────────────────────────────────────────────────── */
.gg-cr__hero{
	position: relative; overflow: hidden;
	border-radius: 22px;
	background: linear-gradient(135deg, #FFF8F8 0%, #FFF1F2 50%, #FFFAF7 100%);
	border: 1px solid rgba(237,41,56,.14);
	box-shadow: 0 1px 2px rgba(237,41,56,.04), 0 18px 38px -22px rgba(237,41,56,.2);
}
.gg-cr__hero-bg{ position: absolute; inset: 0; pointer-events: none; overflow: hidden; }
.gg-cr__hero-glow{ position: absolute; border-radius: 50%; filter: blur(70px); }
.gg-cr__hero-glow--a{ top: -90px; left: -60px; width: 340px; height: 340px; background: radial-gradient(circle, rgba(237,41,56,.22), transparent 70%); }
.gg-cr__hero-glow--b{ bottom: -80px; right: -50px; width: 320px; height: 320px; background: radial-gradient(circle, rgba(245,158,11,.16), transparent 70%); }

.gg-cr__hero-inner{
	position: relative;
	padding: clamp(32px, 4.4vw, 56px) clamp(22px, 4vw, 56px);
	display: flex; flex-direction: column; align-items: center;
	text-align: center;
	max-width: 920px; margin: 0 auto;
}
.gg-cr__hero-title{
	margin: 2px 0 0;
	font-family: var(--gg-font-head);
	font-size: clamp(28px, 3.8vw, 46px);
	font-weight: 800;
	line-height: 1.05;
	letter-spacing: -.025em;
	color: var(--gg-black, #0A0A0A);
}
.gg-cr__hero-accent{
	background: linear-gradient(135deg, var(--gg-red, #ED2938), var(--gg-red-deep, #B91C28));
	-webkit-background-clip: text; background-clip: text;
	-webkit-text-fill-color: transparent; color: transparent;
}
.gg-cr__hero-sub{
	margin: 14px 0 0;
	font-family: var(--gg-font-body);
	font-size: clamp(14px, 1.1vw, 16px);
	color: var(--gg-gray-700, #374151);
	line-height: 1.6;
	max-width: 62ch;
}
.gg-cr__hero-cta{ display: flex; flex-wrap: wrap; justify-content: center; gap: 10px; margin-top: clamp(18px, 2.4vw, 26px); }
.gg-cr__hero-stats{
	list-style: none; padding: 22px 0 0; margin: clamp(20px, 2.4vw, 28px) 0 0;
	border-top: 1px dashed rgba(237,41,56,.22);
	width: 100%; max-width: 720px;
	display: grid;
	grid-template-columns: repeat(4, minmax(0, 1fr));
	gap: clamp(8px, 1.4vw, 18px);
}
@media (max-width: 600px){ .gg-cr__hero-stats{ grid-template-columns: repeat(2, 1fr); gap: 16px 0; } }
.gg-cr__hero-stats li{ display: flex; flex-direction: column; gap: 4px; line-height: 1.05; align-items: center; }
.gg-cr__hero-stats strong{
	font-family: var(--gg-font-head);
	font-size: clamp(22px, 2.2vw, 30px);
	font-weight: 800;
	color: var(--gg-black, #0A0A0A);
	letter-spacing: -.025em;
}
.gg-cr__hero-stats small{
	font-family: var(--gg-font-head);
	font-size: 10px;
	color: var(--gg-gray-500, #6B7280);
	letter-spacing: .12em; text-transform: uppercase;
	font-weight: 700;
}

/* ── Section heads ──────────────────────────────────────────────────── */
.gg-cr__sec-head{ display: flex; flex-direction: column; gap: 4px; margin-bottom: 18px; }
.gg-cr__sec-head--row{ flex-direction: row; align-items: flex-end; justify-content: space-between; flex-wrap: wrap; gap: 14px; }
.gg-cr__sec-title{
	margin: 0;
	font-family: var(--gg-font-head);
	font-size: clamp(var(--gg-text-lg, 18px), 2vw, var(--gg-text-2xl, 26px));
	font-weight: 800;
	color: var(--gg-black, #0A0A0A);
	letter-spacing: -.025em;
	line-height: 1.15;
}
.gg-cr__sec-sub{
	margin: 0;
	font-family: var(--gg-font-body);
	font-size: var(--gg-text-sm, 14px);
	color: var(--gg-gray-500, #6B7280);
}

/* ── Perks (4-up) ───────────────────────────────────────────────────── */
.gg-cr__perks-grid{
	list-style: none; padding: 0; margin: 0;
	display: grid;
	grid-template-columns: repeat(4, minmax(0, 1fr));
	gap: clamp(12px, 1.4vw, 18px);
}
@media (max-width: 1200px){ .gg-cr__perks-grid{ grid-template-columns: repeat(3, minmax(0, 1fr)); } }
@media (max-width: 900px){  .gg-cr__perks-grid{ grid-template-columns: repeat(2, minmax(0, 1fr)); } }
@media (max-width: 560px){  .gg-cr__perks-grid{ grid-template-columns: 1fr; } }

.gg-cr__perk-card{
	display: flex; flex-direction: column; gap: 8px;
	padding: clamp(18px, 2vw, 22px);
	background: var(--gg-white, #fff);
	border: 1px solid var(--gg-gray-200, #E5E7EB);
	border-radius: 16px;
	box-shadow: 0 1px 2px rgba(15,23,42,.04);
	transition: transform 240ms cubic-bezier(.16,1,.3,1), border-color 240ms ease, box-shadow 240ms ease;
	height: 100%;
}
.gg-cr__perk-card:hover{
	transform: translateY(-3px);
	border-color: var(--gg-red-subtle, rgba(237,41,56,.32));
	box-shadow: 0 1px 2px rgba(237,41,56,.06), 0 22px 36px -18px rgba(237,41,56,.2);
}
.gg-cr__perk-ico{
	display: grid; place-items: center;
	width: 42px; height: 42px;
	border-radius: 12px;
	background: linear-gradient(135deg, var(--gg-red, #ED2938), var(--gg-red-deep, #B91C28));
	color: #fff;
	font-size: 18px;
	box-shadow: 0 10px 22px -10px rgba(237,41,56,.55);
	transition: transform 280ms ease;
}
.gg-cr__perk-card:hover .gg-cr__perk-ico{ transform: rotate(-4deg) scale(1.05); }
.gg-cr__perk-title{
	margin: 4px 0 0;
	font-family: var(--gg-font-head);
	font-size: 15px;
	font-weight: 800;
	color: var(--gg-black, #0A0A0A);
	letter-spacing: -.015em;
}
.gg-cr__perk-short{
	margin: 0;
	font-family: var(--gg-font-body);
	font-size: 13px;
	color: var(--gg-gray-600, #4B5563);
	line-height: 1.55;
}

/* ── Roles ──────────────────────────────────────────────────────────── */
.gg-cr__role-tabs{
	display: flex; flex-wrap: wrap; gap: 6px;
	margin-bottom: 14px;
	padding: 6px;
	background: var(--gg-gray-100, #F3F4F6);
	border-radius: 12px;
	width: max-content; max-width: 100%;
	overflow-x: auto;
}
.gg-cr__role-tab{
	display: inline-flex; align-items: center; gap: 6px;
	padding: 8px 14px;
	border: 0;
	background: transparent;
	color: var(--gg-gray-700, #374151);
	font-family: var(--gg-font-head);
	font-size: 12px; font-weight: 700;
	border-radius: 8px;
	cursor: pointer;
	white-space: nowrap;
	transition: background 180ms ease, color 180ms ease, box-shadow 180ms ease;
}
.gg-cr__role-tab-count{
	display: inline-grid; place-items: center;
	min-width: 20px; height: 18px;
	padding: 0 6px;
	border-radius: 999px;
	background: var(--gg-white, #fff);
	color: var(--gg-gray-500, #6B7280);
	font-size: 10px; font-weight: 800;
	letter-spacing: 0;
}
.gg-cr__role-tab:hover{ color: var(--gg-red-deep, #B91C28); }
.gg-cr__role-tab.is-active{
	background: var(--gg-white, #fff);
	color: var(--gg-black, #0A0A0A);
	box-shadow: 0 1px 2px rgba(15,23,42,.04), 0 8px 18px -10px rgba(15,23,42,.18);
}
.gg-cr__role-tab.is-active .gg-cr__role-tab-count{
	background: linear-gradient(135deg, var(--gg-red, #ED2938), var(--gg-red-deep, #B91C28));
	color: #fff;
}

.gg-cr__role-list{
	list-style: none; padding: 0; margin: 0;
	display: flex; flex-direction: column;
	background: var(--gg-white, #fff);
	border: 1px solid var(--gg-gray-200, #E5E7EB);
	border-radius: 18px;
	overflow: hidden;
	box-shadow: 0 1px 2px rgba(15,23,42,.04);
}
.gg-cr__role-row{ border-bottom: 1px solid var(--gg-gray-100, #F3F4F6); }
.gg-cr__role-row:last-child{ border-bottom: 0; }
.gg-cr__role-link{
	display: grid;
	grid-template-columns: minmax(0, 1fr) auto;
	align-items: center;
	gap: 14px;
	padding: 18px clamp(16px, 2vw, 22px);
	color: inherit;
	transition: background 200ms ease, padding 200ms ease;
}
.gg-cr__role-link:hover{ background: var(--gg-gray-50, #F9FAFB); padding-left: clamp(20px, 2.4vw, 26px); }
.gg-cr__role-main{ display: flex; flex-direction: column; gap: 4px; min-width: 0; }
.gg-cr__role-dept{
	font-family: var(--gg-font-head);
	font-size: 10px;
	font-weight: 800;
	color: var(--gg-red-deep, #B91C28);
	letter-spacing: .12em; text-transform: uppercase;
}
.gg-cr__role-title{
	font-family: var(--gg-font-head);
	font-size: 16px;
	font-weight: 800;
	color: var(--gg-black, #0A0A0A);
	letter-spacing: -.015em;
	line-height: 1.2;
}
.gg-cr__role-meta{
	display: flex; flex-wrap: wrap; gap: 4px 14px;
	margin-top: 2px;
	font-family: var(--gg-font-body);
	font-size: 12.5px;
	color: var(--gg-gray-500, #6B7280);
}
.gg-cr__role-meta span{ display: inline-flex; align-items: center; gap: 4px; }
.gg-cr__role-meta i{ color: var(--gg-red, #ED2938); font-size: 12px; }
.gg-cr__role-cta{
	display: inline-flex; align-items: center; gap: 6px;
	padding: 9px 16px;
	border-radius: 999px;
	background: var(--gg-gray-100, #F3F4F6);
	color: var(--gg-gray-800, #1F2937);
	font-family: var(--gg-font-head);
	font-size: 11px; font-weight: 800;
	letter-spacing: .04em; text-transform: uppercase;
	flex-shrink: 0;
	transition: background 220ms ease, color 220ms ease, gap 220ms ease, box-shadow 220ms ease;
}
.gg-cr__role-cta i{ font-size: 12px; transition: transform 220ms ease; }
.gg-cr__role-link:hover .gg-cr__role-cta{
	background: linear-gradient(135deg, var(--gg-red, #ED2938), var(--gg-red-deep, #B91C28));
	color: #fff; gap: 8px;
	box-shadow: 0 10px 22px -10px rgba(237,41,56,.5);
}
.gg-cr__role-link:hover .gg-cr__role-cta i{ transform: translateX(2px); }

/* ── Process (5 cards, ghost numerals) ──────────────────────────────── */
.gg-cr__proc-grid{
	list-style: none; padding: 0; margin: 0;
	display: grid;
	grid-template-columns: repeat(5, minmax(0, 1fr));
	gap: clamp(12px, 1.4vw, 18px);
}
@media (max-width: 1280px){ .gg-cr__proc-grid{ grid-template-columns: repeat(3, minmax(0, 1fr)); } }
@media (max-width: 740px){  .gg-cr__proc-grid{ grid-template-columns: 1fr; } }
.gg-cr__proc-step{
	position: relative;
	padding: clamp(18px, 2vw, 22px);
	background: var(--gg-white, #fff);
	border: 1px solid var(--gg-gray-200, #E5E7EB);
	border-radius: 18px;
	box-shadow: 0 1px 2px rgba(15,23,42,.04);
	display: flex; flex-direction: column; gap: 8px;
	overflow: hidden;
}
.gg-cr__proc-step::before{
	content: ""; position: absolute; inset: 0;
	background: radial-gradient(320px 180px at 0% 0%, rgba(237,41,56,.05), transparent 60%);
	pointer-events: none;
}
.gg-cr__proc-num{
	position: absolute; top: 10px; right: 14px;
	font-family: var(--gg-font-head);
	font-size: 56px; font-weight: 800;
	color: var(--gg-red-light, #FFF1F2);
	letter-spacing: -.05em;
	line-height: 1;
	pointer-events: none;
}
.gg-cr__proc-ico{
	position: relative;
	display: grid; place-items: center;
	width: 42px; height: 42px;
	border-radius: 12px;
	background: linear-gradient(135deg, var(--gg-red, #ED2938), var(--gg-red-deep, #B91C28));
	color: #fff;
	font-size: 18px;
	box-shadow: 0 10px 22px -10px rgba(237,41,56,.55);
}
.gg-cr__proc-title{
	position: relative;
	margin: 6px 0 0;
	font-family: var(--gg-font-head);
	font-size: 15px;
	font-weight: 800;
	color: var(--gg-black, #0A0A0A);
	letter-spacing: -.015em;
}
.gg-cr__proc-short{
	position: relative;
	margin: 0;
	font-family: var(--gg-font-body);
	font-size: 13px;
	color: var(--gg-gray-600, #4B5563);
	line-height: 1.55;
}

/* ── Inclusion (dark feature) ───────────────────────────────────────── */
.gg-cr__incl{
	position: relative; overflow: hidden;
	border-radius: 22px;
	background: linear-gradient(135deg, var(--gg-black, #0A0A0A), var(--gg-black-soft, #141414));
}
.gg-cr__incl-glow{
	position: absolute; inset: 0;
	background:
		radial-gradient(640px 320px at 8% 120%, rgba(237,41,56,.4), transparent 70%),
		radial-gradient(540px 280px at 92% -10%, rgba(245,158,11,.22), transparent 70%);
	pointer-events: none;
}
.gg-cr__incl-inner{ position: relative; padding: clamp(32px, 4vw, 56px) clamp(22px, 4vw, 56px); max-width: 880px; }
.gg-cr__incl-title{
	margin: 0 0 12px;
	font-family: var(--gg-font-head);
	font-size: clamp(22px, 2.6vw, 32px);
	font-weight: 800;
	color: #fff;
	letter-spacing: -.025em;
	line-height: 1.15;
}
.gg-cr__incl-text{
	margin: 0;
	font-family: var(--gg-font-body);
	font-size: 15px;
	color: rgba(255,255,255,.76);
	line-height: 1.65;
	max-width: 64ch;
}

/* ── Talent network email capture ───────────────────────────────────── */
.gg-cr__talent{
	position: relative; overflow: hidden;
	background: linear-gradient(135deg, #FFFAF7 0%, #FFF1F2 100%);
	border: 1px solid rgba(237,41,56,.16);
	border-radius: 22px;
	box-shadow: 0 1px 2px rgba(237,41,56,.04), 0 18px 36px -22px rgba(237,41,56,.22);
}
.gg-cr__talent-inner{
	display: grid;
	grid-template-columns: minmax(0, 1fr) minmax(0, 1.1fr);
	gap: clamp(20px, 3vw, 36px); align-items: center;
	padding: clamp(28px, 4vw, 44px) clamp(22px, 4vw, 44px);
}
@media (max-width: 900px){ .gg-cr__talent-inner{ grid-template-columns: 1fr; } }
.gg-cr__talent-text{ display: flex; flex-direction: column; min-width: 0; }
.gg-cr__talent-title{
	margin: 0;
	font-family: var(--gg-font-head);
	font-size: clamp(22px, 2.4vw, 30px);
	font-weight: 800;
	color: var(--gg-black, #0A0A0A);
	letter-spacing: -.025em;
	line-height: 1.15;
}
.gg-cr__talent-sub{
	margin: 8px 0 0;
	font-family: var(--gg-font-body);
	font-size: 14px;
	color: var(--gg-gray-700, #374151);
	line-height: 1.5;
}
.gg-cr__talent-form{
	display: flex; align-items: center;
	background: #fff;
	border: 1.5px solid rgba(237,41,56,.18);
	border-radius: 999px;
	padding: 6px 6px 6px 18px;
	box-shadow: 0 1px 2px rgba(15,23,42,.06), 0 18px 32px -20px rgba(237,41,56,.28);
	transition: border-color 220ms ease, box-shadow 220ms ease;
}
.gg-cr__talent-form:focus-within{
	border-color: var(--gg-red, #ED2938);
	box-shadow: 0 1px 2px rgba(15,23,42,.06), 0 0 0 4px rgba(237,41,56,.1), 0 18px 32px -20px rgba(237,41,56,.36);
}
.gg-cr__talent-input{
	flex: 1; min-width: 0;
	border: 0; background: transparent; outline: 0;
	padding: 12px 12px;
	font-family: var(--gg-font-body);
	font-size: 14px;
	color: var(--gg-gray-800, #1F2937);
}
.gg-cr__talent-input::placeholder{ color: var(--gg-gray-400, #9CA3AF); }
.gg-cr__talent-form .gg-cr__btn{ padding: 11px 18px; border-radius: 999px; flex-shrink: 0; }
@media (max-width: 540px){
	.gg-cr__talent-form{ flex-direction: column; align-items: stretch; padding: 6px; border-radius: 16px; }
	.gg-cr__talent-input{ padding: 12px 14px; }
	.gg-cr__talent-form .gg-cr__btn{ border-radius: 12px; padding: 12px; }
}

/* ── Reduced motion ──────────────────────────────────────────────────── */
@media (prefers-reduced-motion: reduce){
	.gg-cr__perk-card, .gg-cr__perk-ico, .gg-cr__role-link, .gg-cr__role-cta, .gg-cr__btn{ transition: none !important; }
}
