/* ═══════════════════════════════════════════════════
   BRIDGE® X:CELLERATOR — Swiss International Style
   ═══════════════════════════════════════════════════ */

/* ─── DESIGN TOKENS ─── */
:root {
  --darknavy:  #060E2A;
  --navy:      #0C2054;
  --blue:      #1D51D3;
  --softblue:  #E8EDFB;
  --white:     #FFFFFF;
  --lgray:     #F5F7FA;
  --mgray:     #D0D5DD;
  --dgray:     #667085;

  --font-display: 'Inter', Arial, sans-serif;
  --font-body:    'Inter', Arial, sans-serif;

  --ease-snappy: cubic-bezier(0.19, 1, 0.22, 1);
  --ease-base:   cubic-bezier(0.25, 0.1, 0.25, 1);
}

/* ─── RESET ─── */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
html { scroll-behavior: smooth; font-size: 10px; }

body {
  background: var(--darknavy);
  color: var(--darknavy);
  font-family: var(--font-body);
  font-weight: 400;
  font-size: 16px;
  line-height: 24px;
  overflow-x: hidden;
  letter-spacing: 0.01rem;
}

a { text-decoration: none; color: inherit; }

.container {
  max-width: 100%;
  margin: 0 auto;
  padding: 0 120px;
  position: relative;
  z-index: 1;
}

/* ─── NAV (shared) ─── */
.nav {
  position: fixed;
  top: 0; left: 0; right: 0;
  z-index: 100;
  padding: 1.6rem 24px;
  display: flex;
  justify-content: space-between;
  align-items: center;
}

.nav-logo {
  display: flex;
  align-items: center;
}

.nav-logo-img {
  height: 64px;
  width: auto;
  display: block;
}

/* ─── NAV: transparent (hero) ─── */
.nav--top {
  top: 16px;
  left: 120px;
  right: 120px;
  background: transparent;
  transition: opacity 500ms var(--ease-base) 300ms;
}

.nav--top.hidden {
  opacity: 0;
  pointer-events: none;
  transition-delay: 0ms;
}

.nav--top .nav-logo {
  position: relative;
}

/* ─── NAV: sticky (on scroll) ─── */
.nav--sticky {
  top: 16px;
  left: 120px;
  right: 120px;
  background: rgba(255, 255, 255, 0.92);
  backdrop-filter: blur(16px);
  -webkit-backdrop-filter: blur(16px);
  border: none;
  border-radius: 12px;
  box-shadow: 0 8px 32px rgba(6, 14, 42, 0.12), 0 2px 8px rgba(6, 14, 42, 0.06);
  opacity: 0;
  pointer-events: none;
  transition: opacity 500ms var(--ease-base);
}

.nav--sticky.visible {
  opacity: 1;
  pointer-events: auto;
}

.nav--sticky .nav-logo-img {
  height: 40px;
  filter: invert(1);
}

.nav--sticky .nav-link {
  font-size: 14px;
  line-height: 20px;
  color: rgba(6,14,42,0.6);
}

.nav--sticky .nav-link:hover {
  color: var(--darknavy);
}

.nav--sticky .nav-cta {
  font-size: 14px;
  line-height: 20px;
  padding: 8px 16px;
  color: var(--white);
  background: var(--darknavy);
}

.nav--sticky .nav-cta:hover {
  background: var(--navy);
}


.nav-right {
  display: flex;
  gap: 24px;
  align-items: center;
}

.nav-link {
  font-family: var(--font-body);
  font-size: 18px;
  line-height: 24px;
  font-weight: 500;
  color: rgba(255,255,255,0.8);
  padding: 0.8rem 1.6rem;
  transition: color 150ms;
}

.nav-link:hover { color: var(--white); }

.nav-cta {
  font-family: var(--font-body);
  font-size: 18px;
  line-height: 24px;
  font-weight: 700;
  color: var(--white);
  background: var(--blue);
  padding: 16px 24px;
  margin-left: 1rem;
  border-radius: 4px;
  transition: background 150ms;
}

