/* ============================================
   Careers Page
   ============================================ */

/* ---------- HERO ---------- */
.careers-hero { height: auto; min-height: 100vh; align-items: flex-end; }
.careers-hero .hero__overlay {
  background: linear-gradient(180deg, rgba(10,22,40,.35) 0%, rgba(10,22,40,.55) 45%, rgba(10,22,40,.95) 100%);
}
.careers-hero__content {
  width: 100%;
  padding: 140px var(--pad) 48px;
  max-width: var(--max-w); margin: 0 auto;
}
.careers-hero__content .hero__title {
  font-family: var(--serif); font-weight: 400;
  font-size: clamp(40px, 10vw, 104px); line-height: 1.02;
  color: var(--cream); margin-top: 16px;
  letter-spacing: -1px;
  max-width: none;
}
.careers-hero__content .hero__sub {
  font-size: 15px; color: var(--muted); line-height: 1.7;
  max-width: 560px; margin-top: 24px;
}
.careers-hero__content .hero__ctas { display: flex; gap: 12px; margin-top: 28px; flex-wrap: wrap; }

.careers-hero__stats {
  display: flex; gap: 32px; margin-top: 48px;
  padding-top: 24px; border-top: 1px solid rgba(201,169,110,.25);
  max-width: 560px;
}
.careers-hero__stats > div { display: flex; flex-direction: column; gap: 2px; }
.careers-hero__stats span { font-family: var(--serif); font-size: 26px; color: var(--cream); font-weight: 400; line-height: 1; }
.careers-hero__stats em { font-style: normal; font-size: 10px; letter-spacing: 2px; color: var(--gold); font-weight: 600; }

/* ---------- MISSION QUOTE ---------- */
.careers-quote {
  padding: 80px var(--pad); max-width: 960px; margin: 0 auto;
  position: relative;
  text-align: left;
}
.careers-quote__mark {
  font-family: var(--serif); font-size: 180px; line-height: .6;
  color: var(--gold); opacity: .22;
  position: absolute; top: 64px; left: var(--pad);
}
.careers-quote blockquote {
  font-family: var(--serif); font-weight: 400;
  font-size: clamp(22px, 3.6vw, 38px); line-height: 1.35;
  color: var(--cream);
  padding-left: 0; padding-top: 48px;
  position: relative;
}
.careers-quote blockquote em { color: var(--gold); font-style: italic; }
.careers-quote__attr { display: flex; flex-direction: column; gap: 2px; margin-top: 32px; padding-left: 0; }
.careers-quote__attr span { font-size: 14px; color: var(--cream); font-weight: 500; letter-spacing: .3px; }
.careers-quote__attr em { font-style: normal; font-size: 11px; color: var(--gold); letter-spacing: 2px; font-weight: 600; }

/* ---------- VALUES (numbered narrative) ---------- */
.values { padding: 80px var(--pad); max-width: var(--max-w); margin: 0 auto; }
.value {
  display: grid; grid-template-columns: 1fr;
  gap: 16px; padding: 48px 0;
  border-top: 1px solid rgba(255,255,255,.08);
  align-items: start;
}
.value:last-child { border-bottom: 1px solid rgba(255,255,255,.08); }
.value__no {
  font-family: var(--serif); font-size: 80px; line-height: 1;
  color: var(--gold); font-weight: 400; opacity: .9;
}
.value__body { display: flex; flex-direction: column; gap: 16px; }
.value__title {
  font-family: var(--serif); font-weight: 400;
  font-size: clamp(28px, 5vw, 48px); line-height: 1.1;
  color: var(--cream); letter-spacing: -.5px;
}
.value__desc {
  font-size: 15px; line-height: 1.8; color: var(--muted);
  max-width: 620px;
}
.value__img { overflow: hidden; aspect-ratio: 4/3; }
.value__img img { width: 100%; height: 100%; object-fit: cover; }

