*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }

:root {
  --navy:       #1E325D;
  --navy-mid:   #16284E;
  --navy-light: #2A4373;
  --navy-hover: #324E83;
  --accent:     #8EA9DB;
  --gold:       #8EA9DB; /* legacy alias */
  --accent-light: #B0C4E5;
  --gold-light: #B0C4E5; /* legacy alias */
  --gold-pale:  #DDE5F2;
  --cream:      #F5F8FC;
  --white:      #ffffff;
  --muted:      #8FA3C0;
  --rule:       rgba(142,169,219,0.18);
  --rule-light: rgba(142,169,219,0.08);
}

html { scroll-behavior: smooth; }
body { font-family:'Montserrat',sans-serif; background:var(--navy); color:var(--cream); overflow-x:hidden; }

/* ─── PAGES ─── */
.page { display:none; min-height:100vh; }
.page.active { display:block; }

/* ─── NAV ─── */
nav {
  position:fixed; top:0; left:0; right:0; z-index:200;
  display:flex; align-items:center; justify-content:space-between;
  padding:18px 56px;
  transition:background 0.4s, border-color 0.4s, padding 0.3s;
  border-bottom:1px solid transparent;
}
nav.scrolled {
  background:rgba(10,20,34,0.97);
  border-bottom-color:var(--rule);
  padding:14px 56px;
  backdrop-filter:blur(10px);
}
.nav-logo {
  display:inline-flex; align-items:center;
  text-decoration:none; cursor:pointer;
  height:78px;
}
.nav-logo-img {
  height:76px; width:auto;
  display:block;
  transition:height 0.35s, opacity 0.3s;
}
.nav-logo:hover .nav-logo-img { opacity:0.85; }
nav.scrolled .nav-logo { height:46px; }
nav.scrolled .nav-logo-img { height:44px; }

/* Homepage nav uses the longer "Investment Banking Services" lockup — even larger */
.nav-logo-home { height:88px; }
.nav-logo-home .nav-logo-img { height:86px; }
nav.scrolled .nav-logo-home { height:50px; }
nav.scrolled .nav-logo-home .nav-logo-img { height:48px; }
.nav-center {
  display:flex; gap:36px; list-style:none;
}
.nav-center a {
  font-size:0.72rem; font-weight:700; letter-spacing:0.18em;
  text-transform:uppercase; color:var(--white); text-decoration:none;
  cursor:pointer; transition:color 0.3s;
}
.nav-center a:hover, .nav-center a.active-link { color:var(--accent-light); }
.nav-cta {
  font-size:0.72rem; font-weight:500; letter-spacing:0.16em;
  text-transform:uppercase; color:var(--gold); text-decoration:none;
  border:1px solid var(--gold); padding:10px 22px; cursor:pointer;
  white-space:nowrap;
  transition:background 0.3s, color 0.3s;
}
.nav-cta:hover { background:var(--gold); color:var(--navy); }

/* Hamburger toggle hidden by default (shown only on mobile) */
.nav-toggle { display:none; }

