/*
 * Culture Page Sections
 *
 * Covers culture-specific patterns:
 *   - culture-work (header + 3 numbered services)
 *   - culture-approach (3-card model)
 *   - culture-what-changes (checklist + quote)
 *   - culture-for-you (navy split layout)
 *
 * Dependencies: tokens.css, buttons.css, animations.css
 */


/* ══════════════════════════════════════
   BLOCK GAP OVERRIDES
   Override .page-content .wp-block-post-content > * + * { margin-top: var(--space-2xl) }
   Culture sections that need to sit flush against neighbours.
   ══════════════════════════════════════ */

.page-content .wp-block-post-content > .culture-work,
.page-content .wp-block-post-content > .wp-block-group.culture-work,
.page-content .wp-block-post-content > .culture-work__service,
.page-content .wp-block-post-content > .wp-block-group.culture-work__service,
.page-content .wp-block-post-content > .culture-approach,
.page-content .wp-block-post-content > .wp-block-group.culture-approach,
.page-content .wp-block-post-content > .culture-what-changes,
.page-content .wp-block-post-content > .wp-block-group.culture-what-changes,
.page-content .wp-block-post-content > .culture-for-you,
.page-content .wp-block-post-content > .wp-block-group.culture-for-you {
  margin-top: 0 !important;
  margin-block-start: 0 !important;
}


/* ══════════════════════════════════════
   OUR CULTURE WORK — Header
   ══════════════════════════════════════ */

.culture-work {
  background: var(--color-white);
  padding: var(--space-100) 0 var(--space-lg);
}
.culture-work__header {
  text-align: center;
  margin-bottom: var(--space-xl);
  max-width: var(--max-width);
  margin-left: auto;
  margin-right: auto;
}
.culture-work__eyebrow {
  font-family: var(--font-heading);
  font-weight: var(--fw-semibold);
  font-size: var(--font-md);
  text-transform: uppercase;
  letter-spacing: 1.4px;
  color: var(--color-primary);
  margin-bottom: var(--space-3xs);
}
.culture-work__heading {
  font-family: var(--font-heading);
  font-weight: var(--fw-semibold);
  font-size: clamp(28px, 3.5vw, 40px);
  color: var(--color-navy);
  line-height: 1.15;
}


/* ══════════════════════════════════════
   CULTURE WORK — Numbered Services
   ══════════════════════════════════════ */

.culture-work__service {
  max-width: var(--max-width);
  margin: 0 auto;
  padding: var(--space-48) 0;
  border-bottom: 1px solid var(--color-grey-200);
}
.culture-work__service:last-child { border-bottom: none; }

.culture-work__service-grid {
  display: grid;
  grid-template-columns: 80px 1fr;
  gap: var(--space-lg);
  align-items: start;
}

.culture-work__service-number {
  font-family: var(--font-body);
  font-weight: 900;
  font-size: 64px;
  line-height: 1;
  color: var(--color-primary);
  opacity: 0.9;
}

.culture-work__service-content {
  display: flex;
  flex-direction: column;
  gap: var(--space-xs);
}

.culture-work__service-header {
  display: flex;
  flex-direction: column;
  gap: var(--space-3xs);
}
.culture-work__service-eyebrow {
  font-family: var(--font-heading);
  font-weight: var(--fw-semibold);
  font-size: var(--font-xs);
  text-transform: uppercase;
  letter-spacing: 2px;
  color: var(--color-primary);
}
.culture-work__service-title {
  font-family: var(--font-heading);
  font-weight: var(--fw-semibold);
  font-size: 32px;
  color: var(--color-navy);
  line-height: 1.15;
}

.culture-work__service-body {
  font-size: var(--font-md);
  line-height: 1.65;
  color: #1A1A1A;
}
.culture-work__service-body p + p { margin-top: 1em; }