/* ---------- LIFE AT CCS ---------- */
.life { padding: 80px var(--pad); max-width: var(--max-w); margin: 0 auto; }
.life__heading { font-family: var(--serif); font-size: clamp(30px, 5vw, 52px); line-height: 1.1; color: var(--cream); margin: 20px 0 40px; font-weight: 400; }
.life__grid { display: grid; grid-template-columns: 1fr; gap: 12px; }
.life__cell { position: relative; overflow: hidden; aspect-ratio: 4/3; }
.life__cell img { width: 100%; height: 100%; object-fit: cover; transition: transform 1.2s ease; }
.life__cell figcaption {
  position: absolute; inset: auto 0 0 0;
  padding: 60px 20px 20px;
  background: linear-gradient(180deg, transparent, rgba(6,14,26,.9));
  display: flex; flex-direction: column; gap: 4px;
}
.life__cell figcaption span {
  font-size: 9px; letter-spacing: 2.5px; color: var(--gold); font-weight: 700;
}
.life__cell figcaption p {
  font-size: 13px; color: var(--cream); line-height: 1.4; font-weight: 400;
}

/* ---------- BENEFITS ---------- */
.benefits { padding: 80px var(--pad); max-width: var(--max-w); margin: 0 auto; }
.benefits__heading { font-family: var(--serif); font-size: clamp(30px, 5vw, 52px); line-height: 1.1; color: var(--cream); margin: 20px 0 40px; font-weight: 400; }
.benefits__grid { display: grid; grid-template-columns: 1fr; gap: 1px; background: rgba(255,255,255,.08); border: 1px solid rgba(255,255,255,.08); }
.benefit {
  background: var(--navy); padding: 36px 28px;
  display: flex; flex-direction: column; gap: 10px;
  transition: background .3s;
}
.benefit:hover { background: var(--navy-card); }
.benefit__ico {
  display: inline-flex; align-items: center; justify-content: center;
  width: 36px; height: 36px; border: 1px solid var(--gold-40);
  border-radius: 50%; color: var(--gold); font-size: 14px; margin-bottom: 4px;
}
.benefit h4 { font-family: var(--serif); font-weight: 400; font-size: 20px; color: var(--cream); line-height: 1.2; }
.benefit p { font-size: 13px; color: var(--muted); line-height: 1.7; }

/* ---------- OPEN POSITIONS ACCORDION ---------- */
.openings { padding: 80px var(--pad); max-width: var(--max-w); margin: 0 auto; }
.openings__heading { font-family: var(--serif); font-size: clamp(30px, 5vw, 52px); line-height: 1.1; color: var(--cream); margin: 20px 0 8px; font-weight: 400; }
.openings__sub { font-size: 13px; color: var(--muted); letter-spacing: .3px; margin-bottom: 40px; }

.openings__list { display: flex; flex-direction: column; gap: 0; }
.dept { border-top: 1px solid rgba(255,255,255,.1); }
.dept:last-of-type { border-bottom: 1px solid rgba(255,255,255,.1); }
.dept > summary {
  list-style: none; cursor: pointer;
  padding: 28px 0;
  display: grid; grid-template-columns: 1fr auto auto; gap: 16px; align-items: center;
  transition: color .2s;
  -webkit-tap-highlight-color: transparent;
  outline: none;
}
.dept > summary::-webkit-details-marker { display: none; }
.dept > summary::marker { content: ''; }
.dept__name { font-family: var(--serif); font-size: clamp(20px, 3vw, 28px); color: var(--cream); font-weight: 400; line-height: 1.2; }
.dept__count { font-size: 11px; letter-spacing: 2px; color: var(--muted); font-weight: 600; }
.dept__toggle {
  display: inline-block; position: relative; flex-shrink: 0;
  width: 36px; height: 36px; border: 1px solid var(--gold-40); border-radius: 50%;
  color: var(--gold); background: transparent;
  transition: background .3s ease, border-color .3s ease, color .3s ease, transform .45s cubic-bezier(.4,0,.2,1);
}
.dept__toggle::before,
.dept__toggle::after {
  content: ''; position: absolute; top: 50%; left: 50%;
  background: currentColor;
}
.dept__toggle::before { width: 12px; height: 1px; transform: translate(-50%, -50%); }
.dept__toggle::after { width: 1px; height: 12px; transform: translate(-50%, -50%); }
.dept:hover .dept__toggle { background: var(--gold-10); border-color: var(--gold); }
.dept[open] .dept__toggle { background: var(--gold); color: var(--navy); border-color: var(--gold); transform: rotate(45deg); }