/* ─── HERO ─── */
.hero {
  min-height:100vh; display:flex; flex-direction:column;
  justify-content:flex-end; padding:0 56px 90px;
  position:relative; overflow:hidden;
}
.hero-bg {
  position:absolute; inset:0; z-index:0;
  background:
    radial-gradient(ellipse 80% 55% at 72% 38%, rgba(26,45,68,0.85) 0%, transparent 68%),
    radial-gradient(ellipse 45% 35% at 18% 78%, rgba(142,169,219,0.05) 0%, transparent 55%),
    linear-gradient(155deg, #0F1F3F 0%, #1E325D 45%, #0B1A38 100%);
}
.hero-grid {
  position:absolute; inset:0; z-index:0;
  background-image:
    linear-gradient(rgba(142,169,219,0.09) 1px, transparent 1px),
    linear-gradient(90deg, rgba(142,169,219,0.09) 1px, transparent 1px);
  background-size:90px 90px;
}
.hero-content { position:relative; z-index:2; max-width:860px; }
.hero-eyebrow {
  display:flex; align-items:center; gap:14px; margin-bottom:32px;
  opacity:0; animation:fadeUp 0.9s 0.2s forwards;
}
.eyebrow-line { width:40px; height:1px; background:var(--gold); }
.eyebrow-text {
  font-size:0.78rem; font-weight:500; letter-spacing:0.24em;
  text-transform:uppercase; color:var(--gold);
}
.hero-headline {
  font-family:'Cormorant Garamond',serif;
  font-weight:300; font-size:clamp(3rem,5.8vw,5.4rem);
  line-height:1.07; color:var(--white); margin-bottom:28px;
  opacity:0; animation:fadeUp 0.9s 0.38s forwards;
}
.hero-headline em { font-style:italic; color:var(--gold-light); }
.hero-sub {
  font-size:1.0rem; font-weight:400; letter-spacing:0.01em;
  line-height:1.85; color:#C5D2E5; max-width:520px; margin-bottom:48px;
  opacity:0; animation:fadeUp 0.9s 0.56s forwards;
}
.hero-sub strong { color:var(--cream); font-weight:400; }
.hero-actions {
  display:flex; align-items:center; gap:34px;
  opacity:0; animation:fadeUp 0.9s 0.72s forwards;
}
.btn-primary {
  font-size:0.82rem; font-weight:500; letter-spacing:0.18em;
  text-transform:uppercase; color:var(--navy); background:var(--gold);
  padding:15px 34px; text-decoration:none; display:inline-block;
  cursor:pointer; border:none; transition:background 0.3s, transform 0.2s;
}
.btn-primary:hover { background:var(--gold-light); transform:translateY(-1px); }
.btn-ghost {
  font-size:0.82rem; font-weight:500; letter-spacing:0.18em;
  text-transform:uppercase; color:var(--muted); text-decoration:none;
  display:flex; align-items:center; gap:12px; cursor:pointer;
  background:none; border:none; transition:color 0.3s;
}
.btn-ghost:hover { color:var(--cream); }
.ghost-arrow { width:28px; height:1px; background:currentColor; position:relative; transition:width 0.3s; }
.btn-ghost:hover .ghost-arrow { width:42px; }
.ghost-arrow::after {
  content:''; position:absolute; right:0; top:-3px;
  border:3px solid transparent; border-left:6px solid currentColor;
  border-right:none;
}
.hero-stats {
  position:absolute; right:56px; bottom:90px; z-index:2;
  display:flex; flex-direction:column; gap:42px; text-align:right;
  opacity:0; animation:fadeIn 1.1s 1.1s forwards;
}
.stat-num {
  font-family:'Cormorant Garamond',serif; font-weight:300;
  font-size:3.6rem; line-height:1; color:var(--white);
  letter-spacing:-0.005em;
}
.stat-num span { color:var(--gold); }
.stat-label {
  font-size:0.78rem; font-weight:500; letter-spacing:0.2em; text-transform:uppercase; color:var(--muted); margin-top:8px;
}
.stat-rule { width:100%; height:1px; background:linear-gradient(to left, var(--rule), transparent); }

/* ─── TICKER ─── */
.ticker {
  border-top:1px solid var(--rule); border-bottom:1px solid var(--rule);
  padding:18px 0; background:var(--navy-mid); overflow:hidden;
}
.ticker-track {
  display:flex; width:max-content;
  animation:ticker 32s linear infinite;
}
.tick {
  display:flex; align-items:center; gap:20px; padding:0 48px;
  font-size:0.78rem; font-weight:600; letter-spacing:0.24em;
  text-transform:uppercase; color:var(--white); white-space:nowrap;
}
.tick.hi { color:var(--accent-light); }
.tick-dot { width:5px; height:5px; background:var(--accent); border-radius:50%; flex-shrink:0; opacity:0.9; }

/* ─── SECTION COMMONS ─── */
.section { padding:110px 56px; }
.section-alt { background:var(--navy-mid); }
.sec-label { display:flex; align-items:center; gap:14px; margin-bottom:60px; }
.sec-label-line { width:30px; height:1px; background:var(--gold); flex-shrink:0; }
.sec-label-text { font-size:0.78rem; font-weight:500; letter-spacing:0.24em; text-transform:uppercase; color:var(--gold); }
.sec-title {
  font-family:'Cormorant Garamond',serif; font-weight:300;
  font-size:clamp(2rem,3.8vw,3.2rem); line-height:1.14; color:var(--white);
}
.sec-title em { font-style:italic; color:var(--gold-light); }

/* ─── SERVICES ─── */
.svc-intro-grid {
  display:grid; grid-template-columns:1fr 1fr; gap:56px;
  align-items:end; margin-bottom:72px;
}
.svc-intro-body {
  font-size:1.05rem; font-weight:400; line-height:1.8;
  color:#C5D2E5; letter-spacing:0.005em;
}

/* Founder pull-quote inside the What We Do intro */
.svc-intro-quote {
  position:relative;
  padding:32px 36px 32px 44px;
  border-left:2px solid var(--accent);
  background:linear-gradient(90deg, rgba(142,169,219,0.04) 0%, transparent 100%);
  margin:0;
}
.svc-quote-mark {
  position:absolute;
  top:14px; left:14px;
  width:22px; height:16px;
  color:var(--accent);
  opacity:0.45;
}
.svc-quote-text {
  font-family:'Cormorant Garamond',serif;
  font-style:italic;
  font-weight:400;
  font-size:1.35rem;
  line-height:1.55;
  color:var(--white);
  letter-spacing:0.005em;
  margin:0 0 22px 0;
  padding-left:18px;
}
.svc-quote-attrib {
  display:flex; flex-direction:column;
  gap:4px;
  padding-left:18px;
}
.svc-quote-name {
  font-family:'Cormorant Garamond',serif;
  font-size:1.05rem;
  font-weight:500;
  color:var(--accent-light);
  letter-spacing:0.01em;
}
.svc-quote-role {
  font-family:'Montserrat',sans-serif;
  font-size:0.66rem; font-weight:500;
  letter-spacing:0.22em; text-transform:uppercase;
  color:var(--muted);
}
.svc-cards { display:grid; grid-template-columns:repeat(3,1fr); gap:2px; }
.svc-card {
  background:var(--navy-mid); padding:48px 40px;
  position:relative; overflow:hidden;
  transition:background 0.4s; cursor:default;
}
.svc-card::before {
  content:''; position:absolute; top:0; left:0; right:0; height:2px;
  background:var(--gold); transform:scaleX(0); transform-origin:left;
  transition:transform 0.5s ease;
}
.svc-card:hover { background:var(--navy-light); }
.svc-card:hover::before { transform:scaleX(1); }
.svc-num {
  font-family:'Cormorant Garamond',serif; font-size:3.2rem;
  font-weight:300; color:rgba(142,169,219,0.1); line-height:1; margin-bottom:24px;
  transition:color 0.4s;
}
.svc-card:hover .svc-num { color:rgba(142,169,219,0.18); }
.svc-name {
  font-family:'Cormorant Garamond',serif; font-size:1.5rem;
  font-weight:500; color:var(--white); margin-bottom:16px; letter-spacing:0.01em;
}
.svc-desc {
  font-size:0.97rem; font-weight:400; line-height:1.8; color:#C5D2E5; letter-spacing:0.01em;
}
.svc-link {
  display:inline-flex; align-items:center; gap:10px; margin-top:28px;
  font-size:0.78rem; font-weight:500; letter-spacing:0.1em; text-transform:uppercase; color:var(--gold); text-decoration:none;
  opacity:0; transform:translateY(6px); cursor:pointer; background:none; border:none;
  transition:opacity 0.3s, transform 0.3s;
}
.svc-card:hover .svc-link { opacity:1; transform:translateY(0); }

/* ─── ACCESSIBILITY UTILITIES ─── */
.visually-hidden {
  position:absolute !important;
  width:1px; height:1px;
  margin:-1px; padding:0;
  border:0; overflow:hidden;
  clip:rect(0, 0, 0, 0);
  white-space:nowrap;
}

/* ─── TRANSACTION TILE GRID (NEW) ─── */
.tx-grid {
  display:grid;
  grid-template-columns:repeat(4, 1fr);
  gap:32px;
  margin-top:8px;
}
/* Homepage: 4 tiles per row × 2 rows (8 total), generous spacing */
.tx-grid-home {
  margin-top:48px;
  grid-template-columns:repeat(4, 1fr);
  gap:48px 40px;
  max-width:1080px;
  margin-left:auto; margin-right:auto;
  padding:0 32px;
}
/* Full transactions page: 5-up, tighter spacing */
.tx-grid-full {
  margin-top:8px;
  grid-template-columns:repeat(5, 1fr);
  gap:24px;
}

.tx-tile {
  display:flex; flex-direction:column;
  background:transparent;
  cursor:default;
}
.tile-image-wrap {
  position:relative;
  aspect-ratio:1 / 1;
  overflow:hidden;
  border-radius:4px;
  background:var(--navy-mid);
  box-shadow:0 4px 24px rgba(0,0,0,0.35);
  transition:transform 0.4s cubic-bezier(.2,.8,.2,1), box-shadow 0.4s;
}
.tx-tile:hover .tile-image-wrap {
  transform:translateY(-4px);
  box-shadow:0 12px 40px rgba(0,0,0,0.55);
}
.tile-tombstone {
  display:block;
  width:100%; height:100%;
  object-fit:contain;
  background:var(--navy);
  transition:filter 0.4s, opacity 0.4s;
}
.tx-tile:hover .tile-tombstone {
  filter:blur(3px) brightness(0.6);
  opacity:0.65;
}

/* Placeholder for transactions without a tombstone yet */
.tile-placeholder {
  width:100%; height:100%;
  display:flex; flex-direction:column; align-items:center; justify-content:center;
  gap:14px; padding:24px;
  background:linear-gradient(180deg, var(--navy-mid) 0%, var(--navy) 100%);
  position:relative;
  text-align:center;
}
.tile-placeholder::before {
  content:''; position:absolute; inset:0;
  background-image:
    linear-gradient(rgba(142,169,219,0.05) 1px, transparent 1px),
    linear-gradient(90deg, rgba(142,169,219,0.05) 1px, transparent 1px);
  background-size:30px 30px;
  pointer-events:none;
}
.placeholder-monogram {
  font-family:'Cormorant Garamond',serif;
  font-weight:300; font-size:3.6rem;
  color:var(--accent);
  letter-spacing:0.03em;
  line-height:1;
  position:relative;
}
.placeholder-name {
  font-family:'Cormorant Garamond',serif;
  font-size:1.05rem; font-weight:400;
  color:var(--white);
  line-height:1.25;
  letter-spacing:0.005em;
  position:relative;
  max-width:80%;
}
.placeholder-tag {
  font-family:'Montserrat',sans-serif;
  font-size:0.66rem; font-weight:500;
  letter-spacing:0.22em; text-transform:uppercase;
  color:var(--muted);
  position:relative;
  margin-top:4px;
}
.tx-tile:hover .tile-placeholder {
  filter:brightness(0.55);
}

/* Hover overlay with description */
.tile-overlay {
  position:absolute; inset:0;
  display:flex; flex-direction:column; justify-content:center;
  padding:28px 24px;
  background:linear-gradient(180deg, rgba(11,26,56,0.92) 0%, rgba(10,23,48,0.96) 100%);
  opacity:0;
  transition:opacity 0.4s ease;
  pointer-events:none;
  text-align:left;
}
.tx-tile:hover .tile-overlay { opacity:1; }
.tx-tile:focus-within .tile-overlay { opacity:1; }
.tile-desc {
  font-family:'Cormorant Garamond',serif;
  font-size:1.02rem; font-weight:400;
  font-style:italic;
  color:var(--white);
  line-height:1.5;
  letter-spacing:0.005em;
  margin:0;
}
.tile-desc-empty { opacity:0.6; }
.tile-meta {
  margin-top:14px;
  font-family:'Montserrat',sans-serif;
  font-size:0.66rem; font-weight:500;
  letter-spacing:0.2em; text-transform:uppercase;
  color:var(--accent);
}
.tile-counterparty {
  margin-top:10px;
  font-family:'Cormorant Garamond',serif;
  font-size:1.0rem; font-weight:400;
  color:var(--accent-light);
}
.tile-counterparty::before {
  content:'Acquired by '; color:var(--muted); font-style:italic;
  font-family:'Cormorant Garamond',serif;
}

/* Label below tile */
.tile-label {
  margin-top:18px;
  padding:0 4px;
}
.tile-name {
  font-family:'Cormorant Garamond',serif;
  font-size:1.15rem; font-weight:400;
  color:var(--white);
  letter-spacing:0.005em;
  line-height:1.25;
  transition:color 0.3s;
}
.tx-tile:hover .tile-name { color:var(--accent-light); }
.tile-sector {
  margin-top:6px;
  font-family:'Montserrat',sans-serif;
  font-size:0.66rem; font-weight:500;
  letter-spacing:0.2em; text-transform:uppercase;
  color:var(--muted);
}

/* Smaller label typography for the homepage's smaller tiles */
.tx-grid-home .tile-label { margin-top:14px; }
.tx-grid-home .tile-name { font-size:1.04rem; }
.tx-grid-home .tile-sector { margin-top:5px; font-size:0.98rem; }
.tx-grid-home .tile-overlay { padding:18px 16px; }
.tx-grid-home .tile-desc { font-size:1.0rem; line-height:1.4; }
.tx-grid-home .tile-meta { margin-top:10px; font-size:0.98rem; }
.tx-grid-home .tile-counterparty { margin-top:8px; font-size:0.97rem; }
.tx-grid-home .placeholder-monogram { font-size:2.4rem; }
.tx-grid-home .placeholder-name { font-size:1.04rem; }

/* Tighter typography for full transactions page (5-up = smaller tiles) */
.tx-grid-full .tile-label { margin-top:12px; }
.tx-grid-full .tile-name { font-size:0.97rem; line-height:1.3; }
.tx-grid-full .tile-sector { margin-top:4px; font-size:0.68rem; }
.tx-grid-full .tile-overlay { padding:14px 12px; }
.tx-grid-full .tile-desc { font-size:1.0rem; line-height:1.38; }
.tx-grid-full .tile-meta { margin-top:8px; font-size:0.68rem; }
.tx-grid-full .tile-counterparty { margin-top:6px; font-size:0.98rem; }
.tx-grid-full .placeholder-monogram { font-size:2.2rem; }
.tx-grid-full .placeholder-name { font-size:0.97rem; }

/* Filter behavior — hide tiles that don't match */
.tx-tile.tx-hidden { display:none; }
.tx-tile-link.tx-hidden { display:none; }

/* Hide all the old details/row markup (now obsolete but might still be referenced elsewhere) */
details.tx-row.tx-expandable,
details.tx-full-row.tx-expandable { display:none !important; }

/* ─── TRANSACTIONS ─── */
.tx-header { display:flex; justify-content:space-between; align-items:flex-end; margin-bottom:64px; }
.tx-view-all {
  font-size:0.98rem; font-weight:500; letter-spacing:0.2em;
  text-transform:uppercase; color:var(--gold); text-decoration:none;
  display:flex; align-items:center; gap:10px; cursor:pointer;
  background:none; border:none; flex-shrink:0;
  transition:gap 0.3s;
}
.tx-view-all:hover { gap:16px; }
.tx-row:not(details) {
  display:grid; grid-template-columns:48px 1fr 1fr auto;
  align-items:center; gap:36px; padding:28px 0;
  border-bottom:1px solid var(--rule);
  transition:padding 0.25s, background 0.25s;
  cursor:default;
}
.tx-row:not(details):first-child { border-top:1px solid var(--rule); }
.tx-row:not(details):hover { background:rgba(142,169,219,0.025); padding-left:12px; padding-right:12px; margin:0 -12px; }
.tx-idx { font-family:'Cormorant Garamond',serif; font-size:1rem; font-weight:300; color:rgba(142,169,219,0.28); }
.tx-name { font-family:'Cormorant Garamond',serif; font-size:1.25rem; font-weight:400; color:var(--white); }
.tx-sector { font-size:0.7rem; font-weight:500; letter-spacing:0.18em; text-transform:uppercase; color:var(--muted); }
.tx-tag {
  font-size:0.56rem; font-weight:500; letter-spacing:0.14em;
  text-transform:uppercase; color:var(--gold);
  border:1px solid rgba(142,169,219,0.28); padding:5px 11px; white-space:nowrap;
}

/* ─── EXPANDABLE TRANSACTION ROWS ─── */
details.tx-expandable {
  display:block;
  border-bottom:1px solid var(--rule);
  border-top:none;
  padding:0;
  transition:background 0.3s;
}
details.tx-expandable + details.tx-expandable {
  border-top:none;
}
details.tx-row.tx-expandable:first-of-type,
details.tx-full-row.tx-expandable:first-of-type {
  border-top:1px solid var(--rule);
}

/* The summary acts as the visible row */
details.tx-expandable > summary {
  list-style:none;
  cursor:pointer;
  padding:28px 16px 28px 0;
  display:grid; align-items:center; gap:36px;
  transition:padding 0.25s, background 0.25s;
  outline:none;
}
details.tx-expandable > summary::-webkit-details-marker { display:none; }
details.tx-expandable > summary::marker { display:none; content:''; }

/* Home/sector page row layout: 5 cols (idx, name, sector, tag, chevron) */
details.tx-row.tx-expandable > summary {
  grid-template-columns:48px 1fr 1fr auto 28px;
}
/* Full transactions page row layout: 6 cols (idx, name+desc, sector, tag, chevron) */
details.tx-full-row.tx-expandable > summary {
  grid-template-columns:48px 1fr 180px 120px 28px;
  gap:32px;
  padding:26px 16px 26px 0;
}

details.tx-expandable:hover > summary {
  background:rgba(142,169,219,0.04);
  padding-left:14px;
  padding-right:18px;
}
details.tx-expandable[open] > summary {
  background:rgba(142,169,219,0.06);
  padding-left:14px;
  padding-right:18px;
}

/* Chevron indicator */
.tx-chevron {
  width:14px; height:14px;
  border-right:1.5px solid var(--gold);
  border-bottom:1.5px solid var(--gold);
  transform:rotate(45deg);
  margin-top:-4px;
  transition:transform 0.3s, border-color 0.3s;
  justify-self:end;
  opacity:0.7;
}
details.tx-expandable:hover .tx-chevron {
  opacity:1;
  border-color:var(--gold-light);
}
details.tx-expandable[open] .tx-chevron {
  transform:rotate(225deg);
  margin-top:4px;
  opacity:1;
}

/* Detail panel */
.tx-detail {
  padding:8px 16px 36px 64px;
  background:rgba(142,169,219,0.03);
  animation:txDetailSlide 0.35s ease-out;
  border-left:2px solid var(--gold);
  margin:0 0 0 16px;
}
@keyframes txDetailSlide {
  from { opacity:0; transform:translateY(-6px); }
  to { opacity:1; transform:translateY(0); }
}
.tx-detail-grid {
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:32px;
  margin-bottom:20px;
  max-width:760px;
}
.tx-detail-col { }
.tx-detail-label {
  font-size:0.68rem; font-weight:500; letter-spacing:0.2em;
  text-transform:uppercase; color:var(--gold);
  margin-bottom:6px;
}
.tx-detail-value {
  font-family:'Cormorant Garamond',serif;
  font-size:1.15rem; font-weight:400;
  color:var(--white); letter-spacing:0.005em;
}
.tx-detail-desc {
  font-size:1.0rem; font-weight:400; line-height:1.85;
  color:#C5D2E5; letter-spacing:0.01em;
  max-width:780px; margin:0;
}

/* ─── CTA BAND ─── */
.cta-band {
  padding:90px 56px;
  display:grid; grid-template-columns:1fr auto; align-items:center; gap:56px;
  border-top:1px solid var(--rule); position:relative; overflow:hidden;
}
.cta-band::before {
  content:''; position:absolute; left:0; top:0; bottom:0;
  width:3px; background:linear-gradient(to bottom, var(--gold), transparent);
}
.cta-title { font-family:'Cormorant Garamond',serif; font-weight:300; font-size:clamp(1.7rem,2.8vw,2.6rem); line-height:1.2; color:var(--white); }
.cta-title em { font-style:italic; color:var(--gold-light); }
.cta-sub { font-size:0.98rem; font-weight:400; color:#C5D2E5; line-height:1.8; margin-top:14px; max-width:460px; letter-spacing:0.01em; }

/* ─── FOOTER ─── */
footer {
  padding:44px 56px; background:#0A1730;
  display:flex; align-items:center; justify-content:space-between;
  border-top:1px solid rgba(142,169,219,0.08); gap:20px; flex-wrap:wrap;
}
.footer-logo { display:inline-flex; align-items:center; text-decoration:none; cursor:pointer; }
.footer-logo-img { height:54px; width:auto; display:block; opacity:0.9; transition:opacity 0.3s; }
.footer-logo:hover .footer-logo-img { opacity:1; }
.footer-legal { font-size:0.7rem; font-weight:400; letter-spacing:0.08em; color:rgba(125,144,166,0.45); text-align:center; line-height:1.7; }
.footer-links { display:flex; gap:24px; }
.footer-links a { font-size:0.66rem; font-weight:500; letter-spacing:0.16em; text-transform:uppercase; color:var(--muted); text-decoration:none; cursor:pointer; transition:color 0.3s; }
.footer-links a:hover { color:var(--accent-light); }

/* ─── LEGAL / PRIVACY CONTENT ─── */
.legal-content {
  max-width:820px;
  margin:0 auto;
  font-size:1.0rem;
  line-height:1.85;
  color:#C5D2E5;
  letter-spacing:0.005em;
}
.legal-content h2 {
  font-family:'Cormorant Garamond',serif;
  font-size:1.7rem;
  font-weight:500;
  color:var(--white);
  margin:0 0 32px 0;
  padding-bottom:20px;
  border-bottom:1px solid var(--rule);
  letter-spacing:0.005em;
}
.legal-content h3 {
  font-family:'Cormorant Garamond',serif;
  font-size:1.35rem;
  font-weight:500;
  color:var(--white);
  margin:48px 0 16px 0;
  letter-spacing:0.005em;
}
.legal-content p {
  margin:0 0 18px 0;
}
.legal-content p:last-child { margin-bottom:0; }
.legal-content strong { color:var(--accent-light); font-weight:500; }

/* ─── INNER PAGE HERO ─── */
.page-hero {
  padding:160px 56px 80px;
  position:relative; overflow:hidden;
  border-bottom:1px solid var(--rule);
}
.page-hero-bg {
  position:absolute; inset:0;
  background:linear-gradient(155deg, #0F1F3F 0%, #1E325D 60%, #0B1A38 100%);
  z-index:0;
}
.page-hero-grid {
  position:absolute; inset:0; z-index:0;
  background-image:
    linear-gradient(rgba(142,169,219,0.07) 1px, transparent 1px),
    linear-gradient(90deg, rgba(142,169,219,0.07) 1px, transparent 1px);
  background-size:90px 90px;
}
.page-hero-content { position:relative; z-index:2; max-width:720px; }
.page-hero-label { display:flex; align-items:center; gap:14px; margin-bottom:28px; }
.page-hero-title { font-family:'Cormorant Garamond',serif; font-weight:300; font-size:clamp(2.4rem,4.5vw,4.2rem); line-height:1.08; color:var(--white); }
.page-hero-title em { font-style:italic; color:var(--gold-light); }
.page-hero-sub { font-size:1.0rem; font-weight:400; letter-spacing:0.01em; line-height:1.85; color:#C5D2E5; margin-top:24px; max-width:580px; }

/* ─── VALUES PAGE ─── */
.stats-band {
  background:var(--navy-mid); border-bottom:1px solid var(--rule);
  padding:60px 56px;
  display:grid; grid-template-columns:repeat(4,1fr); gap:0;
}
.stat-block {
  padding:0 40px; border-right:1px solid var(--rule);
  text-align:center;
}
.stat-block:first-child { padding-left:0; }
.stat-block:last-child { border-right:none; }
.stat-big { font-family:'Cormorant Garamond',serif; font-weight:300; font-size:3.4rem; line-height:1; color:var(--white); }
.stat-big span { color:var(--gold); }
.stat-small { font-size:0.78rem; font-weight:500; letter-spacing:0.2em; text-transform:uppercase; color:var(--muted); margin-top:8px; }

.values-grid { display:grid; grid-template-columns:1fr 1fr; gap:2px; margin-top:56px; }
.value-card { background:var(--navy-mid); padding:44px 40px; }
.value-icon { font-family:'Cormorant Garamond',serif; font-size:2rem; color:var(--gold); margin-bottom:18px; font-style:italic; }
.value-title { font-family:'Cormorant Garamond',serif; font-size:1.4rem; font-weight:500; color:var(--white); margin-bottom:12px; }
.value-body { font-size:0.97rem; font-weight:400; line-height:1.8; color:#C5D2E5; letter-spacing:0.01em; }

/* ─── TEAM PAGE ─── */
.team-grid { display:grid; grid-template-columns:repeat(4,1fr); gap:2px; margin-top:64px; }
.team-card {
  background:var(--navy-mid);
  position:relative; overflow:hidden;
  transition:background 0.35s;
  display:flex; flex-direction:column;
}
.team-card:hover { background:var(--navy-light); }
.team-card::after {
  content:''; position:absolute; bottom:0; left:0; right:0;
  height:2px; background:var(--gold);
  transform:scaleX(0); transform-origin:left;
  transition:transform 0.45s ease;
}
.team-card:hover::after { transform:scaleX(1); }
.team-photo {
  width:100%; aspect-ratio:4/3; overflow:hidden;
  position:relative; flex-shrink:0;
}
.team-photo img {
  width:100%; height:100%; object-fit:cover; object-position:top center;
  filter:grayscale(30%) contrast(1.05);
  transition:filter 0.4s, transform 0.5s;
}
.team-card:hover .team-photo img {
  filter:grayscale(0%) contrast(1.05);
  transform:scale(1.03);
}

/* Placeholder when no headshot is available */
.team-photo-placeholder {
  background:linear-gradient(180deg, var(--navy-mid) 0%, var(--navy) 100%);
  display:flex; align-items:center; justify-content:center;
  position:relative;
}
.team-photo-placeholder::before {
  content:''; position:absolute; inset:0;
  background-image:
    linear-gradient(rgba(142,169,219,0.06) 1px, transparent 1px),
    linear-gradient(90deg, rgba(142,169,219,0.06) 1px, transparent 1px);
  background-size:36px 36px;
  pointer-events:none;
}
.team-placeholder-mark {
  font-family:'Cormorant Garamond',serif;
  font-weight:300;
  font-size:4.4rem;
  color:var(--accent);
  opacity:0.55;
  letter-spacing:0.04em;
  position:relative;
  transition:opacity 0.4s, color 0.4s, transform 0.5s;
}
.team-card:hover .team-placeholder-mark {
  opacity:0.85;
  color:var(--accent-light);
  transform:scale(1.04);
}
.team-photo-overlay {
  position:absolute; inset:0;
  background:linear-gradient(to bottom, transparent 55%, rgba(18,32,48,0.85) 100%);
}
.team-card-body { padding:22px 24px 28px; }
.team-name { font-family:'Cormorant Garamond',serif; font-size:1.32rem; font-weight:500; color:var(--white); margin-bottom:4px; line-height:1.25; }
.team-title { font-size:0.62rem; font-weight:600; letter-spacing:0.16em; text-transform:uppercase; color:var(--accent); margin-bottom:14px; }
.team-bio { font-size:0.92rem; font-weight:400; line-height:1.75; color:#C5D2E5; letter-spacing:0.005em; }

/* Make team cards clickable */
.team-card[data-member] { cursor:pointer; }
.team-card[data-member]::after {
  /* Subtle "click for more" hint - small chevron in corner */
  content:'';
  position:absolute;
  bottom:18px; right:20px;
  width:22px; height:22px;
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%238EA9DB' stroke-width='1.4'><circle cx='12' cy='12' r='10'/><line x1='12' y1='8' x2='12' y2='12'/><circle cx='12' cy='16' r='0.8' fill='%238EA9DB'/></svg>");
  background-size:contain;
  background-repeat:no-repeat;
  opacity:0;
  transition:opacity 0.3s, transform 0.3s;
  z-index:5;
}
.team-card[data-member]:hover::after {
  opacity:0.7;
  transform:scale(1.05);
}

/* ─── TEAM MEMBER MODAL ─── */
.team-modal {
  position:fixed; inset:0;
  z-index:1000;
  display:none;
  align-items:flex-start;
  justify-content:center;
  padding:64px 24px 24px;
  overflow-y:auto;
}
.team-modal.is-open { display:flex; animation:modalFadeIn 0.25s ease; }
body.modal-open { overflow:hidden; }
body.nav-open { overflow:hidden; }

.team-modal-backdrop {
  position:fixed; inset:0;
  background:rgba(8,16,30,0.85);
  backdrop-filter:blur(8px);
  cursor:pointer;
}

.team-modal-panel {
  position:relative;
  width:100%;
  max-width:980px;
  background:linear-gradient(180deg, var(--navy-mid) 0%, var(--navy) 100%);
  border:1px solid var(--rule);
  border-radius:6px;
  box-shadow:0 24px 80px rgba(0,0,0,0.6);
  overflow:hidden;
  margin:0 auto;
  animation:modalSlideUp 0.35s cubic-bezier(.2,.8,.2,1);
}

.team-modal-close {
  position:absolute;
  top:16px; right:16px;
  width:36px; height:36px;
  background:rgba(255,255,255,0.06);
  border:1px solid var(--rule);
  border-radius:50%;
  color:var(--accent-light);
  cursor:pointer;
  display:flex; align-items:center; justify-content:center;
  z-index:5;
  transition:background 0.25s, border-color 0.25s, transform 0.25s;
}
.team-modal-close:hover {
  background:var(--accent);
  border-color:var(--accent);
  color:var(--navy);
  transform:rotate(90deg);
}
.team-modal-close svg { width:16px; height:16px; }

.team-modal-grid {
  display:grid;
  grid-template-columns:300px 1fr;
  gap:0;
  align-items:start;
}

.team-modal-photo-col {
  background:var(--navy);
  border-right:1px solid var(--rule);
  padding:0;
}
.team-modal-photo {
  width:100%;
  aspect-ratio:3/4;
  background-position:center top;
  background-size:cover;
  background-color:var(--navy);
  position:relative;
}
.team-modal-photo.is-placeholder {
  display:flex; align-items:center; justify-content:center;
  background:linear-gradient(180deg, var(--navy-mid) 0%, var(--navy) 100%);
  position:relative;
}
.team-modal-photo.is-placeholder::before {
  content:''; position:absolute; inset:0;
  background-image:
    linear-gradient(rgba(142,169,219,0.06) 1px, transparent 1px),
    linear-gradient(90deg, rgba(142,169,219,0.06) 1px, transparent 1px);
  background-size:36px 36px;
  pointer-events:none;
}
.team-modal-photo .placeholder-initials {
  font-family:'Cormorant Garamond',serif;
  font-weight:300;
  font-size:5rem;
  color:var(--accent);
  opacity:0.55;
  letter-spacing:0.04em;
  position:relative;
}

.team-modal-contact {
  padding:24px 28px 28px;
  display:flex; flex-direction:column;
  gap:14px;
  border-top:1px solid var(--rule);
}
.team-modal-contact-row {
  display:flex; flex-direction:column;
  gap:4px;
}
.team-modal-contact-label {
  font-family:'Montserrat',sans-serif;
  font-size:0.62rem;
  font-weight:600;
  letter-spacing:0.22em;
  text-transform:uppercase;
  color:var(--muted);
}
.team-modal-contact-value {
  font-size:0.97rem;
  font-weight:400;
  color:var(--white);
  text-decoration:none;
  word-break:break-word;
  transition:color 0.25s;
}
a.team-modal-contact-value:hover { color:var(--accent-light); }

.team-modal-body-col {
  padding:36px 40px 40px;
  min-height:300px;
}
.team-modal-name {
  font-family:'Cormorant Garamond',serif;
  font-size:2.2rem;
  font-weight:500;
  color:var(--white);
  letter-spacing:0.005em;
  line-height:1.1;
  margin:0 0 8px 0;
}
.team-modal-title {
  font-family:'Montserrat',sans-serif;
  font-size:0.98rem;
  font-weight:600;
  letter-spacing:0.22em;
  text-transform:uppercase;
  color:var(--accent);
  margin-bottom:28px;
  padding-bottom:24px;
  border-bottom:1px solid var(--rule);
}
.team-modal-bio {
  font-size:1.0rem;
  font-weight:400;
  line-height:1.78;
  color:#C5D2E5;
  letter-spacing:0.005em;
}
.team-modal-bio p {
  margin:0 0 16px 0;
}
.team-modal-bio p:last-child { margin-bottom:0; }

@keyframes modalFadeIn {
  from { opacity:0; }
  to { opacity:1; }
}
@keyframes modalSlideUp {
  from { opacity:0; transform:translateY(24px); }
  to { opacity:1; transform:translateY(0); }
}

/* ─── SERVICES DETAIL PAGE ─── */
.svc-detail-grid { display:grid; grid-template-columns:1fr 1fr; gap:56px; align-items:start; }
.svc-detail-body { font-size:0.98rem; font-weight:400; line-height:1.85; color:#C5D2E5; letter-spacing:0.01em; }
.svc-detail-body p + p { margin-top:18px; }
.feature-list { margin-top:40px; display:flex; flex-direction:column; gap:0; }
.feature-item {
  display:flex; align-items:flex-start; gap:18px;
  padding:22px 0; border-bottom:1px solid var(--rule);
}
.feature-item:first-child { border-top:1px solid var(--rule); }
.feature-bullet { width:6px; height:6px; background:var(--gold); border-radius:50%; flex-shrink:0; margin-top:5px; }
.feature-text { font-size:0.97rem; font-weight:400; line-height:1.75; color:#C5D2E5; letter-spacing:0.01em; }
.feature-text strong { color:var(--cream); font-weight:400; }

/* ─── TRANSACTIONS PAGE ─── */
.tx-filter { display:flex; gap:12px; margin-bottom:52px; flex-wrap:wrap; }
.filter-btn {
  font-size:0.78rem; font-weight:500; letter-spacing:0.1em; text-transform:uppercase; color:var(--muted); background:none;
  border:1px solid var(--rule); padding:9px 18px; cursor:pointer;
  transition:border-color 0.3s, color 0.3s, background 0.3s;
}
.filter-btn:hover, .filter-btn.active { border-color:var(--gold); color:var(--gold); }
.filter-btn.active { background:rgba(142,169,219,0.07); }
.tx-full-row:not(details) {
  display:grid; grid-template-columns:48px 1fr 180px 120px auto;
  align-items:center; gap:32px; padding:26px 0;
  border-bottom:1px solid var(--rule);
  transition:padding 0.25s, background 0.25s;
}
.tx-full-row:not(details):first-child { border-top:1px solid var(--rule); }
.tx-full-row:not(details):hover { background:rgba(142,169,219,0.025); padding-left:12px; padding-right:12px; margin:0 -12px; }
.tx-desc { font-size:1.0rem; font-weight:400; color:#C5D2E5; line-height:1.6; letter-spacing:0.01em; margin-top:4px; }

/* ─── CONTACT PAGE ─── */
.contact-grid { display:grid; grid-template-columns:1fr 1fr; gap:80px; align-items:start; }
.contact-info { }
.contact-info-block { margin-bottom:44px; }
.contact-info-label { font-size:0.78rem; font-weight:500; letter-spacing:0.22em; text-transform:uppercase; color:var(--gold); margin-bottom:10px; }
.contact-info-value { font-family:'Cormorant Garamond',serif; font-size:1.3rem; font-weight:300; color:var(--white); line-height:1.4; }
.contact-info-sub { font-size:0.97rem; font-weight:400; color:#C5D2E5; line-height:1.75; margin-top:6px; letter-spacing:0.01em; }
.contact-form { }
.form-row { display:grid; grid-template-columns:1fr 1fr; gap:16px; margin-bottom:16px; }
.form-field { display:flex; flex-direction:column; gap:8px; margin-bottom:16px; }
.form-label { font-size:0.7rem; font-weight:500; letter-spacing:0.2em; text-transform:uppercase; color:var(--muted); }
.form-input, .form-select, .form-textarea {
  background:var(--navy-mid); border:1px solid var(--rule);
  color:var(--cream); font-family:'Montserrat',sans-serif;
  font-size:0.97rem; font-weight:300; padding:14px 18px;
  outline:none; transition:border-color 0.3s;
  appearance:none; letter-spacing:0.03em;
}
.form-input:focus, .form-select:focus, .form-textarea:focus {
  border-color:var(--accent-light);
  outline:2px solid var(--accent-light);
  outline-offset:2px;
}
/* WCAG 2.2: visible focus indicators on every interactive element for keyboard users */
:focus-visible {
  outline:2px solid var(--accent-light);
  outline-offset:2px;
  border-radius:2px;
}
button:focus-visible, a:focus-visible, .form-submit:focus-visible, .nav-cta:focus-visible {
  outline:2px solid var(--accent-light);
  outline-offset:3px;
}
.form-input::placeholder, .form-textarea::placeholder { color:rgba(125,144,166,0.4); }
.form-textarea { min-height:120px; resize:vertical; }
.form-submit {
  width:100%; font-size:1.04rem; font-weight:500; letter-spacing:0.18em;
  text-transform:uppercase; color:var(--navy); background:var(--gold);
  border:none; padding:16px; cursor:pointer; margin-top:8px;
  transition:background 0.3s;
}
.form-submit:hover { background:var(--gold-light); }

/* ─── INDUSTRIES PAGE ─── */
.industry-cards { display:grid; grid-template-columns:repeat(2,1fr); gap:2px; margin-top:56px; }
.sector-icon {
  width:48px; height:48px;
  color:var(--gold);
  display:block;
  margin-bottom:28px;
  opacity:0.85;
  transition:opacity 0.35s, transform 0.5s, color 0.35s;
}
.industry-card:hover .sector-icon {
  opacity:1;
  color:var(--gold-light);
  transform:translateY(-2px);
}
.industry-card {
  background:var(--navy-mid); padding:52px 48px;
  position:relative; overflow:hidden; transition:background 0.35s;
}
.industry-card:hover { background:var(--navy-light); }
.industry-card::before {
  content:''; position:absolute; left:0; top:0; bottom:0;
  width:3px; background:var(--gold);
  transform:scaleY(0); transform-origin:bottom;
  transition:transform 0.45s ease;
}
.industry-card:hover::before { transform:scaleY(1); }
.industry-label { font-size:0.78rem; font-weight:500; letter-spacing:0.2em; text-transform:uppercase; color:var(--gold); margin-bottom:18px; }
.industry-title { font-family:'Cormorant Garamond',serif; font-size:1.8rem; font-weight:400; color:var(--white); margin-bottom:20px; }
.industry-body { font-size:0.97rem; font-weight:400; line-height:1.8; color:#C5D2E5; letter-spacing:0.01em; }
.industry-examples { display:flex; flex-wrap:wrap; gap:8px; margin-top:28px; }
.industry-link {
  display:inline-flex; align-items:center; gap:10px;
  margin-top:32px;
  font-size:1.04rem; font-weight:500; letter-spacing:0.18em;
  text-transform:uppercase; color:var(--gold);
  text-decoration:none; transition:gap 0.3s, color 0.3s;
}
.industry-link:hover { gap:18px; color:var(--gold-light); }
.ex-tag { font-size:0.6rem; font-weight:500; letter-spacing:0.14em; text-transform:uppercase; color:var(--muted); border:1px solid var(--rule); padding:5px 10px; }

/* ─── INSIGHTS PAGE ─── */
/* ─── INSIGHTS — IMAGE-LED CARDS ─── */
.insights-grid {
  display:grid;
  grid-template-columns:repeat(3, 1fr);
  gap:36px 32px;
  margin-top:48px;
}

/* Featured: 3-up larger format */
.insights-featured-grid {
  display:grid;
  grid-template-columns:repeat(3, 1fr);
  gap:36px 32px;
  margin-top:48px;
  margin-bottom:0;
}

/* Common card structure */
.insight-card,
.insight-featured-card {
  display:flex; flex-direction:column;
  background:var(--navy-mid);
  text-decoration:none;
  position:relative; overflow:hidden;
  border:1px solid transparent;
  border-radius:4px;
  transition:transform 0.4s cubic-bezier(.2,.8,.2,1), border-color 0.35s, box-shadow 0.4s;
}
.insight-card:hover,
.insight-featured-card:hover {
  transform:translateY(-4px);
  border-color:var(--accent);
  box-shadow:0 12px 40px rgba(0,0,0,0.45);
}

/* Featured cards are slightly larger / more prominent */
.insight-featured-card { background:var(--navy-mid); }

/* Cover image area */
.insight-cover-wrap {
  position:relative;
  width:100%;
  aspect-ratio:4 / 3;
  overflow:hidden;
  background:#ffffff;
  display:flex; align-items:center; justify-content:center;
}
.insight-featured-card .insight-cover-wrap {
  aspect-ratio:3 / 2;
}
.insight-cover {
  display:block;
  width:100%; height:100%;
  object-fit:contain;
  transition:transform 0.5s ease;
}
.insight-card:hover .insight-cover,
.insight-featured-card:hover .insight-cover {
  transform:scale(1.04);
}

/* Placeholder cover when no image */
.insight-cover-placeholder {
  width:100%; height:100%;
  background:linear-gradient(180deg, var(--navy) 0%, var(--navy-mid) 100%);
  display:flex; flex-direction:column; align-items:center; justify-content:center;
  gap:14px; padding:24px;
  position:relative;
}
.insight-cover-placeholder::before {
  content:''; position:absolute; inset:0;
  background-image:
    linear-gradient(rgba(142,169,219,0.05) 1px, transparent 1px),
    linear-gradient(90deg, rgba(142,169,219,0.05) 1px, transparent 1px);
  background-size:32px 32px;
  pointer-events:none;
}
.insight-placeholder-mark {
  color:var(--accent);
  position:relative; z-index:1;
}
.insight-placeholder-mark svg { width:48px; height:60px; }
.insight-placeholder-tag {
  font-family:'Montserrat',sans-serif;
  font-size:0.66rem; font-weight:500;
  letter-spacing:0.22em; text-transform:uppercase;
  color:var(--muted);
  position:relative; z-index:1;
}

/* Card body (text below image) */
.insight-body {
  padding:28px 28px 28px;
  display:flex; flex-direction:column;
  flex:1;
}
.insight-featured-card .insight-body {
  padding:32px 32px 32px;
}

.insight-cat {
  font-family:'Montserrat',sans-serif;
  font-size:0.66rem; font-weight:500;
  letter-spacing:0.2em; text-transform:uppercase;
  color:var(--accent);
  margin-bottom:16px;
}

.insight-title {
  font-family:'Cormorant Garamond',serif;
  font-size:1.2rem; font-weight:500;
  color:var(--white);
  line-height:1.3;
  letter-spacing:0.005em;
  margin:0 0 14px 0;
  transition:color 0.3s;
}
.insight-card:hover .insight-title,
.insight-featured-card:hover .insight-title { color:var(--accent-light); }

.insight-featured-title {
  font-family:'Cormorant Garamond',serif;
  font-size:1.5rem; font-weight:500;
  color:var(--white);
  line-height:1.25;
  letter-spacing:0.005em;
  margin:0 0 16px 0;
  transition:color 0.3s;
}
.insight-featured-card:hover .insight-featured-title { color:var(--accent-light); }

.insight-excerpt {
  font-size:1.04rem; font-weight:400;
  line-height:1.6;
  color:#C5D2E5;
  letter-spacing:0.005em;
  margin:0;
  flex:1;
}

.insight-meta {
  display:flex; align-items:center;
  margin-top:24px; padding-top:18px;
  border-top:1px solid var(--rule);
}
.insight-read {
  font-family:'Montserrat',sans-serif;
  font-size:0.66rem; font-weight:500;
  letter-spacing:0.18em; text-transform:uppercase;
  color:var(--accent);
  transition:color 0.3s, letter-spacing 0.3s;
}
.insight-card:hover .insight-read,
.insight-featured-card:hover .insight-read {
  color:var(--accent-light);
  letter-spacing:0.22em;
}

/* Filter pills */
.insights-filter {
  display:flex; gap:12px; flex-wrap:wrap;
  margin-bottom:48px;
}

/* Hidden state for filtering */
.insight-card.tx-hidden,
.insight-card[style*="display: none"] { display:none; }

/* ─── (legacy insights styles below — preserved for any old markup) ─── */
.insight-featured-label { display:none; }
.insight-featured-body {
  font-size:0.98rem; font-weight:400; line-height:1.8;
  color:#C5D2E5; letter-spacing:0.01em;
}
.insights-filter { display:flex; gap:12px; margin-bottom:52px; flex-wrap:wrap; }

/* ─── PROCESS PAGE ─── */
/* ─── PROCESS TIMELINE — REDESIGNED ─── */
.process-timeline {
  position:relative;
  display:grid;
  grid-template-columns:repeat(6, 1fr);
  gap:0;
  margin:48px auto 96px;
  padding:48px 24px 32px;
  max-width:1180px;
}
.timeline-track {
  position:absolute;
  top:96px;
  left:8.33%;
  right:8.33%;
  height:2px;
  background:linear-gradient(to right,
    rgba(142,169,219,0.1) 0%,
    var(--accent) 12%,
    var(--accent) 88%,
    rgba(142,169,219,0.1) 100%);
  border-radius:2px;
}
.timeline-track::before {
  content:'';
  position:absolute;
  top:-1px;
  left:0; right:0;
  height:4px;
  background:linear-gradient(to right,
    transparent 0%,
    rgba(142,169,219,0.18) 12%,
    rgba(142,169,219,0.18) 88%,
    transparent 100%);
  filter:blur(3px);
}
.timeline-step {
  display:flex; flex-direction:column; align-items:center;
  text-align:center;
  position:relative;
  z-index:2;
  gap:18px;
  padding:0 10px;
}
.timeline-step::before {
  /* Subtle vertical guide line below each dot down to text */
  content:'';
  position:absolute;
  top:96px;
  left:50%;
  width:1px;
  height:18px;
  background:linear-gradient(to bottom, var(--accent), transparent);
  opacity:0.3;
  transform:translateX(-50%);
}
.timeline-dot {
  width:96px; height:96px;
  border-radius:50%;
  background:radial-gradient(circle at 30% 30%, var(--navy-mid) 0%, var(--navy) 70%);
  border:1.5px solid var(--accent);
  box-shadow:
    0 0 0 6px rgba(30,50,93,0.5),
    0 0 24px rgba(142,169,219,0.15),
    inset 0 1px 0 rgba(255,255,255,0.06);
  display:flex; align-items:center; justify-content:center;
  font-family:'Cormorant Garamond',serif;
  font-size:2.2rem; font-weight:300;
  color:var(--accent-light);
  letter-spacing:0.02em;
  transition:all 0.4s cubic-bezier(.2,.8,.2,1);
  flex-shrink:0;
  position:relative;
}
.timeline-dot::after {
  /* Outer halo ring */
  content:'';
  position:absolute;
  inset:-12px;
  border:1px solid rgba(142,169,219,0.15);
  border-radius:50%;
  transition:all 0.4s ease;
}
.timeline-step:hover .timeline-dot {
  background:radial-gradient(circle at 30% 30%, var(--accent) 0%, var(--accent) 70%);
  color:var(--navy);
  border-color:var(--accent-light);
  transform:scale(1.06);
  box-shadow:
    0 0 0 8px rgba(142,169,219,0.12),
    0 8px 32px rgba(142,169,219,0.35),
    inset 0 1px 0 rgba(255,255,255,0.2);
}
.timeline-step:hover .timeline-dot::after {
  inset:-18px;
  border-color:rgba(142,169,219,0.3);
}
.timeline-label {
  font-family:'Cormorant Garamond',serif;
  font-size:1.25rem; font-weight:400;
  font-style:italic;
  color:var(--white);
  letter-spacing:0.005em;
  margin-top:8px;
  transition:color 0.3s;
}
.timeline-step:hover .timeline-label { color:var(--accent-light); }
.timeline-time {
  font-family:'Montserrat',sans-serif;
  font-size:0.66rem; font-weight:500;
  letter-spacing:0.24em; text-transform:uppercase;
  color:var(--muted);
  padding:6px 12px;
  border:1px solid var(--rule);
  border-radius:2px;
  margin-top:-4px;
  transition:border-color 0.3s, color 0.3s;
}
.timeline-step:hover .timeline-time {
  border-color:var(--accent);
  color:var(--accent-light);
}
.process-list { display:flex; flex-direction:column; gap:0; }
.process-step {
  display:grid; grid-template-columns:120px 1fr;
  gap:48px; align-items:start;
  padding:48px 0; border-bottom:1px solid var(--rule);
}
.process-step:first-child { border-top:1px solid var(--rule); }
.process-step-num {
  font-family:'Cormorant Garamond',serif;
  font-size:4.5rem; font-weight:300;
  color:var(--gold-light);
  line-height:1; opacity:0.85;
}
.process-step-title {
  font-family:'Cormorant Garamond',serif;
  font-size:1.8rem; font-weight:400;
  color:var(--white); margin-bottom:8px;
  letter-spacing:0.005em;
}
.process-step-time {
  font-size:1.0rem; font-weight:500; letter-spacing:0.2em;
  text-transform:uppercase; color:var(--gold);
  margin-bottom:18px;
}
.process-step-text {
  font-size:1.0rem; font-weight:400; line-height:1.85;
  color:#C5D2E5; letter-spacing:0.01em;
  max-width:780px;
}

/* ─── FAQ SECTION ─── */
/* ─── FAQ CATEGORY GROUPS ─── */
.faq-groups {
  display:flex; flex-direction:column;
  gap:64px; max-width:980px;
}
.faq-group { }
.faq-group-title {
  font-size:0.78rem; font-weight:500; letter-spacing:0.2em; text-transform:uppercase; color:var(--gold);
  margin:0 0 24px 0;
  padding-bottom:18px;
  border-bottom:1px solid var(--rule);
  display:flex; align-items:center; gap:16px;
}
.faq-group-title::before {
  content:''; width:8px; height:8px;
  background:var(--gold); border-radius:50%;
  flex-shrink:0;
}

.faq-list { display:flex; flex-direction:column; gap:0; max-width:980px; }
.faq-item {
  border-top:1px solid var(--rule);
  transition:background 0.3s;
}
.faq-list .faq-item:last-child { border-bottom:1px solid var(--rule); }
.faq-item summary {
  list-style:none;
  cursor:pointer;
  padding:28px 0;
  font-family:'Cormorant Garamond',serif;
  font-size:1.4rem;
  font-weight:400;
  color:var(--white);
  letter-spacing:0.005em;
  display:flex; align-items:center; justify-content:space-between;
  position:relative;
  transition:color 0.3s;
}
.faq-item summary::-webkit-details-marker { display:none; }
.faq-item summary::after {
  content:'+';
  font-family:'Cormorant Garamond',serif;
  font-size:1.8rem;
  font-weight:300;
  color:var(--gold);
  margin-left:24px;
  transition:transform 0.3s, color 0.3s;
  flex-shrink:0;
}
.faq-item[open] summary::after {
  content:'−';
  color:var(--gold-light);
}
.faq-item summary:hover { color:var(--gold-light); }
.faq-item > div { padding:0 0 28px 0; }
.faq-item p {
  font-size:1.0rem;
  font-weight:400;
  line-height:1.85;
  color:#C5D2E5;
  letter-spacing:0.01em;
  max-width:820px;
}

/* ─── RELATED PAGES (cross-link footer) ─── */
.related-pages {
  background:#0A1730;
  border-top:1px solid var(--rule);
  padding:36px 56px;
}
.related-inner {
  display:flex; align-items:center; justify-content:space-between;
  gap:32px; flex-wrap:wrap; max-width:1400px; margin:0 auto;
}
.related-label {
  font-size:1.0rem; font-weight:500; letter-spacing:0.22em;
  text-transform:uppercase; color:var(--gold);
}
.related-list {
  display:flex; gap:32px; flex-wrap:wrap;
  list-style:none; padding:0; margin:0;
}
.related-list a {
  font-family:'Cormorant Garamond',serif;
  font-size:1.1rem; font-weight:400; color:var(--white);
  text-decoration:none; letter-spacing:0.005em;
  transition:color 0.3s, transform 0.3s;
  display:inline-block;
}
.related-list a:hover {
  color:var(--gold-light);
  transform:translateX(2px);
}

/* ─── ACQUIRER BADGES (logo-style) ─── */
.acquirer-badge {
  display:flex; align-items:center; gap:12px;
  padding:10px 14px 10px 10px;
  background:rgba(142,169,219,0.06);
  border:1px solid rgba(142,169,219,0.18);
  border-radius:2px;
  margin-top:4px;
  max-width:280px;
}
.acquirer-monogram {
  display:flex; align-items:center; justify-content:center;
  width:34px; height:34px;
  background:var(--accent);
  color:var(--navy);
  font-family:'Cormorant Garamond',serif;
  font-size:1.04rem; font-weight:500;
  letter-spacing:0.02em;
  flex-shrink:0;
  border-radius:2px;
}
.acquirer-name {
  font-family:'Cormorant Garamond',serif;
  font-size:1rem; font-weight:400;
  color:var(--white);
  line-height:1.25;
  letter-spacing:0.005em;
  flex:1;
}
.acquirer-ticker {
  display:block;
  font-family:'Montserrat',sans-serif;
  font-size:0.62rem; font-weight:500;
  letter-spacing:0.18em; text-transform:uppercase;
  color:var(--accent);
  margin-top:3px;
}

/* ─── ACQUIRER BRAND COLOR TREATMENTS ─── */
/* Each acquirer's monogram restored to their actual brand colors */

/* CBRE — corporate forest green + accent green */
.acquirer-badge.logo-cbre .acquirer-monogram {
  background:#003F2D; color:#17E88F;
  font-family:'Montserrat',sans-serif; font-weight:700;
  font-size:1.0rem; letter-spacing:0.05em;
}
.acquirer-badge.logo-cbre .acquirer-ticker { color:#17E88F; }

/* AgencyBloc — bright blue */
.acquirer-badge.logo-agencybloc .acquirer-monogram {
  background:#0078D4; color:#ffffff;
  font-family:'Montserrat',sans-serif; font-weight:700;
}

/* New State Capital — deep teal/navy */
.acquirer-badge.logo-newstate .acquirer-monogram {
  background:#0F2A44; color:#C9A961;
  font-family:'Montserrat',sans-serif; font-weight:700;
  font-size:1.04rem; letter-spacing:0.04em;
}

/* MPE Partners — navy + gold (per their own branding) */
.acquirer-badge.logo-mpe .acquirer-monogram {
  background:#1B2B57; color:#C9A961;
  font-family:'Cormorant Garamond',serif; font-weight:600;
}

/* National Tube Supply — corporate red */
.acquirer-badge.logo-nts .acquirer-monogram {
  background:#B22234; color:#ffffff;
  font-family:'Montserrat',sans-serif; font-weight:700;
  font-size:0.98rem; letter-spacing:0.05em;
}

/* Cornerstone Industrial Group — orange + black */
.acquirer-badge.logo-cig .acquirer-monogram {
  background:#1A1A1A; color:#F26B22;
  font-family:'Montserrat',sans-serif; font-weight:700;
  font-size:0.98rem; letter-spacing:0.05em;
}

/* Test Equipment Distributors — corporate dark blue */
.acquirer-badge.logo-ted .acquirer-monogram {
  background:#1B365D; color:#ffffff;
  font-family:'Montserrat',sans-serif; font-weight:700;
  font-size:0.98rem; letter-spacing:0.05em;
}

/* Cleveland Electric Laboratories — corporate red + dark blue */
.acquirer-badge.logo-cleveland-electric .acquirer-monogram {
  background:#0A2240; color:#E63329;
  font-family:'Montserrat',sans-serif; font-weight:700;
  font-size:1.0rem; letter-spacing:0.04em;
}

/* Mason Wells — corporate dark navy */
.acquirer-badge.logo-mason-wells .acquirer-monogram {
  background:#1A2C42; color:#A89968;
  font-family:'Cormorant Garamond',serif; font-weight:500;
  font-size:1.04rem;
}

/* Client/Target Logo display in transaction detail */
.tx-detail-logo-col { grid-column:span 1; }
.tx-client-logo {
  display:block;
  max-height:38px; max-width:160px;
  width:auto; height:auto;
  margin-top:4px;
  background:rgba(255,255,255,0.96);
  padding:6px 10px;
  border-radius:2px;
  object-fit:contain;
}

/* Branded wordmarks for clients/acquirers we don't have logo files for */
.tx-client-wordmark {
  display:inline-flex; align-items:center;
  background:#ffffff;
  padding:8px 14px;
  border-radius:2px;
  margin-top:4px;
  min-height:38px;
  max-width:200px;
}

/* AFIMAC Global — bold black with red accent square */
.tx-client-wordmark.wordmark-afimac {
  font-family:'Montserrat',sans-serif;
  font-weight:800;
  font-size:1.04rem;
  color:#1A1A1A;
  letter-spacing:0.04em;
  position:relative;
  padding-left:12px;
  gap:0; flex-direction:column; align-items:flex-start;
  line-height:1.0;
}
.tx-client-wordmark.wordmark-afimac::before {
  content:''; position:absolute; left:6px; top:50%;
  transform:translateY(-50%);
  width:3px; height:80%;
  background:#D7252C;
}
.tx-client-wordmark.wordmark-afimac span {
  font-size:0.62rem; font-weight:600;
  color:#D7252C; letter-spacing:0.18em;
  margin-top:3px;
}

/* Service-Tech Corporation — red mark + black name */
.tx-client-wordmark.wordmark-servicetech {
  gap:10px; padding:6px 12px;
}
.wordmark-servicetech .stc-mark {
  font-family:'Montserrat',sans-serif;
  font-weight:900; font-size:1.05rem;
  color:#ffffff;
  background:#C8102E;
  padding:4px 7px;
  letter-spacing:0.02em;
  line-height:1;
  border-radius:2px;
}
.wordmark-servicetech .stc-name {
  font-family:'Montserrat',sans-serif;
  font-weight:600; font-size:0.98rem;
  color:#1A1A1A; letter-spacing:0.02em;
  line-height:1.15;
}

/* ─── TRANSACTION TOMBSTONES ─── */
.tx-tombstone-wrap {
  display:flex; justify-content:center;
  margin:8px 0 24px;
  padding:0;
}
.tx-tombstone {
  display:block;
  max-width:240px;
  width:100%;
  height:auto;
  border-radius:4px;
  box-shadow:0 4px 24px rgba(0,0,0,0.4);
  background:#ffffff;
}
.tx-detail-empty {
  color:var(--muted);
  font-style:italic;
  opacity:0.7;
}

/* Legacy: preserve old acquirer-badge classes harmlessly in case anything still references them */
.acquirer-badge { display:none; }
.tx-client-logo { display:none; }

/* ─── PULL-QUOTE ─── */
.pullquote-section {
  background:linear-gradient(180deg, var(--navy) 0%, var(--navy-mid) 100%);
  padding:120px 56px;
  border-top:1px solid var(--rule);
  border-bottom:1px solid var(--rule);
  position:relative;
  overflow:hidden;
}
.pullquote-section::before {
  content:'';
  position:absolute; inset:0;
  background-image:
    linear-gradient(rgba(142,169,219,0.04) 1px, transparent 1px),
    linear-gradient(90deg, rgba(142,169,219,0.04) 1px, transparent 1px);
  background-size:80px 80px;
  pointer-events:none;
}
.pullquote {
  max-width:880px; margin:0 auto;
  position:relative; z-index:2;
  text-align:center;
}
.pullquote-mark {
  width:56px; height:42px;
  color:var(--gold);
  opacity:0.45;
  margin:0 auto 32px;
  display:block;
}
.pullquote blockquote {
  margin:0; padding:0;
}
.pullquote blockquote p {
  font-family:'Cormorant Garamond',serif;
  font-weight:300; font-style:italic;
  font-size:clamp(1.5rem, 2.6vw, 2.1rem);
  line-height:1.45;
  color:var(--white);
  letter-spacing:0.005em;
  margin:0;
}
.pullquote figcaption {
  margin-top:40px;
  display:flex; flex-direction:column; align-items:center; gap:6px;
}
.pullquote-author {
  font-family:'Cormorant Garamond',serif;
  font-size:1.15rem; font-weight:500;
  color:var(--gold-light);
  letter-spacing:0.01em;
}
.pullquote-role {
  font-size:0.78rem; font-weight:500; letter-spacing:0.2em; text-transform:uppercase;
  color:var(--muted);
}

/* ─── ANIMATIONS ─── */
@keyframes fadeUp { from { opacity:0; transform:translateY(22px); } to { opacity:1; transform:translateY(0); } }
@keyframes fadeIn { from { opacity:0; } to { opacity:1; } }
@keyframes ticker { from { transform:translateX(0); } to { transform:translateX(-50%); } }
.reveal { opacity:0; transform:translateY(26px); transition:opacity 0.75s ease, transform 0.75s ease; }
.reveal.visible { opacity:1; transform:none; }
.rd1 { transition-delay:0.12s; }
.rd2 { transition-delay:0.24s; }
.rd3 { transition-delay:0.36s; }
.rd4 { transition-delay:0.48s; }

/* ═══════════════════════════════════════════════
   RESPONSIVE — TABLET (≤960px) & MOBILE (≤600px)
═══════════════════════════════════════════════ */

/* ─── TABLET / iPad (≤960px) ─── */
@media (max-width: 1080px) {
  /* Tile grid: 3 columns on tablet */
  .tx-grid { grid-template-columns:repeat(3, 1fr); gap:24px; }
  .tx-grid-home { grid-template-columns:repeat(3, 1fr); gap:36px 28px; padding:0 16px; max-width:780px; }
  .tx-grid-full { grid-template-columns:repeat(3, 1fr); gap:20px; }
  .tile-overlay { padding:18px 16px; }
  .tile-desc { font-size:1.04rem; }
  .placeholder-monogram { font-size:2.4rem; }

  /* Nav: hamburger from this breakpoint down */
  nav {
    padding:14px 20px;
    background:rgba(10,20,34,0.97);
    backdrop-filter:blur(10px);
    border-bottom:1px solid var(--rule);
  }
  nav.scrolled { padding:12px 20px; }
  .nav-center {
    position:fixed; top:64px; left:0; right:0;
    background:#0A1730; border-top:1px solid var(--rule);
    flex-direction:column; gap:0;
    padding:0; margin:0;
    max-height:0; overflow:hidden;
    transition:max-height 0.4s ease;
    z-index:99;
  }
  body.nav-open .nav-center { max-height:80vh; padding:8px 0; }
  .nav-center li { width:100%; list-style:none; }
  .nav-center a {
    display:block;
    padding:18px 24px;
    font-size:1.0rem;
    font-weight:700;
    letter-spacing:0.18em;
    border-bottom:1px solid var(--rule);
  }
  .nav-cta {
    font-size:0.98rem;
    padding:8px 16px;
    margin-left:auto;
    white-space:nowrap;
  }
  .nav-toggle {
    display:flex; flex-direction:column;
    justify-content:center; align-items:center;
    width:44px; height:44px;
    background:none; border:none;
    cursor:pointer; padding:0; gap:5px;
    margin-left:14px; margin-right:0;
  }
  .nav-toggle span {
    display:block; width:22px; height:1.5px;
    background:var(--gold);
    transition:transform 0.3s, opacity 0.3s;
  }
  body.nav-open .nav-toggle span:nth-child(1) {
    transform:translateY(6.5px) rotate(45deg);
  }
  body.nav-open .nav-toggle span:nth-child(2) {
    opacity:0;
  }
  body.nav-open .nav-toggle span:nth-child(3) {
    transform:translateY(-6.5px) rotate(-45deg);
  }

  /* Hero */
  .hero { padding:0 32px 70px; min-height:auto; padding-top:130px; }
  .hero-headline { font-size:clamp(2.4rem, 7vw, 4rem); }
  .hero-sub { font-size:0.97rem; max-width:none; }
  .hero-stats {
    position:static; right:auto; bottom:auto;
    flex-direction:row; gap:0;
    margin-top:48px; padding-top:32px;
    border-top:1px solid var(--rule);
    text-align:left;
  }
  .hero-stats > div:not(.stat-rule) {
    flex:1; padding:0 16px;
  }
  .hero-stats > div:first-child { padding-left:0; }
  .stat-rule {
    width:1px; height:48px;
    background:linear-gradient(to bottom, var(--rule), transparent);
  }
  .stat-num { font-size:2.4rem; }
  .stat-label { font-size:0.66rem; letter-spacing:0.18em; }

  /* Section padding */
  .section, .section-alt { padding:80px 32px; }
  .page-hero { padding:130px 32px 60px; }
  .cta-band { padding:64px 32px; gap:32px; }
  .ticker { padding:14px 0; }
  footer { padding:36px 32px; }
  .related-pages { padding:28px 32px; }

  /* Grids → 2 cols on tablet */
  .svc-cards { grid-template-columns:1fr 1fr; }
  .industry-cards { grid-template-columns:1fr 1fr; }
  .team-grid { grid-template-columns:repeat(3, 1fr); }
  .insights-grid { grid-template-columns:repeat(2, 1fr); gap:24px; }
  .insights-featured-grid { grid-template-columns:repeat(2, 1fr); gap:24px; }

  /* Two-column detail grids stack */
  .services-header { grid-template-columns:1fr; gap:32px; }
  .svc-intro-grid { grid-template-columns:1fr; gap:32px; margin-bottom:48px; }
  .svc-intro-quote { padding:24px 24px 24px 30px; }
  .svc-quote-text { font-size:1.15rem; padding-left:14px; }
  .svc-quote-attrib { padding-left:14px; }
  .svc-detail-grid { grid-template-columns:1fr; gap:40px; }
  .contact-grid { grid-template-columns:1fr; gap:48px; }

  /* Stats band on Our Firm */
  .stats-band { padding:48px 32px; grid-template-columns:1fr 1fr; gap:32px 0; }
  .stat-block { padding:0 24px; border-right:1px solid var(--rule); }
  .stat-block:nth-child(2) { border-right:none; }
  .stat-block:nth-child(3), .stat-block:nth-child(4) {
    padding-top:32px; border-top:1px solid var(--rule);
  }
  .stat-big { font-size:2.6rem; }

  /* Tx tables: collapse columns */
  .tx-row:not(details), details.tx-row.tx-expandable > summary {
    grid-template-columns:36px 1fr auto;
    gap:20px;
  }
  .tx-row .tx-sector, details.tx-row.tx-expandable > summary > .tx-sector { display:none; }
  .tx-full-row:not(details), details.tx-full-row.tx-expandable > summary {
    grid-template-columns:36px 1fr 100px 24px;
    gap:16px;
  }
  details.tx-full-row.tx-expandable > summary > .tx-sector { display:none; }
  .tx-name { font-size:1.1rem; }
  .tx-detail { padding:8px 16px 28px 36px; margin-left:8px; }
  .tx-detail-grid { grid-template-columns:1fr 1fr; gap:20px; }

  /* Filter buttons */
  .tx-filter { gap:8px; }
  .filter-btn { padding:10px 14px; font-size:0.78rem; letter-spacing:0.14em; }

  /* Process steps */
  .process-step { grid-template-columns:80px 1fr; gap:28px; padding:36px 0; }
  .process-step-num { font-size:3rem; }
  .process-step-title { font-size:1.45rem; }

  /* Process timeline — tablet (slightly smaller dots) */
  .process-timeline { gap:0; margin:32px auto 72px; padding:32px 12px 24px; }
  .timeline-dot {
    width:72px; height:72px;
    font-size:1.7rem;
    box-shadow:
      0 0 0 4px rgba(30,50,93,0.5),
      0 0 16px rgba(142,169,219,0.12),
      inset 0 1px 0 rgba(255,255,255,0.06);
  }
  .timeline-dot::after { inset:-9px; }
  .timeline-track { top:68px; left:8.33%; right:8.33%; }
  .timeline-step::before { top:68px; height:14px; }
  .timeline-label { font-size:1.05rem; }
  .timeline-time { font-size:0.62rem; letter-spacing:0.2em; padding:5px 10px; }

  /* Form */
  .form-row { grid-template-columns:1fr; gap:0; }

  /* CTA band */
  .cta-band { grid-template-columns:1fr; gap:24px; }
  .cta-band a.btn-primary { width:100%; text-align:center; }

  /* Related pages */
  .related-inner { gap:18px; }
  .related-list { gap:20px; }
  .related-list a { font-size:1rem; }

  /* FAQ */
  .faq-groups { gap:48px; }
  .faq-item summary { font-size:1.2rem; padding:22px 0; }

  /* Insights cards */
  .insight-featured-card .insight-body { padding:24px; }
  .insight-card .insight-body { padding:22px; }
  .insight-featured-title { font-size:1.3rem; }
  .insight-title { font-size:1.1rem; }

  /* Pull-quote */
  .pullquote-section { padding:80px 32px; }
  .pullquote-mark { width:46px; height:34px; margin-bottom:24px; }

  /* Value cards */
  .values-grid { grid-template-columns:1fr 1fr; }
  .value-card { padding:36px 28px; }
}

/* ─── MOBILE (≤600px) ─── */
@media (max-width: 600px) {
  /* Team modal — stack on mobile */
  .team-modal { padding:16px; align-items:flex-start; }
  .team-modal-grid { grid-template-columns:1fr; }
  .team-modal-photo-col { border-right:none; border-bottom:1px solid var(--rule); }
  .team-modal-photo { aspect-ratio:1/1; max-height:60vh; }
  .team-modal-contact { padding:18px 20px; flex-direction:row; flex-wrap:wrap; gap:16px 24px; }
  .team-modal-contact-row { flex:1; min-width:140px; }
  .team-modal-body-col { padding:28px 22px 32px; }
  .team-modal-name { font-size:1.8rem; }
  .team-modal-title { font-size:0.74rem; margin-bottom:20px; padding-bottom:18px; letter-spacing:0.18em; }
  .team-modal-bio { font-size:1.04rem; line-height:1.75; }
  .team-modal-close { top:10px; right:10px; width:32px; height:32px; }

  /* Tile grid: 2 columns on phone-tablet boundary, 1 column on small phones */
  .tx-grid { grid-template-columns:repeat(2, 1fr); gap:20px; }
  .tx-grid-home { grid-template-columns:repeat(2, 1fr); gap:28px 20px; padding:0 12px; }
  .tx-grid-full { grid-template-columns:repeat(2, 1fr); gap:14px; }
  .tile-overlay { padding:14px 12px; }
  .tile-desc { font-size:0.97rem; line-height:1.4; }
  .tx-grid-home .tile-name, .tx-grid-full .tile-name { font-size:0.97rem; }
  .placeholder-monogram { font-size:2.2rem; }
  .tx-grid-home .placeholder-monogram, .tx-grid-full .placeholder-monogram { font-size:2.2rem; }
  .tile-label { text-align:left; }

  /* Mobile-only nav refinements (hamburger is already shown from 960px down) */
  .nav-logo { height:48px; } .nav-logo-img { height:46px; }
  .nav-logo-home { height:52px; } .nav-logo-home .nav-logo-img { height:50px; }
  .nav-cta {
    font-size:0.66rem;
    padding:7px 12px;
    letter-spacing:0.12em;
  }

  /* Hero */
  .hero { padding:0 20px 56px; padding-top:120px; }
  .hero-headline { font-size:clamp(2.2rem, 9vw, 3.4rem); line-height:1.1; }
  .hero-sub { font-size:1.02rem; line-height:1.75; margin-bottom:36px; }
  .hero-actions { flex-direction:column; align-items:stretch; gap:18px; }
  .btn-primary { text-align:center; padding:16px 24px; font-size:1.0rem; }
  .btn-ghost { justify-content:center; padding:14px 0; font-size:1.0rem; }
  .hero-stats {
    flex-direction:column; gap:24px;
    margin-top:40px; padding-top:28px;
  }
  .hero-stats > div:not(.stat-rule) { padding:0; }
  .stat-rule { width:100%; height:1px; background:linear-gradient(to right, var(--rule), transparent); }
  .stat-num { font-size:2.4rem; }
  .stat-label { font-size:0.72rem; letter-spacing:0.15em; }

  /* Sections */
  .section, .section-alt { padding:64px 20px; }
  .page-hero { padding:110px 20px 48px; }
  .cta-band { padding:52px 20px; }
  footer { padding:32px 20px; gap:18px; flex-direction:column; text-align:center; }
  .footer-links { justify-content:center; flex-wrap:wrap; gap:18px; }
  .related-pages { padding:24px 20px; }
  .related-inner { flex-direction:column; align-items:flex-start; gap:14px; }

  /* Typography on mobile */
  .sec-title { font-size:1.8rem; }
  .page-hero-title { font-size:2rem; line-height:1.12; }
  .page-hero-sub { font-size:1.02rem; }
  .cta-title { font-size:1.5rem; }

  /* Single-col grids on mobile */
  .svc-cards { grid-template-columns:1fr; }
  .industry-cards { grid-template-columns:1fr; }
  .team-grid { grid-template-columns:1fr; }
  .insights-grid { grid-template-columns:1fr; gap:20px; }
  .insights-featured-grid { grid-template-columns:1fr; gap:20px; }
  .values-grid { grid-template-columns:1fr; }

  /* Stats band — single column */
  .stats-band { grid-template-columns:1fr 1fr; padding:36px 20px; }
  .stat-block { padding:16px 12px !important; border:none !important; border-bottom:1px solid var(--rule) !important; }
  .stat-block:nth-child(odd) { border-right:1px solid var(--rule) !important; }
  .stat-block:nth-last-child(-n+2) { border-bottom:none !important; }
  .stat-big { font-size:2.1rem; }
  .stat-small { font-size:0.72rem; letter-spacing:0.15em; }

  /* Service cards */
  .svc-card { padding:36px 24px; }
  .svc-num { font-size:2.6rem; margin-bottom:18px; }
  .svc-name { font-size:1.3rem; }
  .svc-desc { font-size:1.02rem; }
  .svc-link {
    opacity:1 !important; transform:none !important;
    padding:14px 0 4px;
  }

  /* Industry cards */
  .industry-card { padding:36px 24px; }
  .industry-title { font-size:1.5rem; }
  .industry-link { font-size:0.98rem; padding:12px 0 0; }

  /* Service detail grid */
  .svc-detail-grid { gap:32px; }
  .feature-item { padding:18px 0; gap:14px; }
  .feature-text { font-size:1.02rem; }

  /* Team cards */
  .team-photo { aspect-ratio:1/1; }
  .team-card-body { padding:24px 24px 32px; }
  .team-name { font-size:1.4rem; }
  .team-title { font-size:0.7rem; letter-spacing:0.14em; }
  .team-bio { font-size:1.0rem; }

  /* Process steps */
  .process-step {
    grid-template-columns:1fr;
    gap:14px; padding:32px 0;
  }
  .process-step-num { font-size:2.4rem; opacity:0.7; }
  .process-step-title { font-size:1.35rem; }
  .process-step-text { font-size:1.02rem; }

  /* Process timeline → switch to vertical on mobile */
  .process-timeline {
    grid-template-columns:1fr;
    gap:24px;
    padding:24px 8px;
    margin:24px 0 48px;
    max-width:none;
  }
  .timeline-track {
    top:32px; bottom:32px; left:30px; right:auto;
    width:2px; height:auto;
    background:linear-gradient(to bottom,
      rgba(142,169,219,0.1) 0%,
      var(--accent) 12%,
      var(--accent) 88%,
      rgba(142,169,219,0.1) 100%);
  }
  .timeline-track::before { display:none; }
  .timeline-step {
    flex-direction:row;
    align-items:center;
    text-align:left;
    gap:18px;
    padding:0;
  }
  .timeline-step::before { display:none; }
  .timeline-dot {
    width:60px; height:60px; font-size:1.5rem;
    flex-shrink:0;
    box-shadow:
      0 0 0 3px rgba(30,50,93,0.5),
      0 0 12px rgba(142,169,219,0.1),
      inset 0 1px 0 rgba(255,255,255,0.06);
  }
  .timeline-dot::after { inset:-6px; }
  .timeline-label {
    margin-top:0; font-size:1.1rem;
    flex:1;
  }
  .timeline-time {
    margin-top:0; font-size:0.7rem;
    margin-left:auto;
    flex-shrink:0;
    padding:5px 10px;
  }

  /* Transactions list — fully restructured for mobile */
  .tx-row:not(details), details.tx-row.tx-expandable > summary {
    grid-template-columns:32px 1fr 24px;
    gap:14px;
    padding:22px 8px 22px 0;
  }
  .tx-row > .tx-tag, details.tx-row.tx-expandable > summary > .tx-tag { display:none; }
  .tx-full-row:not(details), details.tx-full-row.tx-expandable > summary {
    grid-template-columns:32px 1fr 24px;
    gap:14px;
    padding:22px 8px 22px 0;
  }
  details.tx-full-row.tx-expandable > summary > .tx-tag { display:none; }
  .tx-name { font-size:1rem; line-height:1.3; }
  .tx-desc { font-size:1.02rem; }
  .tx-idx { font-size:1.04rem; }
  .tx-detail { padding:6px 12px 24px 8px; margin-left:0; }
  .tx-detail-grid { grid-template-columns:1fr; gap:14px; margin-bottom:16px; max-width:none; }
  .tx-detail-value { font-size:1.05rem; }
  .tx-detail-desc { font-size:1.02rem; }

  /* Tx page header */
  .tx-header { flex-direction:column; align-items:flex-start; gap:24px; }
  .tx-filter { gap:6px; }
  .filter-btn { padding:8px 12px; font-size:1.02rem; }

  /* Forms */
  .form-input, .form-select, .form-textarea {
    font-size:1rem; /* iOS won't zoom-in on focus when input ≥16px */
    padding:14px 16px;
  }
  .form-submit { padding:18px; font-size:0.98rem; }

  /* CTA band */
  .cta-band { grid-template-columns:1fr; gap:20px; padding:48px 20px; }
  .cta-band-text br { display:none; }

  /* Insights */
  .insight-featured-card .insight-body { padding:20px; }
  .insight-card .insight-body { padding:20px; }
  .insight-featured-title { font-size:1.2rem; }
  .insight-title { font-size:1.1rem; }
  .insight-excerpt { font-size:1.0rem; line-height:1.55; }

  /* Pull-quote */
  .pullquote-section { padding:60px 20px; }
  .pullquote-mark { width:40px; height:30px; margin-bottom:20px; }
  .pullquote figcaption { margin-top:28px; }
  .pullquote-author { font-size:1.05rem; }
  .pullquote-role { font-size:0.74rem; letter-spacing:0.18em; }

  /* Tooltip / ticker */
  .ticker { padding:14px 0; }
  .tick { padding:0 20px; gap:14px; font-size:0.74rem; letter-spacing:0.2em; }

  /* Section labels */
  .sec-label { margin-bottom:36px; }

  /* Ensure tap targets are 44px+ */
  .nav-center a,
  .footer-links a,
  .filter-btn,
  .industry-link,
  .svc-link,
  .tx-view-all,
  .insight-read,
  details.faq-item summary,
  details.tx-expandable > summary {
    min-height:44px;
  }

  /* FAQ groups */
  .faq-groups { gap:36px; max-width:none; }
  .faq-group-title { font-size:1.15rem; gap:12px; padding-bottom:14px; }
  .faq-item summary { font-size:1.08rem; padding:18px 32px 18px 0; line-height:1.4; }
  .faq-item summary::after { font-size:1.5rem; margin-left:14px; }
  .faq-item p { font-size:1.05rem; line-height:1.7; }
  .faq-item > div { padding-bottom:22px; }

  /* Eyebrows */
  .eyebrow-text, .sec-label-text { font-size:0.74rem; letter-spacing:0.2em; }

  /* Contact info */
  .contact-info-block { margin-bottom:32px; }
  .contact-info-value { font-size:1.1rem; }
}

/* ─── SMALL PHONE (≤380px) ─── */
@media (max-width: 380px) {
  .hero { padding:120px 16px 48px; }
  .section, .section-alt { padding:56px 16px; }
  .page-hero { padding:100px 16px 40px; }
  .hero-headline { font-size:2rem; }
  .page-hero-title { font-size:1.7rem; }
  .sec-title { font-size:1.6rem; }
  .nav-logo { height:40px; } .nav-logo-img { height:38px; }
  .nav-logo-home { height:42px; } .nav-logo-home .nav-logo-img { height:40px; }
}

/* ─── SAFE AREA (notched iPhones) ─── */
@supports (padding: max(0px)) {
  nav { padding-left:max(20px, env(safe-area-inset-left)); padding-right:max(20px, env(safe-area-inset-right)); }
  .hero { padding-left:max(20px, env(safe-area-inset-left)); padding-right:max(20px, env(safe-area-inset-right)); }
  .section, .section-alt { padding-left:max(20px, env(safe-area-inset-left)); padding-right:max(20px, env(safe-area-inset-right)); }
  footer { padding-left:max(20px, env(safe-area-inset-left)); padding-right:max(20px, env(safe-area-inset-right)); padding-bottom:max(32px, env(safe-area-inset-bottom)); }
}


/* ─── TESTIMONIAL CARDS (Cleveland landing page) ─── */
.testimonial-grid {
  display:grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 28px;
  margin-top: 12px;
}
@media (max-width: 1080px) {
  .testimonial-grid { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 768px) {
  .testimonial-grid { grid-template-columns: 1fr; gap: 22px; }
}
.testimonial-card {
  background: linear-gradient(180deg, rgba(27,43,87,0.55) 0%, rgba(15,31,63,0.55) 100%);
  border: 1px solid rgba(142, 169, 219, 0.18);
  border-radius: 4px;
  padding: 36px 36px 30px;
  position: relative;
}
@media (max-width: 600px) {
  .testimonial-card { padding: 28px 24px 24px; }
}
.testimonial-card::before {
  content: "\201C";
  position: absolute;
  top: 14px; left: 26px;
  font-family: 'Cormorant Garamond', serif;
  font-size: 78px;
  line-height: 1;
  color: var(--accent);
  opacity: 0.32;
}
.testimonial-quote {
  font-family: 'Cormorant Garamond', serif;
  font-weight: 400;
  font-size: 1.2rem;
  line-height: 1.6;
  color: #E8EEF7;
  margin: 0 0 26px;
  position: relative;
  z-index: 1;
}
@media (max-width: 600px) {
  .testimonial-quote { font-size: 1.08rem; line-height: 1.65; }
}
.testimonial-attribution {
  border-top: 1px solid rgba(142, 169, 219, 0.18);
  padding-top: 18px;
  display: flex;
  flex-direction: column;
  gap: 4px;
}
.testimonial-attr-name {
  font-family: 'Cormorant Garamond', serif;
  font-size: 1.08rem;
  font-weight: 500;
  color: #FFFFFF;
  letter-spacing: 0.01em;
}
.testimonial-attr-role {
  font-family: 'Montserrat', sans-serif;
  font-size: 0.74rem;
  font-weight: 500;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--accent-light);
}

/* ─── HOMEPAGE TESTIMONIAL STRIP ─── */
.testimonial-home-header {
  display:flex;
  flex-direction:column;
  gap:20px;
  margin-bottom:48px;
  max-width:760px;
}
.testimonial-grid-home {
  grid-template-columns: repeat(3, 1fr);
}
@media (max-width: 1080px) {
  .testimonial-grid-home { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 768px) {
  .testimonial-grid-home { grid-template-columns: 1fr; }
}
.testimonial-home-footer {
  margin-top:40px;
  display:flex;
  justify-content:flex-end;
}
@media (max-width: 768px) {
  .testimonial-home-footer { justify-content:flex-start; }
}


/* ===== TRANSACTION DETAIL PAGES ===== */
.tx-detail-meta {
  font-family: 'Montserrat', sans-serif; font-size: 0.78rem;
  letter-spacing: 0.18em; text-transform: uppercase;
  color: var(--accent-light); margin-top: 18px;
}
.tx-detail-section {
  background: var(--cream); padding: 80px 0;
}
.tx-detail-wrap {
  max-width: 1080px; margin: 0 auto; padding: 0 40px;
  display: grid; grid-template-columns: 1fr 1fr; gap: 60px; align-items: start;
}
.tx-detail-tombstone {
  background: white; padding: 30px; border: 1px solid rgba(30, 50, 93, 0.08);
}
.tx-detail-image {
  width: 100%; height: auto; display: block;
}
.tx-detail-info { padding-top: 8px; }
.tx-detail-h {
  font-family: 'Cormorant Garamond', serif; font-size: 2rem; font-weight: 400;
  color: var(--navy); margin: 0 0 28px; letter-spacing: -0.01em;
}
.tx-detail-dl {
  display: grid; grid-template-columns: 160px 1fr; gap: 14px 24px;
  margin: 0; font-size: 0.95rem;
}
.tx-detail-dl dt {
  font-family: 'Montserrat', sans-serif; font-size: 0.72rem; font-weight: 500;
  letter-spacing: 0.18em; text-transform: uppercase; color: var(--navy-mid);
  padding-top: 3px;
}
.tx-detail-dl dd {
  margin: 0; color: var(--navy); font-weight: 300; line-height: 1.5;
}
.tx-detail-dl a { color: var(--navy); border-bottom: 1px solid var(--accent); }
.tx-detail-dl a:hover { color: var(--accent); }

.tx-detail-context {
  background: white; padding: 80px 0;
}
.tx-detail-context-wrap {
  max-width: 780px; margin: 0 auto; padding: 0 40px;
}
.tx-detail-context p {
  font-size: 1.04rem; line-height: 1.75; color: var(--navy);
  margin: 0 0 20px; font-weight: 300;
}
.tx-detail-context a {
  color: var(--navy); border-bottom: 1px solid var(--accent);
}
.tx-detail-context a:hover { color: var(--accent); }

.tx-related-section {
  background: var(--cream); padding: 80px 0;
}
.tx-related-wrap {
  max-width: 1180px; margin: 0 auto; padding: 0 40px;
}
.tx-related-h {
  font-family: 'Cormorant Garamond', serif; font-size: 2rem; font-weight: 400;
  color: var(--navy); margin: 0 0 40px; text-align: center;
}
.tx-related-grid {
  display: grid; grid-template-columns: repeat(3, 1fr); gap: 24px;
}
.tx-related-card {
  background: white; text-decoration: none; color: var(--navy);
  border: 1px solid rgba(30, 50, 93, 0.08);
  transition: transform 0.3s, box-shadow 0.3s;
  display: flex; flex-direction: column;
}
.tx-related-card:hover {
  transform: translateY(-4px); box-shadow: 0 12px 30px rgba(30, 50, 93, 0.1);
}
.tx-related-image {
  aspect-ratio: 4/3; overflow: hidden; background: white;
  display: flex; align-items: center; justify-content: center;
}
.tx-related-image img {
  width: 100%; height: 100%; object-fit: contain;
}
.tx-related-body { padding: 18px 22px; }
.tx-related-name {
  font-family: 'Cormorant Garamond', serif; font-size: 1.2rem; font-weight: 500;
  margin: 0 0 6px; color: var(--navy);
}
.tx-related-sector {
  font-family: 'Montserrat', sans-serif; font-size: 0.72rem;
  letter-spacing: 0.14em; text-transform: uppercase; color: var(--navy-mid);
}
.tx-related-cta { text-align: center; margin-top: 48px; }

.tx-cta-section {
  background: var(--navy); color: white; padding: 80px 0;
}
.tx-cta-wrap {
  max-width: 720px; margin: 0 auto; padding: 0 40px; text-align: center;
}
.tx-cta-h {
  font-family: 'Cormorant Garamond', serif; font-size: 2.4rem; font-weight: 400;
  color: white; margin: 0 0 24px; letter-spacing: -0.01em;
}
.tx-cta-section p {
  font-size: 1.08rem; line-height: 1.7; color: var(--accent-light);
  margin: 0 0 32px; font-weight: 300;
}

@media (max-width: 1080px) {
  .tx-detail-wrap { grid-template-columns: 1fr; gap: 40px; }
  .tx-related-grid { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 768px) {
  .tx-detail-wrap { padding: 0 24px; }
  .tx-detail-dl { grid-template-columns: 1fr; gap: 4px 0; }
  .tx-detail-dl dt { padding-top: 12px; }
  .tx-related-grid { grid-template-columns: 1fr; }
  .tx-cta-h { font-size: 1.9rem; }
  .tx-detail-h, .tx-related-h { font-size: 1.7rem; }
}

.tx-tile-link { text-decoration:none; color:inherit; display:block; }

/* ============================================================
   ARTICLE / INSIGHT DETAIL PAGES
   ============================================================ */
.article-section { padding:72px 56px 40px; position:relative; }
.article-wrap { max-width:1060px; margin:0 auto; }
.article-hero-meta { display:flex; flex-wrap:wrap; gap:10px 22px; margin-top:26px; }
.article-hero-meta span { font-family:'Montserrat',sans-serif; font-size:0.72rem; font-weight:500; letter-spacing:0.16em; text-transform:uppercase; color:var(--accent); }
.article-hero-meta span + span { padding-left:22px; border-left:1px solid var(--rule); }

.article-cover { max-width:480px; margin:0 auto 64px; border:1px solid var(--rule); border-radius:4px; overflow:hidden; box-shadow:0 24px 60px rgba(0,0,0,0.35); }
.article-cover img { display:block; width:100%; height:auto; }

.article-body { max-width:740px; margin:0 auto; }
.article-lead { font-family:'Cormorant Garamond',serif; font-weight:300; font-style:italic; font-size:clamp(1.4rem,2.4vw,1.85rem); line-height:1.5; color:var(--white); margin-bottom:48px; padding-bottom:48px; border-bottom:1px solid var(--rule); }
.article-body h2 { font-family:'Cormorant Garamond',serif; font-weight:300; font-size:clamp(1.8rem,3.2vw,2.6rem); line-height:1.16; color:var(--white); margin:64px 0 28px; }
.article-body h2:first-child { margin-top:0; }
.article-body p { font-family:'Montserrat',sans-serif; font-size:1.0rem; font-weight:400; line-height:1.85; color:#C5D2E5; margin-bottom:1.4em; letter-spacing:0.005em; }
.article-body p a, .endnotes a { color:var(--accent-light); text-decoration:none; border-bottom:1px solid var(--rule); transition:border-color 0.25s, color 0.25s; }
.article-body p a:hover, .endnotes a:hover { color:var(--white); border-bottom-color:var(--accent-light); }
.article-eyebrow { font-family:'Montserrat',sans-serif; font-size:0.74rem; font-weight:500; letter-spacing:0.22em; text-transform:uppercase; color:var(--accent); margin:0 0 18px; }

/* Numbered takeaway / trend cards */
.takeaways { display:grid; gap:20px; margin:8px 0 16px; }
.takeaway { background:var(--navy-mid); border:1px solid var(--rule); border-left:3px solid var(--accent); border-radius:4px; padding:30px 34px; }
.takeaway-num { font-family:'Cormorant Garamond',serif; font-weight:400; font-size:1.5rem; color:var(--accent-light); line-height:1; margin-bottom:10px; }
.takeaway h3 { font-family:'Montserrat',sans-serif; font-size:0.98rem; font-weight:600; letter-spacing:0.01em; color:var(--white); margin:0 0 12px; line-height:1.4; }
.takeaway p { font-size:0.95rem; line-height:1.78; color:#BFCDE2; margin:0; }
.takeaway p + p { margin-top:0.9em; }

/* Notable transaction blocks */
.deal-grid { display:grid; gap:20px; margin:8px 0 16px; }
.deal-card { background:var(--navy-mid); border:1px solid var(--rule); border-radius:4px; padding:28px 32px; }
.deal-head { font-family:'Cormorant Garamond',serif; font-weight:400; font-style:italic; font-size:1.3rem; color:var(--white); margin:0 0 14px; line-height:1.3; }
.deal-head strong { font-style:normal; font-weight:500; color:var(--accent-light); }
.deal-card p { font-size:0.95rem; line-height:1.78; color:#BFCDE2; margin:0; }

/* Data tables */
.data-table-block { margin:36px 0 8px; }
.data-table-title { font-family:'Montserrat',sans-serif; font-size:0.8rem; font-weight:600; letter-spacing:0.16em; text-transform:uppercase; color:var(--accent); margin:0 0 16px; }
.data-table-wrap { overflow-x:auto; border:1px solid var(--rule); border-radius:4px; -webkit-overflow-scrolling:touch; }
table.data-table { width:100%; border-collapse:collapse; font-family:'Montserrat',sans-serif; font-size:0.82rem; min-width:560px; }
.data-table thead th { background:#102648; color:var(--accent); font-weight:600; font-size:0.68rem; letter-spacing:0.12em; text-transform:uppercase; text-align:left; padding:14px 16px; white-space:nowrap; }
.data-table tbody td { padding:12px 16px; color:#CBD7EA; border-top:1px solid var(--rule-light); }
.data-table tbody tr:nth-child(even) td { background:rgba(142,169,219,0.03); }
.data-table td.num, .data-table th.num { text-align:right; white-space:nowrap; }
.data-table tfoot td { padding:12px 16px; border-top:1px solid var(--rule); color:var(--white); font-weight:600; font-size:0.78rem; }
.data-table tfoot tr:first-child td { border-top:2px solid var(--accent); }
.data-table-foot { font-size:0.78rem; color:var(--muted); margin:14px 0 0; font-style:italic; }

/* Endnotes */
.endnotes { margin-top:64px; padding-top:36px; border-top:1px solid var(--rule); }
.endnotes h2 { font-size:1.4rem; margin-bottom:20px; }
.endnotes ol { margin:0; padding-left:20px; }
.endnotes li { font-family:'Montserrat',sans-serif; font-size:0.84rem; line-height:1.7; color:var(--muted); margin-bottom:8px; }

/* Article CTA */
.article-cta { max-width:1060px; margin:72px auto 0; background:linear-gradient(135deg,#16284E,#1E325D); border:1px solid var(--rule); border-radius:6px; padding:52px 48px; text-align:center; }
.article-cta h2 { font-family:'Cormorant Garamond',serif; font-weight:300; font-size:clamp(1.6rem,3vw,2.2rem); color:var(--white); margin:0 0 16px; }
.article-cta p { font-family:'Montserrat',sans-serif; font-size:0.98rem; line-height:1.7; color:#C5D2E5; max-width:520px; margin:0 auto 28px; }
.article-cta .btn-primary { display:inline-block; }
.back-to-insights { display:inline-flex; align-items:center; gap:8px; margin-top:40px; font-family:'Montserrat',sans-serif; font-size:0.82rem; font-weight:500; letter-spacing:0.04em; color:var(--accent); text-decoration:none; transition:color 0.25s; }
.back-to-insights:hover { color:var(--white); }

/* De-linked "coming soon" insight cards */
.insight-card.is-soon, .insight-featured-card.is-soon { cursor:default; }
.insight-card.is-soon:hover, .insight-featured-card.is-soon:hover { transform:none; box-shadow:none; border-color:var(--rule); }
.insight-card.is-soon .insight-read, .insight-featured-card.is-soon .insight-read { color:var(--muted); }

@media (max-width:768px) {
  .article-section { padding:48px 32px 32px; }
  .article-cover { max-width:340px; margin-bottom:44px; }
  .takeaway, .deal-card { padding:24px 22px; }
  .article-cta { padding:40px 26px; }
}
@media (max-width:480px) {
  .article-section { padding:36px 20px 24px; }
  .article-hero-meta span + span { padding-left:0; border-left:none; }
}