/* ── Mini icon cards ── */
.culture-work__service-list {
  padding-left: 0;
  margin: var(--space-md) 0;
  list-style: none;
  display: flex;
  flex-wrap: wrap;
  justify-content: flex-start;
  gap: var(--space-xs);
}
.culture-work__service-list li {
  font-family: var(--font-heading);
  font-weight: var(--fw-semibold);
  font-size: var(--font-sm);
  line-height: 1.5;
  color: #1A1A1A;
  display: flex;
  gap: var(--space-3xs);
  align-items: center;
  background: var(--color-grey-100);
  border-radius: var(--radius-lg);
  padding: var(--space-xs) var(--space-sm);
  transition: transform 0.3s cubic-bezier(0.2, 0.8, 0.2, 1),
              box-shadow 0.3s ease,
              background 0.3s ease;
  flex: 0 0 calc(33.333% - (var(--space-xs) * 2 / 3));
}
.culture-work__service-list li:hover {
  transform: translateY(-3px);
  box-shadow: 0 8px 24px rgba(0, 0, 0, 0.08);
  background: var(--color-white);
}
/* Icon circle — wraps FA icon */
.culture-work__icon-wrap {
  width: 32px;
  height: 32px;
  min-width: 32px;
  background: var(--color-success);
  color: var(--color-white);
  border-radius: var(--radius-pill);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  transition: transform 0.35s cubic-bezier(0.2, 0.8, 0.2, 1);
}
.culture-work__service-list li:hover .culture-work__icon-wrap {
  transform: scale(1.1) rotate(-4deg);
}
.culture-work__icon-wrap i,
.culture-work__icon-wrap svg {
  font-size: 14px;
  width: 14px !important;
  height: 14px !important;
}

/* 4-item lists: 2x2 */
.culture-work__service-list--2x2 li {
  flex: 0 0 calc(50% - (var(--space-xs) / 2));
}

/* ── Closing pull quote ── */
.culture-work__service-closing {
  border-left: 4px solid var(--color-success);
  padding-left: var(--space-sm);
  margin-top: var(--space-3xs);
}
.culture-work__service-closing p {
  font-family: var(--font-body);
  font-size: var(--font-md);
  line-height: 1.6;
  color: #1A1A1A;
  margin-bottom: var(--space-3xs);
}
.culture-work__service-closing-punch {
  font-family: var(--font-heading) !important;
  font-weight: var(--fw-semibold) !important;
  font-size: 22px !important;
  color: var(--color-navy) !important;
  margin-top: var(--space-3xs) !important;
}

/* ── Phases (Culture Evolution) ── */
.culture-work__phases {
  display: flex;
  flex-direction: column;
  gap: 0;
  margin: 0;
}
.culture-work__phase {
  display: grid;
  grid-template-columns: 120px 1fr;
  gap: var(--space-sm);
  padding: var(--space-xs) 0;
  border-bottom: 1px solid var(--color-grey-200);
  transition: background 0.3s ease;
}
.culture-work__phase:last-child { border-bottom: none; }
.culture-work__phase:hover {
  background: var(--color-grey-100);
}
.culture-work__phase-label {
  font-family: var(--font-heading);
  font-weight: var(--fw-semibold);
  font-size: var(--font-sm);
  text-transform: uppercase;
  letter-spacing: 1px;
  color: var(--color-primary);
  padding-top: 2px;
  padding-left: var(--space-2xs);
}
.culture-work__phase-text {
  font-size: var(--font-md);
  line-height: 1.65;
  color: #1A1A1A;
  padding-right: var(--space-2xs);
}


/* ══════════════════════════════════════
   OUR APPROACH — 3-card model
   ══════════════════════════════════════ */