.nav-cta:hover { background: #1641b0; }

/* ─── NAV FLYOUT DROPDOWNS ─── */
.nav-dropdown {
  position: relative;
}

.nav-link--has-sub {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  cursor: pointer;
  border: none;
  background: none;
}

.nav-chevron {
  transition: transform 300ms var(--ease-snappy);
  flex-shrink: 0;
}

.nav-dropdown:hover .nav-chevron,
.nav-dropdown.open .nav-chevron {
  transform: rotate(180deg);
}

.nav-flyout {
  position: absolute;
  top: calc(100% + 12px);
  left: 50%;
  transform: translateX(-50%) translateY(8px);
  min-width: 320px;
  background: rgba(255, 255, 255, 0.96);
  backdrop-filter: blur(20px);
  -webkit-backdrop-filter: blur(20px);
  border-radius: 8px;
  box-shadow: 0 16px 48px rgba(6, 14, 42, 0.14), 0 4px 12px rgba(6, 14, 42, 0.06);
  padding: 8px;
  opacity: 0;
  pointer-events: none;
  transition: opacity 250ms var(--ease-base), transform 250ms var(--ease-snappy);
  z-index: 110;
}

.nav-flyout::before {
  content: '';
  position: absolute;
  top: -12px;
  left: 0;
  right: 0;
  height: 12px;
}

.nav-dropdown:hover .nav-flyout,
.nav-dropdown.open .nav-flyout {
  opacity: 1;
  pointer-events: auto;
  transform: translateX(-50%) translateY(0);
}

.nav-flyout-link {
  display: flex;
  flex-direction: column;
  gap: 2px;
  padding: 14px 20px;
  border-radius: 6px;
  transition: background 180ms var(--ease-base);
}

.nav-flyout-link:hover {
  background: var(--lgray);
}

.nav-flyout-label {
  font-family: var(--font-body);
  font-size: 18px;
  font-weight: 600;
  color: var(--darknavy);
  letter-spacing: -0.01em;
  line-height: 1.3;
}

.nav-flyout-desc {
  font-family: var(--font-body);
  font-size: 13px;
  font-weight: 400;
  color: var(--dgray);
  line-height: 1.4;
}

.nav-flyout-link:hover .nav-flyout-label {
  color: var(--blue);
}

/* Sticky nav flyout adjustments */
.nav--sticky .nav-flyout {
  top: calc(100% + 8px);
}

.nav--sticky .nav-link--has-sub {
  font-size: 14px;
  line-height: 20px;
  color: rgba(6,14,42,0.6);
}

.nav--sticky .nav-link--has-sub:hover {
  color: var(--darknavy);
}

/* Top nav button text inherits nav-link style */
.nav--top .nav-link--has-sub {
  font-family: var(--font-body);
  font-size: 18px;
  line-height: 24px;
  font-weight: 500;
  color: rgba(255,255,255,0.8);
  padding: 0.8rem 1.6rem;
  transition: color 150ms;
}

.nav--top .nav-link--has-sub:hover {
  color: var(--white);
}

/* ─── HERO ─── */
.hero {
  min-height: 100lvh;
  background: transparent;
  position: relative;
  z-index: 1;
  display: flex;
  flex-direction: column;
  justify-content: center;
  overflow: hidden;
  padding: 120px 120px 160px;
}

/* Blob canvas background */
.blob-canvas {
  position: absolute;
  inset: 0;
  pointer-events: none;
}

.blob-canvas--global {
  position: fixed;
  inset: 0;
  z-index: 0;
}

.hero-grid-overlay {
  display: none;
}

/* Blue vertical rule — Swiss accent */
.hero-rule {
  display: none;
}

/* Radial glow */
.hero-glow {
  position: absolute;
  width: 70vw; height: 70vw;
  border-radius: 50%;
  background: radial-gradient(circle, rgba(29,81,211,0.18) 0%, transparent 65%);
  top: -20vw; right: -10vw;
  pointer-events: none;
}

.hero-content {
  position: relative;
  z-index: 2;
  padding-left: 3.2rem;
}

.hero-eyebrow {
  font-family: var(--font-body);
  font-size: 1.1rem;
  font-weight: 700;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: var(--blue);
  margin-bottom: 2.4rem;
  opacity: 0;
  animation: fadeUp 0.9s var(--ease-snappy) 0.1s forwards;
}

.hero-title {
  font-family: var(--font-display);
  font-size: max(6rem, min(11vw, 15rem));
  font-weight: 400;
  line-height: 0.92;
  letter-spacing: -0.05em;
  color: var(--white);
  margin-bottom: 4.8rem;
  opacity: 0;
  animation: fadeUp 1s var(--ease-snappy) 0.2s forwards;
}

.hero-title .accent { color: var(--blue); font-weight: 400; }

.hero-bottom {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: 3.2rem;
  opacity: 0;
  animation: fadeUp 1s var(--ease-snappy) 0.35s forwards;
}

.hero-sub {
  font-family: var(--font-body);
  font-size: 24px;
  font-weight: 400;
  line-height: 32px;
  color: rgba(255,255,255,0.8);
  max-width: 80%;
  letter-spacing: 0.01em;
}

.hero-cta {
  display: inline-flex;
  align-items: center;
  gap: 1.2rem;
  background: var(--blue);
  color: var(--white);
  padding: 16px 24px;
  font-family: var(--font-body);
  font-size: 18px;
  line-height: 24px;
  font-weight: 700;
  border-radius: 4px;
  white-space: nowrap;
  flex-shrink: 0;
  transition: background 150ms, transform 150ms;
}

.hero-cta:hover { background: #1641b0; transform: translateY(-2px); }

.hero-cta-arrow { width: 20px; height: 20px; transition: transform 150ms; }
.hero-cta:hover .hero-cta-arrow { transform: translate(3px, -3px); }

/* ─── SECTION BASES ─── */
.s-light     { background: var(--lgray);    padding: 160px 0; position: relative; overflow: hidden; }
.s-white     { background: var(--white);    padding: 160px 0; position: relative; overflow: hidden; }
.s-dark      { background: transparent; padding: 160px 0; position: relative; overflow: hidden; z-index: 1; }
.s-navy      { background: var(--navy);     padding: 160px 0; position: relative; overflow: hidden; }
.s-blue      { background: var(--blue);     padding: 160px 0; position: relative; overflow: hidden; }
.s-softblue  { background: var(--softblue); padding: 160px 0; position: relative; overflow: hidden; }

/* ─── FLOATING CARD SECTION ─── */
.s-card-wrap {
  background: transparent;
  padding: 80px 40px 0;
  position: relative;
  z-index: 1;
}

.s-card {
  border-radius: 8px;
  padding: 120px 120px;
  position: relative;
  overflow: hidden;
}

.s-card.card-navy { background: var(--navy); }
.s-card.card-dark { background: var(--darknavy); }
.s-card.card-blue { background: var(--blue); }
.s-card.card-white { background: var(--white); }
.s-card.card-light { background: var(--lgray); }

/* ─── IMAGE CARD ─── */
.s-card.card-image {
  background: var(--darknavy);
  padding-top: 160px;
  padding-bottom: 160px;
  min-height: 560px;
  display: flex;
  flex-direction: column;
  justify-content: flex-end;
}

.card-image-bg {
  position: absolute;
  inset: 0;
  background-size: cover;
  background-position: center;
  border-radius: 8px;
}

.card-image-overlay {
  position: absolute;
  inset: 0;
  background: linear-gradient(to bottom, rgba(6,14,42,0.2) 0%, rgba(6,14,42,0.85) 70%);
  border-radius: 8px;
}

.card-image-content {
  position: relative;
  z-index: 1;
  display: flex;
  flex-direction: column;
  gap: 32px;
}

/* ─── EYEBROW LABEL ─── */
.label {
  font-family: var(--font-body);
  font-size: 18px;
  font-weight: 400;
  letter-spacing: 0.01em;
  color: var(--navy);
  display: flex;
  align-items: center;
  gap: 0.6rem;
  margin-bottom: 2.4rem;
}

.label::before {
  display: none;
}

.label.on-dark  { color: rgba(255,255,255,0.8); }
.label.on-blue  { color: rgba(255,255,255,0.65); }
.label.on-blue::before { background: rgba(255,255,255,0.65); }

/* ─── DISPLAY TYPE ─── */
.display-xl {
  font-family: var(--font-display);
  font-size: max(4rem, min(5.2vw, 7.2rem));
  font-weight: 400;
  line-height: 1.1;
  letter-spacing: -0.04em;
  color: var(--navy);
}

.display-xl.on-dark { color: var(--white); }
.display-xl.on-blue { color: var(--white); }

.display-lg {
  font-family: var(--font-display);
  font-size: max(4rem, min(6vw, 9rem));
  font-weight: 400;
  line-height: 1.0;
  letter-spacing: -0.04em;
  color: var(--navy);
}

.display-lg.on-dark { color: var(--white); }
.display-lg.on-blue { color: var(--white); }

.display-md {
  font-family: var(--font-display);
  font-size: max(2.4rem, 2.8vw);
  font-weight: 400;
  line-height: 1.1;
  letter-spacing: -0.03em;
  color: rgba(12,32,84,0.8);
}

.display-md.on-dark { color: rgba(255,255,255,0.8); }

.body-copy {
  font-family: var(--font-body);
  font-size: 24px;
  font-weight: 400;
  line-height: 32px;
  color: var(--dgray);
  letter-spacing: 0.01em;
}

.body-copy.on-dark { color: rgba(255,255,255,0.8); }
.body-copy.on-blue { color: rgba(255,255,255,0.65); }

/* ─── 2-COL HEADER LAYOUT ─── */
.section-head {
  display: flex;
  flex-direction: column;
  gap: 32px;
  margin-bottom: 6rem;
}

/* ─── INTRO ─── */
.intro-copy {
  font-family: var(--font-display);
  font-size: max(2.8rem, min(3.6vw, 5rem));
  font-weight: 400;
  line-height: 1.12;
  letter-spacing: -0.03em;
  color: var(--navy);
  max-width: 96rem;
}

.intro-copy .muted { color: rgba(12,32,84,0.8); }

.badge-row {
  display: flex;
  gap: 0.6rem;
  flex-wrap: wrap;
  margin-top: 4rem;
}

.badge {
  font-family: var(--font-body);
  font-size: 1rem;
  font-weight: 500;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--navy);
  border: 1px solid var(--mgray);
  padding: 0.55rem 1.4rem;
  transition: border-color 150ms, background 150ms;
}

.badge:hover { border-color: var(--blue); color: var(--blue); }

.badge.filled {
  background: var(--navy);
  border-color: var(--navy);
  color: var(--white);
}

.badge.filled:hover { background: var(--blue); border-color: var(--blue); }

/* ─── METRICS — bordered grid ─── */
.metrics-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  border-left: 1px solid var(--mgray);
}