/* Override UA <details> closed display:none so height can animate */
.dept > .dept__body {
  display: flex; flex-direction: column; gap: 1px;
  background: rgba(255,255,255,.05);
  overflow: hidden;
  transition: height .45s cubic-bezier(.4,0,.2,1);
}
.dept > .dept__body::after { content: ''; display: block; height: 28px; flex-shrink: 0; background: var(--navy); }
.job {
  background: var(--navy); padding: 20px 20px;
  display: grid; grid-template-columns: 1fr auto; gap: 14px; align-items: center;
  transition: background .2s;
  position: relative;
}
.job::after {
  content: '→'; color: var(--gold); font-size: 16px;
  opacity: .4; transition: opacity .2s, transform .2s;
}
.job:hover { background: var(--navy-card); }
.job:hover::after { opacity: 1; transform: translateX(4px); }
.job__title { font-family: var(--serif); font-size: 16px; color: var(--cream); font-weight: 400; line-height: 1.3; }
.job__meta { font-size: 12px; color: var(--muted); letter-spacing: .3px; }
.job__meta em { font-style: normal; color: var(--gold); font-weight: 600; }

/* ---------- GRADUATE PROGRAMME ---------- */
.graduate {
  background: var(--cream); color: var(--navy);
  padding: 80px var(--pad);
}
.graduate__inner { max-width: var(--max-w); margin: 0 auto; display: flex; flex-direction: column; gap: 48px; }
.section-tag--dark .section-tag__line { background: var(--navy); }
.section-tag--dark .section-tag__text { color: var(--navy); opacity: .6; }
.graduate__title { font-family: var(--serif); font-size: clamp(32px, 6vw, 56px); line-height: 1.05; font-weight: 400; margin: 20px 0 24px; letter-spacing: -.5px; }
.graduate__desc { font-size: 15px; line-height: 1.8; color: rgba(10,22,40,.72); max-width: 560px; margin-bottom: 32px; }
.graduate__list { list-style: none; display: flex; flex-direction: column; gap: 16px; margin-bottom: 40px; }
.graduate__list li {
  display: grid; grid-template-columns: 36px 1fr; gap: 12px; align-items: start;
  padding: 16px 0; border-top: 1px solid rgba(10,22,40,.15);
  font-size: 15px; color: var(--navy); line-height: 1.5;
}
.graduate__list li:last-child { border-bottom: 1px solid rgba(10,22,40,.15); }
.graduate__list span { font-family: var(--serif); font-size: 22px; color: var(--navy); font-weight: 400; line-height: 1; opacity: .5; }
.graduate__meta { display: grid; grid-template-columns: 1fr 1fr 1fr; gap: 16px; padding-top: 32px; border-top: 1px solid rgba(10,22,40,.15); }
.graduate__meta > div { display: flex; flex-direction: column; gap: 4px; }
.graduate__big { font-family: var(--serif); font-size: clamp(36px, 6vw, 56px); color: var(--navy); line-height: 1; font-weight: 400; }
.graduate__meta em { font-style: normal; font-size: 10px; letter-spacing: 2px; color: rgba(10,22,40,.55); font-weight: 600; }