.culture-approach {
  background: var(--color-grey-100);
  padding: var(--space-100) 0;
}
.culture-approach__container {
  max-width: var(--max-width);
  margin: 0 auto;
  padding: 0 var(--space-lg);
}
.culture-approach__header {
  text-align: center;
  margin-bottom: var(--space-64);
}
.culture-approach__eyebrow {
  font-family: var(--font-heading);
  font-weight: var(--fw-semibold);
  font-size: var(--font-md);
  text-transform: uppercase;
  letter-spacing: 1.4px;
  color: var(--color-primary);
  margin-bottom: var(--space-3xs);
}
.culture-approach__heading {
  font-family: var(--font-heading);
  font-weight: var(--fw-semibold);
  font-size: clamp(28px, 3.5vw, 40px);
  color: var(--color-navy);
  line-height: 1.15;
}
.culture-approach__intro {
  font-size: 22px;
  line-height: 1.4;
  color: #1A1A1A;
  max-width: 680px;
  margin: var(--space-xs) auto 0;
}

.culture-approach__layers {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--space-md);
  margin-bottom: var(--space-64);
}
.culture-approach__layer {
  background: var(--color-white);
  border-radius: var(--radius-lg);
  box-shadow: 0 4px 24px rgba(0, 0, 0, 0.06);
  padding: var(--space-lg) var(--space-md);
  text-align: left;
  border-top: 4px solid transparent;
  transition: transform 0.35s cubic-bezier(0.2, 0.8, 0.2, 1),
              box-shadow 0.35s ease;
  min-height: 240px;
  display: flex;
  flex-direction: column;
  position: relative;
  overflow: hidden;
}
.culture-approach__layer::before {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(135deg, rgba(2, 193, 127, 0.035), transparent 60%);
  opacity: 0;
  transition: opacity 0.35s ease;
  pointer-events: none;
}
.culture-approach__layer:hover {
  transform: translateY(-6px);
  box-shadow: 0 16px 44px rgba(38, 38, 95, 0.18), 0 6px 14px rgba(38, 38, 95, 0.10);
}
.culture-approach__layer:hover::before { opacity: 1; }
.culture-approach__layer--foundations { border-top-color: var(--color-primary); }
.culture-approach__layer--enablers { border-top-color: var(--color-success); }
.culture-approach__layer--outcomes { border-top-color: var(--color-accent); }

.culture-approach__layer-icon {
  width: 48px;
  height: 48px;
  min-width: 48px;
  border-radius: var(--radius-pill);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  color: var(--color-white);
  margin: 0 0 var(--space-xs);
  font-size: 20px;
  transition: transform 0.4s cubic-bezier(0.2, 0.8, 0.2, 1);
}
.culture-approach__layer:hover .culture-approach__layer-icon {
  transform: scale(1.08) rotate(-6deg);
}
.culture-approach__layer-icon svg { width: 20px; height: 20px; }
.culture-approach__layer--foundations .culture-approach__layer-icon { background: var(--color-primary); }
.culture-approach__layer--enablers .culture-approach__layer-icon { background: var(--color-success); }
.culture-approach__layer--outcomes .culture-approach__layer-icon { background: var(--color-accent); color: var(--color-navy); }

.culture-approach__layer-title {
  font-family: var(--font-heading);
  font-weight: var(--fw-semibold);
  font-size: 24px;
  color: var(--color-navy);
  margin-bottom: var(--space-3xs);
  text-transform: uppercase;
  letter-spacing: 0.5px;
}
.culture-approach__layer-subtitle {
  font-family: var(--font-heading);
  font-weight: var(--fw-semibold);
  font-size: 14px;
  color: #1A1A1A;
  text-transform: uppercase;
  letter-spacing: 0.5px;
  margin-bottom: var(--space-2xs);
}
.culture-approach__layer-body {
  font-size: 16px;
  line-height: 1.65;
  color: #1A1A1A;
  margin-top: auto;
}