.metric-cell {
  border-right: 1px solid var(--mgray);
  border-top: 1px solid var(--mgray);
  border-bottom: 1px solid var(--mgray);
  padding: 5rem 3.6rem 4rem;
  display: flex;
  flex-direction: column;
  gap: 1rem;
  cursor: default;
  transition: background 250ms var(--ease-base);
  position: relative;
  background: var(--white);
}

.metric-cell:hover { background: var(--navy); }
.metric-cell:hover .metric-num   { color: rgba(255,255,255,0.12); }
.metric-cell:hover .metric-label { color: rgba(255,255,255,0.8); }
.metric-cell:hover .metric-pip   { background: var(--blue); }

.metric-pip {
  width: 0.5rem; height: 0.5rem;
  border-radius: 50%;
  background: var(--blue);
  opacity: 0.5;
  margin-bottom: 0.8rem;
  transition: background 250ms, opacity 250ms;
}

.metric-num {
  font-family: var(--font-display);
  font-size: max(5rem, 7.5vw);
  font-weight: 200;
  line-height: 0.88;
  letter-spacing: -0.03em;
  color: rgba(12,32,84,0.12);
  transition: color 250ms;
}

.metric-num sup {
  font-size: 0.35em;
  vertical-align: top;
  margin-top: 0.3em;
  font-weight: 500;
  font-family: var(--font-body);
}

