/*
 * Clever Prep — EyeQ landing page
 * SaaS-style page for the NBEO study platform.
 */

/* Section base reset */
.brxe-section[class*="cp-eyeq-"] {
  align-items: stretch !important;
  width: 100%;
  padding: 0;
  background: var(--cp-cream-bg);
}
.brxe-container[class*="cp-eyeq-"][class$="__inner"] {
  width: 100%;
  max-width: 1280px;
  margin: 0 auto !important;
  padding: 0 32px;
}


/* ──────────────────── 1. HERO ──────────────────── */
.brxe-section.cp-eyeq-hero {
  padding: clamp(120px, 16vh, 180px) 0 clamp(64px, 9vh, 120px);
}
.brxe-container.cp-eyeq-hero__inner {
  display: flex !important;
  flex-direction: column !important;
  align-items: center !important;
  text-align: center;
  gap: clamp(48px, 6vw, 80px);
}

.brxe-block.cp-eyeq-hero__copy {
  display: flex !important;
  flex-direction: column !important;
  align-items: center !important;
  gap: 22px;
  width: auto !important;
  max-width: 760px;
}

/* Research-preview badge above the H1 */
.cp-eyeq-hero__badge {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  margin: 0 auto -4px;
  padding: 8px 16px 8px 12px;
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.85);
  border: 1px solid rgba(40, 53, 74, 0.10);
  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);
  box-shadow: 0 2px 6px rgba(20, 30, 50, 0.06);
  font-family: var(--cp-font-mono, var(--cp-font-body));
  font-size: 12px;
  font-weight: 500;
  letter-spacing: 0.10em;
  text-transform: uppercase;
  color: var(--cp-text-headline, #28354A);
  text-decoration: none;
  align-self: center;
  transition: transform 0.2s ease, box-shadow 0.2s ease, background-color 0.2s ease;
}
.cp-eyeq-hero__badge:hover {
  transform: translateY(-1px);
  background: #fff;
  box-shadow: 0 6px 14px rgba(20, 30, 50, 0.10);
}
.cp-eyeq-hero__badge .cp-hero-badge__dot {
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background: var(--cp-orange, #ED863C);
  box-shadow: 0 0 0 4px rgba(237, 134, 60, 0.18);
  flex: 0 0 8px;
  animation: cp-eyeq-hero-badge-pulse 2.4s ease-in-out infinite;
}
@keyframes cp-eyeq-hero-badge-pulse {
  0%, 100% { box-shadow: 0 0 0 4px rgba(237, 134, 60, 0.18); }
  50%      { box-shadow: 0 0 0 8px rgba(237, 134, 60, 0.04); }
}
.cp-eyeq-hero__badge .cp-hero-badge__arrow {
  font-size: 13px;
  line-height: 1;
  transition: transform 0.2s ease;
}
.cp-eyeq-hero__badge:hover .cp-hero-badge__arrow {
  transform: translateX(2px);
}
.cp-eyeq-hero__title {
  font-family: var(--cp-font-heading);
  font-weight: 400;
  font-size: clamp(44px, 5.6vw, 80px);
  line-height: 1.02;
  letter-spacing: -.025em;
  color: var(--cp-text-headline);
  margin: 0;
  max-width: 16ch;
}
.cp-eyeq-hero__title em {
  font-style: italic;
  color: var(--cp-orange);
}
.cp-eyeq-hero__body {
  font-family: var(--cp-font-body);
  font-weight: 300;
  font-size: var(--cp-text-body-lg);
  line-height: var(--cp-leading-body);
  color: var(--cp-text-secondary);
  margin: 0;
  max-width: 56ch;
}
.brxe-block.cp-eyeq-hero__ctas {
  display: flex !important;
  flex-direction: row !important;
  flex-wrap: wrap !important;
  align-items: center !important;
  justify-content: center !important;
  gap: 12px !important;
  width: auto !important;
  margin-top: 8px;
}

/* Hero ecosystem visual — the 6-skeleton + dashboard grid that replaced
   the device mockup. Inherits all `.cp-eq-eco__*` styling from the
   ecosystem block below; this wrapper just sets the hero placement. */
.cp-eyeq-hero__eco {
  width: 100%;
  max-width: 1280px;
  margin: 0 auto;
  position: relative;
}
.cp-eyeq-hero__eco .cp-eq-eco__grid {
  /* Same grid the ecosystem section uses, but no surrounding section
     padding — already inside .cp-eyeq-hero with its own top padding. */
  margin-top: 0;
}


/* ──────────────────── 2. PLATFORM FEATURES ──────────────────── */
.brxe-section.cp-eyeq-features {
  padding: clamp(80px, 10vh, 140px) 0;
}
.brxe-container.cp-eyeq-features__inner {
  display: flex !important;
  flex-direction: column !important;
  align-items: stretch !important;
  gap: 48px;
}

.brxe-block.cp-eyeq-features__head {
  display: grid !important;
  grid-template-columns: 1fr auto;
  align-items: end !important;
  gap: 32px;
  width: 100% !important;
}
.brxe-block.cp-eyeq-features__head-left {
  display: flex !important;
  flex-direction: column !important;
  align-items: flex-start !important;
  gap: 14px;
  width: auto !important;
  max-width: 720px;
}
.brxe-block.cp-eyeq-features__head-right {
  display: flex !important;
  flex-direction: row !important;
  align-items: center !important;
  width: auto !important;
}
.cp-eyeq-features__eyebrow {
  color: var(--cp-orange);
  letter-spacing: .14em;
}
.cp-eyeq-features__title {
  font-family: var(--cp-font-heading);
  font-weight: 400;
  font-size: clamp(34px, 4.4vw, 56px);
  line-height: 1.05;
  letter-spacing: -.012em;
  color: var(--cp-text-headline);
  margin: 0;
  max-width: 18ch;
}
.cp-eyeq-features__blurb {
  font-family: var(--cp-font-body);
  font-weight: 300;
  font-size: var(--cp-text-body-lg);
  line-height: var(--cp-leading-body);
  color: var(--cp-text-secondary);
  margin: 0;
  max-width: 56ch;
}

/* Feature grid — 2 / 2 / 1 (5th card spans full width on desktop) */
.brxe-block.cp-eyeq-features__grid {
  display: grid !important;
  grid-template-columns: repeat(2, 1fr);
  gap: 28px 24px;
  width: 100% !important;
}
.brxe-block.cp-eyeq-feature-cell {
  display: flex !important;
  flex-direction: column !important;
  align-items: stretch !important;
  gap: 18px;
  width: 100% !important;
}
.brxe-block.cp-eyeq-feature-cell--wide { grid-column: 1 / -1; }

@media (max-width: 720px) {
  .brxe-block.cp-eyeq-features__head { grid-template-columns: 1fr !important; align-items: flex-start !important; }
  .brxe-block.cp-eyeq-features__grid { grid-template-columns: 1fr !important; }
  .brxe-block.cp-eyeq-feature-cell--wide { grid-column: auto; }
}

/* The card itself — gradient bg, UI image, plus button */
.brxe-block.cp-eyeq-feature {
  display: block !important;
  position: relative;
  width: 100% !important;
  aspect-ratio: 5 / 4;
  /* Mesh-gradient JPG image rides on top of the linear-gradient fallback,
     so the colour shows through if the image 404s. */
  background-color: #ddd;
  background-image: var(--grad-img), var(--grad, linear-gradient(135deg, #6FD3C7, #4AA6C0));
  background-size: cover, cover;
  background-position: center, center;
  background-repeat: no-repeat, no-repeat;
  border-radius: 28px;
  overflow: hidden;
  cursor: pointer;
  transition: transform .3s cubic-bezier(.22,.61,.36,1),
              box-shadow .3s cubic-bezier(.22,.61,.36,1);
  box-shadow: 0 12px 28px rgba(20,30,50,.08), 0 2px 6px rgba(20,30,50,.04);
  padding: 28px !important;
}
.brxe-block.cp-eyeq-feature:hover {
  transform: translateY(-4px);
  box-shadow: 0 24px 50px rgba(20,30,50,.14), 0 6px 14px rgba(20,30,50,.06);
}
.cp-eyeq-feature-cell--wide .brxe-block.cp-eyeq-feature {
  aspect-ratio: 21 / 9;
}

.brxe-block.cp-eyeq-feature__media {
  position: absolute !important;
  inset: 56px 36px 36px 36px !important;
  width: auto !important;
  height: auto !important;
  border-radius: 14px;
  overflow: hidden;
  background: transparent;
  margin: 0 !important;
  padding: 0 !important;
  display: block !important;
  filter: drop-shadow(0 12px 28px rgba(20,30,50,.18))
          drop-shadow(0 4px 10px rgba(20,30,50,.10));
}
.brxe-image.cp-eyeq-feature__preview,
.brxe-image.cp-eyeq-feature__preview img {
  width: 100% !important;
  height: 100% !important;
  display: block !important;
  object-fit: contain !important;
  object-position: center bottom !important;
  border-radius: 14px;
}

/* ── Per-card positioning of the UI mockup ────────────────────────────── */
/* Dashboard: phone mockup shifted down, "cut off" at the bottom edge.
   Top inset pushes the phone down so only the top ~3/4 is visible;
   bottom inset is negative so the image bleeds past the card's bottom.
   Card has overflow:hidden so the bottom of the phone is clipped cleanly. */
.brxe-block.cp-eyeq-feature[data-feature-id="dashboard"] .brxe-block.cp-eyeq-feature__media {
  inset: 88px 24px -120px 24px !important;
  border-radius: 0;
  display: flex !important;
  align-items: flex-start !important;
  justify-content: center !important;
  overflow: visible !important;
  filter: none;
}
.brxe-block.cp-eyeq-feature[data-feature-id="dashboard"] .brxe-image.cp-eyeq-feature__preview,
.brxe-block.cp-eyeq-feature[data-feature-id="dashboard"] .brxe-image.cp-eyeq-feature__preview img {
  object-position: center top !important;
  border-radius: 0;
}

/* Content: screenshot inset on sides + top, pinned to bottom */
.brxe-block.cp-eyeq-feature[data-feature-id="content"] .brxe-block.cp-eyeq-feature__media {
  inset: 70px 56px 0 56px !important;
  border-radius: 14px 14px 0 0;
}
.brxe-block.cp-eyeq-feature[data-feature-id="content"] .brxe-image.cp-eyeq-feature__preview,
.brxe-block.cp-eyeq-feature[data-feature-id="content"] .brxe-image.cp-eyeq-feature__preview img {
  object-position: center bottom !important;
  border-radius: 14px 14px 0 0;
}

/* Ask EyeQ AI: card touches right edge, vertically centred */
.brxe-block.cp-eyeq-feature[data-feature-id="ai"] .brxe-block.cp-eyeq-feature__media {
  inset: 56px 0 36px 36px !important;
  border-radius: 14px 0 0 14px;
}
.brxe-block.cp-eyeq-feature[data-feature-id="ai"] .brxe-image.cp-eyeq-feature__preview,
.brxe-block.cp-eyeq-feature[data-feature-id="ai"] .brxe-image.cp-eyeq-feature__preview img {
  object-position: right center !important;
  border-radius: 14px 0 0 14px;
}

/* Analytics: Course Mastery card falls off the bottom-right corner */
.brxe-block.cp-eyeq-feature[data-feature-id="analytics"] .brxe-block.cp-eyeq-feature__media {
  inset: 56px 0 0 36px !important;
  border-radius: 14px 0 0 0;
}
.brxe-block.cp-eyeq-feature[data-feature-id="analytics"] .brxe-image.cp-eyeq-feature__preview,
.brxe-block.cp-eyeq-feature[data-feature-id="analytics"] .brxe-image.cp-eyeq-feature__preview img {
  object-position: right bottom !important;
  border-radius: 14px 0 0 0;
}

/* Plus icon, top-right */
.cp-eyeq-feature__plus {
  position: absolute;
  top: 18px;
  right: 18px;
  width: 40px;
  height: 40px;
  border-radius: 50%;
  background: rgba(255,255,255,.95);
  color: var(--cp-text-headline);
  display: flex;
  align-items: center;
  justify-content: center;
  font-family: var(--cp-font-body);
  font-size: 26px;
  font-weight: 300;
  line-height: 1;
  z-index: 2;
  pointer-events: none;
  box-shadow: 0 4px 10px rgba(20,30,50,.10);
  transition: transform .25s cubic-bezier(.22,.61,.36,1), background-color .2s ease;
}
.brxe-block.cp-eyeq-feature:hover .cp-eyeq-feature__plus {
  transform: rotate(90deg);
  background: #fff;
}
.brxe-block.cp-eyeq-feature__detail { display: none; }

/* Descriptor under each card */
.brxe-block.cp-eyeq-feature__descriptor {
  display: flex !important;
  flex-direction: column !important;
  align-items: flex-start !important;
  gap: 8px;
  width: 100% !important;
  padding: 0 4px;
}
.cp-eyeq-feature__statement {
  font-family: var(--cp-font-heading);
  font-weight: 500;
  font-size: clamp(20px, 2vw, 26px);
  line-height: 1.2;
  letter-spacing: -.012em;
  color: var(--cp-text-headline);
  margin: 0;
}
.cp-eyeq-feature__description {
  font-family: var(--cp-font-body);
  font-weight: 300;
  font-size: var(--cp-text-body);
  line-height: var(--cp-leading-body);
  color: var(--cp-text-secondary);
  margin: 0;
  max-width: 52ch;
}

/* ── Animate-view: full-screen expanded feature ── */
/* When a card is clicked, JS clones it into a fixed overlay and animates it
   to full screen. We keep the source card visible underneath but hidden
   during the animation. */
.cp-eyeq-feature.is-expanding { visibility: hidden; }

.cp-eyeq-feature-overlay {
  position: fixed;
  inset: 0;
  z-index: 10000;
  pointer-events: auto;
  background: rgba(15, 18, 23, 0);
  transition: background-color .35s ease;
}
.cp-eyeq-feature-overlay.is-open { background: rgba(15, 18, 23, .55); }

.cp-eyeq-feature-card-clone {
  position: fixed;
  border-radius: 28px;
  background-color: #ddd;
  background-image: var(--grad-img), var(--grad, none);
  background-size: cover, cover;
  background-position: center, center;
  background-repeat: no-repeat, no-repeat;
  overflow: hidden;
  z-index: 10001;
  box-shadow: 0 30px 70px rgba(15,18,23,.20), 0 8px 18px rgba(15,18,23,.10);
  display: block;
}
/* Two-pane body: gradient left / cream right */
.cp-eyeq-feature-card-clone__body {
  position: absolute;
  inset: 0;
  display: grid;
  grid-template-columns: 1fr 1fr;
  width: 100%;
  height: 100%;
  box-sizing: border-box;
  opacity: 0;
  transform: translateY(12px);
  transition: opacity .3s ease .15s, transform .35s cubic-bezier(.22,.61,.36,1) .15s;
}
.cp-eyeq-feature-card-clone.is-expanded .cp-eyeq-feature-card-clone__body {
  opacity: 1;
  transform: none;
}
.cp-eyeq-feature-card-clone__left {
  padding: clamp(28px, 4vw, 56px);
  display: flex;
  flex-direction: column;
  justify-content: center;
  gap: 22px;
  color: var(--cp-text-headline, #28354A);
  overflow-y: auto;
}
.cp-eyeq-feature-card-clone__right {
  /* No solid background — let the modal's gradient show through. The
     graphic (img or video) floats on top of the gradient. */
  background: transparent;
  display: flex;
  align-items: center;
  justify-content: center;
  overflow: hidden;
  padding: clamp(20px, 3vw, 40px);
}
.cp-eyeq-feature-card-clone__graphic {
  max-width: 100%;
  max-height: 100%;
  width: auto;
  height: auto;
  border-radius: 0;
  object-fit: contain;
  /* No background or shadow — the graphic floats directly over the
     modal's gradient. Mockup PNGs / SVGs carry their own framing. */
  background: transparent;
  box-shadow: none;
}

/* Video graphics get rounded corners + a video wrapper so we can overlay
   the glass play/pause control without obscuring the gradient. */
.cp-eyeq-feature-card-clone__video-wrap {
  position: relative;
  max-width: 100%;
  max-height: 100%;
  display: inline-flex;
  align-items: center;
  justify-content: center;
}
.cp-eyeq-feature-card-clone__graphic--video {
  border-radius: 18px;
  overflow: hidden;
  display: block;
}

/* Glass play/pause button — small frosted bubble bottom-right of the video. */
.cp-eyeq-feature-card-clone__playpause {
  position: absolute;
  bottom: 12px;
  right: 12px;
  width: 36px;
  height: 36px;
  border-radius: 50%;
  border: 1px solid rgba(255, 255, 255, 0.30);
  background: rgba(15, 18, 23, 0.22);
  backdrop-filter: blur(10px) saturate(140%);
  -webkit-backdrop-filter: blur(10px) saturate(140%);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  color: #fff;
  padding: 0;
  box-shadow: 0 4px 10px rgba(15, 18, 23, 0.16);
  transition: background-color .2s ease, transform .2s ease;
  z-index: 2;
}
.cp-eyeq-feature-card-clone__playpause:hover {
  background: rgba(15, 18, 23, 0.34);
  transform: scale(1.06);
}
.cp-eyeq-feature-card-clone__playpause:focus-visible {
  outline: 2px solid rgba(255, 255, 255, 0.7);
  outline-offset: 2px;
}
.cp-eyeq-feature-card-clone__playpause-icon {
  display: block;
}
.cp-eyeq-feature-card-clone__title {
  font-family: var(--cp-font-heading);
  font-weight: 400;
  font-size: clamp(28px, 3.4vw, 44px);
  line-height: 1.06;
  letter-spacing: -.012em;
  color: var(--cp-text-headline, #28354A);
  margin: 0;
}
.cp-eyeq-feature-card-clone__list {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: 12px;
}
.cp-eyeq-feature-card-clone__list li {
  display: flex;
  align-items: flex-start;
  gap: 12px;
  font-family: var(--cp-font-body);
  font-weight: 400;
  font-size: var(--cp-text-body);
  line-height: 1.45;
  color: var(--cp-text-headline, #28354A);
}
.cp-eyeq-feature-card-clone__list li::before {
  content: '';
  width: 8px;
  height: 8px;
  flex: 0 0 8px;
  margin-top: 9px;
  border-radius: 50%;
  background: var(--cp-text-headline, #28354A);
  opacity: .8;
}
.cp-eyeq-feature-card-clone__cta {
  align-self: flex-start;
  margin-top: 8px;
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 12px 22px;
  border-radius: 999px;
  background: var(--cp-text-headline, #28354A);
  color: #fff;
  font-family: var(--cp-font-body);
  font-weight: 500;
  font-size: 15px;
  text-decoration: none;
  transition: transform .2s ease, box-shadow .2s ease;
  box-shadow: 0 6px 14px rgba(20,30,50,.18);
}
.cp-eyeq-feature-card-clone__cta:hover {
  transform: translateY(-2px);
  box-shadow: 0 12px 22px rgba(20,30,50,.18);
}
.cp-eyeq-feature-card-clone__close {
  position: absolute;
  top: 18px;
  right: 18px;
  width: 40px;
  height: 40px;
  border-radius: 50%;
  /* Solid dark — clear contrast on light gradients. */
  background: var(--cp-text-headline, #28354A);
  border: none;
  display: flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  z-index: 3;
  font-size: 18px;
  font-weight: 500;
  line-height: 1;
  color: #fff;
  box-shadow: 0 4px 12px rgba(15, 18, 23, 0.18);
  transition: background-color .2s ease, transform .2s ease;
}
.cp-eyeq-feature-card-clone__close:hover {
  background: #1a2333;
  transform: scale(1.05);
}

/* AI feature has a dark blue-purple gradient — flip text + chrome to
   white-on-dark for legibility on this card. */
.cp-eyeq-feature-card-clone[data-feature-id="ai"] .cp-eyeq-feature-card-clone__left {
  color: #fff;
}
.cp-eyeq-feature-card-clone[data-feature-id="ai"] .cp-eyeq-feature-card-clone__title,
.cp-eyeq-feature-card-clone[data-feature-id="ai"] .cp-eyeq-feature-card-clone__list li {
  color: #fff;
}
.cp-eyeq-feature-card-clone[data-feature-id="ai"] .cp-eyeq-feature-card-clone__list li::before {
  background: #fff;
  opacity: .85;
}
.cp-eyeq-feature-card-clone[data-feature-id="ai"] .cp-eyeq-feature-card-clone__cta {
  background: #fff;
  color: var(--cp-text-headline, #28354A);
}
.cp-eyeq-feature-card-clone[data-feature-id="ai"] .cp-eyeq-feature-card-clone__close {
  background: rgba(255, 255, 255, 0.18);
  border: 1px solid rgba(255, 255, 255, 0.35);
  color: #fff;
  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);
}
.cp-eyeq-feature-card-clone[data-feature-id="ai"] .cp-eyeq-feature-card-clone__close:hover {
  background: rgba(255, 255, 255, 0.32);
}

@media (max-width: 800px) {
  .cp-eyeq-feature-card-clone__body {
    grid-template-columns: 1fr !important;
    grid-template-rows: auto 1fr;
  }
  .cp-eyeq-feature-card-clone__right { min-height: 220px; padding: 16px; }
}

body.cp-eyeq-overlay-open { overflow: hidden; }


/* ──────────────────── 3. ACADEMIC REVIEW BOARD ──────────────────── */
.brxe-section.cp-eyeq-review {
  padding: clamp(80px, 11vw, 140px) 0 clamp(64px, 8vw, 100px);
  background: var(--cp-cream-bg);
}
.brxe-container.cp-eyeq-review__inner {
  display: flex !important;
  flex-direction: column !important;
  align-items: center !important;
  text-align: center;
  gap: 18px;
}

/* Avatar row — container-width row with the avatar cluster centered.
   Each dash is position:absolute, anchored at the row's centerline and
   extending out to its viewport edge. The avatar cluster sits on top with
   z-index, so the dashes visually break around it without any flex math. */
.brxe-block.cp-eyeq-review__avatars-row {
  position: relative;
  display: flex !important;
  flex-direction: row !important;
  align-items: center !important;
  justify-content: center !important;
  width: 100% !important;
  margin: 6px 0 !important;
  padding: 18px 0;
}
.brxe-block.cp-eyeq-review__dash {
  position: absolute;
  top: 50%;
  height: 0;
  border-top: 1.5px dashed rgba(40, 53, 74, 0.35);
  width: auto !important;
  margin: 0 !important;
  padding: 0 !important;
  pointer-events: none;
}
.brxe-block.cp-eyeq-review__dash--left {
  /* From viewport's left edge to the row's centerline. */
  left: calc(50% - 50vw);
  right: 50%;
  -webkit-mask-image: linear-gradient(to right, transparent 0%, #000 35%, #000 100%);
          mask-image: linear-gradient(to right, transparent 0%, #000 35%, #000 100%);
}
.brxe-block.cp-eyeq-review__dash--right {
  /* From the row's centerline to the viewport's right edge. */
  left: 50%;
  right: calc(50% - 50vw);
  -webkit-mask-image: linear-gradient(to right, #000 0%, #000 65%, transparent 100%);
          mask-image: linear-gradient(to right, #000 0%, #000 65%, transparent 100%);
}
.brxe-block.cp-eyeq-review__avatars {
  position: relative;          /* lifts cluster above the absolute dashes */
  z-index: 1;
  display: flex !important;
  flex-direction: row !important;
  align-items: center !important;
  flex: 0 0 auto !important;
  gap: 0;
  width: auto !important;
  margin: 0 !important;
  padding: 0 16px;
}
.brxe-image.cp-eyeq-review__avatar {
  width: 64px !important;
  height: 64px;
  margin-left: -18px;            /* overlap */
  border-radius: 50%;
  border: 3px solid var(--cp-cream-bg);
  background: var(--cp-cream-bg);
  box-shadow: 0 2px 6px rgba(15,18,23,.10);
  overflow: hidden;
  flex: 0 0 auto;
  position: relative;
}
.brxe-image.cp-eyeq-review__avatar:first-child { margin-left: 0; }
.brxe-image.cp-eyeq-review__avatar img {
  width: 100% !important;
  height: 100% !important;
  object-fit: cover !important;
  display: block;
  border-radius: 50%;
}

.cp-eyeq-review__title {
  font-family: var(--cp-font-heading);
  font-weight: 400;
  font-size: clamp(28px, 3vw, 40px);
  letter-spacing: -.012em;
  color: var(--cp-text-headline);
  margin: 0;
  max-width: none;
  white-space: nowrap;          /* keep "Meet our academic review board" on one line */
}
@media (max-width: 640px) {
  .cp-eyeq-review__title { white-space: normal; }   /* allow wrap on small screens */
}
.cp-eyeq-review__blurb {
  font-family: var(--cp-font-body);
  font-weight: 400;
  font-size: var(--cp-text-body);
  color: var(--cp-text-secondary);
  margin: 0;
  max-width: 56ch;
  line-height: 1.55;
}
.brxe-button.cp-eyeq-review__cta {
  margin-top: 14px !important;
}

@media (max-width: 640px) {
  .brxe-image.cp-eyeq-review__avatar { width: 52px !important; height: 52px; margin-left: -14px; }
  .brxe-block.cp-eyeq-review__avatars { padding: 0 12px; }
}


/* ── Academic Review Board sheet (slide-in right panel) ──
   Parallels the cp-eyeq-research-sheet pattern. */
.cp-eyeq-board-sheet {
  position: fixed !important;
  inset: 0;
  z-index: 10000;
  pointer-events: none;
  background: transparent !important;
  padding: 0 !important;
}
.cp-eyeq-board-sheet.is-open { pointer-events: auto; }
.cp-eyeq-board-sheet__overlay {
  position: absolute;
  inset: 0;
  background: rgba(15, 18, 23, 0);
  transition: background-color .3s ease;
}
.cp-eyeq-board-sheet.is-open .cp-eyeq-board-sheet__overlay {
  background: rgba(15, 18, 23, .42);
}
.cp-eyeq-board-sheet__panel {
  position: absolute !important;
  top: 0; right: 0; bottom: 0;
  width: min(720px, 96vw);
  max-width: 720px;
  background: var(--cp-cream-bg, #f7f4ed);
  box-shadow: 0 30px 70px rgba(15,18,23,.22);
  display: flex !important;
  flex-direction: column !important;
  align-items: stretch !important;
  transform: translateX(100%);
  transition: transform .42s cubic-bezier(.22,.61,.36,1);
  overflow: hidden;
}
.cp-eyeq-board-sheet.is-open .cp-eyeq-board-sheet__panel {
  transform: none;   /* drop the resting transform so iOS paints the overflow-scroll content */
}
.cp-eyeq-board-sheet__head {
  position: relative;
  padding: clamp(24px, 3vw, 36px) clamp(24px, 4vw, 48px);
  border-bottom: 1px solid rgba(40,53,74,.10);
  display: flex !important;
  flex-direction: column !important;
  align-items: flex-start !important;
  gap: 10px;
  width: 100% !important;
}
.cp-eyeq-board-sheet__eyebrow {
  color: var(--cp-orange);
  letter-spacing: .14em;
}
.cp-eyeq-board-sheet__title {
  font-family: var(--cp-font-heading);
  font-weight: 400;
  font-size: clamp(22px, 2.4vw, 32px);
  line-height: 1.12;
  letter-spacing: -.012em;
  color: var(--cp-text-headline);
  margin: 0;
  max-width: 26ch;
}
.cp-eyeq-board-sheet__meta {
  font-family: var(--cp-font-body);
  font-size: 13px;
  color: var(--cp-text-secondary);
  margin: 0;
}
.cp-eyeq-board-sheet__close {
  position: absolute;
  top: 18px;
  right: 18px;
  width: 36px;
  height: 36px;
  border-radius: 50%;
  background: rgba(15, 18, 23, .08);
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  cursor: pointer;
  font-size: 14px;
  color: var(--cp-text-headline);
  transition: background-color .2s ease;
}
.cp-eyeq-board-sheet__close:hover { background: rgba(15, 18, 23, .14); }

.cp-eyeq-board-sheet__body {
  flex: 1 1 auto;
  min-height: 0;                       /* allow the flex child to shrink so overflow scrolls (mobile engines) */
  overflow-y: auto;
  -webkit-overflow-scrolling: touch;
  padding: clamp(24px, 3vw, 36px) clamp(24px, 4vw, 48px) clamp(48px, 6vw, 72px);
  display: flex !important;
  flex-direction: column !important;
  align-items: stretch !important;
  gap: 28px;
  width: 100% !important;
}
/* iOS Safari bug: flex/grid child containers inside an overflow:auto
   flex-column collapse to 0 height — which blanked the sheet body content
   (tiles, members grid, note) on mobile while the plain-text intro survived.
   Pinning flex-shrink:0 on the direct children keeps their content height. */
.cp-eyeq-board-sheet__body > *,
.brxe-block.cp-eyeq-research-sheet__body > * {
  flex-shrink: 0;
}
/* Mobile: both slide-in sheets go full-width, and — crucially — the PANEL
   itself becomes the scroll container while the body flows at its natural
   height. Relying on the body's `flex:1 + min-height:0` collapsed it to zero
   height on iOS (head showed, body blanked). Making the body `flex:0 0 auto`
   with the panel scrolling sidesteps the flex-grow collapse entirely. */
@media (max-width: 900px) {
  /* BULLETPROOF MOBILE: the SECTION is the single fixed full-screen scroll
     container (opaque cream bg). Panel + body are plain in-flow blocks — no
     transform, no nested overflow-scroll, no absolute positioning, no dvh.
     This removes every structure iOS Safari was failing to paint. */
  .cp-eyeq-board-sheet,
  .brxe-section.cp-eyeq-research-sheet {
    display: block !important;
    overflow-y: auto !important;
    background: var(--cp-cream-bg, #f7f4ed) !important;
    visibility: hidden;
    opacity: 0;
    transition: opacity .3s ease, visibility 0s linear .3s !important;
  }
  .cp-eyeq-board-sheet.is-open,
  .brxe-section.cp-eyeq-research-sheet.is-open {
    visibility: visible !important;
    opacity: 1 !important;
    pointer-events: auto !important;
    transition: opacity .3s ease, visibility 0s linear 0s !important;
  }
  /* Overlay unnecessary — the section itself is the opaque background. */
  .cp-eyeq-board-sheet__overlay,
  .brxe-block.cp-eyeq-research-sheet__overlay { display: none !important; }
  /* Panel + body: ordinary in-flow blocks. */
  .cp-eyeq-board-sheet__panel,
  .brxe-block.cp-eyeq-research-sheet__panel {
    position: static !important;
    transform: none !important;
    width: 100% !important;
    max-width: 100% !important;
    height: auto !important;
    min-height: 100% !important;
    overflow: visible !important;
    box-shadow: none !important;
  }
  .cp-eyeq-board-sheet__body,
  .brxe-block.cp-eyeq-research-sheet__body {
    flex: 0 0 auto !important;
    min-height: 0 !important;
    height: auto !important;
    overflow: visible !important;
  }
}
.cp-eyeq-board-sheet__intro {
  font-family: var(--cp-font-body);
  font-size: var(--cp-text-body);
  line-height: 1.6;
  color: var(--cp-text-headline);
  margin: 0;
}
.brxe-block.cp-eyeq-board-sheet__grid {
  display: grid !important;
  grid-template-columns: 1fr;
  gap: 14px;
  width: 100% !important;
}
.brxe-block.cp-eyeq-board-sheet__tile {
  background: #fff;
  border: 1px solid rgba(40,53,74,.08);
  border-radius: 14px;
  padding: 18px 20px;
  display: flex !important;
  flex-direction: column !important;
  align-items: flex-start !important;
  gap: 6px;
  width: 100% !important;
}
.cp-eyeq-board-sheet__tile-title {
  font-family: var(--cp-font-heading);
  font-weight: 500;
  font-size: 17px;
  line-height: 1.2;
  color: var(--cp-text-headline);
  margin: 0;
}
.cp-eyeq-board-sheet__tile-body {
  font-family: var(--cp-font-body);
  font-size: 14px;
  line-height: 1.55;
  color: var(--cp-text-secondary);
  margin: 0;
}
.cp-eyeq-board-sheet__section-title {
  font-family: var(--cp-font-heading);
  font-weight: 400;
  font-size: clamp(20px, 2vw, 24px);
  color: var(--cp-text-headline);
  margin: 8px 0 0;
}
.brxe-block.cp-eyeq-board-sheet__members {
  display: grid !important;
  grid-template-columns: repeat(2, 1fr);
  gap: 12px;
  width: 100% !important;
}
@media (max-width: 560px) {
  .brxe-block.cp-eyeq-board-sheet__members { grid-template-columns: 1fr; }
}
.brxe-block.cp-eyeq-board-sheet__member {
  background: #fff;
  border: 1px solid rgba(40,53,74,.08);
  border-radius: 12px;
  padding: 14px 16px;
  display: flex !important;
  flex-direction: column !important;
  align-items: flex-start !important;
  gap: 2px;
  width: 100% !important;
}
.cp-eyeq-board-sheet__member-name {
  font-family: var(--cp-font-heading);
  font-weight: 500;
  font-size: 15px;
  color: var(--cp-text-headline);
  margin: 0;
}
.cp-eyeq-board-sheet__member-focus {
  font-family: var(--cp-font-body);
  font-size: 13px;
  color: var(--cp-text-headline);
  margin: 0;
}
.cp-eyeq-board-sheet__member-role {
  font-family: var(--cp-font-body);
  font-size: 12px;
  color: var(--cp-text-secondary);
  margin: 0;
}
.cp-eyeq-board-sheet__note {
  font-family: var(--cp-font-body);
  font-size: 13px;
  color: var(--cp-text-secondary);
  margin: 16px 0 0;
  padding-top: 16px;
  border-top: 1px solid rgba(40,53,74,.08);
}
body.cp-eyeq-board-open { overflow: hidden; }


/* ──────────────────── 4. SCIENCE-BACKED + STATS ──────────────────── */
/* Restyled to match the homepage `cp-stat-card` pattern (gradient cards,
   staircase heights, mono label top-left, big serif number, body at bottom). */
.brxe-section.cp-eyeq-science {
  padding: clamp(80px, 10vh, 140px) 0;
}
.brxe-container.cp-eyeq-science__inner {
  display: flex !important;
  flex-direction: column !important;
  align-items: stretch !important;
  gap: 56px;
}

/* Higher specificity (extra ancestor selector) so this beats the shared
   `.brxe-block.cp-section-stats__head` rule which centers everything. */
.brxe-section.cp-eyeq-science .brxe-block.cp-eyeq-science__head {
  display: flex !important;
  flex-direction: column !important;
  align-items: flex-start !important;
  text-align: left !important;
  gap: 16px;
  width: auto !important;
  max-width: 760px;
  margin-bottom: 56px;
}
.brxe-section.cp-eyeq-science .brxe-block.cp-eyeq-science__ctas {
  margin-left: 0 !important;
  margin-right: auto !important;
}
.cp-eyeq-science__eyebrow {
  letter-spacing: .14em;
  color: var(--cp-orange);
}
.cp-eyeq-science__title {
  font-family: var(--cp-font-heading);
  font-weight: 400;
  font-size: clamp(36px, 4.6vw, 60px);
  line-height: 1.05;
  letter-spacing: -.014em;
  color: var(--cp-text-headline);
  margin: 0;
  max-width: 22ch;
}
.cp-eyeq-science__body {
  font-family: var(--cp-font-body);
  font-weight: 300;
  font-size: var(--cp-text-body-lg);
  line-height: var(--cp-leading-body);
  color: var(--cp-text-secondary);
  margin: 0;
  max-width: 60ch;
}
.brxe-block.cp-eyeq-science__ctas {
  display: flex !important;
  flex-direction: row !important;
  flex-wrap: wrap !important;
  align-items: center !important;
  gap: 12px !important;
  width: auto !important;
  margin-top: 4px;
}

/* Stat cards — homepage cp-stat-card visual (gradient, staircase) */
.brxe-block.cp-eyeq-science__stats {
  display: grid !important;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  align-items: end !important;
  gap: 24px;
  width: 100% !important;
}
@media (max-width: 900px) {
  .brxe-block.cp-eyeq-science__stats { grid-template-columns: 1fr !important; }
}
.brxe-block.cp-eyeq-science__stat {
  display: flex !important;
  flex-direction: column !important;
  align-items: stretch !important;
  width: 100% !important;
  padding: 38px !important;
  border-radius: var(--cp-radius-2xl);
  background: linear-gradient(180deg,
                              var(--cp-stat-grad-from, #dfdacf) 0%,
                              var(--cp-stat-grad-to, #eae8e3) 100%);
  position: relative;
  overflow: hidden;
}
/* Staircase heights — same Figma rhythm as the homepage stats */
.brxe-block.cp-eyeq-science__stats .cp-eyeq-science__stat:nth-child(1) { min-height: 348px; }
.brxe-block.cp-eyeq-science__stats .cp-eyeq-science__stat:nth-child(2) { min-height: 407px; }
.brxe-block.cp-eyeq-science__stats .cp-eyeq-science__stat:nth-child(3) { min-height: 472px; }
@media (max-width: 900px) {
  .brxe-block.cp-eyeq-science__stats .cp-eyeq-science__stat { min-height: 280px !important; }
}

.cp-eyeq-science__stat-label {
  letter-spacing: 2.16px;
  color: var(--cp-text-meta);
  align-self: flex-start;
}
.cp-eyeq-science__big {
  font-family: var(--cp-font-heading);
  font-weight: 400;
  font-size: var(--cp-text-h3);
  line-height: var(--cp-leading-h2);
  letter-spacing: var(--cp-tracking-h3);
  color: var(--cp-text-headline);
  margin: 16px 0 0;
}
.cp-eyeq-science__stat-desc {
  font-family: var(--cp-font-body);
  font-weight: 300;
  font-size: var(--cp-text-body-lg);
  line-height: 28px;
  color: var(--cp-text-mono);
  margin: auto 0 0;
  max-width: 333px;
}

.cp-eyeq-science__citation {
  font-family: var(--cp-font-mono);
  font-size: 12px;
  line-height: 1.55;
  color: var(--cp-text-muted);
  letter-spacing: -.005em;
  margin: 0;
  max-width: 80ch;
}
.cp-eyeq-science__citation em {
  font-style: italic;
  color: var(--cp-text-secondary);
}


/* ──────────────────── 4b. RESEARCH RIGHT-SIDE SHEET ──────────────────── */
/* Slides in from the right with an overlay backdrop. Triggered by
   buttons with [data-research-open] (the "Read the research" CTA). */
.brxe-section.cp-eyeq-research-sheet {
  position: fixed !important;
  inset: 0 !important;
  z-index: 10000;
  display: block !important;
  width: 100% !important;
  pointer-events: none;
  visibility: hidden;
  background: transparent;
  padding: 0 !important;
  transition: visibility 0s linear .42s;
}
.brxe-section.cp-eyeq-research-sheet.is-open {
  pointer-events: auto;
  visibility: visible;
  transition: visibility 0s linear 0s;
}

.brxe-block.cp-eyeq-research-sheet__overlay {
  position: absolute !important;
  inset: 0 !important;
  width: 100% !important;
  background: rgba(15, 18, 23, .55);
  opacity: 0;
  transition: opacity .35s ease;
}
.cp-eyeq-research-sheet.is-open .cp-eyeq-research-sheet__overlay { opacity: 1; }

.brxe-block.cp-eyeq-research-sheet__panel {
  position: absolute !important;
  top: 0;
  right: 0;
  bottom: 0;
  width: min(720px, 92vw) !important;
  background: var(--cp-cream-bg);
  box-shadow: -24px 0 60px rgba(15, 18, 23, .18);
  transform: translateX(100%);
  transition: transform .42s cubic-bezier(.22,.61,.36,1);
  display: flex !important;
  flex-direction: column !important;
  overflow: hidden;
  margin: 0 !important;
  padding: 0 !important;
}
.cp-eyeq-research-sheet.is-open .cp-eyeq-research-sheet__panel {
  transform: none;   /* drop the resting transform so iOS paints the overflow-scroll content */
}

/* Sheet header — sticky */
.brxe-block.cp-eyeq-research-sheet__head {
  position: relative;
  display: flex !important;
  flex-direction: column !important;
  align-items: flex-start !important;
  gap: 8px;
  width: 100% !important;
  padding: 28px 32px 22px !important;
  background: var(--cp-text-headline);
  color: #fff;
  flex: 0 0 auto;
}
.cp-eyeq-research-sheet__eyebrow {
  letter-spacing: .14em;
  color: var(--cp-orange);
}
.cp-eyeq-research-sheet__title {
  font-family: var(--cp-font-heading);
  font-weight: 400;
  font-size: clamp(20px, 2.4vw, 26px);
  line-height: 1.18;
  letter-spacing: -.008em;
  color: #fff;
  margin: 0;
  padding-right: 56px;
  max-width: 38ch;
}
.cp-eyeq-research-sheet__meta {
  font-family: var(--cp-font-body);
  font-weight: 300;
  font-size: 12px;
  line-height: 1.5;
  color: rgba(255, 255, 255, .72);
  margin: 0;
  max-width: 56ch;
}
.cp-eyeq-research-sheet__close {
  position: absolute;
  top: 22px;
  right: 22px;
  width: 36px;
  height: 36px;
  border-radius: 50%;
  background: rgba(255, 255, 255, .1);
  color: #fff;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-size: 14px;
  cursor: pointer;
  user-select: none;
  transition: background-color .2s ease;
}
.cp-eyeq-research-sheet__close:hover { background: rgba(255, 255, 255, .2); }

/* Sheet body — scrollable */
.brxe-block.cp-eyeq-research-sheet__body {
  flex: 1 1 auto;
  overflow-y: auto;
  padding: 24px 32px 48px !important;
  display: flex !important;
  flex-direction: column !important;
  align-items: stretch !important;
  gap: 36px;
  width: 100% !important;
  -webkit-overflow-scrolling: touch;
}

.brxe-block.cp-eyeq-research-sheet__section,
.brxe-block.cp-eyeq-research-sheet__section-head {
  display: flex !important;
  flex-direction: column !important;
  align-items: flex-start !important;
  gap: 8px;
  width: 100% !important;
  margin: 0 !important;
  padding: 0 !important;
}
.cp-eyeq-research-sheet__section-eyebrow {
  letter-spacing: .14em;
  color: var(--cp-orange);
  font-size: 11px;
}
.cp-eyeq-research-sheet__section-title {
  font-family: var(--cp-font-heading);
  font-weight: 400;
  font-size: clamp(20px, 2vw, 24px);
  line-height: 1.2;
  letter-spacing: -.008em;
  color: var(--cp-text-headline);
  margin: 0 0 4px;
}
.cp-eyeq-research-sheet__p {
  font-family: var(--cp-font-body);
  font-weight: 300;
  font-size: 15px;
  line-height: 1.62;
  color: var(--cp-text-secondary);
  margin: 0;
  max-width: 64ch;
}

/* TL;DR three-stat row */
.brxe-block.cp-eyeq-research-sheet__glance {
  display: grid !important;
  grid-template-columns: repeat(3, 1fr);
  gap: 12px;
  width: 100% !important;
  margin: 4px 0 0 !important;
}
@media (max-width: 540px) {
  .brxe-block.cp-eyeq-research-sheet__glance { grid-template-columns: 1fr; }
}
.brxe-block.cp-eyeq-research-sheet__glance-cell {
  display: flex !important;
  flex-direction: column !important;
  align-items: flex-start !important;
  gap: 8px;
  width: 100% !important;
  padding: 18px !important;
  border-radius: var(--cp-radius-lg);
  background: #fff;
  border: 1px solid var(--cp-border-soft);
}
.cp-eyeq-research-sheet__glance-big {
  font-family: var(--cp-font-heading);
  font-weight: 400;
  font-size: clamp(28px, 3vw, 36px);
  line-height: 1;
  letter-spacing: -.022em;
  color: var(--cp-orange);
  margin: 0;
}
.cp-eyeq-research-sheet__glance-text {
  font-family: var(--cp-font-body);
  font-size: 12px;
  line-height: 1.45;
  color: var(--cp-text-secondary);
  margin: 0;
}

/* Methods — 2-col fact grid */
.brxe-block.cp-eyeq-research-sheet__methods {
  display: grid !important;
  grid-template-columns: 1fr 1fr;
  gap: 12px;
  width: 100% !important;
  margin: 4px 0 0 !important;
}
@media (max-width: 600px) {
  .brxe-block.cp-eyeq-research-sheet__methods { grid-template-columns: 1fr; }
}
.brxe-block.cp-eyeq-research-sheet__method {
  display: flex !important;
  flex-direction: column !important;
  align-items: flex-start !important;
  gap: 6px;
  width: 100% !important;
  padding: 16px 18px !important;
  border-radius: var(--cp-radius-lg);
  background: #fff;
  border: 1px solid var(--cp-border-soft);
}
.cp-eyeq-research-sheet__method-label {
  letter-spacing: .14em;
  color: var(--cp-text-meta);
  font-size: 10px;
}
.cp-eyeq-research-sheet__method-text {
  font-family: var(--cp-font-body);
  font-weight: 400;
  font-size: 13px;
  line-height: 1.5;
  color: var(--cp-text-headline);
  margin: 0;
}

/* Findings — each finding has eyebrow, headline, then 2-col data/implication */
.brxe-block.cp-eyeq-research-sheet__finding {
  display: flex !important;
  flex-direction: column !important;
  align-items: stretch !important;
  gap: 14px;
  width: 100% !important;
  padding: 22px 0 !important;
  border-top: 1px solid var(--cp-border-soft);
  margin: 0 !important;
}
.brxe-block.cp-eyeq-research-sheet__finding:first-of-type { border-top: none; padding-top: 8px !important; }
.cp-eyeq-research-sheet__finding-eyebrow {
  letter-spacing: .14em;
  color: var(--cp-orange);
  font-size: 11px;
}
.cp-eyeq-research-sheet__finding-title {
  font-family: var(--cp-font-heading);
  font-weight: 400;
  font-size: clamp(17px, 1.6vw, 20px);
  line-height: 1.25;
  letter-spacing: -.005em;
  color: var(--cp-text-headline);
  margin: 0 0 6px;
  max-width: 32ch;
}
.brxe-block.cp-eyeq-research-sheet__finding-cols {
  display: grid !important;
  grid-template-columns: 1fr 1fr;
  gap: 16px;
  width: 100% !important;
  margin: 0 !important;
}
@media (max-width: 640px) {
  .brxe-block.cp-eyeq-research-sheet__finding-cols { grid-template-columns: 1fr; }
}
.brxe-block.cp-eyeq-research-sheet__finding-col {
  display: flex !important;
  flex-direction: column !important;
  align-items: flex-start !important;
  gap: 8px;
  width: 100% !important;
  padding: 14px 16px !important;
  border-radius: var(--cp-radius-md);
  background: #fff;
  border: 1px solid var(--cp-border-soft);
}
.brxe-block.cp-eyeq-research-sheet__finding-col--imp {
  background: rgba(237, 134, 60, .08);
  border-color: rgba(237, 134, 60, .25);
}
.cp-eyeq-research-sheet__finding-col-label {
  letter-spacing: .14em;
  color: var(--cp-text-meta);
  font-size: 10px;
}
.brxe-block.cp-eyeq-research-sheet__finding-col--imp .cp-eyeq-research-sheet__finding-col-label {
  color: var(--cp-orange-border);
}
.cp-eyeq-research-sheet__finding-text {
  font-family: var(--cp-font-body);
  font-size: 13px;
  line-height: 1.55;
  color: var(--cp-text-headline);
  margin: 0;
}
.brxe-block.cp-eyeq-research-sheet__finding-col--imp .cp-eyeq-research-sheet__finding-text {
  color: var(--cp-text-headline);
}

/* References */
.brxe-block.cp-eyeq-research-sheet__refs {
  display: flex !important;
  flex-direction: column !important;
  align-items: stretch !important;
  gap: 6px;
  width: 100% !important;
  margin: 0 !important;
  padding: 0 !important;
}
.cp-eyeq-research-sheet__ref {
  display: flex;
  align-items: flex-start;
  gap: 12px;
  font-family: var(--cp-font-body);
  font-size: 12px;
  line-height: 1.55;
  color: var(--cp-text-secondary);
  margin: 0;
}
.cp-eyeq-research-sheet__ref-num {
  flex: 0 0 22px;
  font-family: var(--cp-font-mono);
  font-size: 11px;
  font-weight: 500;
  color: var(--cp-text-muted);
}
.cp-eyeq-research-sheet__ref-text {
  flex: 1 1 auto;
}
.cp-eyeq-research-sheet__ack {
  font-family: var(--cp-font-body);
  font-style: italic;
  font-size: 12px;
  line-height: 1.6;
  color: var(--cp-text-muted);
  margin: 12px 0 0;
  padding: 16px 0 0;
  border-top: 1px solid var(--cp-border-soft);
}

body.cp-eyeq-research-open { overflow: hidden; }

@media (prefers-reduced-motion: reduce) {
  .brxe-block.cp-eyeq-research-sheet__panel,
  .brxe-block.cp-eyeq-research-sheet__overlay { transition: none !important; }
}


/* ──────────────────── Reduced motion ──────────────────── */
@media (prefers-reduced-motion: reduce) {
  .brxe-block.cp-eyeq-feature,
  .cp-eyeq-feature-card-clone,
  .cp-eyeq-feature-card-clone__body,
  .cp-eyeq-feature-overlay { transition: none !important; }
}


/* ──────────────────── 5. TRUST BAR ──────────────────── */
.brxe-section.cp-eyeq-trust {
  padding: clamp(40px, 5vh, 64px) 0;
  background: var(--cp-cream-bg);
  border-top: 1px solid var(--cp-border-soft);
  border-bottom: 1px solid var(--cp-border-soft);
}
.brxe-container.cp-eyeq-trust__inner {
  display: flex !important;
  flex-direction: column !important;
  align-items: center !important;
  text-align: center;
  gap: 18px;
  padding: 0 !important;
  max-width: none !important;
}
.cp-eyeq-trust__eyebrow {
  letter-spacing: .14em;
  color: var(--cp-text-meta);
}
.brxe-block.cp-eyeq-trust__marquee {
  width: 100% !important;
  overflow: hidden;
  -webkit-mask-image: linear-gradient(to right, transparent 0%, #000 8%, #000 92%, transparent 100%);
          mask-image: linear-gradient(to right, transparent 0%, #000 8%, #000 92%, transparent 100%);
}
.brxe-block.cp-eyeq-trust__track {
  display: flex !important;
  flex-direction: row !important;
  /* Bricks adds `flex-wrap: wrap` to all .brxe-block at <=767px which makes
     marquee items stack into multiple rows. Pin nowrap to keep them inline. */
  flex-wrap: nowrap !important;
  align-items: center !important;
  width: max-content !important;
  min-width: max-content !important;
  max-width: none !important;
  gap: 56px;
  padding: 0 28px;
  animation: cp-eyeq-trust-marquee 36s linear infinite;
}
@keyframes cp-eyeq-trust-marquee {
  from { transform: translateX(0); }
  to   { transform: translateX(-50%); }
}
.cp-eyeq-trust__item {
  font-family: var(--cp-font-heading);
  font-size: clamp(18px, 1.6vw, 22px);
  letter-spacing: -.005em;
  color: var(--cp-text-headline);
  white-space: nowrap;
  opacity: .82;
  /* Bricks text-basic defaults to width:100% which would force each item
     to fill the flex row at the mobile breakpoint — pinning width:auto and
     flex:0 0 auto keeps every name inline regardless of viewport. */
  display: inline-flex !important;
  flex: 0 0 auto !important;
  width: auto !important;
  max-width: none !important;
}


/* ──────────────────── 6. HOW IT WORKS — scroll narrative ──────────────────── */
.brxe-section.cp-eyeq-how {
  padding: clamp(80px, 10vh, 140px) 0;
  background: var(--cp-cream-bg);
}
.brxe-container.cp-eyeq-how__inner {
  display: flex !important;
  flex-direction: column !important;
  align-items: stretch !important;
  gap: 56px;
}
.brxe-block.cp-eyeq-how__head {
  display: flex !important;
  flex-direction: column !important;
  align-items: flex-start !important;
  gap: 14px;
  width: auto !important;
  max-width: 720px;
}
.cp-eyeq-how__eyebrow { color: var(--cp-orange); letter-spacing: .14em; }
.cp-eyeq-how__title {
  font-family: var(--cp-font-heading);
  font-weight: 400;
  font-size: clamp(34px, 4.4vw, 56px);
  line-height: 1.05;
  letter-spacing: -.012em;
  color: var(--cp-text-headline);
  margin: 0;
  max-width: 18ch;
}
.cp-eyeq-how__blurb {
  font-family: var(--cp-font-body);
  font-weight: 300;
  font-size: var(--cp-text-body-lg);
  line-height: var(--cp-leading-body);
  color: var(--cp-text-secondary);
  margin: 0;
  max-width: 56ch;
}

/* ── Story grid: progress rail · sticky preview · steps ── */
.brxe-block.cp-eyeq-how__story {
  display: grid !important;
  grid-template-columns: 4px minmax(0, 1.05fr) minmax(0, 1fr);
  gap: 56px;
  width: 100% !important;
  align-items: start !important;
  position: relative;
}
@media (max-width: 980px) {
  .brxe-block.cp-eyeq-how__story {
    grid-template-columns: 4px minmax(0, 1fr) !important;
    gap: 28px;
  }
  .brxe-block.cp-eyeq-how__sticky { display: none !important; }
}

/* Far-left orange progress rail */
.brxe-block.cp-eyeq-how__progress {
  position: relative;
  width: 4px !important;
  height: 100% !important;
  margin: 0 !important;
  padding: 0 !important;
  background: rgba(15, 18, 23, .06);
  border-radius: 2px;
  overflow: hidden;
}
.brxe-block.cp-eyeq-how__progress-fill {
  position: absolute !important;
  top: 0;
  left: 0;
  width: 100%;
  height: 0%;
  background: var(--cp-orange);
  border-radius: 2px;
  transition: height .25s linear;
  margin: 0 !important;
  padding: 0 !important;
}

/* Sticky preview column */
.brxe-block.cp-eyeq-how__sticky {
  position: sticky;
  top: 100px;
  display: flex !important;
  flex-direction: column !important;
  align-items: stretch !important;
  gap: 12px;
  width: 100% !important;
  height: fit-content;
  padding: 0 !important;
  margin: 0 !important;
}
.cp-eyeq-how__pill {
  display: inline-flex;
  align-self: flex-start;
  align-items: center;
  padding: 6px 12px;
  background: var(--cp-text-headline);
  color: #fff;
  border-radius: 999px;
  font-size: 11px;
  letter-spacing: .14em;
  transition: background-color .25s ease;
}

.brxe-block.cp-eyeq-how__mocks {
  position: relative;
  width: 100% !important;
  aspect-ratio: 4 / 3.4;
  margin: 0 !important;
  padding: 0 !important;
  display: block !important;
}
.brxe-block.cp-eyeq-how__mock {
  position: absolute !important;
  inset: 0 !important;
  width: 100% !important;
  height: 100%;
  display: flex !important;
  flex-direction: column !important;
  align-items: stretch !important;
  gap: 16px;
  padding: 26px 28px !important;
  margin: 0 !important;
  background: #fff;
  border: 1px solid var(--cp-border-soft);
  border-radius: var(--cp-radius-2xl);
  box-shadow: 0 18px 40px rgba(20, 30, 50, .08), 0 4px 10px rgba(20, 30, 50, .04);
  opacity: 0;
  transform: scale(.98) translateY(8px);
  transition: opacity .45s cubic-bezier(.22,.61,.36,1),
              transform .45s cubic-bezier(.22,.61,.36,1);
  pointer-events: none;
  overflow: hidden;
}
.brxe-block.cp-eyeq-how__mock.is-active {
  opacity: 1;
  transform: scale(1) translateY(0);
  pointer-events: auto;
}

.brxe-block.cp-eyeq-how__mock-row {
  display: flex !important;
  flex-direction: row !important;
  justify-content: space-between !important;
  align-items: center !important;
  width: 100% !important;
  gap: 12px;
  margin: 0 !important;
  padding: 0 !important;
}
.cp-eyeq-how__mock-eyebrow { color: var(--cp-orange); letter-spacing: .14em; font-size: 10px; }
.cp-eyeq-how__mock-topic {
  font-family: var(--cp-font-mono);
  font-size: 11px;
  color: var(--cp-text-meta);
  letter-spacing: -.005em;
}

/* Mock 01 — Diagnostic question */
.cp-eyeq-how__mock-question {
  font-family: var(--cp-font-heading);
  font-weight: 400;
  font-size: clamp(15px, 1.4vw, 18px);
  line-height: 1.35;
  letter-spacing: -.005em;
  color: var(--cp-text-headline);
  margin: 0;
}
.brxe-block.cp-eyeq-how__mock-choices {
  display: flex !important;
  flex-direction: column !important;
  gap: 8px;
  width: 100% !important;
  margin: 0 !important;
  padding: 0 !important;
}
.brxe-block.cp-eyeq-how__mock-choice {
  display: flex !important;
  flex-direction: row !important;
  align-items: center !important;
  gap: 12px;
  width: 100% !important;
  padding: 10px 14px !important;
  margin: 0 !important;
  border: 1px solid var(--cp-border-soft);
  border-radius: var(--cp-radius-md);
  background: #fff;
  transition: background-color .2s ease, border-color .2s ease;
}
.brxe-block.cp-eyeq-how__mock-choice.is-correct {
  background: rgba(111, 191, 138, .14);
  border-color: rgba(111, 191, 138, .55);
}
.cp-eyeq-how__mock-choice-letter {
  flex: 0 0 24px;
  width: 24px;
  height: 24px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border: 1px solid var(--cp-border-input);
  border-radius: 50%;
  font-family: var(--cp-font-mono);
  font-size: 11px;
  font-weight: 500;
  color: var(--cp-text-meta);
}
.cp-eyeq-how__mock-choice.is-correct .cp-eyeq-how__mock-choice-letter {
  background: #6fbf8a;
  border-color: #6fbf8a;
  color: #fff;
}
.cp-eyeq-how__mock-choice-text {
  font-family: var(--cp-font-body);
  font-size: 13px;
  color: var(--cp-text-headline);
}
.brxe-block.cp-eyeq-how__mock-confidence {
  display: flex !important;
  flex-direction: row !important;
  align-items: center !important;
  justify-content: space-between !important;
  width: 100% !important;
  margin-top: auto !important;
  padding: 10px 14px !important;
  border-top: 1px solid var(--cp-border-soft);
}
.cp-eyeq-how__mock-confidence-label {
  font-size: 10px;
  letter-spacing: .14em;
  color: var(--cp-text-meta);
}
.brxe-block.cp-eyeq-how__mock-confidence-dots {
  display: flex !important;
  flex-direction: row !important;
  gap: 4px;
  width: auto !important;
  margin: 0 !important;
  padding: 0 !important;
}
.brxe-block.cp-eyeq-how__mock-cd-dot {
  width: 8px !important;
  height: 8px;
  border-radius: 50%;
  background: rgba(15, 18, 23, .14);
  margin: 0 !important;
  padding: 0 !important;
}
.brxe-block.cp-eyeq-how__mock-cd-dot.is-on {
  background: var(--cp-orange);
}

/* Mock 02 — Weekly plan */
.brxe-block.cp-eyeq-how__mock-cal {
  display: grid !important;
  grid-template-columns: repeat(7, 1fr);
  gap: 6px;
  width: 100% !important;
  margin: 0 !important;
  padding: 0 !important;
  flex: 1 1 auto;
}
.brxe-block.cp-eyeq-how__mock-cal-col {
  display: flex !important;
  flex-direction: column !important;
  align-items: stretch !important;
  gap: 4px;
  width: 100% !important;
  margin: 0 !important;
  padding: 6px !important;
  border-radius: 8px;
  background: rgba(15, 18, 23, .03);
}
.brxe-block.cp-eyeq-how__mock-cal-col.is-today {
  background: rgba(237, 134, 60, .12);
  outline: 1px solid rgba(237, 134, 60, .35);
}
.cp-eyeq-how__mock-cal-day {
  font-family: var(--cp-font-mono);
  font-size: 10px;
  font-weight: 500;
  text-align: center;
  color: var(--cp-text-meta);
  letter-spacing: .04em;
}
.is-today .cp-eyeq-how__mock-cal-day { color: var(--cp-orange-border); }
.brxe-block.cp-eyeq-how__mock-cal-stack {
  display: flex !important;
  flex-direction: column !important;
  gap: 2px;
  width: 100% !important;
  margin: 0 !important;
  padding: 0 !important;
}
.brxe-block.cp-eyeq-how__mock-cal-block {
  width: 100% !important;
  margin: 0 !important;
  padding: 0 !important;
  border-radius: 4px;
  display: block !important;
}
.cp-eyeq-how__mock-cal-block--qbank   { background: var(--cp-orange); }
.cp-eyeq-how__mock-cal-block--content { background: var(--cp-text-headline); }
.cp-eyeq-how__mock-cal-block--review  { background: #6fbf8a; }
.cp-eyeq-how__mock-cal-block--mock    { background: #4a66d6; }

.brxe-block.cp-eyeq-how__mock-cal-legend {
  display: flex !important;
  flex-direction: row !important;
  flex-wrap: wrap !important;
  gap: 12px;
  width: 100% !important;
  margin: 0 !important;
  padding-top: 8px !important;
  border-top: 1px solid var(--cp-border-soft);
}
.brxe-block.cp-eyeq-how__mock-cal-legend-item {
  display: inline-flex !important;
  align-items: center !important;
  gap: 6px;
  width: auto !important;
  margin: 0 !important;
  padding: 0 !important;
}
.brxe-block.cp-eyeq-how__mock-cal-legend-dot {
  width: 8px !important;
  height: 8px;
  border-radius: 50%;
  margin: 0 !important;
  padding: 0 !important;
}
.cp-eyeq-how__mock-cal-legend-text {
  font-family: var(--cp-font-body);
  font-size: 11px;
  color: var(--cp-text-headline);
}

/* Mock 03 — Topic mastery rings + spaced review strip */
.brxe-block.cp-eyeq-how__mock-rings {
  display: grid !important;
  grid-template-columns: repeat(3, 1fr);
  gap: 14px;
  width: 100% !important;
  margin: 0 !important;
  padding: 0 !important;
  flex: 1 1 auto;
}
.brxe-block.cp-eyeq-how__mock-ring {
  display: flex !important;
  flex-direction: column !important;
  align-items: center !important;
  gap: 6px;
  width: 100% !important;
  margin: 0 !important;
  padding: 12px 8px !important;
  border-radius: 12px;
  background: rgba(15, 18, 23, .03);
  position: relative;
}
.brxe-block.cp-eyeq-how__mock-ring-track {
  width: 64px !important;
  height: 64px;
  border-radius: 50%;
  margin: 0 !important;
  padding: 0 !important;
  background: conic-gradient(
    var(--ring-color, var(--cp-orange)) calc(var(--p, 0) * 1%),
    rgba(15, 18, 23, .08) 0
  );
  position: relative;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
}
.brxe-block.cp-eyeq-how__mock-ring-track::after {
  content: "";
  position: absolute;
  inset: 8px;
  background: #fff;
  border-radius: 50%;
}
.brxe-block.cp-eyeq-how__mock-ring.is-strong .cp-eyeq-how__mock-ring-track { --ring-color: #6fbf8a; }
.brxe-block.cp-eyeq-how__mock-ring.is-mid    .cp-eyeq-how__mock-ring-track { --ring-color: var(--cp-orange); }
.brxe-block.cp-eyeq-how__mock-ring.is-weak   .cp-eyeq-how__mock-ring-track { --ring-color: #d16c6c; }

.cp-eyeq-how__mock-ring-pct {
  position: absolute;
  font-family: var(--cp-font-heading);
  font-size: 18px;
  line-height: 1;
  letter-spacing: -.02em;
  color: var(--cp-text-headline);
  margin: 0;
  top: 50%;
  left: 50%;
  transform: translate(-50%, calc(-50% + 9px));  /* nudge: track is 88px area */
  z-index: 1;
}
.brxe-block.cp-eyeq-how__mock-ring {
  position: relative;
}
.cp-eyeq-how__mock-ring-pct {
  /* Reset: position relative to the ring */
  position: static;
  transform: none;
  margin-top: -42px;
  pointer-events: none;
}
.cp-eyeq-how__mock-ring-label {
  font-family: var(--cp-font-mono);
  font-size: 10px;
  color: var(--cp-text-meta);
  letter-spacing: -.005em;
  text-align: center;
}

.brxe-block.cp-eyeq-how__mock-spaced {
  display: flex !important;
  flex-direction: row !important;
  align-items: center !important;
  justify-content: space-between !important;
  width: 100% !important;
  gap: 12px;
  margin: 0 !important;
  padding: 12px 14px !important;
  border-radius: var(--cp-radius-md);
  background: rgba(15, 18, 23, .04);
}
.cp-eyeq-how__mock-spaced-eyebrow { font-size: 10px; color: var(--cp-text-meta); letter-spacing: .14em; }
.brxe-block.cp-eyeq-how__mock-spaced-dots {
  display: flex !important;
  gap: 4px;
  width: auto !important;
  margin: 0 !important;
  padding: 0 !important;
}
.brxe-block.cp-eyeq-how__mock-spaced-dot {
  width: 10px !important;
  height: 10px;
  border-radius: 50%;
  background: rgba(15, 18, 23, .14);
  margin: 0 !important;
  padding: 0 !important;
}
.brxe-block.cp-eyeq-how__mock-spaced-dot.is-due {
  background: var(--cp-orange);
}
.cp-eyeq-how__mock-spaced-count {
  font-family: var(--cp-font-mono);
  font-size: 11px;
  color: var(--cp-text-headline);
  font-weight: 500;
}

/* Mock 04 — Score report */
.brxe-block.cp-eyeq-how__mock-score {
  display: flex !important;
  flex-direction: row !important;
  align-items: baseline !important;
  gap: 6px;
  width: auto !important;
  margin: 0 !important;
  padding: 0 !important;
}
.cp-eyeq-how__mock-score-num {
  font-family: var(--cp-font-heading);
  font-weight: 400;
  font-size: clamp(56px, 6vw, 88px);
  line-height: 1;
  letter-spacing: -.025em;
  color: var(--cp-text-headline);
  margin: 0;
}
.cp-eyeq-how__mock-score-suffix {
  font-family: var(--cp-font-body);
  font-size: 14px;
  color: var(--cp-text-secondary);
}
.brxe-block.cp-eyeq-how__mock-delta {
  display: inline-flex !important;
  align-items: center !important;
  gap: 6px;
  width: auto !important;
  margin: 0 !important;
  padding: 4px 10px !important;
  background: rgba(111, 191, 138, .14);
  color: #2f8c52;
  border: 1px solid rgba(111, 191, 138, .35);
  border-radius: 999px;
  align-self: flex-start;
}
.cp-eyeq-how__mock-delta-arrow {
  font-family: var(--cp-font-mono);
  font-weight: 700;
  color: #2f8c52;
  font-size: 13px;
}
.cp-eyeq-how__mock-delta-text {
  font-family: var(--cp-font-body);
  font-size: 11px;
  font-weight: 500;
  color: #2f8c52;
  letter-spacing: -.005em;
}
.brxe-block.cp-eyeq-how__mock-bars {
  display: flex !important;
  flex-direction: column !important;
  gap: 8px;
  width: 100% !important;
  margin: 0 !important;
  padding-top: 4px !important;
  border-top: 1px solid var(--cp-border-soft);
  flex: 1 1 auto;
}
.brxe-block.cp-eyeq-how__mock-bar-row {
  display: grid !important;
  grid-template-columns: minmax(120px, 30%) 1fr 36px;
  gap: 10px;
  align-items: center !important;
  width: 100% !important;
  margin: 0 !important;
  padding: 0 !important;
}
.cp-eyeq-how__mock-bar-label {
  font-family: var(--cp-font-body);
  font-size: 12px;
  color: var(--cp-text-headline);
}
.brxe-block.cp-eyeq-how__mock-bar-track {
  width: 100% !important;
  height: 8px;
  background: rgba(15, 18, 23, .06);
  border-radius: 999px;
  overflow: hidden;
  margin: 0 !important;
  padding: 0 !important;
}
.brxe-block.cp-eyeq-how__mock-bar-fill {
  height: 100%;
  background: var(--cp-orange);
  border-radius: 999px;
  margin: 0 !important;
  padding: 0 !important;
  transition: width .8s cubic-bezier(.22,.61,.36,1);
}
.cp-eyeq-how__mock-bar-value {
  font-family: var(--cp-font-mono);
  font-size: 12px;
  font-weight: 500;
  color: var(--cp-text-headline);
  text-align: right;
}

/* ── Right column: step cards stacked vertically ── */
.brxe-block.cp-eyeq-how__steps {
  display: flex !important;
  flex-direction: column !important;
  align-items: stretch !important;
  gap: clamp(48px, 7vh, 96px);
  width: 100% !important;
  margin: 0 !important;
  padding: 0 !important;
}

.brxe-block.cp-eyeq-how__step {
  display: flex !important;
  flex-direction: column !important;
  align-items: flex-start !important;
  gap: 12px;
  width: 100% !important;
  margin: 0 !important;
  padding: 28px 0 !important;
  background: transparent;
  border: none;
  border-radius: 0;
  position: relative;
  scroll-margin-top: 100px;
  transition: transform .35s cubic-bezier(.22,.61,.36,1);
}

.cp-eyeq-how__step-num {
  font-family: var(--cp-font-heading);
  font-weight: 400;
  font-size: clamp(48px, 6vw, 88px);
  line-height: .95;
  letter-spacing: -.025em;
  color: rgba(15, 18, 23, .14);
  margin: 0;
  transition: color .35s ease, font-size .35s ease;
}
.cp-eyeq-how__step.is-active .cp-eyeq-how__step-num {
  color: var(--cp-orange);
}

.cp-eyeq-how__step-eyebrow {
  letter-spacing: .14em;
  color: var(--cp-text-meta);
  transition: color .25s ease;
}
.cp-eyeq-how__step.is-active .cp-eyeq-how__step-eyebrow { color: var(--cp-orange); }

.cp-eyeq-how__step-title {
  font-family: var(--cp-font-heading);
  font-weight: 400;
  font-size: clamp(26px, 3vw, 36px);
  line-height: 1.1;
  letter-spacing: -.014em;
  color: var(--cp-text-headline);
  margin: 0;
  max-width: 18ch;
}
.cp-eyeq-how__step-body {
  font-family: var(--cp-font-body);
  font-weight: 300;
  font-size: var(--cp-text-body);
  line-height: var(--cp-leading-body);
  color: var(--cp-text-secondary);
  margin: 0;
  max-width: 56ch;
}
.brxe-block.cp-eyeq-how__step-bullets {
  display: flex !important;
  flex-direction: column !important;
  gap: 8px;
  width: 100% !important;
  margin: 8px 0 0 !important;
  padding: 0 !important;
}
.brxe-block.cp-eyeq-how__step-bullet {
  display: flex !important;
  flex-direction: row !important;
  align-items: center !important;
  gap: 10px;
  width: auto !important;
  margin: 0 !important;
  padding: 0 !important;
}
.cp-eyeq-how__step-bullet-check {
  flex: 0 0 18px;
  width: 18px;
  height: 18px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border-radius: 50%;
  background: rgba(237, 134, 60, .14);
  color: var(--cp-orange);
  font-size: 10px;
  font-weight: 700;
}
.cp-eyeq-how__step-bullet-text {
  font-family: var(--cp-font-body);
  font-size: 14px;
  color: var(--cp-text-headline);
}

@media (prefers-reduced-motion: reduce) {
  .brxe-block.cp-eyeq-how__mock,
  .cp-eyeq-how__step-num,
  .brxe-block.cp-eyeq-how__progress-fill { transition: none !important; }
}


/* ──────────────────── 7. TESTIMONIALS ──────────────────── */
.brxe-section.cp-eyeq-testimonials {
  padding: clamp(80px, 10vh, 140px) 0;
  background: #fff;
}
.brxe-container.cp-eyeq-testimonials__inner {
  display: flex !important;
  flex-direction: column !important;
  align-items: stretch !important;
  gap: 48px;
}
.brxe-block.cp-eyeq-testimonials__head {
  display: flex !important;
  flex-direction: column !important;
  align-items: flex-start !important;
  gap: 14px;
  width: auto !important;
  max-width: 720px;
}
.cp-eyeq-testimonials__eyebrow { color: var(--cp-orange); letter-spacing: .14em; }
.cp-eyeq-testimonials__title {
  font-family: var(--cp-font-heading);
  font-weight: 400;
  font-size: clamp(34px, 4.4vw, 56px);
  line-height: 1.05;
  letter-spacing: -.012em;
  color: var(--cp-text-headline);
  margin: 0;
}
.brxe-block.cp-eyeq-testimonials__grid {
  display: grid !important;
  grid-template-columns: repeat(3, 1fr);
  gap: 18px;
  width: 100% !important;
}
@media (max-width: 900px) {
  .brxe-block.cp-eyeq-testimonials__grid { grid-template-columns: 1fr !important; }
}
.brxe-block.cp-eyeq-testimonial {
  display: flex !important;
  flex-direction: column !important;
  align-items: stretch !important;
  gap: 24px;
  width: 100% !important;
  padding: 32px !important;
  border-radius: var(--cp-radius-2xl);
  background: var(--cp-cream-bg);
  border: 1px solid var(--cp-border-soft);
}
.cp-eyeq-testimonial__quote {
  font-family: var(--cp-font-heading);
  font-weight: 400;
  font-size: clamp(18px, 1.6vw, 21px);
  line-height: 1.4;
  letter-spacing: -.005em;
  color: var(--cp-text-headline);
  margin: 0;
  flex: 1 1 auto;
}
.brxe-block.cp-eyeq-testimonial__meta {
  display: flex !important;
  flex-direction: row !important;
  align-items: center !important;
  gap: 12px;
  width: auto !important;
  margin: 0 !important;
}
.brxe-image.cp-eyeq-testimonial__avatar {
  width: 44px !important;
  height: 44px;
  border-radius: 50%;
  flex: 0 0 44px;
  overflow: hidden;
}
.brxe-image.cp-eyeq-testimonial__avatar img {
  width: 100% !important;
  height: 100% !important;
  object-fit: cover !important;
  display: block;
}
.brxe-block.cp-eyeq-testimonial__info {
  display: flex !important;
  flex-direction: column !important;
  align-items: flex-start !important;
  gap: 2px;
  width: auto !important;
}
.cp-eyeq-testimonial__name {
  font-family: var(--cp-font-heading);
  font-size: 15px;
  color: var(--cp-text-headline);
}
.cp-eyeq-testimonial__org {
  font-family: var(--cp-font-body);
  font-size: 13px;
  color: var(--cp-text-meta);
}

.brxe-block.cp-eyeq-testimonial__lift {
  display: grid !important;
  grid-template-columns: auto auto auto auto auto;
  align-items: center !important;
  gap: 8px 14px !important;
  width: auto !important;
  padding: 14px 16px !important;
  border-radius: 12px;
  background: #fff;
  border: 1px solid var(--cp-border-soft);
  margin: 0 !important;
}
.cp-eyeq-testimonial__lift-label {
  font-size: 10px;
  letter-spacing: .14em;
  color: var(--cp-text-muted);
  grid-row: 1;
}
.cp-eyeq-testimonial__lift-val {
  font-family: var(--cp-font-heading);
  font-size: 22px;
  font-weight: 400;
  letter-spacing: -.012em;
  grid-row: 2;
}
.cp-eyeq-testimonial__lift-val--before { color: var(--cp-text-muted); }
.cp-eyeq-testimonial__lift-val--after  { color: var(--cp-orange); }
.cp-eyeq-testimonial__lift-arrow {
  grid-row: 1 / span 2;
  align-self: center;
  font-size: 18px;
  color: var(--cp-text-muted);
}


/* ──────────────────── 8. PRICING TEASER ──────────────────── */
.brxe-section.cp-eyeq-pricing {
  padding: clamp(80px, 10vh, 140px) 0;
  background: var(--cp-cream-bg);
}
.brxe-container.cp-eyeq-pricing__inner {
  display: flex !important;
  flex-direction: column !important;
  align-items: stretch !important;
  gap: 48px;
}
.brxe-block.cp-eyeq-pricing__head {
  display: flex !important;
  flex-direction: column !important;
  align-items: center !important;
  text-align: center;
  gap: 14px;
  width: auto !important;
  margin: 0 auto !important;
  max-width: 720px;
}
.cp-eyeq-pricing__eyebrow { color: var(--cp-orange); letter-spacing: .14em; }
.cp-eyeq-pricing__title {
  font-family: var(--cp-font-heading);
  font-weight: 400;
  font-size: clamp(34px, 4.4vw, 56px);
  line-height: 1.05;
  letter-spacing: -.012em;
  color: var(--cp-text-headline);
  margin: 0;
  max-width: 18ch;
}
.cp-eyeq-pricing__blurb {
  font-family: var(--cp-font-body);
  font-weight: 300;
  font-size: var(--cp-text-body-lg);
  color: var(--cp-text-secondary);
  margin: 0;
}

.brxe-block.cp-eyeq-pricing__grid {
  display: grid !important;
  grid-template-columns: repeat(3, 1fr);
  gap: 18px;
  width: 100% !important;
  align-items: stretch !important;
}
@media (max-width: 900px) {
  .brxe-block.cp-eyeq-pricing__grid { grid-template-columns: 1fr !important; max-width: 480px; margin: 0 auto !important; }
}
.brxe-block.cp-eyeq-pricing__card {
  position: relative;
  display: flex !important;
  flex-direction: column !important;
  align-items: stretch !important;
  gap: 16px;
  width: 100% !important;
  padding: 36px 28px !important;
  border-radius: var(--cp-radius-2xl);
  background: #fff;
  border: 1px solid var(--cp-border-soft);
}
.cp-eyeq-pricing__card.is-featured {
  background: var(--cp-text-headline);
  border-color: var(--cp-text-headline);
  color: #fff;
  transform: translateY(-12px);
}
.cp-eyeq-pricing__ribbon {
  position: absolute;
  top: -12px;
  right: 24px;
  display: inline-flex;
  align-items: center;
  padding: 6px 14px;
  background: var(--cp-orange);
  color: #fff;
  font-family: var(--cp-font-body);
  font-size: 12px;
  font-weight: 500;
  letter-spacing: .02em;
  border-radius: 999px;
  border: 1px solid var(--cp-orange-border);
}
.cp-eyeq-pricing__tier {
  font-family: var(--cp-font-body);
  font-weight: 500;
  font-size: 14px;
  text-transform: uppercase;
  letter-spacing: .08em;
  color: var(--cp-text-meta);
}
.cp-eyeq-pricing__card.is-featured .cp-eyeq-pricing__tier { color: rgba(255,255,255,.7); }

.brxe-block.cp-eyeq-pricing__price-row {
  display: flex !important;
  flex-direction: row !important;
  align-items: baseline !important;
  gap: 8px;
  width: auto !important;
  margin: 0 !important;
}
.cp-eyeq-pricing__amount {
  font-family: var(--cp-font-heading);
  font-weight: 400;
  font-size: clamp(40px, 4.4vw, 56px);
  line-height: 1;
  letter-spacing: -.025em;
  color: var(--cp-text-headline);
  margin: 0;
}
.cp-eyeq-pricing__card.is-featured .cp-eyeq-pricing__amount { color: #fff; }
.cp-eyeq-pricing__period {
  font-family: var(--cp-font-body);
  font-size: var(--cp-text-body);
  color: var(--cp-text-secondary);
}
.cp-eyeq-pricing__card.is-featured .cp-eyeq-pricing__period { color: rgba(255,255,255,.7); }

.cp-eyeq-pricing__tag {
  font-family: var(--cp-font-body);
  font-size: 13px;
  line-height: 1.4;
  color: var(--cp-text-secondary);
  margin: 0 0 4px;
  min-height: 36px;
}
.cp-eyeq-pricing__card.is-featured .cp-eyeq-pricing__tag { color: rgba(255,255,255,.78); }

.brxe-block.cp-eyeq-pricing__features {
  display: flex !important;
  flex-direction: column !important;
  align-items: stretch !important;
  gap: 12px;
  width: 100% !important;
  margin: 0 !important;
  padding: 16px 0 !important;
  border-top: 1px solid var(--cp-border-soft);
}
.cp-eyeq-pricing__card.is-featured .cp-eyeq-pricing__features { border-top-color: rgba(255,255,255,.18); }
.brxe-block.cp-eyeq-pricing__feature {
  display: flex !important;
  flex-direction: row !important;
  align-items: flex-start !important;
  gap: 10px;
  width: auto !important;
  margin: 0 !important;
}
.cp-eyeq-pricing__check {
  flex: 0 0 18px;
  width: 18px; height: 18px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border-radius: 50%;
  background: rgba(237,134,60,.16);
  color: var(--cp-orange);
  font-size: 11px;
  font-weight: 700;
  margin-top: 2px;
}
.cp-eyeq-pricing__card.is-featured .cp-eyeq-pricing__check {
  background: rgba(237,134,60,.22);
}
.cp-eyeq-pricing__feat-txt {
  font-family: var(--cp-font-body);
  font-size: 14px;
  line-height: 1.45;
  color: var(--cp-text-headline);
}
.cp-eyeq-pricing__card.is-featured .cp-eyeq-pricing__feat-txt { color: rgba(255,255,255,.92); }

.cp-eyeq-pricing__cta {
  align-self: stretch;
  justify-content: center;
  margin-top: auto;
}
.cp-eyeq-pricing__card.is-featured .cp-eyeq-pricing__cta.cp-btn--primary {
  background: var(--cp-orange) !important;
  border-color: var(--cp-orange-border) !important;
}
.cp-eyeq-pricing__card.is-featured .cp-eyeq-pricing__cta.cp-btn--ghost {
  background: rgba(255,255,255,.10) !important;
  border-color: rgba(255,255,255,.30) !important;
  color: #fff !important;
}


/* ──────────────────── 9. FAQ ──────────────────── */
.brxe-section.cp-eyeq-faq {
  padding: clamp(80px, 10vh, 140px) 0;
}
.brxe-container.cp-eyeq-faq__inner {
  display: flex !important;
  flex-direction: column !important;
  align-items: center !important;
  gap: 48px;
}
.brxe-block.cp-eyeq-faq__head {
  display: flex !important;
  flex-direction: column !important;
  align-items: center !important;
  text-align: center;
  gap: 14px;
  width: auto !important;
  max-width: 640px;
}
.cp-eyeq-faq__eyebrow { color: var(--cp-orange); letter-spacing: .14em; }
.cp-eyeq-faq__title {
  font-family: var(--cp-font-heading);
  font-weight: 400;
  font-size: clamp(34px, 4.4vw, 56px);
  line-height: 1.05;
  letter-spacing: -.012em;
  color: var(--cp-text-headline);
  margin: 0;
}

.brxe-block.cp-eyeq-faq__accordion {
  display: flex !important;
  flex-direction: column !important;
  align-items: stretch !important;
  width: 100% !important;
  max-width: 800px;
  gap: 0;
}
.brxe-block.cp-eyeq-faq__item {
  display: flex !important;
  flex-direction: column !important;
  align-items: stretch !important;
  width: 100% !important;
  border-bottom: 1px solid var(--cp-border-soft);
  padding: 0 !important;
}
.brxe-block.cp-eyeq-faq__q-row {
  display: flex !important;
  flex-direction: row !important;
  align-items: center !important;
  justify-content: space-between !important;
  width: 100% !important;
  padding: 24px 4px !important;
  cursor: pointer;
  user-select: none;
  margin: 0 !important;
}
.cp-eyeq-faq__q {
  font-family: var(--cp-font-heading);
  font-size: clamp(17px, 1.4vw, 19px);
  letter-spacing: -.006em;
  color: var(--cp-text-headline);
}
.cp-eyeq-faq__caret {
  font-family: var(--cp-font-body);
  font-weight: 300;
  font-size: 22px;
  color: var(--cp-text-meta);
  transition: transform .25s cubic-bezier(.22,.61,.36,1), color .25s ease;
  margin-left: 16px;
}
.cp-eyeq-faq__item.is-open .cp-eyeq-faq__caret {
  transform: rotate(45deg);
  color: var(--cp-orange);
}
.brxe-block.cp-eyeq-faq__body-wrap {
  display: block !important;
  width: 100% !important;
  margin: 0 !important;
  padding: 0 !important;
  max-height: 0;
  overflow: hidden;
  transition: max-height .4s cubic-bezier(.22,.61,.36,1);
}
.cp-eyeq-faq__item.is-open .cp-eyeq-faq__body-wrap {
  /* High enough for any reasonable FAQ answer; clamped by overflow:hidden */
  max-height: 600px;
}
.cp-eyeq-faq__body {
  font-family: var(--cp-font-body);
  font-weight: 300;
  font-size: var(--cp-text-body);
  line-height: var(--cp-leading-body);
  color: var(--cp-text-secondary);
  margin: 0;
  padding: 0 4px 24px;
  max-width: 60ch;
}


/* ──────────────────── 10. FINAL CTA ──────────────────── */
.brxe-section.cp-eyeq-cta {
  padding: clamp(60px, 8vh, 100px) 0 clamp(80px, 12vh, 140px);
  background: var(--cp-cream-bg);
}
.brxe-block.cp-eyeq-cta__card {
  display: flex !important;
  flex-direction: column !important;
  align-items: center !important;
  text-align: center;
  gap: 18px;
  width: 100% !important;
  padding: clamp(60px, 9vh, 96px) 32px !important;
  border-radius: var(--cp-radius-3xl);
  background:
    radial-gradient(60% 80% at 50% 0%, rgba(237,134,60,.15) 0%, rgba(237,134,60,0) 60%),
    var(--cp-text-headline);
  color: #fff;
  position: relative;
  overflow: hidden;
}
.cp-eyeq-cta__eyebrow {
  letter-spacing: .14em;
  color: var(--cp-orange);
}
.cp-eyeq-cta__title {
  font-family: var(--cp-font-heading);
  font-weight: 400;
  font-size: clamp(40px, 5.6vw, 76px);
  line-height: 1.02;
  letter-spacing: -.022em;
  color: #fff;
  margin: 0;
  max-width: 18ch;
}
.cp-eyeq-cta__body {
  font-family: var(--cp-font-body);
  font-weight: 300;
  font-size: var(--cp-text-body-lg);
  line-height: var(--cp-leading-body);
  color: rgba(255,255,255,.82);
  margin: 0;
  max-width: 56ch;
}
.brxe-block.cp-eyeq-cta__row {
  display: flex !important;
  flex-direction: row !important;
  flex-wrap: wrap !important;
  align-items: center !important;
  justify-content: center !important;
  gap: 12px !important;
  width: auto !important;
  margin-top: 14px;
}
.cp-eyeq-cta__row .cp-btn--ghost {
  background: rgba(255,255,255,.10) !important;
  border-color: rgba(255,255,255,.30) !important;
  color: #fff !important;
}


@media (prefers-reduced-motion: reduce) {
  .brxe-block.cp-eyeq-trust__track { animation: none !important; }
  .cp-eyeq-faq__caret,
  .brxe-block.cp-eyeq-faq__body-wrap { transition: none !important; }
}


/* ──────────────────── 4c. RESEARCH SHEET — collapse + TOC + charts ──────────────────── */

/* Header collapse-on-scroll. Default state shows eyebrow + full title + meta;
   when the body scrolls, JS adds .is-scrolled to the header and we hide the
   eyebrow + meta and shrink the title to a single compact line. */
.brxe-block.cp-eyeq-research-sheet__head {
  transition: padding .3s cubic-bezier(.22,.61,.36,1);
}
.cp-eyeq-research-sheet__eyebrow,
.cp-eyeq-research-sheet__meta {
  transition: opacity .25s ease, max-height .3s cubic-bezier(.22,.61,.36,1),
              margin .3s cubic-bezier(.22,.61,.36,1);
  max-height: 60px;
  overflow: hidden;
}
.cp-eyeq-research-sheet__title {
  transition: font-size .3s cubic-bezier(.22,.61,.36,1);
}

.cp-eyeq-research-sheet__head.is-scrolled {
  padding: 16px 32px 12px !important;
}
.cp-eyeq-research-sheet__head.is-scrolled .cp-eyeq-research-sheet__eyebrow,
.cp-eyeq-research-sheet__head.is-scrolled .cp-eyeq-research-sheet__meta {
  opacity: 0;
  max-height: 0;
  margin: 0 !important;
  pointer-events: none;
}
.cp-eyeq-research-sheet__head.is-scrolled .cp-eyeq-research-sheet__title {
  font-size: clamp(15px, 1.4vw, 17px);
  line-height: 1.3;
  -webkit-line-clamp: 1;
  display: -webkit-box;
  -webkit-box-orient: vertical;
  overflow: hidden;
  max-width: calc(100% - 56px);
}
.cp-eyeq-research-sheet__head.is-scrolled .cp-eyeq-research-sheet__close {
  top: 12px;
  width: 32px;
  height: 32px;
}

/* Table of contents strip — sticky just below header */
.brxe-block.cp-eyeq-research-sheet__toc {
  display: flex !important;
  flex-direction: row !important;
  flex-wrap: nowrap !important;
  align-items: center !important;
  gap: 4px;
  width: 100% !important;
  padding: 10px 24px !important;
  background: rgba(247, 244, 237, .92);
  -webkit-backdrop-filter: saturate(180%) blur(8px);
          backdrop-filter: saturate(180%) blur(8px);
  border-bottom: 1px solid var(--cp-border-soft);
  overflow-x: auto;
  flex: 0 0 auto;
  scrollbar-width: none;
}
.brxe-block.cp-eyeq-research-sheet__toc::-webkit-scrollbar { display: none; }

.brxe-block.cp-eyeq-research-sheet__toc-link {
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  width: auto !important;
  padding: 8px 14px !important;
  margin: 0 !important;
  border-radius: 999px;
  cursor: pointer;
  user-select: none;
  white-space: nowrap;
  background: transparent;
  border: 1px solid transparent;
  transition: background-color .2s ease, border-color .2s ease, color .2s ease;
}
.brxe-block.cp-eyeq-research-sheet__toc-link:hover {
  background: rgba(15, 18, 23, .04);
}
.brxe-block.cp-eyeq-research-sheet__toc-link.is-active {
  background: var(--cp-text-headline);
  color: #fff;
  border-color: var(--cp-text-headline);
}
.cp-eyeq-research-sheet__toc-label {
  font-family: var(--cp-font-body);
  font-size: 13px;
  font-weight: 500;
  letter-spacing: -.005em;
  color: var(--cp-text-secondary);
}
.brxe-block.cp-eyeq-research-sheet__toc-link.is-active .cp-eyeq-research-sheet__toc-label {
  color: #fff;
}

.brxe-block.cp-eyeq-research-sheet__section {
  scroll-margin-top: 80px;
}

/* ── Charts — common ── */
.brxe-block.cp-eyeq-research-sheet__figure {
  display: flex !important;
  flex-direction: column !important;
  align-items: stretch !important;
  gap: 10px;
  width: 100% !important;
  padding: 18px 18px 14px !important;
  border-radius: var(--cp-radius-lg);
  background: #fff;
  border: 1px solid var(--cp-border-soft);
  margin: 4px 0 4px !important;
}
.cp-eyeq-research-sheet__figure-caption {
  font-family: var(--cp-font-mono);
  font-size: 11px;
  letter-spacing: -.005em;
  color: var(--cp-text-meta);
  margin: 0;
}

/* Bar chart (Fig 1, Fig 4) */
.brxe-block.cp-eyeq-rs-chart {
  display: flex !important;
  flex-direction: column !important;
  align-items: stretch !important;
  gap: 8px;
  width: 100% !important;
  margin: 0 !important;
  padding: 0 !important;
}
.brxe-block.cp-eyeq-rs-chart__row {
  display: grid !important;
  grid-template-columns: minmax(110px, 28%) 1fr 48px;
  align-items: center !important;
  gap: 12px;
  width: 100% !important;
  margin: 0 !important;
  padding: 0 !important;
}
.cp-eyeq-rs-chart__label {
  font-family: var(--cp-font-body);
  font-size: 12px;
  color: var(--cp-text-headline);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.brxe-block.cp-eyeq-rs-chart__track {
  width: 100% !important;
  height: 14px;
  background: rgba(15, 18, 23, .05);
  border-radius: 999px;
  overflow: hidden;
  margin: 0 !important;
  padding: 0 !important;
  display: block !important;
}
.brxe-block.cp-eyeq-rs-chart__fill {
  height: 100%;
  border-radius: 999px;
  background: var(--cp-orange);
  margin: 0 !important;
  display: block !important;
  transition: width .8s cubic-bezier(.22,.61,.36,1);
}
.cp-eyeq-rs-chart__row--primary    .cp-eyeq-rs-chart__fill { background: var(--cp-orange); }
.cp-eyeq-rs-chart__row--secondary  .cp-eyeq-rs-chart__fill { background: var(--cp-text-headline); }
.cp-eyeq-rs-chart__row--muted      .cp-eyeq-rs-chart__fill { background: rgba(15, 18, 23, .25); }

.cp-eyeq-rs-chart__value {
  font-family: var(--cp-font-mono);
  font-size: 12px;
  font-weight: 500;
  color: var(--cp-text-headline);
  text-align: right;
  letter-spacing: -.01em;
}

/* Stacked bar (Fig 3) */
.brxe-block.cp-eyeq-rs-stack {
  display: flex !important;
  flex-direction: column !important;
  gap: 14px;
  width: 100% !important;
}
.brxe-block.cp-eyeq-rs-stack__bar {
  display: flex !important;
  flex-direction: row !important;
  width: 100% !important;
  height: 36px;
  border-radius: 8px;
  overflow: hidden;
  margin: 0 !important;
  padding: 0 !important;
}
.brxe-block.cp-eyeq-rs-stack__seg {
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  height: 100%;
  margin: 0 !important;
  padding: 0 6px !important;
  position: relative;
  overflow: hidden;
  transition: width .8s cubic-bezier(.22,.61,.36,1);
}
.cp-eyeq-rs-stack__seg-label {
  font-family: var(--cp-font-mono);
  font-size: 11px;
  font-weight: 500;
  color: #fff;
  letter-spacing: -.01em;
  white-space: nowrap;
}
.cp-eyeq-rs-stack__seg--primary   { background: var(--cp-text-headline); }
.cp-eyeq-rs-stack__seg--secondary { background: var(--cp-orange); }
.cp-eyeq-rs-stack__seg--success   { background: #6fbf8a; }
.cp-eyeq-rs-stack__seg--neutral   { background: var(--cp-orange-grad-from, #ea8b3f); opacity: .65; }
.cp-eyeq-rs-stack__seg--danger    { background: #d16c6c; }
.cp-eyeq-rs-stack__seg--muted     { background: rgba(15, 18, 23, .25); }

.brxe-block.cp-eyeq-rs-stack__legend {
  display: flex !important;
  flex-direction: row !important;
  flex-wrap: wrap !important;
  align-items: center !important;
  gap: 14px;
  width: 100% !important;
  margin: 0 !important;
  padding: 0 !important;
}
.brxe-block.cp-eyeq-rs-stack__legend-item {
  display: inline-flex !important;
  align-items: center !important;
  gap: 6px;
  width: auto !important;
  margin: 0 !important;
  padding: 0 !important;
}
.brxe-block.cp-eyeq-rs-stack__legend-dot {
  width: 10px !important;
  height: 10px;
  border-radius: 50%;
  margin: 0 !important;
  padding: 0 !important;
}
.cp-eyeq-rs-stack__legend-dot--primary   { background: var(--cp-text-headline); }
.cp-eyeq-rs-stack__legend-dot--secondary { background: var(--cp-orange); }
.cp-eyeq-rs-stack__legend-dot--success   { background: #6fbf8a; }
.cp-eyeq-rs-stack__legend-dot--neutral   { background: var(--cp-orange-grad-from, #ea8b3f); opacity: .65; }
.cp-eyeq-rs-stack__legend-dot--danger    { background: #d16c6c; }
.cp-eyeq-rs-stack__legend-dot--muted     { background: rgba(15, 18, 23, .25); }
.cp-eyeq-rs-stack__legend-text {
  font-family: var(--cp-font-body);
  font-size: 11px;
  color: var(--cp-text-headline);
}

/* Paired stacked bars (Fig 2) */
.brxe-block.cp-eyeq-rs-paired {
  display: flex !important;
  flex-direction: column !important;
  gap: 14px;
  width: 100% !important;
}
.brxe-block.cp-eyeq-rs-paired__row {
  display: grid !important;
  grid-template-columns: 100px 1fr;
  align-items: center !important;
  gap: 14px;
  width: 100% !important;
}
.brxe-block.cp-eyeq-rs-paired__label-wrap {
  display: flex !important;
  flex-direction: column !important;
  align-items: flex-start !important;
  gap: 2px;
  width: auto !important;
  margin: 0 !important;
  padding: 0 !important;
}
.cp-eyeq-rs-paired__label-main {
  font-family: var(--cp-font-heading);
  font-size: 14px;
  letter-spacing: -.005em;
  color: var(--cp-text-headline);
}
.cp-eyeq-rs-paired__label-sub {
  font-family: var(--cp-font-mono);
  font-size: 10px;
  color: var(--cp-text-muted);
  letter-spacing: -.005em;
}
.brxe-block.cp-eyeq-rs-paired__bar {
  display: flex !important;
  flex-direction: row !important;
  width: 100% !important;
  height: 28px;
  border-radius: 6px;
  overflow: hidden;
  margin: 0 !important;
  padding: 0 !important;
}
.brxe-block.cp-eyeq-rs-paired__seg {
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  margin: 0 !important;
  padding: 0 4px !important;
  height: 100%;
  transition: width .8s cubic-bezier(.22,.61,.36,1);
}
.cp-eyeq-rs-paired__seg-label {
  font-family: var(--cp-font-mono);
  font-size: 11px;
  font-weight: 500;
  color: #fff;
  letter-spacing: -.01em;
  white-space: nowrap;
}
.cp-eyeq-rs-paired__seg--success { background: #6fbf8a; }
.cp-eyeq-rs-paired__seg--neutral { background: var(--cp-orange); opacity: .85; }
.cp-eyeq-rs-paired__seg--danger  { background: #d16c6c; }

/* ──────────────────── ECOSYSTEM (animated dashboard hub) ────────────────────
   3 left nodes + center Dashboard + 3 right nodes, with animated traffic
   lines flowing into the hub. Line animation reuses cp-fc-flow pattern:
   pathLength=100, stroke-dasharray 12 88, stroke-dashoffset -100 per cycle. */
.brxe-section.cp-eq-eco {
  padding: clamp(80px, 10vw, 140px) clamp(20px, 5vw, 64px) !important;
  background: var(--cp-cream-bg);
  display: block !important;
}
.cp-eq-eco__inner {
  max-width: 1280px;
  margin: 0 auto;
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
  gap: 16px;
}
.cp-eq-eco__eyebrow {
  letter-spacing: .14em;
  color: var(--cp-orange);
}
.cp-eq-eco__title {
  font-family: var(--cp-font-heading);
  font-weight: 400;
  font-size: clamp(32px, 4vw, 52px);
  line-height: 1.05;
  letter-spacing: -.012em;
  color: var(--cp-text-headline);
  margin: 0;
  max-width: 22ch;
}
.cp-eq-eco__blurb {
  font-family: var(--cp-font-body);
  font-weight: 300;
  font-size: clamp(16px, 1.4vw, 18px);
  line-height: 1.5;
  color: var(--cp-text-secondary);
  margin: 0 0 56px;
  max-width: 56ch;
}

.cp-eq-eco__grid {
  position: relative;
  width: 100%;
  display: grid;
  /* Side columns narrowed (skeleton icons reduced ~25%); center column
     widened so the dashboard reads as the dominant visual. */
  grid-template-columns: minmax(120px, 1fr) minmax(480px, 3.4fr) minmax(120px, 1fr);
  align-items: stretch;
  gap: clamp(24px, 4vw, 80px);
}

.cp-eq-eco__col {
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  gap: clamp(20px, 3vw, 40px);
  position: relative;
  z-index: 2;
}
.cp-eq-eco__node {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 14px;
  margin: 0;
}
.cp-eq-eco__icon {
  width: 100%;
  max-width: 140px;     /* was 186px — reduced ~25% per Simon */
  aspect-ratio: 186 / 143;
  background: transparent;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: transform .3s cubic-bezier(.22,.61,.36,1);
}
.cp-eq-eco__node:hover .cp-eq-eco__icon {
  transform: translateY(-3px);
}
.cp-eq-eco__icon img {
  width: 100%;
  height: 100%;
  display: block;
}
.cp-eq-eco__label {
  font-family: var(--cp-font-mono, var(--cp-font-body));
  font-weight: 500;
  font-size: 12px;
  letter-spacing: .14em;
  text-transform: uppercase;
  color: var(--cp-text-headline);
  position: relative;
  padding-left: 18px;
  margin: 0;
}
.cp-eq-eco__label::before {
  content: '';
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background: var(--cp-orange);
  position: absolute;
  left: 0;
  top: 50%;
  transform: translateY(-50%);
}
.cp-eq-eco__label--hub {
  margin-top: 14px;
}

.cp-eq-eco__center {
  display: flex;
  flex-direction: column;
  gap: 0;
  align-items: center;
  position: relative;
  z-index: 2;
  justify-content: center;
}
.cp-eq-eco__hub {
  width: 100%;
  border-radius: 18px;
  overflow: hidden;
  background: #0f1923;
  box-shadow: 0 28px 70px rgba(20,30,50,.20), 0 8px 18px rgba(20,30,50,.10);
}
.cp-eq-eco__hub img {
  width: 100%;
  display: block;
}

/* Animated flow lines — base + flow overlay per path. Two SVGs (desktop
   horizontal vs mobile vertical); toggled via media query. Default state
   shows desktop, hides mobile. */
.cp-eq-eco__lines {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  z-index: 1;
  pointer-events: none;
  overflow: visible;
}
.cp-eq-eco__lines--mobile { display: none; }
.cp-eq-eco__line {
  fill: none;
  vector-effect: non-scaling-stroke;
}
.cp-eq-eco__line--base {
  stroke-linecap: round;
  stroke-linejoin: round;
}
/* Single pulse per cycle. dasharray "55 220" — 55-unit pulse, 220-unit gap.
   With pathLength=100, the pulse covers more than half the path's length at
   any moment, so even the shorter middle (straight) routes spend most of
   each travel phase with a visible segment. Each path is staggered so the
   6 routes ripple in turn into the dashboard. */
.cp-eq-eco__line--flow {
  stroke-linecap: round;
  stroke-linejoin: round;
  stroke-dasharray: 55 220;
  animation: cp-eq-eco-flow 2.4s linear infinite;
}
.cp-eq-eco__line--flow-0 { animation-delay:  0s;    }
.cp-eq-eco__line--flow-1 { animation-delay: -0.4s;  }
.cp-eq-eco__line--flow-2 { animation-delay: -0.8s;  }
.cp-eq-eco__line--flow-3 { animation-delay: -0.2s;  }
.cp-eq-eco__line--flow-4 { animation-delay: -0.6s;  }
.cp-eq-eco__line--flow-5 { animation-delay: -1.0s;  }
@keyframes cp-eq-eco-flow {
  from { stroke-dashoffset:    0; }
  to   { stroke-dashoffset: -275; }
}
@media (prefers-reduced-motion: reduce) {
  .cp-eq-eco__line--flow { animation: none; opacity: .55; }
}

@media (max-width: 820px) {
  /* Vertical "donut": top row of 3 icons → animated lines down → hub →
     animated lines up → bottom row of 3 icons. */
  .cp-eq-eco__grid {
    grid-template-columns: 1fr;
    gap: 0;
    row-gap: 0;
    position: relative;
  }
  /* Each col becomes a horizontal row of 3 icons. */
  .cp-eq-eco__col {
    flex-direction: row !important;
    justify-content: space-between !important;
    align-items: flex-start;
    gap: clamp(8px, 2vw, 18px);
    padding: 0 4%;
    width: 100% !important;
  }
  .cp-eq-eco__node {
    flex: 1 1 0;
    max-width: 96px;     /* was 120px — reduced for tighter mobile row */
    margin: 0 auto;
  }
  .cp-eq-eco__icon { max-width: 100%; }
  /* Order: top row → spacer-for-down-lines → hub → spacer-for-up-lines →
     bottom row. col-left = top row, col-right = bottom row. */
  .cp-eq-eco__col--left  { order: 1; padding-bottom: clamp(70px, 14vw, 110px); }
  .cp-eq-eco__center     { order: 2; padding: 0 6%; }
  .cp-eq-eco__col--right { order: 3; padding-top:   clamp(70px, 14vw, 110px); }
  /* Hub label sits right under the dashboard image; keep it tight. */
  .cp-eq-eco__label--hub { margin-top: 12px; }

  /* Swap which SVG renders the animated lines. */
  .cp-eq-eco__lines--desktop { display: none; }
  .cp-eq-eco__lines--mobile  { display: block; }
}

/* ── Mobile research-sheet panel: source-order/specificity fix ──────────────
 * The base `.brxe-block.cp-eyeq-research-sheet__panel { position:absolute }`
 * rule appears LATER in this file than the mobile @media block above, so with
 * equal specificity + !important it was winning — leaving the research panel
 * absolute (and its content unpainted) on mobile. This rule adds the section
 * class for higher specificity so the mobile in-flow override always wins,
 * regardless of source order. (The board sheet's base rule precedes the
 * @media block, which is why it worked without this.) */
@media (max-width: 900px) {
  .cp-eyeq-research-sheet .brxe-block.cp-eyeq-research-sheet__panel {
    position: static !important;
    transform: none !important;
    width: 100% !important;
    max-width: 100% !important;
    height: auto !important;
    min-height: 100% !important;
    overflow: visible !important;
    box-shadow: none !important;
  }
}