.culture-approach__closing {
  text-align: center;
  max-width: 700px;
  margin: 0 auto;
}
.culture-approach__closing p {
  font-size: var(--font-md);
  line-height: 1.65;
  color: #1A1A1A;
}
.culture-approach__closing p + p { margin-top: 1em; }
.culture-approach__closing em {
  font-style: italic;
  color: var(--color-navy);
}


/* ══════════════════════════════════════
   WHAT CHANGES — Checklist + quote
   ══════════════════════════════════════ */

.culture-what-changes {
  background: var(--color-white);
  padding: var(--space-100) 0;
}
.culture-what-changes__container {
  max-width: var(--max-width);
  margin: 0 auto;
  padding: 0 var(--space-lg);
}
.culture-what-changes__heading {
  font-family: var(--font-heading);
  font-weight: var(--fw-semibold);
  font-size: clamp(28px, 3.5vw, 40px);
  color: var(--color-navy);
  margin-bottom: var(--space-48);
  line-height: 1.15;
}

.culture-what-changes__layout {
  display: flex;
  gap: var(--space-80);
  align-items: flex-start;
}
.culture-what-changes__left { flex: 1; }
.culture-what-changes__intro {
  font-size: 22px;
  line-height: 1.4;
  color: #1A1A1A;
  margin-bottom: var(--space-md);
}
.culture-what-changes__list {
  display: flex;
  flex-direction: column;
  gap: var(--space-xs);
  margin-bottom: var(--space-md);
}
.culture-what-changes__item {
  display: flex;
  gap: var(--space-3xs);
  align-items: center;
  transition: transform 0.3s cubic-bezier(0.2, 0.8, 0.2, 1);
}
.culture-what-changes__item:hover { transform: translateX(4px); }
.culture-what-changes__check {
  width: 28px;
  height: 28px;
  min-width: 28px;
  background: var(--color-success);
  border-radius: var(--radius-pill);
  display: flex;
  align-items: center;
  justify-content: center;
  box-shadow: 0 2px 8px rgba(2, 193, 127, 0.25);
}
.culture-what-changes__check svg { width: 14px; height: 14px; }
.culture-what-changes__item span {
  font-size: var(--font-md);
  color: #1A1A1A;
  line-height: 1.6;
}
.culture-what-changes__closing {
  font-family: var(--font-heading);
  font-weight: var(--fw-semibold);
  font-size: 20px;
  color: var(--color-navy);
  line-height: 1.4;
}

.culture-what-changes__right { flex: 0 0 480px; }
.culture-what-changes__quote {
  background: var(--color-grey-100);
  border-left: 4px solid var(--color-success);
  border-radius: 0 var(--radius-lg) var(--radius-lg) 0;
  padding: var(--space-lg);
  font-style: italic;
  margin: 0;
}
.culture-what-changes__quote-text {
  font-size: var(--font-md);
  line-height: 1.7;
  color: #1A1A1A;
  margin-bottom: var(--space-xs);
}
.culture-what-changes__quote-author {
  font-family: var(--font-heading);
  font-weight: var(--fw-semibold);
  font-size: var(--font-xs);
  color: var(--color-success);
  text-transform: uppercase;
  letter-spacing: 1px;
  font-style: normal;
}


/* ══════════════════════════════════════
   IS THIS FOR YOU? — Navy split
   ══════════════════════════════════════ */

.culture-for-you {
  background: var(--color-navy);
  border-bottom-left-radius: 300px;
  padding: var(--space-100) 0;
  position: relative;
  overflow: hidden;
}
.culture-for-you::after {
  content: "";
  position: absolute;
  inset: auto -15% -40% auto;
  width: 600px;
  height: 600px;
  background: radial-gradient(circle, rgba(2, 193, 127, 0.12), transparent 60%);
  pointer-events: none;
}
.culture-for-you__container {
  max-width: var(--max-width);
  margin: 0 auto;
  padding: 0 var(--space-lg);
  position: relative;
  z-index: 1;
}
.culture-for-you__heading {
  font-family: var(--font-heading);
  font-weight: var(--fw-semibold);
  font-size: clamp(28px, 3.5vw, 40px);
  color: var(--color-white);
  margin-bottom: var(--space-48);
  line-height: 1.15;
}
.culture-for-you__heading .dot { color: var(--color-success); }