.metric-label {
  font-family: var(--font-body);
  font-size: 1.05rem;
  font-weight: 700;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--dgray);
  transition: color 250ms;
  margin-top: 0.4rem;
}

/* ─── 6D LOGIC ─── */
.sixd-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 0 5rem;
  border-top: 1px solid rgba(255,255,255,0.08);
}

.sixd-item {
  border-bottom: 1px solid rgba(255,255,255,0.08);
  padding: 2.8rem 0;
  display: flex;
  gap: 2.4rem;
  align-items: flex-start;
  cursor: default;
  transition: padding 200ms var(--ease-snappy);
}

.sixd-item:hover { padding-left: 1.2rem; }
.sixd-item:hover .sixd-num   { color: var(--blue); }
.sixd-item:hover .sixd-title { color: var(--white); }

.sixd-num {
  font-family: var(--font-body);
  font-size: 1rem;
  font-weight: 500;
  letter-spacing: 0.12em;
  color: rgba(255,255,255,0.8);
  flex-shrink: 0;
  padding-top: 0.5rem;
  transition: color 200ms;
  min-width: 2.8rem;
}

.sixd-title {
  font-family: var(--font-display);
  font-size: 2.4rem;
  font-weight: 400;
  letter-spacing: -0.03em;
  color: rgba(255,255,255,0.8);
  line-height: 1;
  margin-bottom: 0.8rem;
  transition: color 200ms;
}

.sixd-desc {
  font-family: var(--font-body);
  font-size: 18px;
  font-weight: 400;
  line-height: 24px;
  color: rgba(255,255,255,0.8);
}

/* ─── SOLUTIONS CARDS ─── */
.solutions-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 1px;
  background: var(--mgray);
  border: 1px solid var(--mgray);
}

.solution-card {
  background: var(--white);
  aspect-ratio: 674/420;
  padding: 4.8rem;
  display: flex;
  flex-direction: column;
  position: relative;
  overflow: hidden;
  cursor: default;
  transition: background 280ms var(--ease-base);
}

.solution-card:hover { background: var(--navy); }
.solution-card:hover .sol-label  { color: var(--blue); }
.solution-card:hover .sol-num    { color: rgba(255,255,255,0.06); }
.solution-card:hover .sol-title  { color: var(--white); }
.solution-card:hover .sol-copy   { color: rgba(255,255,255,0.8); }

.solution-card.blue-card { background: var(--blue); }
.solution-card.blue-card:hover { background: #1641b0; }
.solution-card.blue-card .sol-label { color: rgba(255,255,255,0.8); }
.solution-card.blue-card .sol-num   { color: rgba(255,255,255,0.08); }
.solution-card.blue-card .sol-title { color: var(--white); }
.solution-card.blue-card .sol-copy  { color: rgba(255,255,255,0.8); }

.sol-label {
  font-family: var(--font-body);
  font-size: 1rem;
  font-weight: 700;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  color: var(--blue);
  transition: color 280ms;
}

.sol-num {
  font-family: var(--font-display);
  font-size: max(9rem, 13vw);
  font-weight: 200;
  line-height: 0.88;
  letter-spacing: -0.04em;
  color: rgba(12,32,84,0.07);
  margin-top: auto;
  margin-bottom: -1.5rem;
  transition: color 280ms;
}

.sol-title {
  font-family: var(--font-display);
  font-size: 2.4rem;
  font-weight: 400;
  line-height: 1.1;
  letter-spacing: -0.03em;
  color: var(--navy);
  margin-bottom: 1.2rem;
  transition: color 280ms;
}

.sol-copy {
  font-family: var(--font-body);
  font-size: 18px;
  font-weight: 400;
  line-height: 24px;
  color: var(--dgray);
  max-width: 34rem;
  transition: color 280ms;
}

/* ─── IMPACT LIST ─── */
.impact-list { border-top: 1px solid rgba(255,255,255,0.1); }

.impact-item {
  display: grid;
  grid-template-columns: 3.2rem 1fr 1.2fr 1.6rem;
  gap: 3rem;
  align-items: flex-start;
  border-bottom: 1px solid rgba(255,255,255,0.1);
  padding: 2.4rem 0;
  cursor: default;
  transition: padding 200ms var(--ease-snappy), background 200ms;
}

.impact-item:hover { padding-left: 1.2rem; background: rgba(29,81,211,0.08); }
.impact-item:hover .impact-num   { color: var(--blue); }
.impact-item:hover .impact-title { color: var(--white); }
.impact-item:hover .impact-arr   { opacity: 1; transform: translate(0,0); }

.impact-num {
  font-family: var(--font-body);
  font-size: 1rem;
  font-weight: 500;
  letter-spacing: 0.12em;
  color: rgba(255,255,255,0.8);
  transition: color 200ms;
}

.impact-title {
  font-family: var(--font-display);
  font-size: 20px;
  font-weight: 400;
  letter-spacing: -0.025em;
  color: rgba(255,255,255,0.8);
  line-height: 1.2;
  transition: color 200ms;
}

.impact-desc {
  font-family: var(--font-body);
  font-size: 16px;
  font-weight: 400;
  line-height: 24px;
  color: rgba(255,255,255,0.8);
}

.impact-arr {
  width: 18px; height: 18px;
  color: var(--blue);
  opacity: 0;
  transform: translate(-4px, 4px);
  transition: opacity 200ms, transform 200ms;
}

/* ─── EXPERTISE ─── */
.expertise-item {
  background: transparent;
  padding: 2.4rem 2.8rem;
  display: grid;
  grid-template-columns: 3.2rem 1fr 1.4fr 1.6rem;
  gap: 3rem;
  align-items: center;
  border-bottom: 1px solid var(--mgray);
  cursor: default;
  transition: background 200ms, transform 200ms;
}

.expertise-item:first-child { border-top: 1px solid var(--mgray); }

.expertise-item:hover { background: var(--navy); transform: translateX(0.5rem); }
.expertise-item:hover .exp-num   { color: var(--blue); }
.expertise-item:hover .exp-name  { color: var(--white); }
.expertise-item:hover .exp-desc  { color: rgba(255,255,255,0.8); }
.expertise-item:hover .exp-arr   { opacity: 1; color: var(--blue); }

.exp-num {
  font-family: var(--font-body);
  font-size: 1rem;
  font-weight: 500;
  letter-spacing: 0.12em;
  color: var(--mgray);
  transition: color 200ms;
}

.exp-name {
  font-family: var(--font-display);
  font-size: 2rem;
  font-weight: 400;
  letter-spacing: -0.03em;
  color: var(--navy);
  line-height: 1;
  transition: color 200ms;
}

.exp-desc {
  font-family: var(--font-body);
  font-size: 18px;
  font-weight: 400;
  line-height: 24px;
  color: var(--dgray);
  transition: color 200ms;
}

.exp-arr {
  width: 18px; height: 18px;
  color: var(--mgray);
  opacity: 0;
  text-align: right;
  transition: opacity 200ms, color 200ms;
}

/* ─── TEAM ─── */
.team-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 1px;
  background: var(--mgray);
  border: 1px solid var(--mgray);
  margin-bottom: 1px;
}