/* ---------- TALENT COMMUNITY ---------- */
.talent { padding: 100px var(--pad); text-align: center; max-width: 720px; margin: 0 auto; }
.talent__title { font-family: var(--serif); font-size: clamp(32px, 6vw, 56px); line-height: 1.05; font-weight: 400; color: var(--cream); margin-bottom: 20px; letter-spacing: -.5px; }
.talent__desc { font-size: 15px; line-height: 1.7; color: var(--muted); max-width: 480px; margin: 0 auto 32px; }
.talent__form { display: flex; flex-direction: column; gap: 10px; max-width: 480px; margin: 0 auto; }
.talent__input {
  background: var(--navy-card); border: 1px solid rgba(201,169,110,.25);
  color: var(--cream); font-size: 15px; padding: 14px 18px;
  font-family: inherit; border-radius: 0;
  transition: border-color .2s;
  -webkit-tap-highlight-color: transparent; outline: none;
}
.talent__input::placeholder { color: rgba(139,154,181,.6); }
.talent__input:focus { border-color: var(--gold); }
.talent__form .btn { width: 100%; }
.talent__fine { font-size: 11px; color: var(--muted); margin-top: 20px; line-height: 1.6; }
.talent__fine a { color: var(--gold); border-bottom: 1px solid var(--gold-40); }

/* ============================================
   RESPONSIVE — Tablet (>= 640px)
   ============================================ */
@media (min-width: 640px) {
  .benefits__grid { grid-template-columns: 1fr 1fr; }
  .life__grid { grid-template-columns: 1fr 1fr; grid-auto-rows: 280px; }
  .life__cell { aspect-ratio: auto; }
  .life__cell--tall { grid-row: span 2; }
  .life__cell--wide { grid-column: span 2; }
  .talent__form { flex-direction: row; }
  .talent__input { flex: 1; }
  .talent__form .btn { width: auto; white-space: nowrap; }
  .graduate__meta { gap: 32px; }
}

/* ============================================
   RESPONSIVE — Desktop (>= 1024px)
   ============================================ */
@media (min-width: 1024px) {
  .careers-hero__content { padding: 200px var(--pad-desk) 100px; }
  .careers-hero__content .hero__sub { font-size: 17px; }
  .careers-hero__stats { gap: 56px; padding-top: 32px; margin-top: 64px; }
  .careers-hero__stats span { font-size: 34px; }

  .careers-quote { padding: 140px var(--pad-desk); }
  .careers-quote__mark { font-size: 280px; top: 80px; left: var(--pad-desk); }
  .careers-quote blockquote { padding-top: 72px; padding-left: 60px; }
  .careers-quote__attr { padding-left: 60px; }

  .values, .life, .benefits, .openings { padding-left: var(--pad-desk); padding-right: var(--pad-desk); padding-top: 140px; padding-bottom: 140px; }
  .value { grid-template-columns: 180px 1fr; gap: 48px; padding: 72px 0; }
  .value--image { grid-template-columns: 180px 1fr 360px; }
  .value--image-right { grid-template-columns: 180px 1fr 360px; }
  .value__no { font-size: 120px; }
  .value__img { aspect-ratio: 3/4; max-width: 360px; }
  /* Swap image to left on even rows for alternating rhythm */
  .value--image-right .value__no { order: 2; }
  .value--image-right .value__body { order: 3; }
  .value--image-right .value__img { order: 1; }

  .life__grid { grid-template-columns: 2fr 1fr 1.4fr; grid-auto-rows: 300px; }
  .life__cell--tall { grid-row: span 2; grid-column: 1; }
  .life__cell--wide { grid-column: 2 / span 2; grid-row: 2; }
  .life__cell:not(.life__cell--tall):not(.life__cell--wide) { grid-column: 2 / span 2; grid-row: 1; }

  .benefits__grid { grid-template-columns: repeat(3, 1fr); }
  .benefit { padding: 44px 36px; }

  .graduate { padding: 120px var(--pad-desk); }
  .graduate__inner { flex-direction: row; align-items: center; gap: 80px; }
  .graduate__left { flex: 1; }
  .graduate__meta { flex-shrink: 0; grid-template-columns: 1fr; gap: 32px; min-width: 240px; padding: 32px 0 0; border-top: none; border-left: 1px solid rgba(10,22,40,.15); padding-left: 40px; }

  .talent { padding: 160px var(--pad-desk); max-width: 880px; }

  .dept > summary { padding: 36px 0; }
  .job { padding: 22px 28px; }
  .job__title { font-size: 18px; }
}

@media (min-width: 1280px) {
  .careers-hero__content .hero__title { font-size: 120px; }
}