.culture-for-you__split {
  display: flex;
  gap: var(--space-64);
  align-items: flex-start;
}
.culture-for-you__split-left { flex: 1; }
.culture-for-you__split-right { flex: 0 0 380px; }

.culture-for-you__label {
  font-family: var(--font-heading);
  font-weight: var(--fw-semibold);
  font-size: var(--font-xs);
  text-transform: uppercase;
  letter-spacing: 2px;
  color: var(--color-success);
  margin-bottom: var(--space-sm);
}

.culture-for-you__list {
  display: flex;
  flex-direction: column;
  gap: var(--space-xs);
}
.culture-for-you__item {
  display: flex;
  gap: var(--space-3xs);
  align-items: flex-start;
  transition: transform 0.3s cubic-bezier(0.2, 0.8, 0.2, 1);
}
.culture-for-you__item:hover { transform: translateX(4px); }
.culture-for-you__check {
  width: 24px;
  height: 24px;
  min-width: 24px;
  background: rgba(2, 193, 127, 0.18);
  border-radius: var(--radius-pill);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  color: var(--color-success);
  font-size: 12px;
  margin-top: 4px;
  flex-shrink: 0;
}
.culture-for-you__item-text {
  font-size: var(--font-md);
  line-height: 1.65;
  color: var(--color-white);
}

.culture-for-you__not-box {
  background: rgba(255, 255, 255, 0.06);
  border-radius: var(--radius-lg);
  padding: var(--space-md);
  border: 1px solid rgba(255, 255, 255, 0.1);
  backdrop-filter: blur(4px);
}
.culture-for-you__not-title {
  font-family: var(--font-heading);
  font-weight: var(--fw-semibold);
  font-size: 20px;
  color: var(--color-white);
  margin-bottom: var(--space-xs);
}
.culture-for-you__not-body {
  font-size: var(--font-md);
  color: rgba(255, 255, 255, 0.8);
  line-height: 1.65;
}
.culture-for-you__not-closing {
  font-family: var(--font-heading);
  font-weight: var(--fw-semibold);
  font-size: var(--font-md);
  color: var(--color-success);
  margin-top: var(--space-xs);
  line-height: 1.4;
}


/* ══════════════════════════════════════
   RESPONSIVE
   ══════════════════════════════════════ */

@media (max-width: 1024px) {
  .culture-work { padding: var(--space-2xl) 0 var(--space-md); }
  .culture-work__service { padding: var(--space-48) var(--space-sm); }
  .culture-work__service-grid { grid-template-columns: 60px 1fr; gap: var(--space-sm); }
  .culture-work__service-number { font-size: 48px; }
  .culture-work__service-title { font-size: 28px; }
  .culture-work__service-list li { flex: 0 0 calc(50% - (var(--space-xs) / 2)); }
  .culture-work__service-list--2x2 li { flex: 0 0 calc(50% - (var(--space-xs) / 2)); }
  .culture-work__phase { grid-template-columns: 100px 1fr; gap: var(--space-xs); }

  .culture-approach { padding: var(--space-2xl) 0; }
  .culture-approach__container { padding: 0 var(--space-sm); }
  .culture-approach__header { margin-bottom: var(--space-48); }
  .culture-approach__layers { grid-template-columns: 1fr; gap: var(--space-sm); }
  .culture-approach__layer { min-height: 0; padding: var(--space-md); }

  .culture-what-changes { padding: var(--space-2xl) 0; }
  .culture-what-changes__container { padding: 0 var(--space-sm); }
  .culture-what-changes__heading { margin-bottom: var(--space-md); }
  .culture-what-changes__layout { flex-direction: column; gap: var(--space-48); }
  .culture-what-changes__right { flex: none; width: 100%; }

  .culture-for-you { padding: var(--space-2xl) 0; border-bottom-left-radius: 150px; }
  .culture-for-you__container { padding: 0 var(--space-sm); }
  .culture-for-you__heading { margin-bottom: var(--space-md); }
  .culture-for-you__split { flex-direction: column; gap: var(--space-48); }
  .culture-for-you__split-right { flex: none; width: 100%; }
}