.team-card {
  background: var(--softblue);
  padding: 3.2rem 2.8rem;
  display: flex;
  flex-direction: column;
  gap: 1.6rem;
  cursor: default;
  transition: background 250ms;
}

.team-card:hover { background: var(--navy); }
.team-card:hover .team-avatar { background: var(--blue); }
.team-card:hover .team-initials { color: var(--white); }
.team-card:hover .team-name   { color: var(--white); }
.team-card:hover .team-role   { color: var(--blue); }
.team-card:hover .team-bio    { color: rgba(255,255,255,0.8); }

.team-avatar {
  width: 5.6rem; height: 5.6rem;
  background: var(--white);
  display: flex;
  align-items: center;
  justify-content: center;
  transition: background 250ms;
}

.team-initials {
  font-family: var(--font-display);
  font-size: 1.8rem;
  font-weight: 500;
  letter-spacing: 0.06em;
  color: var(--navy);
  transition: color 250ms;
}

.team-name {
  font-family: var(--font-display);
  font-size: 1.9rem;
  font-weight: 400;
  letter-spacing: -0.03em;
  line-height: 1.1;
  color: var(--navy);
  transition: color 250ms;
}

.team-role {
  font-family: var(--font-body);
  font-size: 1rem;
  font-weight: 700;
  line-height: 1.2;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--blue);
  margin-top: 8px;
  transition: color 250ms;
}

.team-bio {
  font-family: var(--font-body);
  font-size: 18px;
  font-weight: 400;
  line-height: 24px;
  color: var(--dgray);
  transition: color 250ms;
}

/* ─── EXPERTS BAND ─── */
.experts-band {
  background: var(--blue);
  padding: 5rem 4rem;
  display: grid;
  grid-template-columns: auto 1fr;
  gap: 5rem;
  align-items: center;
}

.experts-num {
  font-family: var(--font-display);
  font-size: max(7rem, 10vw);
  font-weight: 200;
  line-height: 0.88;
  letter-spacing: -0.04em;
  color: rgba(255,255,255,0.8);
  flex-shrink: 0;
}

.experts-desc {
  font-family: var(--font-body);
  font-size: 18px;
  font-weight: 400;
  line-height: 24px;
  color: rgba(255,255,255,0.8);
}

/* ─── FOOTER ─── */
footer {
  background: transparent;
  padding: 80px 120px 116px;
  position: relative;
  z-index: 1;
}

.footer-inner {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 6rem;
}

.footer-headline {
  font-family: var(--font-display);
  font-size: max(3rem, 3.8vw);
  font-weight: 400;
  line-height: 1.05;
  letter-spacing: -0.04em;
  color: var(--white);
  margin-bottom: 2rem;
}

.footer-sub {
  font-family: var(--font-body);
  font-size: 18px;
  font-weight: 400;
  line-height: 24px;
  color: rgba(255,255,255,0.8);
  margin-bottom: 3.2rem;
  max-width: 40rem;
}

.footer-btns { display: flex; gap: 1rem; }

.footer-btn {
  font-family: var(--font-body);
  font-size: 18px;
  line-height: 24px;
  font-weight: 700;
  color: var(--white);
  background: var(--darknavy);
  padding: 16px 24px;
  border-radius: 4px;
  transition: background 150ms;
}

.footer-btn:hover { background: var(--navy); }

.footer-btn.ghost {
  background: transparent;
  border: 1px solid rgba(255,255,255,0.2);
}

.footer-btn.ghost:hover { border-color: var(--blue); color: var(--blue); background: transparent; }