@media (max-width: 768px) {
  .culture-work { padding: var(--space-xl) 0 var(--space-sm); }
  .culture-work__header { margin-bottom: var(--space-md); }
  .culture-work__service { padding: var(--space-md) var(--space-xs); }
  .culture-work__service-grid { grid-template-columns: 1fr; gap: var(--space-3xs); }
  .culture-work__service-number { font-size: 36px; opacity: 0.7; }
  .culture-work__service-title { font-size: 24px; }
  .culture-work__service-eyebrow { font-size: 12px; letter-spacing: 1.5px; }
  .culture-work__service-body { font-size: 15px; }
  .culture-work__service-list li { flex: 0 0 100%; padding: var(--space-3xs) var(--space-xs); }
  .culture-work__service-list--2x2 li { flex: 0 0 100%; }
  .culture-work__service-list li:hover { transform: none; }
  .culture-work__phase { grid-template-columns: 1fr; gap: var(--space-4xs); padding: var(--space-2xs) 0; }
  .culture-work__phase-label { padding-left: 0; }
  .culture-work__phase-text { font-size: 15px; }
  .culture-work__phase:hover { background: transparent; }

  .culture-approach { padding: var(--space-xl) 0; }
  .culture-approach__container { padding: 0 var(--space-xs); }
  .culture-approach__header { margin-bottom: var(--space-md); }
  .culture-approach__heading { font-size: 26px; }
  .culture-approach__intro { font-size: 17px; }
  .culture-approach__layer { padding: var(--space-sm); min-height: 0; }
  .culture-approach__layer:hover { transform: none; }
  .culture-approach__layer-title { font-size: 20px; }
  .culture-approach__closing p { font-size: 15px; }

  .culture-what-changes { padding: var(--space-xl) 0; }
  .culture-what-changes__container { padding: 0 var(--space-xs); }
  .culture-what-changes__heading { font-size: 26px; }
  .culture-what-changes__intro { font-size: 17px; }
  .culture-what-changes__item span { font-size: 15px; }
  .culture-what-changes__closing { font-size: 17px; }
  .culture-what-changes__quote { padding: var(--space-sm); }
  .culture-what-changes__quote-text { font-size: 15px; }

  .culture-for-you { padding: var(--space-xl) 0; border-bottom-left-radius: 80px; }
  .culture-for-you__container { padding: 0 var(--space-xs); }
  .culture-for-you__heading { font-size: 26px; }
  .culture-for-you__item-text { font-size: 15px; }
  .culture-for-you__item:hover { transform: none; }
  .culture-for-you__not-box { padding: var(--space-sm); }
  .culture-for-you__not-title { font-size: 18px; }
  .culture-for-you__not-body,
  .culture-for-you__not-closing { font-size: 15px; }
}

@media (max-width: 480px) {
  .culture-work__service-title { font-size: 22px; }
  .culture-approach__heading,
  .culture-what-changes__heading,
  .culture-for-you__heading { font-size: 24px; }
  .culture-for-you { border-bottom-left-radius: 48px; }
}

@media (prefers-reduced-motion: reduce) {
  .culture-work__service-list li,
  .culture-work__icon-wrap,
  .culture-work__phase,
  .culture-approach__layer,
  .culture-approach__layer::before,
  .culture-approach__layer-icon,
  .culture-what-changes__item,
  .culture-for-you__item {
    transition: none;
  }
}