.footer-nav-item {
  border-bottom: 1px solid rgba(255,255,255,0.1);
  padding: 1.4rem 0;
  display: flex;
  justify-content: space-between;
  align-items: center;
  font-family: var(--font-display);
  font-size: max(2rem, 2.6vw);
  font-weight: 400;
  letter-spacing: -0.03em;
  color: var(--white);
  transition: color 150ms, padding-left 200ms;
}

.footer-nav-item:hover { color: var(--blue); padding-left: 0.8rem; }

.footer-nav-arrow { width: 24px; height: 24px; }

.footer-bottom {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 80px 0 0;
  margin: 1px 0 0;
  border-top: 1px solid rgba(255,255,255,0.06);
}

.footer-logo {
  height: 64px;
  width: auto;
  opacity: 0.8;
}

.footer-legal {
  font-family: var(--font-body);
  font-size: 1.1rem;
  font-weight: 500;
  letter-spacing: 0.04em;
  color: rgba(255,255,255,0.8);
  text-align: right;
  line-height: 1.9;
  text-transform: uppercase;
}

/* ─── SCROLL REVEAL ─── */
.reveal {
  opacity: 0;
  transform: translateY(2.4rem);
  transition: opacity 0.75s var(--ease-snappy), transform 0.75s var(--ease-snappy);
}

.reveal.visible { opacity: 1; transform: translateY(0); }
.reveal-delay-1 { transition-delay: 0.08s; }
.reveal-delay-2 { transition-delay: 0.16s; }
.reveal-delay-3 { transition-delay: 0.24s; }

/* ─── ANIMATIONS ─── */
@keyframes fadeUp {
  from { opacity: 0; transform: translateY(2.4rem); }
  to   { opacity: 1; transform: translateY(0); }
}

/* ─── CHAT PROMPT (floating bar) ─── */
.chat-prompt {
  position: fixed;
  bottom: 56px;
  left: 50%;
  transform: translateX(-50%) translateY(24px);
  z-index: 200;
  width: min(728px, calc(100vw - 80px));
  opacity: 0;
  pointer-events: none;
  transition: opacity 600ms var(--ease-base), transform 600ms var(--ease-snappy);
}

.chat-prompt.entered {
  opacity: 1;
  pointer-events: auto;
  transform: translateX(-50%) translateY(0);
}

.chat-prompt.hidden {
  opacity: 0;
  transform: translateX(-50%) translateY(24px);
  pointer-events: none;
}

.chat-prompt-bar {
  display: flex;
  align-items: center;
  gap: 8px;
  background: rgba(255, 255, 255, 0.92);
  backdrop-filter: blur(16px);
  border-radius: 12px;
  padding: 8px 8px 8px 24px;
  box-shadow: 0 8px 32px rgba(6, 14, 42, 0.12), 0 2px 8px rgba(6, 14, 42, 0.06);
}

.chat-prompt-input {
  flex: 1;
  border: none;
  outline: none;
  background: transparent;
  font-family: var(--font-body);
  font-size: 18px;
  line-height: 24px;
  color: var(--darknavy);
}

.chat-prompt-input::placeholder {
  color: rgba(6, 14, 42, 0.4);
}

.chat-prompt-send {
  width: 40px;
  height: 40px;
  border: none;
  border-radius: 8px;
  background: var(--darknavy);
  color: var(--white);
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  transition: background 150ms;
}

.chat-prompt-send:hover {
  background: var(--blue);
}

.chat-prompt-send svg {
  width: 18px;
  height: 18px;
}

/* ─── CHAT PANEL ─── */
.chat-overlay {
  position: fixed;
  inset: 0;
  z-index: 200;
  background: rgba(6, 14, 42, 0.4);
  backdrop-filter: blur(24px);
  -webkit-backdrop-filter: blur(24px);
  display: flex;
  align-items: center;
  justify-content: center;
  opacity: 0;
  pointer-events: none;
  transition: opacity 400ms var(--ease-base);
}

.chat-overlay.open {
  opacity: 1;
  pointer-events: auto;
}

.chat-panel {
  width: 80vw;
  max-height: 88%;
  min-height: 88vh;
  background: var(--lgray);
  border-radius: 8px;
  display: flex;
  flex-direction: column;
  transform: scale(0.97);
  transition: transform 400ms var(--ease-base);
}

.chat-overlay.open .chat-panel {
  transform: scale(1);
}

.chat-panel-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 16px 40px;
  border-bottom: 1px solid rgba(6, 14, 42, 0.06);
}

.chat-panel-title {
  font-family: var(--font-body);
  font-size: 18px;
  line-height: 24px;
  font-weight: 700;
  color: var(--darknavy);
  letter-spacing: 0.04em;
}

.chat-panel-close {
  width: 32px;
  height: 32px;
  border: none;
  border-radius: 8px;
  background: transparent;
  color: var(--dgray);
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: background 150ms, color 150ms;
}

.chat-panel-close:hover {
  background: var(--lgray);
  color: var(--darknavy);
}

.chat-panel-close svg {
  width: 18px;
  height: 18px;
}

.chat-panel-messages {
  flex: 1;
  overflow-y: auto;
  padding: 40px 40px;
  display: flex;
  flex-direction: column;
  gap: 16px;
}

.chat-msg {
  max-width: 85%;
  padding: 12px 16px;
  border-radius: 12px;
  font-family: var(--font-body);
  font-size: 24px;
  line-height: 32px;
}

.chat-msg.user {
  align-self: flex-end;
  background: var(--darknavy);
  color: var(--white);
  border-bottom-right-radius: 4px;
}

.chat-msg.bot {
  align-self: flex-start;
  background: var(--lgray);
  color: var(--darknavy);
  border-bottom-left-radius: 4px;
}

.chat-panel-input-wrap {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 24px 40px;
  border-top: 1px solid rgba(6, 14, 42, 0.06);
}

.chat-panel-input {
  flex: 1;
  border: none;
  outline: none;
  background: transparent;
  font-family: var(--font-body);
  font-size: 24px;
  line-height: 32px;
  color: var(--darknavy);
}

.chat-panel-input::placeholder {
  color: rgba(6, 14, 42, 0.4);
}

.chat-panel-send {
  width: 36px;
  height: 36px;
  border: none;
  border-radius: 8px;
  background: var(--darknavy);
  color: var(--white);
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  transition: background 150ms;
}

.chat-panel-send:hover {
  background: var(--blue);
}

.chat-panel-send svg {
  width: 16px;
  height: 16px;
}

/* ─── HAMBURGER (hidden on desktop) ─── */
.nav-hamburger {
  display: none;
  background: none;
  border: none;
  cursor: pointer;
  width: 44px;
  height: 44px;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  gap: 7px;
  padding: 0;
  z-index: 10;
}

.hamburger-line {
  display: block;
  width: 24px;
  height: 2px;
  background: var(--white);
  transition: transform 300ms var(--ease-snappy), opacity 200ms;
}

.nav--sticky .hamburger-line {
  background: var(--darknavy);
}

/* ─── MOBILE MENU ─── */
.mobile-menu {
  position: fixed;
  inset: 0;
  z-index: 300;
  background: var(--darknavy);
  display: flex;
  flex-direction: column;
  opacity: 0;
  pointer-events: none;
  transition: opacity 400ms var(--ease-base);
  overflow-y: auto;
  -webkit-overflow-scrolling: touch;
}

.mobile-menu.open {
  opacity: 1;
  pointer-events: auto;
}

.mobile-menu-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 1.6rem 24px;
  flex-shrink: 0;
}

.mobile-menu-header .nav-logo-img {
  height: 48px;
}

.mobile-menu-close {
  background: none;
  border: none;
  cursor: pointer;
  width: 44px;
  height: 44px;
  display: flex;
  align-items: center;
  justify-content: center;
  position: relative;
}

.close-line {
  display: block;
  width: 24px;
  height: 2px;
  background: var(--white);
  position: absolute;
}

.close-line:first-child {
  transform: rotate(45deg);
}

.close-line:last-child {
  transform: rotate(-45deg);
}

.mobile-menu-body {
  flex: 1;
  display: flex;
  flex-direction: column;
  justify-content: center;
  padding: 0 32px 80px;
}

.mobile-menu-item {
  border-bottom: 1px solid rgba(255, 255, 255, 0.08);
}

.mobile-menu-item:first-child {
  border-top: 1px solid rgba(255, 255, 255, 0.08);
}

.mobile-menu-link {
  display: flex;
  align-items: center;
  justify-content: space-between;
  width: 100%;
  padding: 20px 0;
  font-family: var(--font-display);
  font-size: clamp(3.2rem, 8vw, 5.6rem);
  font-weight: 400;
  letter-spacing: -0.04em;
  line-height: 1.1;
  color: var(--white);
  background: none;
  border: none;
  cursor: pointer;
  text-align: left;
  transition: color 200ms;
}

.mobile-menu-link:hover,
.mobile-menu-link:active {
  color: var(--blue);
}

.mobile-menu-cta {
  color: var(--blue);
}

.mobile-menu-arrow {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 40px;
  height: 40px;
  color: rgba(255, 255, 255, 0.4);
  transition: transform 400ms var(--ease-snappy), color 200ms;
  flex-shrink: 0;
}

.mobile-menu-arrow svg {
  width: 28px;
  height: 28px;
}

.mobile-menu-item.open .mobile-menu-arrow {
  transform: rotate(180deg);
  color: var(--blue);
}

.mobile-menu-sub {
  display: grid;
  grid-template-rows: 0fr;
  transition: grid-template-rows 500ms var(--ease-snappy);
}

.mobile-menu-item.open .mobile-menu-sub {
  grid-template-rows: 1fr;
}

.mobile-menu-sub > * {
  overflow: hidden;
}

/* Inner wrapper for sub items */
.mobile-menu-sub {
  overflow: hidden;
  max-height: 0;
  transition: max-height 500ms var(--ease-snappy);
}

.mobile-menu-item.open .mobile-menu-sub {
  max-height: 600px;
}

.mobile-sub-link {
  display: block;
  padding: 12px 0 12px 8px;
  font-family: var(--font-body);
  font-size: 1.8rem;
  font-weight: 400;
  letter-spacing: 0.01em;
  color: rgba(255, 255, 255, 0.6);
  transition: color 200ms, padding-left 200ms var(--ease-snappy);
}

.mobile-sub-link:hover,
.mobile-sub-link:active {
  color: var(--white);
  padding-left: 16px;
}

.mobile-sub-link:last-child {
  padding-bottom: 24px;
}

/* ─── MOBILE BREAKPOINT ─── */
@media (max-width: 768px) {

  /* Show hamburger, hide desktop nav-right & flyouts */
  .nav-hamburger {
    display: flex;
  }

  .nav-right {
    display: none;
  }

  .nav-flyout {
    display: none;
  }

  /* Both navs: use sticky style on mobile */
  .nav--top {
    top: 0;
    left: 0;
    right: 0;
    padding: 2.4rem 16px;
  }

  .nav--top .nav-logo-img {
    height: 40px;
  }

  .nav--top .hamburger-line {
    background: var(--white);
  }

  .nav--sticky {
    top: 0;
    left: 8px;
    right: 8px;
    top: 8px;
    padding: 1rem 16px;
  }

  .nav--sticky .nav-logo-img {
    height: 36px;
  }

  /* Hero mobile */
  .hero {
    min-height: auto;
    padding: 120px 24px 64px;
  }

  .hero-content {
    padding-left: 0;
  }

  .hero-title {
    font-size: max(4.4rem, 12vw);
    margin-bottom: 3.2rem;
  }

  .hero-eyebrow {
    font-size: 1rem;
    margin-bottom: 2rem;
  }

  .hero-bottom {
    flex-direction: column;
    align-items: flex-start;
    gap: 2.4rem;
  }

  .hero-sub {
    font-size: 18px;
    line-height: 26px;
    max-width: 100%;
  }

  .hero-cta {
    font-size: 16px;
    padding: 14px 20px;
  }

  /* Cards mobile */
  .s-card-wrap {
    padding: 40px 12px 0;
  }

  .s-card {
    padding: 48px 24px;
    border-radius: 6px;
  }

  .s-dark {
    padding: 80px 0;
  }

  .container {
    padding: 0 24px;
  }

  /* Intro */
  .intro-copy {
    font-size: max(2.4rem, 7vw);
  }

  .badge-row {
    margin-top: 2.4rem;
  }

  .badge {
    font-size: 0.85rem;
    padding: 0.4rem 1rem;
  }

  /* Metrics */
  .metrics-grid {
    grid-template-columns: 1fr 1fr;
    margin-top: 48px !important;
  }

  .metric-cell {
    padding: 3rem 2rem 2.4rem;
  }

  .metric-num {
    font-size: max(4rem, 14vw);
  }

  .metric-label {
    font-size: 0.85rem;
  }

  /* Display type */
  .display-xl {
    font-size: max(3rem, 8vw);
  }

  .body-copy {
    font-size: 18px;
    line-height: 26px;
  }

  .section-head {
    gap: 24px;
    margin-bottom: 4rem;
  }

  /* 6D grid */
  .sixd-grid {
    grid-template-columns: 1fr;
    gap: 0;
  }

  .sixd-title {
    font-size: 2rem;
  }

  .sixd-desc {
    font-size: 16px;
    line-height: 22px;
  }

  /* Solutions */
  .solutions-grid {
    grid-template-columns: 1fr;
  }

  .solution-card {
    aspect-ratio: auto;
    padding: 3.2rem 2.4rem;
  }

  .sol-num {
    font-size: max(6rem, 20vw);
  }

  .sol-title {
    font-size: 2rem;
  }

  .sol-copy {
    font-size: 16px;
    line-height: 22px;
  }

  /* Impact */
  .impact-item {
    grid-template-columns: 2.4rem 1fr 1.6rem;
    gap: 1.2rem;
  }

  .impact-desc {
    display: none;
  }

  .impact-title {
    font-size: 18px;
  }

  /* Expertise */
  .expertise-item {
    grid-template-columns: 2.4rem 1fr 1.6rem;
    gap: 1.2rem;
    padding: 2rem 1.2rem;
  }

  .exp-desc {
    display: none;
  }

  .exp-name {
    font-size: 1.6rem;
  }

  /* Team */
  .team-grid {
    grid-template-columns: 1fr;
  }

  .team-card {
    padding: 2.4rem 2rem;
  }

  /* Experts band */
  .experts-band {
    grid-template-columns: 1fr;
    gap: 2rem;
    padding: 3.2rem 2.4rem;
  }

  .experts-num {
    font-size: max(5rem, 16vw);
  }

  /* Image card */
  .s-card.card-image {
    min-height: 400px;
    padding-top: 120px;
    padding-bottom: 48px;
  }

  /* Footer */
  footer {
    padding: 40px 12px 96px;
  }

  .footer-inner {
    grid-template-columns: 1fr;
    gap: 4rem;
  }

  .footer-headline {
    font-size: max(2.8rem, 7vw);
  }

  .footer-btns {
    flex-direction: column;
  }

  .footer-btn {
    text-align: center;
    font-size: 16px;
    padding: 14px 20px;
  }

  .footer-nav-item {
    font-size: max(1.8rem, 5vw);
    padding: 1.2rem 0;
  }

  .footer-bottom {
    flex-direction: column;
    gap: 2rem;
    padding: 40px 0 0;
    align-items: flex-start;
  }

  .footer-logo {
    height: 48px;
  }

  .footer-legal {
    font-size: 0.9rem;
    text-align: left;
  }

  /* Chat prompt */
  .chat-prompt {
    bottom: 24px;
    width: calc(100vw - 32px);
  }

  .chat-panel {
    width: 96vw;
    min-height: 80vh;
  }

  .chat-panel-messages {
    padding: 24px 20px;
  }

  .chat-panel-input-wrap {
    padding: 16px 20px;
  }

  .chat-msg {
    font-size: 18px;
    line-height: 26px;
  }

  .chat-panel-input {
    font-size: 18px;
    line-height: 26px;
  }
}

/* ─── UTILITIES ─── */
.mt-sm { margin-top: 2rem; }
.mt-md { margin-top: 4rem; }
