/* creative.moraq.io - Identity document (Moraq spec) */

body.mc-identity-overview {
  background: #0a0a0a;
  color: #f8fafc;
}

body.mc-section-identity .mc-main {
  padding-bottom: 0;
}

.mc-gl.mc-gl--identity-dark,
.mc-gl.mc-gl--identity-light {
  grid-template-columns: 300px minmax(0, 1fr);
  width: min(1520px, calc(100vw - 48px));
  max-width: none;
}

.mc-gl.mc-gl--identity-dark .mc-gl-sidebar,
.mc-gl.mc-gl--identity-light .mc-gl-sidebar {
  width: 300px;
  max-width: 300px;
  padding: 32px 32px 92px 32px;
  box-sizing: border-box;
}

.mc-gl.mc-gl--identity-dark .mc-gl-sidebar {
  border-right-color: rgba(255, 255, 255, 0.12);
}

.mc-gl.mc-gl--identity-dark .mc-gl-sidebar__kicker,
.mc-gl.mc-gl--identity-light .mc-gl-sidebar__kicker {
  margin: 0 0 16px;
}

.mc-gl.mc-gl--identity-dark .mc-gl-sidebar__kicker {
  color: rgba(255, 255, 255, 0.48);
}

.mc-gl.mc-gl--identity-dark .mc-gl-nav,
.mc-gl.mc-gl--identity-light .mc-gl-nav {
  display: flex;
  flex-direction: column;
  gap: 24px;
  width: 100%;
  margin: 0;
  padding: 0;
}

.mc-gl.mc-gl--identity-dark .mc-gl-nav__group,
.mc-gl.mc-gl--identity-light .mc-gl-nav__group {
  margin-bottom: 0;
}

.mc-gl.mc-gl--identity-dark .mc-gl-nav__group-toggle,
.mc-gl.mc-gl--identity-light .mc-gl-nav__group-toggle {
  padding: 5.6px 0;
  font-family: var(--font-body);
  font-size: 16px;
  font-weight: 400;
  line-height: 24px;
  gap: 28px;
}

.mc-gl.mc-gl--identity-dark .mc-gl-nav__group:first-child .mc-gl-nav__group-toggle,
.mc-gl.mc-gl--identity-light .mc-gl-nav__group:first-child .mc-gl-nav__group-toggle {
  border-top: none;
  padding-top: 8px;
  padding-bottom: 7px;
}

.mc-gl.mc-gl--identity-dark .mc-gl-nav__group-label,
.mc-gl.mc-gl--identity-light .mc-gl-nav__group-label {
  flex: 1 1 auto;
  min-width: 0;
}

.mc-gl.mc-gl--identity-dark .mc-gl-nav__chev,
.mc-gl.mc-gl--identity-light .mc-gl-nav__chev {
  width: 10px;
  height: 10px;
  opacity: 0.72;
  flex-shrink: 0;
}

.mc-gl.mc-gl--identity-dark .mc-gl-nav__pages,
.mc-gl.mc-gl--identity-light .mc-gl-nav__pages {
  padding: 10px 0 0;
}

.mc-gl.mc-gl--identity-dark .mc-gl-nav__link,
.mc-gl.mc-gl--identity-light .mc-gl-nav__link {
  padding: 5.6px 0;
  min-height: 24px;
  line-height: 24px;
  font-family: var(--font-body);
  font-size: 16px;
  font-weight: 400;
  border-radius: 0;
}

.mc-gl.mc-gl--identity-dark .mc-gl-nav__link.is-active,
.mc-gl.mc-gl--identity-light .mc-gl-nav__link.is-active {
  min-height: 30px;
  background: transparent;
  font-weight: 400;
  text-decoration: underline;
  text-underline-offset: 4px;
}

/* Section nested links (Spec: 14px / 300, padding-left 15px) */
.mc-gl.mc-gl--identity-dark .mc-gl-nav__section .mc-gl-nav__link,
.mc-gl.mc-gl--identity-light .mc-gl-nav__section .mc-gl-nav__link {
  padding: 3px 0 3px 15px;
  min-height: 30px;
  font-size: 14px;
  font-weight: 300;
  line-height: 24px;
}

.mc-gl.mc-gl--identity-dark .mc-gl-nav__link--overview,
.mc-gl.mc-gl--identity-light .mc-gl-nav__link--overview {
  display: block;
  margin-bottom: 8px;
  padding: 5.6px 0;
  min-height: 24px;
  font-size: 16px;
  font-weight: 400;
  line-height: 24px;
}

/* Group-level pages (Tuyên ngôn, Trụ cột tính cách) - flush with section heading */
.mc-gl.mc-gl--identity-dark .mc-gl-nav__link--group-page,
.mc-gl.mc-gl--identity-light .mc-gl-nav__link--group-page {
  padding: 3px 0;
  min-height: 30px;
  font-size: 14px;
  font-weight: 300;
  line-height: 24px;
}

.mc-gl.mc-gl--identity-dark .mc-gl-nav__pages > .mc-gl-nav__link--group-page:first-of-type,
.mc-gl.mc-gl--identity-light .mc-gl-nav__pages > .mc-gl-nav__link--group-page:first-of-type {
  margin-top: 6px;
}

.mc-gl.mc-gl--identity-dark .mc-gl-nav__section-label,
.mc-gl.mc-gl--identity-light .mc-gl-nav__section-label {
  margin: 12px 0 6px;
  padding: 0;
  font-family: var(--font-body);
  font-size: 14px;
  font-weight: 650;
  line-height: 24px;
  color: var(--mc-ink);
}

/* Collapsible strategy section (Nền tảng của chúng tôi) */
.mc-gl-nav__section--collapsible {
  margin-bottom: 0;
}

.mc-gl-nav__section--collapsible .mc-gl-nav__section-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 8px;
  margin: 12px 0 0;
}

.mc-gl-nav__section--collapsible .mc-gl-nav__link--section-root {
  flex: 1 1 auto;
  min-width: 0;
  padding: 3px 0;
  min-height: 30px;
  font-size: 14px;
  font-weight: 650;
  line-height: 24px;
}

.mc-gl-nav__section--collapsible .mc-gl-nav__link--section-root.is-active {
  font-weight: 650;
  text-decoration: underline;
  text-underline-offset: 4px;
}

.mc-gl-nav__section-toggle {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  width: 18px;
  height: 18px;
  padding: 0;
  border: none;
  background: transparent;
  color: var(--mc-ink);
  cursor: pointer;
}

.mc-gl-nav__section-toggle:hover {
  color: var(--mc-accent);
}

.mc-gl-nav__section-chev {
  width: 6px;
  height: 6px;
  border-right: 1px solid currentColor;
  border-bottom: 1px solid currentColor;
  transform: rotate(-45deg);
  opacity: 0.72;
  transition: transform 0.2s ease;
}

.mc-gl-nav__section--collapsible.is-open .mc-gl-nav__section-chev {
  transform: rotate(45deg);
}

.mc-gl-nav__section--collapsible .mc-gl-nav__section-pages {
  display: none;
}

.mc-gl-nav__section--collapsible.is-open .mc-gl-nav__section-pages {
  display: block;
}

.mc-gl.mc-gl--identity-dark .mc-gl-nav__section--collapsible .mc-gl-nav__section-pages .mc-gl-nav__link,
.mc-gl.mc-gl--identity-light .mc-gl-nav__section--collapsible .mc-gl-nav__section-pages .mc-gl-nav__link {
  padding: 3px 0 3px 15px;
}

.mc-gl.mc-gl--identity-dark .mc-gl-main,
.mc-gl.mc-gl--identity-light .mc-gl-main {
  padding-left: 32px;
  padding-right: 40px;
}

@media (max-width: 1023px) {
  .mc-gl.mc-gl--identity-dark,
  .mc-gl.mc-gl--identity-light {
    width: min(var(--mc-shell-width), var(--mc-page-width));
    margin-left: auto;
    margin-right: auto;
  }

  body.mc-section-identity .mc-chrome__inner {
    width: min(var(--mc-shell-width), var(--mc-page-width));
  }
}

.mc-gl.mc-gl--identity-dark .mc-gl-nav__group-toggle {
  color: #fff;
  border-top: 1px solid rgba(255, 255, 255, 0.12);
}

.mc-gl.mc-gl--identity-dark .mc-gl-nav__group-toggle:hover {
  color: #fff;
  opacity: 0.82;
}

.mc-gl.mc-gl--identity-dark .mc-gl-nav__link {
  color: rgba(255, 255, 255, 0.62);
}

.mc-gl.mc-gl--identity-dark .mc-gl-nav__link:hover {
  background: rgba(255, 255, 255, 0.06);
  color: #fff;
}

.mc-gl.mc-gl--identity-dark .mc-gl-nav__link.is-active {
  color: #fff;
}

/* Overview page */
.mc-id-page {
  color: #fff;
}

.mc-id-hero {
  margin: 0 0 40px;
  overflow: hidden;
}

.mc-id-hero--fan {
  overflow: visible;
  max-width: min(var(--mc-content-max), 100%);
}

.mc-id-hero--fan > .mc-story--how {
  padding-top: 0;
}

.mc-id-hero--fan .mc-visual--fan {
  margin: 0;
  width: 100%;
  max-width: 100%;
}

.mc-id-hero--fan .mc-story--how .mc-visual-fan {
  background: transparent;
  border-radius: 4px;
  padding: clamp(16px, 3vw, 28px) 0;
  min-height: clamp(260px, 36vw, 400px);
  height: auto;
  max-height: none;
}

.mc-id-hero--platform {
  overflow: visible;
  max-width: min(var(--mc-content-max), 100%);
}

.mc-id-hero--platform .mc-id-platform-showcase {
  margin-bottom: 0;
}

.mc-id-page--overview .mc-id-hero--platform .mc-id-platform-showcase {
  width: 100%;
  max-width: 100%;
}

.mc-id-hero__strip {
  display: flex;
  gap: 8px;
  align-items: stretch;
  min-height: clamp(180px, 28vw, 280px);
}

.mc-id-hero__slide {
  position: relative;
  flex: 1 1 0;
  border-radius: 4px;
  background: linear-gradient(180deg, var(--mc-id-slide-tone), var(--mc-id-slide-accent));
  min-height: 100%;
  overflow: hidden;
}

.mc-id-hero__slide--art {
  background: var(--mc-id-slide-tone);
}

.mc-id-hero__art {
  display: block;
  width: 100%;
  height: 100%;
  min-height: clamp(180px, 28vw, 280px);
  object-fit: cover;
  object-position: center;
}

.mc-id-hero__slide:nth-child(3) {
  flex-grow: 1.35;
}

/* Title + lead on one row (Spec: title 72px/300, lead 18px/300/23.4px) */
.mc-id-page__lead-row {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(0, 518px);
  gap: 40px 48px;
  align-items: start;
  margin: 0 0 40px;
}

.mc-id-page__title {
  margin: 0;
  max-width: 621px;
  font-family: var(--font-display-vi);
  font-size: clamp(2.5rem, 5vw, 4.5rem);
  font-weight: 300;
  line-height: 1;
  letter-spacing: -0.72px;
  color: #f0f0eb;
}

.mc-id-page__title.font-display-vi {
  font-weight: 300;
}

.mc-id-page__lead {
  margin: 0;
  max-width: 518px;
  font-family: var(--font-body);
  font-size: 18px;
  font-weight: 300;
  line-height: 23.4px;
  color: #f0f0eb;
}

.mc-id-page__rule {
  height: 1px;
  background: rgba(255, 255, 255, 0.18);
}

/* Explore block below title row (Spec: 40px after rule, cols ~513px) */
.mc-id-page__explore {
  margin-bottom: 56px;
}

.mc-id-page__explore-rule {
  margin: 0;
}

.mc-id-page__explore-grid {
  display: grid;
  grid-template-columns: minmax(0, 513px) minmax(0, 513px);
  gap: 48px 60px;
  align-items: start;
  padding-top: 40px;
}

.mc-id-page__explore-intro {
  min-height: 63px;
  display: flex;
  align-items: flex-start;
}

.mc-id-page__kicker {
  margin: 0;
  font-family: var(--font-body);
  font-size: 18px;
  font-weight: 300;
  line-height: 23.4px;
  color: #f0f0eb;
  max-width: 513px;
}

.mc-id-explore-rows {
  list-style: none;
  margin: 0;
  padding: 0;
  width: 100%;
  max-width: 513px;
}

.mc-id-explore-rows li {
  border-top: 1px solid rgba(255, 255, 255, 0.12);
}

.mc-id-explore-rows li:last-child {
  border-bottom: 1px solid rgba(255, 255, 255, 0.12);
}

.mc-id-explore-rows a {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
  min-height: 63px;
  padding: 10px 0;
  color: #fff;
}

.mc-id-explore-rows a:hover {
  opacity: 0.86;
}

.mc-id-explore-rows__label {
  margin: 0;
  flex: 1 1 auto;
  min-width: 0;
  max-width: 252px;
  font-family: var(--font-display-vi);
  font-size: clamp(1.75rem, 3vw, 2.625rem);
  font-weight: 300;
  line-height: 1;
  letter-spacing: -0.42px;
  color: #f0f0eb;
}

.mc-id-explore-rows__cta {
  flex: 0 0 auto;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 122px;
  min-height: 43px;
  padding: 0 18px;
  border-radius: 999px;
  font-family: var(--font-body);
  font-size: 13px;
  font-weight: 300;
  line-height: 20.8px;
  text-align: center;
}

.mc-id-explore-rows a:not(.mc-cta-pill-host--ready) .mc-id-explore-rows__cta {
  border: 1px solid #fff;
  background: #fff;
  color: #0a0a0a;
}

.mc-id-straight {
  margin-bottom: 48px;
  padding-top: 40px;
  border-top: 1px solid rgba(255, 255, 255, 0.18);
}

.mc-id-straight__label {
  display: flex;
  align-items: center;
  min-height: 40px;
  margin: 0 0 32px;
  font-family: var(--font-body);
  font-size: 18px;
  font-weight: 300;
  line-height: 23.4px;
  color: #f0f0eb;
}

.mc-id-card-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 513px));
  gap: 40px;
  max-width: min(1066px, 100%);
}

.mc-id-card {
  display: flex;
  flex-direction: column;
  gap: 28px;
  text-decoration: none;
}

.mc-id-card:hover .mc-id-card__visual {
  transform: translateY(-3px);
  box-shadow:
    0 16px 48px rgba(0, 48, 222, 0.18),
    0 0 0 1px rgba(255, 255, 255, 0.1);
}

.mc-id-card__visual {
  width: 100%;
  max-width: 513px;
  aspect-ratio: 513 / 289;
  border-radius: 8px;
  overflow: hidden;
  background: var(--est-mustkivi);
  border: 1px solid rgba(255, 255, 255, 0.1);
  transition: transform 0.4s cubic-bezier(0.22, 1, 0.36, 1), box-shadow 0.4s ease;
}

.mc-id-card__label {
  margin: 0;
  font-family: var(--font-body);
  font-size: 18px;
  font-weight: 300;
  line-height: 23.4px;
  color: #f0f0eb;
}

/* Foundation - strategy tier stack */
.mc-id-card__visual--foundation {
  background:
    radial-gradient(ellipse 80% 60% at 72% 18%, rgba(0, 98, 245, 0.22), transparent 55%),
    linear-gradient(165deg, #0f172a 0%, #1a1f2e 48%, #000087 100%);
}

.mc-id-card__foundation-scene {
  position: relative;
  width: 100%;
  height: 100%;
  display: flex;
  align-items: center;
  justify-content: center;
}

.mc-id-card__foundation-glow {
  position: absolute;
  inset: 10% 8% 12%;
  border-radius: 50%;
  background: radial-gradient(circle, rgba(0, 48, 222, 0.35) 0%, transparent 68%);
  filter: blur(18px);
  pointer-events: none;
}

.mc-id-card__foundation-grid {
  position: absolute;
  inset: 0;
  opacity: 0.35;
  background-image:
    linear-gradient(rgba(255, 255, 255, 0.04) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255, 255, 255, 0.04) 1px, transparent 1px);
  background-size: 28px 28px;
  mask-image: radial-gradient(ellipse 70% 80% at 50% 55%, #000 20%, transparent 75%);
}

.mc-id-card__foundation-tiers {
  position: relative;
  z-index: 1;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: flex-end;
  width: 62%;
  height: 72%;
  gap: 4px;
}

.mc-id-card__foundation-tier {
  display: flex;
  align-items: center;
  justify-content: center;
  height: 22%;
  clip-path: polygon(12% 0, 88% 0, 100% 100%, 0 100%);
  border-radius: 2px;
  transition: transform 0.35s ease, filter 0.35s ease;
}

.mc-id-card:hover .mc-id-card__foundation-tier {
  filter: brightness(1.08);
}

.mc-id-card__foundation-tier span {
  font-family: var(--font-body);
  font-size: clamp(0.5625rem, 1.2vw, 0.6875rem);
  font-weight: 500;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: rgba(255, 255, 255, 0.92);
  text-shadow: 0 1px 8px rgba(0, 0, 0, 0.35);
}

.mc-id-card__foundation-tier--1 {
  width: 38%;
  background: linear-gradient(180deg, #0062f5 0%, #0030de 100%);
}

.mc-id-card__foundation-tier--2 {
  width: 52%;
  background: linear-gradient(180deg, #0030de 0%, #0000b8 100%);
}

.mc-id-card__foundation-tier--3 {
  width: 66%;
  background: linear-gradient(180deg, #0000b8 0%, #000087 100%);
}

.mc-id-card__foundation-tier--4 {
  width: 80%;
  background: linear-gradient(180deg, #1e293b 0%, #0f172a 100%);
  border: 1px solid rgba(255, 255, 255, 0.08);
}

.mc-id-card__foundation-orbit {
  position: absolute;
  right: 8%;
  top: 14%;
  width: 26%;
  height: auto;
  opacity: 0.85;
  animation: mc-id-card-orbit 12s linear infinite;
}

@keyframes mc-id-card-orbit {
  to { transform: rotate(360deg); }
}

/* Personality pillars */
.mc-id-card__visual--portrait {
  position: relative;
  display: flex;
  align-items: flex-end;
  padding: 22px 24px;
  background:
    radial-gradient(circle at 78% 22%, rgba(0, 98, 245, 0.45), transparent 42%),
    linear-gradient(145deg, #000087 0%, #0030de 42%, #0062f5 78%, #0f172a 100%);
}

.mc-id-card__portrait-scene {
  position: absolute;
  inset: 0;
  overflow: hidden;
}

.mc-id-card__portrait-glow {
  position: absolute;
  left: -10%;
  bottom: -20%;
  width: 70%;
  height: 80%;
  background: radial-gradient(circle, rgba(242, 241, 237, 0.14) 0%, transparent 65%);
  pointer-events: none;
}

.mc-id-card__portrait-pillars {
  position: absolute;
  inset: 0;
  display: flex;
  align-items: flex-end;
  justify-content: center;
  gap: 10%;
  padding: 0 14% 8%;
}

.mc-id-card__portrait-pillar {
  flex: 0 0 18%;
  border-radius: 999px 999px 4px 4px;
  background: linear-gradient(180deg, rgba(255, 255, 255, 0.55) 0%, rgba(255, 255, 255, 0.08) 100%);
  border: 1px solid rgba(255, 255, 255, 0.22);
  backdrop-filter: blur(4px);
  transition: transform 0.45s cubic-bezier(0.22, 1, 0.36, 1);
}

.mc-id-card__portrait-pillar--1 { height: 42%; opacity: 0.55; }
.mc-id-card__portrait-pillar--2 { height: 62%; opacity: 0.72; }
.mc-id-card__portrait-pillar--3 { height: 48%; opacity: 0.6; }

.mc-id-card:hover .mc-id-card__portrait-pillar--1 { transform: translateY(-4px); }
.mc-id-card:hover .mc-id-card__portrait-pillar--2 { transform: translateY(-8px); }
.mc-id-card:hover .mc-id-card__portrait-pillar--3 { transform: translateY(-5px); }

.mc-id-card__portrait-mark {
  position: absolute;
  right: 10%;
  top: 12%;
  width: 14%;
  height: auto;
  opacity: 0.7;
}

.mc-id-card__overlay {
  position: relative;
  z-index: 1;
  font-family: var(--font-display-vi);
  font-size: clamp(1.125rem, 2.2vw, 1.625rem);
  font-weight: 300;
  line-height: 1.12;
  letter-spacing: -0.02em;
  max-width: 13ch;
  color: var(--est-ehakivi);
  text-shadow: 0 2px 24px rgba(0, 0, 0, 0.45);
}

/* Culture approach mosaic */
.mc-id-card__visual--approach {
  padding: 6px;
  background: #0a0a0a;
}

.mc-id-card__approach-mosaic {
  position: relative;
  display: grid;
  grid-template-columns: 1fr 1fr;
  grid-template-rows: 1fr 1fr;
  gap: 5px;
  width: 100%;
  height: 100%;
  border-radius: 4px;
  overflow: hidden;
}

.mc-id-card__approach-cell {
  display: flex;
  align-items: center;
  justify-content: center;
  border-radius: 4px;
  color: rgba(15, 23, 42, 0.72);
  transition: transform 0.35s ease, filter 0.35s ease;
}

.mc-id-card__approach-cell svg {
  width: 38%;
  height: auto;
}

.mc-id-card:hover .mc-id-card__approach-cell {
  filter: brightness(1.04);
}

.mc-id-card__approach-cell--listen {
  background: linear-gradient(145deg, #3d4b5e, #0f172a);
  color: var(--est-pahkla);
}

.mc-id-card__approach-cell--collab {
  background: linear-gradient(145deg, #cee2fd, #8eb8f0);
}

.mc-id-card__approach-cell--craft {
  background: linear-gradient(145deg, #fceec8, #e8d4a0);
}

.mc-id-card__approach-cell--grow {
  background: linear-gradient(145deg, #f2f1ed, #d6d3ce);
}

.mc-id-card__approach-core {
  position: absolute;
  left: 50%;
  top: 50%;
  width: 14px;
  height: 14px;
  border-radius: 50%;
  transform: translate(-50%, -50%);
  background: var(--est-blue);
  box-shadow: 0 0 0 4px rgba(0, 48, 222, 0.25), 0 0 24px rgba(0, 98, 245, 0.55);
}

/* Tone of voice pills */
.mc-id-card__visual--tone {
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 20px 16px;
  background:
    radial-gradient(ellipse 90% 70% at 50% 100%, rgba(0, 48, 222, 0.28), transparent 55%),
    radial-gradient(circle at 20% 15%, rgba(255, 255, 255, 0.06), transparent 45%),
    #0f172a;
}

.mc-id-card__tone-scene {
  position: relative;
  width: 100%;
  height: 100%;
  display: flex;
  align-items: center;
  justify-content: center;
}

.mc-id-card__tone-glow {
  position: absolute;
  inset: 20% 10%;
  border-radius: 50%;
  background: radial-gradient(circle, rgba(0, 98, 245, 0.2) 0%, transparent 70%);
  filter: blur(12px);
  pointer-events: none;
}

.mc-id-card__tone-stack {
  position: relative;
  z-index: 1;
  display: flex;
  flex-direction: column;
  gap: 7px;
  align-items: center;
  width: 100%;
  max-width: 220px;
}

.mc-id-card__tone-pill {
  padding: 7px 16px;
  border-radius: 999px;
  background: rgba(242, 241, 237, 0.94);
  color: var(--est-mustkivi);
  font-family: var(--font-body);
  font-size: 0.6875rem;
  font-weight: 600;
  white-space: nowrap;
  border: 1px solid rgba(15, 23, 42, 0.08);
  box-shadow: 0 4px 14px rgba(0, 0, 0, 0.18);
  transform: translateX(calc((var(--mc-tone-i, 0) - 2.5) * 6px));
  transition: transform 0.35s ease, box-shadow 0.35s ease, background 0.35s ease;
}

.mc-id-card__tone-pill.is-active {
  font-size: 0.8125rem;
  padding: 9px 20px;
  background: var(--est-ehakivi);
  border-color: var(--est-blue);
  box-shadow:
    0 6px 20px rgba(0, 48, 222, 0.28),
    0 0 0 1px rgba(0, 48, 222, 0.15);
  transform: translateX(0) scale(1.04);
  z-index: 2;
}

.mc-id-card:hover .mc-id-card__tone-pill {
  transform: translateX(calc((var(--mc-tone-i, 0) - 2.5) * 4px)) translateY(-1px);
}

.mc-id-card:hover .mc-id-card__tone-pill.is-active {
  transform: translateX(0) scale(1.06);
}

@media (prefers-reduced-motion: reduce) {
  .mc-id-card__visual,
  .mc-id-card__foundation-tier,
  .mc-id-card__portrait-pillar,
  .mc-id-card__approach-cell,
  .mc-id-card__tone-pill,
  .mc-id-card__foundation-orbit {
    transition: none;
    animation: none;
  }

  .mc-id-card:hover .mc-id-card__visual {
    transform: none;
  }
}

.mc-id-footer {
  padding: 0 0 96px;
  max-width: min(1067px, 100%);
}

.mc-id-footer__divider {
  display: flex;
  align-items: center;
  gap: 16px;
  min-height: 40px;
  margin-bottom: 20px;
}

.mc-id-footer__line {
  flex: 1;
  height: 1px;
  background: rgba(255, 255, 255, 0.12);
}

.mc-id-footer__chip {
  width: 36px;
  height: 36px;
  border-radius: 10px;
  border: 1px solid rgba(255, 255, 255, 0.14);
  background: rgba(255, 255, 255, 0.06);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
}

.mc-id-footer__chip-icon {
  width: 14px;
  height: 14px;
  background:
    radial-gradient(circle at 35% 50%, #fff 2px, transparent 2px),
    radial-gradient(circle at 65% 50%, #fff 2px, transparent 2px);
}

.mc-id-footer__watermark {
  margin: 0 0 var(--mc-overview-foot-gap, 24px);
  max-width: min(1067px, 100%);
  width: 100%;
  min-height: var(--mc-overview-foot-watermark-min-h, clamp(72px, 12vw, 120px));
  display: flex;
  align-items: center;
  justify-content: center;
  font-family: var(--font-display-vi);
  font-size: var(--mc-overview-foot-watermark-size, clamp(4rem, 14vw, 9rem));
  font-weight: 500;
  line-height: 0.9;
  letter-spacing: -0.04em;
  color: var(--mc-overview-foot-watermark-color, rgba(255, 255, 255, 0.06));
  text-align: center;
  user-select: none;
  overflow: hidden;
}

.mc-id-footer__note {
  margin: 0;
  max-width: 534px;
  font-family: var(--font-body);
  font-size: 14px;
  font-weight: 300;
  line-height: 18.2px;
  color: #f0f0eb;
}

.mc-id-footer__note a {
  color: inherit;
  text-decoration: underline;
  text-underline-offset: 2px;
}

.mc-id-footer__bottom {
  display: flex;
  align-items: flex-end;
  justify-content: flex-end;
  margin-top: 116px;
}

.mc-id-footer__next {
  display: flex;
  flex-direction: row;
  align-items: center;
  justify-content: flex-end;
  gap: 16px;
  min-width: min(100%, 280px);
  max-width: min(100%, 420px);
  min-height: 62px;
  padding: 14px 28px;
  box-sizing: border-box;
  text-align: left;
}

.mc-id-footer__next:not(.mc-cta-pill-host--ready) {
  color: #f0f0eb;
}

.mc-id-footer__next-copy {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
}

.mc-id-footer__next-kicker {
  margin: 0 0 4px;
  font-family: var(--font-body);
  font-size: 11px;
  font-weight: 700;
  line-height: 14.3px;
  letter-spacing: 0.1em;
  text-transform: uppercase;
}

.mc-id-footer__next:not(.mc-cta-pill-host--ready) .mc-id-footer__next-kicker {
  color: #676763;
}

.mc-id-footer__next-label {
  font-family: var(--font-body);
  font-size: 18px;
  font-weight: 300;
  line-height: 23.4px;
}

.mc-id-footer__next:not(.mc-cta-pill-host--ready) .mc-id-footer__next-label {
  color: #f0f0eb;
}

.mc-id-footer__next-arrow {
  flex-shrink: 0;
  width: 32px;
  height: 32px;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 32px;
  font-weight: 300;
  line-height: 1;
}

.mc-id-footer__next:not(.mc-cta-pill-host--ready) .mc-id-footer__next-arrow {
  color: #494946;
}

/* Placeholder pages on dark theme */
.mc-gl--identity-dark .mc-gl-page--soon .mc-gl-page__kicker,
.mc-gl--identity-dark .mc-gl-page--soon .mc-gl-soon__lead {
  color: rgba(255, 255, 255, 0.62);
}

.mc-gl--identity-dark .mc-gl-page--soon .mc-gl-page__title {
  color: #fff;
}

.mc-gl--identity-dark .mc-gl-soon__back {
  color: #fff;
  border: 1px solid rgba(255, 255, 255, 0.2);
  border-radius: 999px;
  padding: 8px 16px;
  display: inline-flex;
}

@media (max-width: 960px) {
  .mc-gl.mc-gl--identity-dark,
  .mc-gl.mc-gl--identity-light {
    grid-template-columns: 1fr;
  }

  .mc-gl.mc-gl--identity-dark .mc-gl-sidebar,
  .mc-gl.mc-gl--identity-light .mc-gl-sidebar {
    display: none;
  }

  .mc-gl.mc-gl--identity-dark .mc-gl-main,
  .mc-gl.mc-gl--identity-light .mc-gl-main {
    padding-left: 0;
    padding-right: 0;
    padding-top: 24px;
  }

  .mc-id-page__lead-row,
  .mc-id-page__explore-grid,
  .mc-id-card-grid {
    grid-template-columns: 1fr;
  }

  /* Single-column straight cards: flex avoids grid row box clipping last card label */
  .mc-id-card-grid {
    display: flex;
    flex-direction: column;
    gap: 32px;
    height: auto;
  }

  .mc-id-card-grid .mc-id-card,
  .mc-id-card-grid .mc-gl-card {
    flex: 0 0 auto;
    width: 100%;
    max-width: none;
  }

  .mc-id-page__explore-grid {
    gap: 32px;
    padding-top: 32px;
  }

  .mc-id-card-grid {
    max-width: none;
    gap: 32px;
  }

  .mc-id-straight__label {
    margin-bottom: 24px;
  }

  .mc-id-card__visual {
    max-width: none;
  }

  .mc-id-explore-rows,
  .mc-id-page__explore-intro,
  .mc-id-page__kicker {
    max-width: none;
  }

  .mc-id-explore-rows__label {
    max-width: none;
    font-size: clamp(1.5rem, 6vw, 2.625rem);
  }

  .mc-id-footer__watermark {
    height: clamp(96px, 22vw, 160px);
  }

  .mc-id-footer__bottom {
    margin-top: 28px;
  }

  .mc-id-footer__next {
    padding-left: 0;
    min-width: 0;
    width: 100%;
    align-items: center;
    justify-content: space-between;
  }

  .mc-id-footer__next-arrow {
    align-self: center;
    width: var(--mc-cta-pill-arrow, 24px);
    height: var(--mc-cta-pill-arrow, 24px);
    font-size: var(--mc-cta-pill-arrow, 24px);
  }
}

@media (max-width: 640px) {
  .mc-id-hero--fan .mc-story--how .mc-visual-fan {
    min-height: 220px;
    padding: 12px 0;
  }

  .mc-id-hero__strip {
    min-height: 140px;
  }

  .mc-id-explore-rows a {
    flex-direction: row;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
  }

  .mc-id-explore-rows__cta {
    align-self: center;
  }
}

/* Light document pages (Strategy, Frameworks, Culture) - colors only */
body.mc-section-identity:not(.mc-identity-overview) {
  background: var(--mc-page-bg);
  color: var(--mc-ink);
}

.mc-gl.mc-gl--identity-light .mc-gl-sidebar {
  border-right-color: rgba(15, 23, 42, 0.1);
}

.mc-gl.mc-gl--identity-light .mc-gl-sidebar__kicker {
  color: var(--mc-ink-soft);
}

.mc-gl.mc-gl--identity-light .mc-gl-nav__group-toggle {
  color: var(--mc-ink);
  border-top: 1px solid rgba(15, 23, 42, 0.1);
}

.mc-gl.mc-gl--identity-light .mc-gl-nav__group-toggle:hover {
  color: var(--mc-ink);
  opacity: 0.82;
}

.mc-gl.mc-gl--identity-light .mc-gl-nav__link {
  color: var(--mc-ink-muted);
}

.mc-gl.mc-gl--identity-light .mc-gl-nav__link:hover {
  background: rgba(15, 23, 42, 0.04);
  color: var(--mc-ink);
}

.mc-gl.mc-gl--identity-light .mc-gl-nav__link.is-active {
  color: var(--mc-ink);
}

.mc-gl.mc-gl--identity-dark .mc-gl-nav__section-label {
  color: rgba(255, 255, 255, 0.92);
}

.mc-gl.mc-gl--identity-light .mc-gl-main {
  color: var(--mc-ink);
}

.mc-id-doc {
  padding-bottom: 48px;
}

.mc-id-doc__rule {
  height: 1px;
  background: rgba(15, 23, 42, 0.12);
  margin: 40px 0;
  max-width: 1066px;
}

.mc-id-doc--foundation .mc-id-foundation-stack {
  max-width: 1066px;
}

.mc-id-doc--foundation-scroll .mc-id-foundation-stack {
  margin-bottom: 52px;
}

.mc-id-foundation-sections {
  max-width: 1066px;
}

.mc-id-doc--foundation-scroll .mc-id-platform-showcase,
.mc-id-doc--foundation-scroll .mc-id-media {
  max-width: 1066px;
}

.mc-id-doc--strategy .mc-id-foundation-stack {
  margin-bottom: 40px;
}

.mc-id-apply--foundation {
  display: grid;
  grid-template-columns: minmax(0, 518px) minmax(0, 518px);
  gap: 30px;
  margin: 72px 0 32px;
  max-width: 1066px;
}

.mc-id-apply--foundation .mc-id-apply__inner {
  grid-column: 2;
  max-width: 518px;
}

.mc-id-apply--foundation .mc-id-apply__title {
  margin: 0 0 24px;
  font-family: var(--font-body);
  font-size: clamp(1.5rem, 3vw, 2rem);
  font-weight: 300;
  line-height: 35.2px;
  letter-spacing: 0;
  color: #111110;
}

.mc-id-apply--foundation .mc-id-apply__lead {
  margin: 0 0 32px;
  max-width: 518px;
  font-family: var(--font-body);
  font-size: 18px;
  font-weight: 300;
  line-height: 23.4px;
  color: #111110;
}

.mc-id-apply--foundation .mc-id-focus {
  margin-top: 0;
}

.mc-id-split {
  display: grid;
  grid-template-columns: minmax(120px, 0.42fr) minmax(0, 1fr);
  gap: 24px 40px;
  align-items: start;
}

.mc-id-split--intro {
  grid-template-columns: minmax(0, 518px) minmax(0, 518px);
  gap: 30px;
  max-width: 1066px;
  align-items: start;
}

.mc-id-split--intro .mc-id-split__rule {
  display: none;
}

.mc-id-split--intro .mc-id-split__title {
  margin: 0 0 10px;
  max-width: 518px;
  font-family: var(--font-display-vi);
  font-size: clamp(2.5rem, 5vw, 4.5rem);
  font-weight: 300;
  line-height: 1;
  letter-spacing: -0.72px;
  color: #111110;
}

.mc-id-split--intro .mc-id-split__body {
  grid-column: 2;
  max-width: 518px;
  border-left: 1px solid rgba(15, 23, 42, 0.12);
  padding-left: 28px;
  margin: 0;
}

.mc-id-split--intro .mc-id-split__quote {
  margin: 0;
  padding: 0;
  border: none;
}

.mc-id-split--intro .mc-id-split__quote p {
  margin: 0 0 10px;
  font-family: var(--font-body);
  font-size: 18px;
  font-weight: 300;
  line-height: 23.4px;
  color: #111110;
}

.mc-id-split--intro .mc-id-split__quote p:last-child {
  margin-bottom: 0;
}

.mc-id-split--row {
  grid-template-columns: minmax(0, 518px) minmax(0, 518px);
  gap: 30px;
  max-width: 1066px;
  padding: 40px 0 52px;
  border-top: 1px solid rgba(15, 23, 42, 0.12);
  align-items: start;
  scroll-margin-top: 120px;
}

.mc-id-split--row .mc-id-split__title {
  margin: 0;
  max-width: 518px;
  font-family: var(--font-display-vi);
  font-size: clamp(2.5rem, 5vw, 4rem);
  font-weight: 300;
  line-height: 1;
  letter-spacing: -0.64px;
  color: #111110;
}

.mc-id-split--row .mc-id-split__content {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  max-width: 518px;
}

.mc-id-split--row .mc-id-split__subtitle {
  margin: 0 0 24px;
  font-family: var(--font-body);
  font-size: 32px;
  font-weight: 300;
  line-height: 35.2px;
  letter-spacing: 0;
  color: #111110;
}

.mc-id-split--row .mc-id-split__body {
  margin: 0;
  font-family: var(--font-body);
  font-size: 18px;
  font-weight: 300;
  line-height: 23.4px;
  color: #111110;
}

.mc-id-apply {
  margin-bottom: 32px;
}

.mc-id-apply__title {
  margin: 0 0 16px;
  font-family: var(--font-headline);
  font-size: clamp(1.125rem, 2vw, 1.375rem);
  font-weight: 650;
  letter-spacing: -0.02em;
}

.mc-id-apply__lead {
  margin: 0 0 28px;
  max-width: 52ch;
  font-size: 1rem;
  line-height: 1.65;
  color: var(--mc-ink-muted);
}

.mc-id-focus {
  position: relative;
  min-height: 280px;
  padding: 48px 32px;
  border-radius: 8px;
  background: #eceae4;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 8px;
  overflow: hidden;
}

.mc-id-focus__word {
  display: inline-flex;
  align-items: center;
  gap: 12px;
  cursor: pointer;
  color: rgba(15, 23, 42, 0.22);
  filter: blur(2px);
  transform: scale(0.92);
  transition: filter 0.25s ease, transform 0.25s ease, color 0.25s ease;
}

.mc-id-focus__word.is-active {
  color: var(--mc-ink);
  filter: none;
  transform: scale(1);
}

.mc-id-focus__word:hover {
  filter: blur(1px);
  color: rgba(15, 23, 42, 0.55);
}

.mc-id-focus__word.is-active:hover {
  filter: none;
  color: var(--mc-ink);
}

.mc-id-focus__arrow {
  font-size: 1.25rem;
  opacity: 0;
  width: 0;
  overflow: hidden;
  transition: opacity 0.2s ease, width 0.2s ease;
}

.mc-id-focus__word.is-active .mc-id-focus__arrow {
  opacity: 1;
  width: auto;
}

.mc-id-focus__label {
  font-family: var(--font-display);
  font-size: clamp(1.75rem, 4vw, 2.75rem);
  line-height: 1;
  letter-spacing: -0.03em;
}

/* Platform showcase - animated GIF-style demo (Moraq spec) */
.mc-id-platform-showcase {
  --mc-platform-cycle: 6s;
  position: relative;
  width: 100%;
  max-width: 1067px;
  min-height: 600px;
  margin: 0 0 56px;
  padding: 32px;
  border-radius: 8px;
  background: #eceae4;
  overflow: hidden;
}

.mc-id-platform-showcase__stage {
  position: relative;
  height: 536px;
  min-height: 536px;
}

.mc-id-platform-showcase__scene {
  position: absolute;
  inset: 0;
}

.mc-id-platform-showcase__scene--hero {
  z-index: 2;
  animation: mc-platform-hero-scene var(--mc-platform-cycle) cubic-bezier(0.45, 0, 0.55, 1) infinite;
  will-change: opacity;
}

.mc-id-platform-showcase__scene--mosaic {
  z-index: 1;
  animation: mc-platform-mosaic-scene var(--mc-platform-cycle) cubic-bezier(0.45, 0, 0.55, 1) infinite;
  will-change: opacity, transform;
}

.mc-id-platform-showcase__desktop {
  position: absolute;
  left: 50%;
  top: 50%;
  width: min(100%, 680px);
  padding: 24px;
  border-radius: 12px;
  background: linear-gradient(160deg, #1a3d2e 0%, #0f172a 100%);
  color: #fff;
  box-shadow: 0 24px 48px rgba(15, 23, 42, 0.18);
  transform: translate(-58%, -50%);
  cursor: grab;
  touch-action: none;
  transition: box-shadow 0.25s ease;
  animation: mc-platform-desktop-drift var(--mc-platform-cycle) cubic-bezier(0.45, 0, 0.55, 1) infinite;
}

.mc-id-platform-showcase.is-dragging .mc-id-platform-showcase__desktop {
  cursor: grabbing;
  box-shadow: 0 32px 56px rgba(15, 23, 42, 0.28);
  animation-play-state: paused;
}

.mc-id-platform-showcase.is-outview .mc-id-platform-showcase__scene--hero,
.mc-id-platform-showcase.is-outview .mc-id-platform-showcase__scene--mosaic,
.mc-id-platform-showcase.is-outview .mc-id-platform-showcase__desktop,
.mc-id-platform-showcase.is-outview .mc-id-platform-showcase__drag-bundle,
.mc-id-platform-showcase.is-outview .mc-id-platform-showcase__cursor,
.mc-id-platform-showcase.is-outview .mc-id-platform-showcase__tile--inspiration,
.mc-id-platform-showcase.is-outview .mc-id-platform-showcase__tile-slot,
.mc-id-platform-showcase.is-outview .mc-id-platform-showcase__tile-mag,
.mc-id-platform-showcase.is-outview .mc-id-platform-showcase__card {
  animation-play-state: paused;
}

.mc-id-platform-showcase__chrome {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: space-between;
  gap: 10px 20px;
  margin-bottom: 20px;
}

.mc-id-platform-showcase__brand {
  font-family: var(--font-display);
  font-size: 1.5rem;
  letter-spacing: -0.02em;
}

.mc-id-platform-showcase__menu {
  font-size: 0.6875rem;
  font-weight: 650;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  opacity: 0.72;
}

.mc-id-platform-showcase__kicker {
  margin: 0 0 16px;
  font-size: 0.75rem;
  font-weight: 650;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  opacity: 0.65;
}

.mc-id-platform-showcase__tiles {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 12px;
}

.mc-id-platform-showcase__tile {
  display: flex;
  flex-direction: column;
  gap: 12px;
  min-height: 112px;
  padding: 14px;
  border-radius: 8px;
  background: rgba(255, 255, 255, 0.08);
}

.mc-id-platform-showcase__tile-label {
  font-size: 0.625rem;
  font-weight: 650;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  opacity: 0.75;
}

.mc-id-platform-showcase__swatches {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 6px;
  margin-top: auto;
}

.mc-id-platform-showcase__swatches i {
  display: block;
  height: 22px;
  border-radius: 4px;
  background: var(--mc-s, #253224);
}

.mc-id-platform-showcase__logo-mark {
  margin-top: auto;
  font-family: var(--font-display);
  font-size: 1.125rem;
  opacity: 0.92;
}

.mc-id-platform-showcase__tile-photo {
  display: block;
  flex: 1;
  min-height: 64px;
  border-radius: 4px;
  background: linear-gradient(145deg, #8a7f72, #c4a48a 55%, #7a9a6d);
}

.mc-id-platform-showcase__tile-mag {
  display: block;
  flex: 1;
  padding: 10px;
  border-radius: 4px;
  background: rgba(255, 255, 255, 0.12);
  font-size: 0.6875rem;
  line-height: 1.35;
  opacity: 0.88;
  animation: mc-platform-slot-fill var(--mc-platform-cycle) cubic-bezier(0.45, 0, 0.55, 1) infinite;
}

.mc-id-platform-showcase__tile-slot {
  display: block;
  flex: 1;
  min-height: 64px;
  border-radius: 4px;
  border: 1px dashed rgba(255, 255, 255, 0.28);
  background: rgba(0, 0, 0, 0.18);
  animation: mc-platform-slot-empty var(--mc-platform-cycle) cubic-bezier(0.45, 0, 0.55, 1) infinite;
}

.mc-id-platform-showcase__tile--inspiration {
  animation: mc-platform-tile-drop-zone var(--mc-platform-cycle) cubic-bezier(0.45, 0, 0.55, 1) infinite;
}

.mc-id-platform-showcase__drag-bundle {
  position: absolute;
  z-index: 5;
  right: 1.5%;
  top: 18%;
  width: 148px;
  animation: mc-platform-drag-bundle var(--mc-platform-cycle) cubic-bezier(0.45, 0, 0.55, 1) infinite;
  pointer-events: none;
}

.mc-id-platform-showcase__float-card {
  display: flex;
  flex-direction: column;
  gap: 10px;
  width: 148px;
  padding: 14px;
  border-radius: 10px;
  border: 2px solid rgba(15, 23, 42, 0.12);
  background: linear-gradient(180deg, #1a3d2e, #0f172a);
  color: #fff;
  box-shadow: 0 20px 40px rgba(15, 23, 42, 0.22);
}

.mc-id-platform-showcase__float-title {
  display: block;
  font-family: var(--font-display-vi);
  font-size: 0.8125rem;
  line-height: 1.25;
}

.mc-id-platform-showcase__float-media {
  display: block;
  height: 72px;
  border-radius: 6px;
  background: linear-gradient(160deg, #fceec8, #cee2fd);
}

.mc-id-platform-showcase__float-lines {
  display: block;
  height: 36px;
  border-radius: 4px;
  background:
    linear-gradient(rgba(255, 255, 255, 0.22), rgba(255, 255, 255, 0.22)) 0 0 / 100% 6px no-repeat,
    linear-gradient(rgba(255, 255, 255, 0.14), rgba(255, 255, 255, 0.14)) 0 12px / 88% 5px no-repeat,
    linear-gradient(rgba(255, 255, 255, 0.14), rgba(255, 255, 255, 0.14)) 0 22px / 72% 5px no-repeat;
}

.mc-id-platform-showcase__cursor {
  position: absolute;
  left: 58%;
  top: 52%;
  z-index: 2;
  display: flex;
  align-items: center;
  gap: 6px;
  animation: mc-platform-cursor-grab var(--mc-platform-cycle) cubic-bezier(0.45, 0, 0.55, 1) infinite;
}

.mc-id-platform-showcase__cursor-icon {
  width: 14px;
  height: 18px;
  background: #7c3aed;
  clip-path: polygon(0 0, 100% 44%, 58% 56%, 68% 100%, 0 0);
  filter: drop-shadow(0 2px 4px rgba(124, 58, 237, 0.35));
}

.mc-id-platform-showcase__cursor-label {
  padding: 3px 8px;
  border-radius: 4px;
  background: #7c3aed;
  color: #fff;
  font-size: 0.6875rem;
  font-weight: 600;
  line-height: 1.2;
  white-space: nowrap;
}

.mc-id-platform-showcase__mosaic {
  display: grid;
  grid-template-columns: repeat(6, minmax(0, 1fr));
  grid-template-rows: repeat(3, minmax(96px, 1fr));
  gap: 10px;
  height: 100%;
  min-height: 536px;
  padding: 16px;
  border-radius: 8px;
  background: #111110;
}

.mc-id-platform-showcase__card {
  border-radius: 8px;
  padding: 14px;
  overflow: hidden;
  animation: mc-platform-card-float var(--mc-platform-cycle) cubic-bezier(0.45, 0, 0.55, 1) infinite;
}

.mc-id-platform-showcase__card--moraq {
  grid-column: 2 / span 2;
  grid-row: 1 / span 2;
  background: linear-gradient(160deg, #1a3d2e, #0f172a);
  color: #fff;
  --mc-card-enter-x: -36px;
  --mc-card-enter-y: 0;
  animation-delay: 0s;
}

.mc-id-platform-showcase__card--hub {
  grid-column: 4 / span 2;
  grid-row: 1 / span 2;
  background: #f5f3ef;
  color: #111110;
  --mc-card-enter-x: 36px;
  --mc-card-enter-y: 0;
  animation-delay: -0.4s;
}

.mc-id-platform-showcase__card--scape {
  grid-column: 1;
  grid-row: 1 / span 2;
  background: linear-gradient(180deg, #2a3140, #0f172a);
  color: #fff;
  --mc-card-enter-x: -28px;
  --mc-card-enter-y: 12px;
  animation-delay: -0.8s;
}

.mc-id-platform-showcase__card--imagery {
  grid-column: 1;
  grid-row: 3;
  background: linear-gradient(135deg, #c45c4a, #8a3030);
  --mc-card-enter-x: -24px;
  --mc-card-enter-y: 20px;
  animation-delay: -0.2s;
}

.mc-id-platform-showcase__card--minimal {
  grid-column: 2 / span 2;
  grid-row: 3;
  background: #fff;
  color: #111110;
  --mc-card-enter-x: 0;
  --mc-card-enter-y: 24px;
  animation-delay: -0.6s;
}

.mc-id-platform-showcase__card--micro {
  grid-column: 4 / span 2;
  grid-row: 3;
  background: #0a0a0a;
  color: #fff;
  --mc-card-enter-x: 28px;
  --mc-card-enter-y: 20px;
  animation-delay: -1s;
}

.mc-id-platform-showcase__card-brand {
  display: block;
  font-size: 0.6875rem;
  font-weight: 650;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  opacity: 0.85;
}

.mc-id-platform-showcase__card-mini-tiles {
  display: block;
  margin-top: 12px;
  height: 48px;
  border-radius: 4px;
  background:
    linear-gradient(90deg, rgba(255,255,255,0.14) 0 22%, transparent 22% 26%, rgba(255,255,255,0.14) 26% 48%, transparent 48% 52%, rgba(255,255,255,0.14) 52% 74%, transparent 74%);
}

.mc-id-platform-showcase__card-block {
  display: block;
  margin-top: 12px;
  height: calc(100% - 24px);
  min-height: 64px;
  border-radius: 6px;
  background: linear-gradient(145deg, #c4b5fd, #a78bfa);
}

.mc-id-platform-showcase__card-quote {
  display: block;
  margin-top: 24px;
  font-size: 0.625rem;
  line-height: 1.35;
  opacity: 0.88;
}

.mc-id-platform-showcase__card-dot {
  display: block;
  width: 36px;
  height: 36px;
  margin: 16px auto 0;
  border-radius: 50%;
  background: radial-gradient(circle at 35% 35%, #fff 0 20%, #c45c4a 21% 100%);
}

.mc-id-platform-showcase__card-headline {
  display: block;
  margin-top: 8px;
  font-family: var(--font-display);
  font-size: 1.125rem;
  color: #e85d04;
  letter-spacing: -0.02em;
}

.mc-id-platform-showcase__card-swatches {
  display: block;
  margin-top: 10px;
  height: 28px;
  border-radius: 4px;
  background: linear-gradient(90deg, #fff 0 22%, #999 22% 44%, #666 44% 66%, #333 66% 88%, #111 88%);
}

@keyframes mc-platform-drag-bundle-mobile {
  0%, 11% { opacity: 0; transform: translateY(-12px) scale(0.92); }
  14%, 18% { opacity: 1; transform: translateY(0) scale(1); }
  26% { opacity: 1; transform: translateY(28px) scale(0.82); }
  32% { opacity: 1; transform: translateY(56px) scale(0.68); }
  34% { opacity: 0.35; transform: translateY(56px) scale(0.64); }
  36%, 100% { opacity: 0; transform: translateY(-12px) scale(0.92); }
}

@keyframes mc-platform-hero-scene {
  0%, 36% { opacity: 1; }
  44%, 78% { opacity: 0; }
  86%, 100% { opacity: 1; }
}

@keyframes mc-platform-mosaic-scene {
  0%, 36% { opacity: 0; transform: scale(1.03); }
  44%, 78% { opacity: 1; transform: scale(1); }
  86%, 100% { opacity: 0; transform: scale(1.03); }
}

@keyframes mc-platform-desktop-drift {
  0%, 16% { transform: translate(-58%, -50%); }
  22%, 36% { transform: translate(-52%, -50%); }
  44%, 100% { transform: translate(-58%, -50%); }
}

@keyframes mc-platform-drag-bundle {
  0%, 11% { opacity: 0; transform: translate(48px, -8px) scale(0.92); }
  14%, 18% { opacity: 1; transform: translate(0, 0) scale(1); }
  20%, 21% { opacity: 1; transform: translate(0, 0) scale(1); }
  26% {
    opacity: 1;
    transform: translate(calc(var(--mc-platform-drop-x, -320px) * 0.5), calc(var(--mc-platform-drop-y, 96px) * 0.5)) scale(0.72);
  }
  32% {
    opacity: 1;
    transform: translate(var(--mc-platform-drop-x, -320px), var(--mc-platform-drop-y, 96px)) scale(0.54);
  }
  34% {
    opacity: 0.35;
    transform: translate(var(--mc-platform-drop-x, -320px), var(--mc-platform-drop-y, 96px)) scale(0.5);
  }
  36%, 100% { opacity: 0; transform: translate(48px, -8px) scale(0.92); }
}

@keyframes mc-platform-cursor-grab {
  0%, 14% { opacity: 0; transform: translate(24px, 18px); }
  16%, 20% { opacity: 1; transform: translate(24px, 18px); }
  21%, 32% { opacity: 1; transform: translate(-6px, -4px); }
  36%, 100% { opacity: 0; transform: translate(-6px, -4px); }
}

@keyframes mc-platform-slot-empty {
  0%, 31% { opacity: 1; }
  33%, 84% { opacity: 0; }
  88%, 100% { opacity: 1; }
}

@keyframes mc-platform-slot-fill {
  0%, 31% { opacity: 0; transform: scale(0.94); }
  33%, 84% { opacity: 0.88; transform: scale(1); }
  88%, 100% { opacity: 0; transform: scale(0.94); }
}

@keyframes mc-platform-tile-drop-zone {
  0%, 19% { box-shadow: none; background-color: rgba(255, 255, 255, 0.08); }
  21%, 32% { box-shadow: inset 0 0 0 2px rgba(124, 58, 237, 0.55); background-color: rgba(124, 58, 237, 0.12); }
  34%, 100% { box-shadow: none; background-color: rgba(255, 255, 255, 0.08); }
}

@keyframes mc-platform-card-float {
  0%, 44% { opacity: 0; transform: translate(var(--mc-card-enter-x, 0), var(--mc-card-enter-y, 28px)) scale(0.94); }
  50%, 76% { opacity: 1; transform: translate(0, 0) scale(1); }
  82%, 100% { opacity: 0; transform: translate(0, -8px) scale(0.98); }
}

.mc-id-platform-showcase.is-measuring-drop .mc-id-platform-showcase__drag-bundle,
.mc-id-platform-showcase.is-measuring-drop .mc-id-platform-showcase__desktop,
.mc-id-platform-showcase.is-measuring-drop .mc-id-platform-showcase__cursor {
  animation: none !important;
}

.mc-id-platform-showcase.is-measuring-drop .mc-id-platform-showcase__desktop {
  transform: translate(-52%, -50%) !important;
}

.mc-id-platform-showcase.is-measuring-drop .mc-id-platform-showcase__drag-bundle {
  transform: translate(0, 0) !important;
  opacity: 1 !important;
}

.mc-id-platform-showcase.is-reduced-motion .mc-id-platform-showcase__scene--hero {
  position: relative;
  opacity: 1;
  visibility: visible;
  animation: none;
}

.mc-id-platform-showcase.is-reduced-motion .mc-id-platform-showcase__scene--mosaic {
  display: none;
}

.mc-id-platform-showcase.is-reduced-motion .mc-id-platform-showcase__phone,
.mc-id-platform-showcase.is-reduced-motion .mc-id-platform-showcase__drag-bundle,
.mc-id-platform-showcase.is-reduced-motion .mc-id-platform-showcase__cursor {
  display: none;
}

.mc-id-platform-showcase.is-reduced-motion .mc-id-platform-showcase__tile-slot {
  display: none;
}

.mc-id-platform-showcase.is-reduced-motion .mc-id-platform-showcase__tile-mag {
  opacity: 0.88;
  animation: none;
}

.mc-id-platform-showcase.is-reduced-motion .mc-id-platform-showcase__desktop {
  position: relative;
  left: auto;
  top: auto;
  transform: none;
  animation: none;
  margin: 0 auto;
}

.mc-id-platform-showcase + .mc-id-split--row {
  margin-top: 0;
}

.mc-id-media {
  margin: 24px 0 32px;
}

.mc-id-media__frame {
  min-height: 280px;
  border-radius: 8px;
  background: linear-gradient(145deg, #fceec8, #cee2fd);
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 12px;
}

.mc-id-media__play {
  width: 56px;
  height: 56px;
  border-radius: 50%;
  border: 2px solid rgba(15, 23, 42, 0.2);
  position: relative;
}

.mc-id-media__play::after {
  content: "";
  position: absolute;
  top: 50%;
  left: 54%;
  transform: translate(-50%, -50%);
  border-style: solid;
  border-width: 8px 0 8px 14px;
  border-color: transparent transparent transparent var(--mc-ink);
}

.mc-id-media__caption {
  margin: 0;
  font-size: 0.8125rem;
  color: var(--mc-ink-muted);
}

@media (max-width: 960px) {
  .mc-id-apply--foundation {
    grid-template-columns: 1fr;
    margin-top: 42px;
  }

  .mc-id-apply--foundation .mc-id-apply__inner {
    grid-column: 1;
    max-width: none;
  }

  .mc-id-split--intro {
    grid-template-columns: 1fr;
    max-width: none;
  }

  .mc-id-split--intro .mc-id-split__title,
  .mc-id-split--intro .mc-id-split__body {
    max-width: none;
  }

  .mc-id-split--intro .mc-id-split__body {
    grid-column: 1;
    border-left: none;
    padding-left: 0;
    padding-top: 24px;
    border-top: 1px solid rgba(15, 23, 42, 0.12);
  }

  .mc-id-split--row {
    grid-template-columns: 1fr;
    max-width: none;
    padding: 32px 0 40px;
    gap: 16px;
  }

  .mc-id-split--row .mc-id-split__title,
  .mc-id-split--row .mc-id-split__content {
    max-width: none;
  }

  .mc-id-split--row .mc-id-split__subtitle {
    font-size: clamp(1.5rem, 3vw, 2rem);
    line-height: 1.1;
  }

  .mc-id-platform-showcase {
    --mc-platform-ui-scale: 0.86;
    min-height: 0;
    padding: 20px 14px 28px;
    margin-bottom: 44px;
  }

  .mc-id-platform-showcase__stage {
    height: calc(536px * var(--mc-platform-ui-scale));
    min-height: 0;
    overflow: visible;
  }

  .mc-id-platform-showcase__scene {
    transform: scale(var(--mc-platform-ui-scale));
    transform-origin: top center;
  }
}

@media (max-width: 640px) {
  .mc-id-platform-showcase {
    --mc-platform-ui-scale: 1;
    --mc-platform-mosaic-width: 680px;
    --mc-platform-mosaic-height: 536px;
    --mc-platform-mosaic-scale: min(1, calc((100vw - 2 * var(--mc-page-gutter, 16px) - 16px) / var(--mc-platform-mosaic-width)));
    min-height: 0;
    padding: 12px 8px 16px;
    margin-bottom: 32px;
  }

  .mc-id-platform-showcase__stage {
    height: auto;
    min-height: 0;
    overflow: visible;
  }

  .mc-id-platform-showcase__scene {
    transform: none;
  }

  .mc-id-platform-showcase__scene--hero {
    position: relative;
    inset: auto;
    display: flex;
    flex-direction: column;
    align-items: center;
  }

  .mc-id-platform-showcase__desktop {
    position: relative;
    left: auto;
    top: auto;
    width: min(100%, 520px);
    padding: 12px;
    transform: none;
    animation: none;
    margin: 0 auto;
  }

  .mc-id-platform-showcase__chrome {
    margin-bottom: 10px;
    gap: 6px 8px;
  }

  .mc-id-platform-showcase__brand {
    font-size: 1.0625rem;
  }

  .mc-id-platform-showcase__menu {
    font-size: 0.5rem;
    letter-spacing: 0.04em;
    line-height: 1.35;
  }

  .mc-id-platform-showcase__kicker {
    margin-bottom: 8px;
    font-size: 0.5625rem;
  }

  .mc-id-platform-showcase__tiles {
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 6px;
  }

  .mc-id-platform-showcase__tile {
    min-height: 72px;
    padding: 8px;
    gap: 6px;
  }

  .mc-id-platform-showcase__tile-label {
    font-size: 0.5rem;
    letter-spacing: 0.04em;
  }

  .mc-id-platform-showcase__swatches {
    gap: 4px;
  }

  .mc-id-platform-showcase__swatches i {
    height: 14px;
  }

  .mc-id-platform-showcase__logo-mark {
    font-size: 0.875rem;
  }

  .mc-id-platform-showcase__tile-photo {
    min-height: 36px;
  }

  .mc-id-platform-showcase__tile-mag {
    padding: 6px;
    font-size: 0.5rem;
    line-height: 1.3;
  }

  .mc-id-platform-showcase__drag-bundle {
    position: relative;
    right: auto;
    top: auto;
    width: min(100%, 132px);
    margin: 10px auto 0;
    opacity: 1;
    transform: none;
  }

  .mc-id-platform-showcase.is-outview .mc-id-platform-showcase__drag-bundle {
    animation-play-state: paused;
  }

  .mc-id-platform-showcase:not(.is-outview) .mc-id-platform-showcase__drag-bundle {
    animation: mc-platform-drag-bundle-mobile var(--mc-platform-cycle) cubic-bezier(0.45, 0, 0.55, 1) infinite;
  }

  .mc-id-platform-showcase__float-card {
    width: 100%;
    padding: 8px;
    gap: 5px;
    border-radius: 8px;
  }

  .mc-id-platform-showcase__float-title {
    font-size: 0.625rem;
    line-height: 1.2;
  }

  .mc-id-platform-showcase__float-media {
    height: 44px;
    border-radius: 4px;
  }

  .mc-id-platform-showcase__float-lines {
    height: 20px;
  }

  .mc-id-platform-showcase__cursor {
    display: none;
  }

  .mc-id-platform-showcase__tile-slot {
    display: none;
  }

  .mc-id-platform-showcase__tile-mag {
    animation: none;
    opacity: 0.88;
  }

  .mc-id-platform-showcase.is-outview .mc-id-platform-showcase__tile-mag {
    animation-play-state: paused;
  }

  .mc-id-platform-showcase:not(.is-outview) .mc-id-platform-showcase__tile-mag {
    animation: mc-platform-slot-fill var(--mc-platform-cycle) cubic-bezier(0.45, 0, 0.55, 1) infinite;
  }

  .mc-id-platform-showcase__scene--mosaic {
    position: relative;
    inset: auto;
    width: 100%;
    height: calc(var(--mc-platform-mosaic-height) * var(--mc-platform-mosaic-scale));
    margin-top: 0;
    overflow: hidden;
  }

  .mc-id-platform-showcase__mosaic {
    position: absolute;
    left: 50%;
    top: 0;
    width: var(--mc-platform-mosaic-width);
    min-height: var(--mc-platform-mosaic-height);
    height: var(--mc-platform-mosaic-height);
    padding: 16px;
    gap: 10px;
    transform: translateX(-50%) scale(var(--mc-platform-mosaic-scale));
    transform-origin: top center;
  }
}

/* Manifesto slide deck - scroll-driven reveal */
.mc-id-doc--manifesto {
  display: flex;
  flex-direction: column;
}

.mc-id-manifesto-scroll {
  --mc-manifesto-count: 5;
  --mc-manifesto-step-vh: 82vh;
  --mc-manifesto-active: 0;
  position: relative;
  height: calc(
    (var(--mc-manifesto-count) - 1) * var(--mc-manifesto-step-vh) +
    (100vh - var(--mc-nav-height) - 96px)
  );
  background:
    radial-gradient(circle at 18% 22%, rgba(0, 48, 222, 0.05), transparent 42%),
    radial-gradient(circle at 82% 78%, rgba(15, 23, 42, 0.04), transparent 38%),
    linear-gradient(
      180deg,
      rgba(247, 247, 244, 0.35) 0%,
      rgba(247, 247, 244, 0) 28%,
      rgba(247, 247, 244, 0) 72%,
      rgba(247, 247, 244, 0.28) 100%
    );
  transition: background 0.6s ease;
}

.mc-id-manifesto__stage {
  position: sticky;
  top: calc(var(--mc-nav-height) + 32px);
  display: grid;
  grid-template-columns: auto minmax(0, 1fr) auto;
  align-items: center;
  gap: 24px 32px;
  min-height: calc(100vh - var(--mc-nav-height) - 120px);
  padding: 48px 0 56px;
  box-sizing: border-box;
}

.mc-id-manifesto__nav {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 10px;
  padding-left: 8px;
  z-index: 2;
}

.mc-id-manifesto__nav-btn {
  display: grid;
  place-items: center;
  width: 36px;
  height: 36px;
  padding: 0;
  border: 1px solid rgba(15, 23, 42, 0.12);
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.88);
  color: #0f172a;
  cursor: pointer;
  transition: border-color 0.2s ease, background 0.2s ease, transform 0.2s ease, opacity 0.2s ease;
}

.mc-id-manifesto__nav-btn svg {
  width: 16px;
  height: 16px;
}

.mc-id-manifesto__nav-btn:hover:not(:disabled),
.mc-id-manifesto__nav-btn:focus-visible {
  border-color: var(--est-blue);
  background: #fff;
  transform: translateY(-1px);
  outline: none;
}

.mc-id-manifesto__nav-btn:disabled {
  opacity: 0.35;
  cursor: default;
}

.mc-id-manifesto__count {
  font-size: 0.6875rem;
  line-height: 1;
  letter-spacing: 0.06em;
  color: rgba(15, 23, 42, 0.55);
  font-variant-numeric: tabular-nums;
}

.mc-id-manifesto__viewport {
  position: relative;
  min-height: 320px;
  width: 100%;
}

.mc-id-manifesto__slide {
  --mc-manifesto-opacity: 0;
  --mc-manifesto-blur: 10px;
  --mc-manifesto-lift: 14px;
  --mc-manifesto-scale: 0.985;
  position: absolute;
  inset: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 24px 32px;
  opacity: var(--mc-manifesto-opacity);
  filter: blur(var(--mc-manifesto-blur));
  transform: translate3d(0, var(--mc-manifesto-lift), 0) scale(var(--mc-manifesto-scale));
  pointer-events: none;
  will-change: opacity, filter, transform;
}

.mc-id-manifesto__slide.is-active {
  pointer-events: auto;
}

.mc-id-manifesto__slide.is-active:not([style*="--mc-manifesto-opacity"]) {
  --mc-manifesto-opacity: 1;
  --mc-manifesto-blur: 0px;
  --mc-manifesto-lift: 0px;
  --mc-manifesto-scale: 1;
}

.mc-id-manifesto__text {
  margin: 0;
  width: min(100%, 920px);
  max-width: 920px;
  font-family: var(--font-display-vi);
  font-size: clamp(1.375rem, 2.35vw, 2rem);
  font-weight: 500;
  line-height: 1.24;
  letter-spacing: -0.025em;
  text-align: center;
}

.mc-id-manifesto__slide--emphasis .mc-id-manifesto__text {
  font-size: clamp(1.625rem, 2.85vw, 2.5rem);
  line-height: 1.18;
}

.mc-id-manifesto__dots {
  position: relative;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 12px;
  padding: 8px 10px 8px 0;
  z-index: 2;
}

.mc-id-manifesto__rail {
  position: absolute;
  top: 10px;
  bottom: 10px;
  right: 13px;
  width: 2px;
  border-radius: 999px;
  background: rgba(15, 23, 42, 0.1);
  overflow: hidden;
  pointer-events: none;
}

.mc-id-manifesto__rail-fill {
  position: absolute;
  left: 0;
  right: 0;
  bottom: 0;
  height: calc(var(--mc-manifesto-progress, 0) * 100%);
  background: linear-gradient(180deg, rgba(0, 48, 222, 0.35), var(--est-blue));
  border-radius: inherit;
  transition: height 0.12s linear;
}

.mc-id-manifesto__dot {
  position: relative;
  display: grid;
  place-items: center;
  width: 28px;
  height: 28px;
  padding: 0;
  border: none;
  background: transparent;
  cursor: pointer;
}

.mc-id-manifesto__dot-core {
  display: block;
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background: rgba(15, 23, 42, 0.18);
  transition: transform 0.28s ease, background 0.28s ease, width 0.28s ease, height 0.28s ease;
}

.mc-id-manifesto__dot.is-active .mc-id-manifesto__dot-core {
  width: 10px;
  height: 10px;
  background: var(--mc-ink);
  transform: scale(1.15);
  box-shadow: 0 0 0 4px rgba(0, 48, 222, 0.1);
}

.mc-id-manifesto__dot:hover .mc-id-manifesto__dot-core,
.mc-id-manifesto__dot:focus-visible .mc-id-manifesto__dot-core {
  background: rgba(0, 48, 222, 0.55);
  transform: scale(1.2);
}

.mc-id-manifesto__dot:focus-visible {
  outline: 2px solid var(--est-blue);
  outline-offset: 2px;
  border-radius: 999px;
}

.mc-id-manifesto__hint {
  position: absolute;
  left: 50%;
  bottom: 0;
  transform: translateX(-50%);
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 4px;
  color: rgba(15, 23, 42, 0.45);
  pointer-events: none;
  transition: opacity 0.35s ease, transform 0.35s ease;
}

.mc-id-manifesto__hint.is-hidden {
  opacity: 0;
  transform: translateX(-50%) translateY(8px);
}

.mc-id-manifesto__hint-text {
  font-size: 0.6875rem;
  letter-spacing: 0.04em;
}

.mc-id-manifesto__hint-icon {
  width: 16px;
  height: 16px;
  animation: mc-manifesto-hint-bob 1.6s ease-in-out infinite;
}

@keyframes mc-manifesto-hint-bob {
  0%, 100% { transform: translateY(0); opacity: 0.7; }
  50% { transform: translateY(4px); opacity: 1; }
}

@media (max-width: 960px) {
  .mc-id-manifesto-scroll {
    --mc-manifesto-step-vh: 72vh;
  }

  .mc-id-manifesto__stage {
    display: block;
    padding: 40px 40px 52px 44px;
  }

  .mc-id-manifesto__nav {
    position: absolute;
    left: 0;
    top: 50%;
    transform: translateY(-50%);
    padding-left: 0;
    gap: 8px;
    z-index: 3;
  }

  .mc-id-manifesto__nav-btn {
    width: 32px;
    height: 32px;
  }

  .mc-id-manifesto__count {
    font-size: 0.625rem;
  }

  .mc-id-manifesto__viewport {
    padding: 0 8px 0 4px;
  }

  .mc-id-manifesto__dots {
    position: absolute;
    right: 0;
    top: 50%;
    transform: translateY(-50%);
    padding-right: 0;
  }

  .mc-id-manifesto__text {
    width: min(100%, 680px);
    max-width: 680px;
    font-size: clamp(1.25rem, 3.2vw, 1.75rem);
  }

  .mc-id-manifesto__slide--emphasis .mc-id-manifesto__text {
    font-size: clamp(1.375rem, 3.6vw, 2rem);
  }
}

@media (max-width: 640px) {
  .mc-id-manifesto-scroll {
    --mc-manifesto-step-vh: 66vh;
    height: calc(
      (var(--mc-manifesto-count) - 1) * var(--mc-manifesto-step-vh) +
      (100vh - var(--mc-nav-height) - 72px)
    );
  }

  .mc-id-manifesto__stage {
    top: calc(var(--mc-nav-height) + 16px);
    min-height: calc(100vh - var(--mc-nav-height) - 88px);
    padding: 32px 0 48px;
  }

  .mc-id-manifesto__viewport {
    padding: 0 28px 0 36px;
  }

  .mc-id-manifesto__slide {
    padding: 16px 8px;
  }

  .mc-id-manifesto__text {
    width: 100%;
    max-width: none;
    font-size: clamp(1.125rem, 4.8vw, 1.5rem);
    line-height: 1.28;
  }

  .mc-id-manifesto__slide--emphasis .mc-id-manifesto__text {
    font-size: clamp(1.25rem, 5.2vw, 1.75rem);
  }

  .mc-id-manifesto__hint {
    bottom: -4px;
  }
}

@media (prefers-reduced-motion: reduce) {
  .mc-id-manifesto-scroll {
    height: auto;
    background: none;
  }

  .mc-id-manifesto__stage {
    position: relative;
    top: auto;
    display: block;
    min-height: 420px;
    padding: 32px 0;
  }

  .mc-id-manifesto__nav {
    position: static;
    transform: none;
    flex-direction: row;
    justify-content: center;
    margin-bottom: 20px;
    padding-left: 0;
  }

  .mc-id-manifesto__viewport {
    padding: 0 16px;
  }

  .mc-id-manifesto__dots {
    flex-direction: row;
    justify-content: center;
    margin-top: 24px;
    padding: 0;
  }

  .mc-id-manifesto__rail {
    display: none;
  }

  .mc-id-manifesto__hint,
  .mc-id-manifesto__hint-icon {
    animation: none;
    display: none;
  }

  .mc-id-manifesto__slide {
    filter: none;
    transform: none;
    transition: opacity 0.25s ease;
  }

  .mc-id-manifesto__rail-fill {
    transition: none;
  }
}

.mc-id-pillars-head {
  display: grid;
  grid-template-columns: minmax(120px, 0.42fr) minmax(0, 1fr);
  gap: 24px 40px;
  align-items: start;
  margin-bottom: 32px;
}

.mc-id-pillars-head__title {
  margin: 0;
  font-family: var(--font-display);
  font-size: clamp(2.5rem, 5vw, 4rem);
  font-weight: 500;
  line-height: 1.02;
  letter-spacing: -0.03em;
}

.mc-id-pillars-head__intro {
  margin: 0;
  padding-left: 40px;
  border-left: 1px solid rgba(15, 23, 42, 0.12);
  font-size: 1.0625rem;
  line-height: 1.7;
  color: var(--mc-ink-muted);
}

.mc-id-pillars-list {
  display: flex;
  flex-direction: column;
  gap: 48px;
  padding-top: 8px;
}

.mc-id-pillar {
  display: grid;
  grid-template-columns: 1fr;
  gap: 24px;
}

.mc-id-pillar__banner {
  min-height: clamp(200px, 32vw, 320px);
  padding: 48px 32px;
  border-radius: 6px;
  background: #eceae4;
  color: #111110;
  display: flex;
  align-items: center;
  justify-content: center;
}

.mc-id-pillar__headline {
  margin: 0;
  max-width: 16ch;
  font-family: var(--font-display);
  font-size: clamp(2rem, 4.5vw, 3.5rem);
  font-weight: 500;
  line-height: 1.08;
  letter-spacing: -0.03em;
  text-align: center;
  color: inherit;
}

.mc-id-pillar__body {
  margin: 0 0 0 auto;
  max-width: 42ch;
  width: min(100%, 520px);
  font-size: 1.0625rem;
  line-height: 1.7;
  color: var(--mc-ink-muted);
}

@media (max-width: 960px) {
  .mc-id-pillars-head {
    grid-template-columns: 1fr;
  }

  .mc-id-pillars-head__intro {
    padding-left: 0;
    border-left: none;
  }

  .mc-id-pillar__body {
    margin-left: 0;
    max-width: none;
    width: 100%;
  }
}

/* Product vision hub + framework story (Frameworks hub spec) */
.mc-id-fw-context {
  display: grid;
  grid-template-columns: minmax(0, 518px) minmax(0, 518px);
  gap: 30px;
  align-items: start;
  max-width: var(--mc-content-max);
}

.mc-id-fw-context__title {
  margin: 0 0 10px;
  max-width: 518px;
  font-family: var(--font-display-vi);
  font-size: clamp(2rem, 5.2vw, 4.5rem);
  font-weight: 300;
  line-height: 1;
  letter-spacing: -0.01em;
  color: #111110;
}

.mc-id-fw-context__intro {
  margin: 0 0 10px;
  max-width: 518px;
  padding-left: 28px;
  border-left: 1px solid rgba(17, 17, 16, 0.12);
  font-family: var(--font-display-vi);
  font-size: clamp(1.375rem, 3.2vw, 2.625rem);
  font-weight: 300;
  line-height: 1;
  letter-spacing: -0.01em;
  color: #111110;
}

.mc-id-doc__rule.mc-id-fw-context__rule {
  display: flex;
  align-items: center;
  width: 100%;
  max-width: var(--mc-content-max);
  height: 72px;
  min-height: 72px;
  margin: 32px 0 52px;
  padding: 16px 0;
  box-sizing: border-box;
  background: transparent;
}

.mc-id-doc__rule.mc-id-fw-context__rule::before {
  content: "";
  display: block;
  width: 100%;
  height: 1px;
  background: rgba(17, 17, 16, 0.12);
}

.mc-id-pv-hub__featured {
  max-width: var(--mc-content-max);
}

.mc-id-doc--pv-stories .mc-id-pv-stories__tabs {
  margin-bottom: 32px;
}

.mc-id-pv-stories__tabs {
  display: flex;
  flex-wrap: wrap;
  gap: 8px 24px;
  margin: 0 0 32px;
  max-width: var(--mc-content-max);
  border-bottom: 1px solid rgba(17, 17, 16, 0.1);
  padding-bottom: 12px;
}

.mc-id-pv-stories__tab {
  appearance: none;
  border: none;
  background: transparent;
  padding: 0 0 10px;
  margin: 0;
  font-family: var(--font-display-vi);
  font-size: clamp(1rem, 2.2vw, 1.375rem);
  font-weight: 300;
  line-height: 1.2;
  letter-spacing: -0.02em;
  color: rgba(17, 17, 16, 0.48);
  cursor: pointer;
  position: relative;
}

.mc-id-pv-stories__tab.is-active {
  color: #111110;
}

.mc-id-pv-stories__tab.is-active::after {
  content: "";
  position: absolute;
  left: 0;
  right: 0;
  bottom: -13px;
  height: 2px;
  background: #111110;
}

.mc-id-pv-stories__tab:focus-visible {
  outline: 2px solid #7c3aed;
  outline-offset: 4px;
}

.mc-id-pv-stories__panels {
  max-width: var(--mc-content-max);
}

.mc-id-pv-stories__panel {
  display: none;
}

.mc-id-pv-stories__panel.is-active {
  display: block;
}

.mc-id-fw-story__title {
  margin: 0 0 10px;
  max-width: var(--mc-content-max);
  font-family: var(--font-display-vi);
  font-size: clamp(1.875rem, 4vw, 4rem);
  font-weight: 300;
  line-height: 1;
  letter-spacing: -0.01em;
  color: #111110;
}

@media (min-width: 961px) {
  .mc-id-fw-context__title {
    font-size: 4.5rem;
    line-height: 4.5rem;
    letter-spacing: -0.72px;
  }

  .mc-id-fw-context__intro {
    font-size: 2.625rem;
    line-height: 2.625rem;
    letter-spacing: -0.42px;
  }

  .mc-id-fw-story__title {
    font-size: 4rem;
    line-height: 4rem;
    letter-spacing: -0.64px;
    margin: 0 0 10px;
  }

  .mc-id-fw-story__headline {
    font-size: 2.625rem;
    line-height: 2.625rem;
    letter-spacing: -0.42px;
  }
}

.mc-id-fw-canvas {
  position: relative;
  width: 100%;
  max-width: var(--mc-content-max);
  min-height: 600px;
  height: clamp(360px, 56vw, 600px);
  margin: 40px 0 52px;
  padding: 32px;
  border-radius: 8px;
  background: #eceae4;
  display: flex;
  align-items: center;
  justify-content: center;
  box-sizing: border-box;
  overflow: hidden;
}

.mc-id-fw-canvas--orbit {
  --mc-fw-orbit-cycle: 6s;
  --mc-orbit-r: 168px;
  --mc-orbit-r-large: 210px;
}

.mc-id-fw-orbit-stage {
  position: relative;
  width: min(100%, 520px);
  aspect-ratio: 1;
}

.mc-id-fw-orbit__swirl {
  position: absolute;
  inset: 0;
  pointer-events: none;
}

.mc-id-fw-canvas.is-outview .mc-id-fw-orbit__swirl,
.mc-id-fw-canvas.is-outview .mc-id-fw-orbit__cluster,
.mc-id-fw-canvas.is-outview .mc-id-fw-orbit__trail,
.mc-id-fw-canvas.is-outview .mc-id-fw-orbit,
.mc-id-fw-canvas.is-outview .mc-id-fw-orbit__vector {
  animation-play-state: paused;
}

.mc-id-fw-canvas--orbit:not(.is-outview):not(.is-reduced-motion) .mc-id-fw-orbit__swirl {
  animation: mc-fw-swirl-layer var(--mc-fw-orbit-cycle) cubic-bezier(0.45, 0, 0.55, 1) infinite;
}

@keyframes mc-fw-swirl-layer {
  0%, 6% { opacity: 1; }
  52% { opacity: 1; }
  58% { opacity: 0; }
  100% { opacity: 0; }
}

.mc-id-fw-orbit__cluster {
  position: absolute;
  top: 50%;
  left: 50%;
  width: 88px;
  height: 88px;
  margin: -44px 0 0 -44px;
  transform-origin: center center;
}

.mc-id-fw-canvas--orbit:not(.is-outview):not(.is-reduced-motion) .mc-id-fw-orbit__cluster {
  animation: mc-fw-cluster-orbit var(--mc-fw-orbit-cycle) cubic-bezier(0.45, 0, 0.55, 1) infinite;
}

.mc-id-fw-orbit__cluster--tl { --mc-cluster-a: 225deg; }
.mc-id-fw-orbit__cluster--tr { --mc-cluster-a: 315deg; width: 104px; height: 120px; margin: -60px 0 0 -52px; }
.mc-id-fw-orbit__cluster--bl { --mc-cluster-a: 135deg; width: 120px; height: 72px; margin: -36px 0 0 -60px; }
.mc-id-fw-orbit__cluster--br { --mc-cluster-a: 45deg; }

.mc-id-fw-orbit__cluster--tl { animation-delay: calc(var(--mc-fw-orbit-cycle) * -0.01); }
.mc-id-fw-orbit__cluster--tr { animation-delay: calc(var(--mc-fw-orbit-cycle) * -0.03); }
.mc-id-fw-orbit__cluster--bl { animation-delay: calc(var(--mc-fw-orbit-cycle) * -0.05); }
.mc-id-fw-orbit__cluster--br { animation-delay: calc(var(--mc-fw-orbit-cycle) * -0.07); }

@keyframes mc-fw-cluster-orbit {
  0% {
    transform:
      rotate(var(--mc-cluster-a))
      translateY(calc(-1 * var(--mc-orbit-r-large)))
      rotate(calc(-1 * var(--mc-cluster-a)))
      scale(1);
    opacity: 1;
  }
  45% {
    transform:
      rotate(calc(var(--mc-cluster-a) + 200deg))
      translateY(calc(-1 * var(--mc-orbit-r)))
      rotate(calc(-1 * var(--mc-cluster-a) - 200deg))
      scale(0.62);
    opacity: 0.92;
  }
  54% {
    transform:
      rotate(calc(var(--mc-cluster-a) + 250deg))
      translateY(calc(-1 * var(--mc-orbit-r)))
      rotate(calc(-1 * var(--mc-cluster-a) - 250deg))
      scale(0.35);
    opacity: 0;
  }
  100% {
    transform:
      rotate(calc(var(--mc-cluster-a) + 360deg))
      translateY(calc(-1 * var(--mc-orbit-r-large)))
      rotate(calc(-1 * var(--mc-cluster-a) - 360deg))
      scale(1);
    opacity: 0;
  }
}

.mc-id-fw-orbit__card {
  position: absolute;
  overflow: hidden;
  border-radius: 6px;
  background: #fff;
  box-shadow: 0 8px 24px rgba(15, 23, 42, 0.12);
  border: 1px solid rgba(15, 23, 42, 0.06);
}

.mc-id-fw-orbit__card--layer-0 {
  inset: 16px 12px -12px -10px;
  z-index: 0;
  opacity: 0.78;
  transform: rotate(8deg);
}

.mc-id-fw-orbit__card--layer-1 {
  inset: 10px -8px -10px 10px;
  z-index: 1;
  opacity: 0.88;
  transform: rotate(-6deg);
}

.mc-id-fw-orbit__card--layer-2 {
  inset: 0;
  z-index: 2;
}

.mc-id-fw-media-img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
  pointer-events: none;
  user-select: none;
}

.mc-id-fw-orbit__cluster--bl .mc-id-fw-orbit__card--layer-0 {
  inset: 8px -6px -8px 8px;
  transform: rotate(4deg);
}

.mc-id-fw-orbit__cluster--bl .mc-id-fw-orbit__card--layer-1 {
  inset: 0;
  transform: none;
}

/* Ghost trail bubbles along orbit path */
.mc-id-fw-orbit__trail {
  position: absolute;
  top: 50%;
  left: 50%;
  width: 32px;
  height: 32px;
  margin: -16px;
  border: 1px solid rgba(15, 23, 42, 0.14);
  border-radius: 50%;
  opacity: 0;
  transform:
    rotate(calc(var(--mc-trail-i) * 45deg))
    translateY(calc(-1 * var(--mc-orbit-r-large)));
}

.mc-id-fw-canvas--orbit:not(.is-outview):not(.is-reduced-motion) .mc-id-fw-orbit__trail {
  animation: mc-fw-orbit-trail var(--mc-fw-orbit-cycle) cubic-bezier(0.45, 0, 0.55, 1) infinite;
  animation-delay: calc(var(--mc-fw-orbit-cycle) * (-0.02 - var(--mc-trail-i) * 0.012));
}

@keyframes mc-fw-orbit-trail {
  0%, 12% {
    opacity: 0;
    transform:
      rotate(calc(var(--mc-trail-i) * 45deg))
      translateY(calc(-1 * var(--mc-orbit-r-large)))
      scale(0.85);
  }
  28% { opacity: 0.45; }
  48% {
    opacity: 0;
    transform:
      rotate(calc(var(--mc-trail-i) * 45deg + 220deg))
      translateY(calc(-1 * var(--mc-orbit-r)))
      scale(0.55);
  }
  100% { opacity: 0; }
}

/* Phase 2 - icon vector ring on circle */
.mc-id-fw-orbit {
  position: absolute;
  inset: 8%;
  opacity: 1;
  transform: none;
}

.mc-id-fw-orbit__vector {
  position: absolute;
  inset: 0;
  transform-origin: center center;
}

.mc-id-fw-canvas--orbit:not(.is-outview):not(.is-reduced-motion) .mc-id-fw-orbit__vector {
  animation: mc-fw-vector-cycle var(--mc-fw-orbit-cycle) cubic-bezier(0.45, 0, 0.55, 1) infinite;
}

@keyframes mc-fw-vector-cycle {
  0%, 48% {
    opacity: 0;
    transform: rotate(-40deg) scale(1.58);
  }
  54% {
    opacity: 1;
    transform: rotate(-8deg) scale(1.08);
  }
  88% {
    opacity: 1;
    transform: rotate(48deg) scale(1);
  }
  100% {
    opacity: 0;
    transform: rotate(72deg) scale(1.58);
  }
}

.mc-id-fw-canvas--orbit.is-reduced-motion .mc-id-fw-orbit__swirl {
  display: none;
}

.mc-id-fw-canvas--orbit.is-reduced-motion .mc-id-fw-orbit {
  position: relative;
  inset: auto;
  width: min(100%, 420px);
  aspect-ratio: 1;
  margin: 0 auto;
  opacity: 1;
  transform: none;
}

.mc-id-fw-canvas--orbit.is-reduced-motion .mc-id-fw-orbit__vector {
  opacity: 1;
  transform: none;
  animation: none;
}
  .mc-id-fw-canvas--orbit {
    --mc-orbit-r: 118px;
    --mc-orbit-r-large: 148px;
  }

  .mc-id-fw-orbit-stage {
    width: min(100%, 320px);
  }
}

.mc-id-fw-canvas__chip {
  position: absolute;
  left: 50%;
  bottom: 16px;
  transform: translateX(-50%);
  width: 36px;
  height: 36px;
  border-radius: 10px;
  border: 1px solid rgba(15, 23, 42, 0.1);
  background: var(--mc-surface);
  display: flex;
  align-items: center;
  justify-content: center;
  box-shadow: var(--mc-shadow-soft);
}

.mc-id-fw-canvas__progress {
  position: absolute;
  left: 20px;
  right: 20px;
  bottom: 12px;
  height: 3px;
  border-radius: 999px;
  background: rgba(15, 23, 42, 0.1);
  overflow: hidden;
  z-index: 6;
  pointer-events: none;
}

.mc-id-fw-canvas__progress-fill {
  display: block;
  height: 100%;
  width: calc(var(--mc-fw-demo-progress, 0) * 100%);
  border-radius: inherit;
  background: linear-gradient(90deg, rgba(0, 48, 222, 0.55), var(--est-blue));
  transition: width 0.06s linear;
}

.mc-id-fw-orbit__ring {
  position: absolute;
  inset: 12%;
  border: 1px dashed rgba(15, 23, 42, 0.22);
  border-radius: 50%;
}

.mc-id-fw-orbit__node {
  position: absolute;
  top: 50%;
  left: 50%;
  width: 40px;
  height: 40px;
  margin: -20px;
  border-radius: 50%;
  overflow: hidden;
  background: var(--mc-surface);
  border: 1px solid rgba(15, 23, 42, 0.1);
  box-shadow: 0 4px 14px rgba(15, 23, 42, 0.08);
  transform:
    rotate(calc(var(--mc-orbit-i) * 45deg))
    translateY(calc(-1 * var(--mc-orbit-r)))
    rotate(calc(var(--mc-orbit-i) * -45deg));
}

.mc-id-fw-orbit__node .mc-id-fw-media-img {
  border-radius: 50%;
}

.mc-id-fw-orbit__node:has(.mc-id-fw-media-img)::after {
  content: none;
  display: none;
}

.mc-id-fw-orbit__node--image::after,
.mc-id-fw-orbit__node--file::after,
.mc-id-fw-orbit__node--photo::after,
.mc-id-fw-orbit__node--video::after,
.mc-id-fw-orbit__node--design::after,
.mc-id-fw-orbit__node--code::after,
.mc-id-fw-orbit__node--audio::after,
.mc-id-fw-orbit__node--grid::after {
  content: "";
  position: absolute;
  inset: 11px;
  border-radius: 3px;
  border: 1.5px solid rgba(15, 23, 42, 0.42);
  background: transparent;
}

.mc-id-fw-orbit__node--image::after {
  border-radius: 2px;
  box-shadow: inset 0 -5px 0 -2px rgba(15, 23, 42, 0.42);
}

.mc-id-fw-orbit__node--file::after {
  border-top-right-radius: 0;
  clip-path: polygon(0 0, 72% 0, 100% 28%, 100% 100%, 0 100%);
}

.mc-id-fw-orbit__node--photo::after {
  border-radius: 2px;
  background: radial-gradient(circle at 35% 35%, rgba(15, 23, 42, 0.42) 0 18%, transparent 19%), linear-gradient(rgba(15, 23, 42, 0.42), rgba(15, 23, 42, 0.42)) 50% 72% / 60% 2px no-repeat;
  border: none;
}

.mc-id-fw-orbit__node--video::after {
  border-radius: 3px;
  background: linear-gradient(rgba(15, 23, 42, 0.42), rgba(15, 23, 42, 0.42)) center / 8px 8px no-repeat;
  clip-path: polygon(38% 28%, 38% 72%, 72% 50%);
  border: 1.5px solid rgba(15, 23, 42, 0.42);
}

.mc-id-fw-orbit__node--design::after {
  inset: 10px;
  border: none;
  background:
    linear-gradient(rgba(15, 23, 42, 0.42), rgba(15, 23, 42, 0.42)) 4px 14px / 14px 1.5px no-repeat,
    linear-gradient(rgba(15, 23, 42, 0.42), rgba(15, 23, 42, 0.42)) 12px 4px / 1.5px 14px no-repeat;
  transform: rotate(-35deg);
}

.mc-id-fw-orbit__node--code::after {
  content: "</>";
  font-size: 0.5625rem;
  font-weight: 700;
  display: flex;
  align-items: center;
  justify-content: center;
  border: none;
  color: rgba(15, 23, 42, 0.55);
}

.mc-id-fw-orbit__node--audio::after {
  border: none;
  background: radial-gradient(circle at 50% 30%, rgba(15, 23, 42, 0.42) 0 22%, transparent 23%), linear-gradient(rgba(15, 23, 42, 0.42), rgba(15, 23, 42, 0.42)) 58% 62% / 8px 12px no-repeat;
}

.mc-id-fw-orbit__node--grid::after {
  border: none;
  background:
    linear-gradient(rgba(15, 23, 42, 0.42), rgba(15, 23, 42, 0.42)) 6px 6px / 6px 6px no-repeat,
    linear-gradient(rgba(15, 23, 42, 0.42), rgba(15, 23, 42, 0.42)) 16px 6px / 6px 6px no-repeat,
    linear-gradient(rgba(15, 23, 42, 0.42), rgba(15, 23, 42, 0.42)) 6px 16px / 6px 6px no-repeat,
    linear-gradient(rgba(15, 23, 42, 0.42), rgba(15, 23, 42, 0.42)) 16px 16px / 6px 6px no-repeat;
}

.mc-id-fw-canvas--connect {
  --mc-fw-connect-cycle: 12s;
  padding: 28px 24px 48px;
}

.mc-id-fw-connect {
  position: relative;
  width: min(100%, 720px);
  min-height: 360px;
  margin: 0 auto;
}

.mc-id-fw-connect__board {
  position: relative;
  display: grid;
  grid-template-columns: 1.15fr 0.85fr 0.55fr;
  grid-template-rows: auto auto;
  gap: 10px;
  padding: 18px;
  border-radius: 8px;
  background: #fff;
  box-shadow: 0 1px 0 rgba(15, 23, 42, 0.04);
}

.mc-id-fw-connect__item {
  position: relative;
  border: none;
  padding: 0;
  margin: 0;
  cursor: grab;
  touch-action: none;
  transform: translate(var(--mc-connect-x, 0px), var(--mc-connect-y, 0px));
  transition: box-shadow 0.18s ease, transform 0.06s linear;
  z-index: 1;
}

.mc-id-fw-connect__item.is-selected,
.mc-id-fw-connect__item.is-demo-selected {
  z-index: 4;
  box-shadow: 0 0 0 2px #7c3aed, 0 14px 28px rgba(15, 23, 42, 0.14);
}

.mc-id-fw-canvas--connect.is-demo-playing .mc-id-fw-connect__item {
  transition: box-shadow 0.22s ease, transform 0.12s linear;
}

.mc-id-fw-connect__item:focus-visible {
  outline: 2px solid #7c3aed;
  outline-offset: 2px;
}

.mc-id-fw-canvas--connect.is-dragging .mc-id-fw-connect__item {
  cursor: grabbing;
}

.mc-id-fw-canvas--connect.is-dragging .mc-id-fw-connect__item.is-selected {
  transition: none;
}

.mc-id-fw-connect__photos {
  grid-column: 1;
  grid-row: 1 / span 2;
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 8px;
}

.mc-id-fw-connect__photo {
  display: block;
  width: 100%;
  aspect-ratio: 4 / 5;
  border-radius: 6px;
  overflow: hidden;
  padding: 0;
  background: #f8f7f4;
}

.mc-id-fw-connect__photo .mc-id-fw-media-img {
  border-radius: 6px;
}

.mc-id-fw-connect__asset .mc-id-fw-media-img {
  border-radius: 6px;
}

.mc-id-fw-connect__asset {
  flex: 1;
  min-height: 72px;
  border-radius: 6px;
  overflow: hidden;
  background: #f8f7f4;
}

.mc-id-fw-connect__asset--mesh {
  min-height: 108px;
}

.mc-id-fw-connect__asset--disc,
.mc-id-fw-connect__asset--pipe {
  min-height: 68px;
}

.mc-id-fw-connect__type {
  grid-column: 2;
  grid-row: 1;
  padding: 16px;
  border-radius: 6px;
  background: #f8f7f4;
  display: flex;
  flex-direction: column;
  gap: 8px;
  font-family: var(--font-headline);
  font-weight: 700;
  font-size: 0.875rem;
  text-align: left;
}

.mc-id-fw-connect__type span:first-child { font-size: 1.125rem; }
.mc-id-fw-connect__type span:nth-child(2) { font-size: 1rem; opacity: 0.85; }
.mc-id-fw-connect__type span:nth-child(3) { font-size: 0.8125rem; opacity: 0.7; }

.mc-id-fw-connect__colors {
  grid-column: 2;
  grid-row: 2;
  margin: 0;
  padding: 12px 16px;
  list-style: none;
  border-radius: 6px;
  background: #f8f7f4;
  display: flex;
  flex-direction: column;
  gap: 8px;
}

.mc-id-fw-connect__colors li {
  display: flex;
  align-items: center;
  gap: 10px;
  font-size: 0.6875rem;
  font-weight: 600;
  letter-spacing: 0.02em;
  border-radius: 6px;
  padding: 2px 4px;
  margin: -2px -4px;
  transition: background 0.18s ease, transform 0.18s ease;
}

.mc-id-fw-connect__colors li.is-demo-active {
  background: rgba(124, 58, 237, 0.1);
  transform: translateX(3px);
}

.mc-id-fw-connect__colors li.is-demo-active .mc-id-fw-connect__swatch {
  box-shadow: 0 0 0 2px #7c3aed;
  transform: scale(1.08);
}

.mc-id-fw-connect__swatch {
  width: 18px;
  height: 18px;
  border-radius: 50%;
  flex-shrink: 0;
  transition: box-shadow 0.18s ease, transform 0.18s ease;
}

.mc-id-fw-connect__assets {
  grid-column: 3;
  grid-row: 1 / span 2;
  display: flex;
  flex-direction: column;
  gap: 8px;
}

.mc-id-fw-connect__asset {
  flex: 1;
  min-height: 72px;
  border-radius: 6px;
  overflow: hidden;
  background: #f8f7f4;
}

.mc-id-fw-connect__asset--mesh {
  min-height: 108px;
}

.mc-id-fw-connect__asset--disc,
.mc-id-fw-connect__asset--pipe {
  min-height: 68px;
}

.mc-id-fw-connect__select-box,
.mc-id-fw-connect__drag-ghost {
  position: absolute;
  left: 0;
  top: 0;
  border-radius: 6px;
  opacity: 0;
  pointer-events: none;
  z-index: 3;
}

.mc-id-fw-connect__select-box {
  border: 2px solid #7c3aed;
}

.mc-id-fw-connect__drag-ghost {
  border: 2px solid rgba(124, 58, 237, 0.72);
  background: rgba(255, 255, 255, 0.42);
  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);
  z-index: 2;
}

.mc-id-fw-connect__cmd-hint {
  position: absolute;
  left: 0;
  top: 0;
  padding: 4px 8px;
  border-radius: 6px;
  background: #fff;
  border: 1px solid rgba(15, 23, 42, 0.1);
  box-shadow: 0 4px 12px rgba(15, 23, 42, 0.08);
  font-size: 0.625rem;
  font-weight: 650;
  color: #111110;
  opacity: 0;
  pointer-events: none;
  z-index: 22;
  transform: translate(-12%, -120%);
}

.mc-id-fw-connect__cursor {
  position: absolute;
  left: var(--mc-cursor-x, 50%);
  top: var(--mc-cursor-y, 50%);
  display: inline-flex;
  align-items: center;
  gap: 6px;
  pointer-events: none;
  z-index: 21;
  opacity: var(--mc-cursor-o, 0);
  transform: translate(0, 0);
  transition: opacity 0.16s ease;
}

.mc-id-fw-canvas--connect.is-demo-playing .mc-id-fw-connect__cursor {
  animation: none;
  transition: opacity 0.16s ease;
}

.mc-id-fw-connect__cursor--a { z-index: 23; }
.mc-id-fw-connect__cursor--r { z-index: 22; }
.mc-id-fw-connect__cursor--e { z-index: 21; }

.mc-id-fw-connect__cursor-arrow {
  width: 0;
  height: 0;
  border-top: 5px solid transparent;
  border-bottom: 5px solid transparent;
  border-left: 9px solid #7c3aed;
  filter: drop-shadow(0 1px 2px rgba(124, 58, 237, 0.35));
}

.mc-id-fw-connect__cursor-label {
  padding: 4px 10px;
  border-radius: 999px;
  background: #7c3aed;
  color: #fff;
  font-size: 0.6875rem;
  font-weight: 650;
  box-shadow: 0 4px 12px rgba(124, 58, 237, 0.35);
  white-space: nowrap;
}

.mc-id-fw-canvas--connect.is-reduced-motion .mc-id-fw-connect__cursor,
.mc-id-fw-canvas--connect.is-reduced-motion .mc-id-fw-connect__select-box,
.mc-id-fw-canvas--connect.is-reduced-motion .mc-id-fw-connect__drag-ghost,
.mc-id-fw-canvas--connect.is-reduced-motion .mc-id-fw-connect__cmd-hint {
  display: none;
}

.mc-id-fw-canvas--agent {
  --mc-fw-agent-cycle: 9.5s;
  padding: 0;
  align-items: stretch;
}

.mc-id-fw-agent {
  position: relative;
  width: 100%;
  height: 100%;
  min-height: 0;
  flex: 1;
  margin: 0;
}

.mc-id-fw-agent__scene {
  position: absolute;
  inset: 0;
  display: flex;
  align-items: stretch;
  justify-content: stretch;
  opacity: 0;
  visibility: hidden;
  pointer-events: none;
  transition: opacity 0.45s ease, visibility 0.45s ease;
}

.mc-id-fw-agent__scene.is-active {
  opacity: 1;
  visibility: visible;
  pointer-events: auto;
}

.mc-id-fw-canvas--agent.is-outview .mc-id-fw-agent__scene {
  transition: none;
}

/* Scene 1 - metrics counter + chart */
.mc-id-fw-agent__metrics-card {
  position: relative;
  width: 100%;
  height: 100%;
  min-height: 100%;
  padding: 28px 32px 24px;
  border-radius: 8px;
  background: #f8f7f4;
  box-shadow: none;
  overflow: visible;
  display: flex;
  flex-direction: column;
  box-sizing: border-box;
}

.mc-id-fw-agent__metric {
  display: inline-flex;
  flex-direction: column;
  gap: 6px;
  padding: 14px 18px;
  border-radius: 6px;
  background: #eceae4;
}

.mc-id-fw-agent__metric-label {
  font-family: var(--font-display);
  font-size: 0.8125rem;
  font-weight: 400;
  line-height: 1.2;
  color: #111110;
}

.mc-id-fw-agent__metric-value {
  font-family: var(--font-display);
  font-size: clamp(2rem, 5vw, 3rem);
  font-weight: 500;
  line-height: 1;
  letter-spacing: -0.03em;
  color: #111110;
  font-variant-numeric: tabular-nums;
}

.mc-id-fw-agent__chart {
  display: block;
  width: 100%;
  flex: 1;
  min-height: 180px;
  height: auto;
  margin-top: 24px;
  overflow: visible;
}

.mc-id-fw-agent__chart-area {
  fill: url(#mc-agent-chart-fill);
}

.mc-id-fw-agent__chart-line {
  fill: none;
  stroke: #111110;
  stroke-width: 2;
  vector-effect: non-scaling-stroke;
  stroke-linecap: round;
  stroke-linejoin: round;
  stroke-dasharray: 480;
  stroke-dashoffset: 480;
}

.mc-id-fw-agent__scene--metrics.is-active.is-replay .mc-id-fw-agent__chart-line {
  animation: mc-agent-chart-draw 1.1s ease forwards;
}

.mc-id-fw-agent__scene--metrics.is-active.is-replay .mc-id-fw-agent__chart-dot {
  animation: mc-agent-chart-dot 0.35s ease forwards;
  opacity: 0;
}

.mc-id-fw-agent__scene--metrics.is-active.is-replay .mc-id-fw-agent__chart-dot:nth-child(4) { animation-delay: 0.2s; }
.mc-id-fw-agent__scene--metrics.is-active.is-replay .mc-id-fw-agent__chart-dot:nth-child(5) { animation-delay: 0.35s; }
.mc-id-fw-agent__scene--metrics.is-active.is-replay .mc-id-fw-agent__chart-dot:nth-child(6) { animation-delay: 0.5s; }
.mc-id-fw-agent__scene--metrics.is-active.is-replay .mc-id-fw-agent__chart-dot:nth-child(7) { animation-delay: 0.65s; }
.mc-id-fw-agent__scene--metrics.is-active.is-replay .mc-id-fw-agent__chart-dot:nth-child(8) { animation-delay: 0.8s; }
.mc-id-fw-agent__scene--metrics.is-active.is-replay .mc-id-fw-agent__chart-dot:nth-child(9) { animation-delay: 0.95s; }

@keyframes mc-agent-chart-draw {
  to { stroke-dashoffset: 0; }
}

@keyframes mc-agent-chart-dot {
  from { opacity: 0; }
  to { opacity: 1; }
}

.mc-id-fw-agent__chart-dot {
  fill: #fff;
  stroke: #111110;
  stroke-width: 2;
  vector-effect: non-scaling-stroke;
  shape-rendering: geometricPrecision;
}

/* Scene 2 - image pick */
.mc-id-fw-agent__scene--pick {
  align-items: center;
  justify-content: center;
  background: #f8f7f4;
  border-radius: 8px;
  overflow: hidden;
}

.mc-id-fw-agent__pick-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 16px;
  width: min(100%, 560px);
  padding: 32px;
  transition: opacity 0.35s ease, transform 0.35s ease;
}

.mc-id-fw-agent__pick-grid.is-hidden {
  opacity: 0;
  transform: scale(0.96);
  pointer-events: none;
}

.mc-id-fw-agent__pick-card {
  position: relative;
  aspect-ratio: 1;
  border-radius: 8px;
  overflow: hidden;
  background: #f8f7f4;
  box-shadow: 0 1px 0 rgba(15, 23, 42, 0.04);
  transition: background 0.35s ease, box-shadow 0.35s ease, transform 0.35s ease;
}

.mc-id-fw-agent__pick-card .mc-id-fw-media-img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.mc-id-fw-agent__pick-card--wrong.is-rejected {
  background: #f5d0cc;
}

.mc-id-fw-agent__pick-card--wrong.is-rejected .mc-id-fw-media-img {
  opacity: 0.72;
  filter: saturate(0.65) sepia(0.12);
}

.mc-id-fw-agent__pick-card--correct.is-approved {
  box-shadow: 0 0 0 2px var(--est-blue), 0 14px 28px rgba(15, 23, 42, 0.12);
  transform: translateY(-2px);
}

.mc-id-fw-agent__pick-badge {
  position: absolute;
  top: 50%;
  left: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  width: 52px;
  height: 52px;
  border-radius: 999px;
  opacity: 0;
  transform: translate(-50%, -50%) scale(0.82);
  transition: opacity 0.28s ease, transform 0.28s cubic-bezier(0.34, 1.4, 0.64, 1);
}

.mc-id-fw-agent__pick-badge--reject {
  background: #fff;
  color: #dc2626;
  box-shadow: 0 8px 24px rgba(15, 23, 42, 0.14);
}

.mc-id-fw-agent__pick-card--wrong.is-rejected .mc-id-fw-agent__pick-badge--reject {
  opacity: 1;
  transform: translate(-50%, -50%) scale(1);
}

.mc-id-fw-agent__pick-badge--approve {
  background: var(--est-blue);
  color: #fff;
  box-shadow: 0 8px 24px rgba(0, 48, 222, 0.32);
}

.mc-id-fw-agent__pick-card--correct.is-approved .mc-id-fw-agent__pick-badge--approve {
  opacity: 1;
  transform: translate(-50%, -50%) scale(1);
}

.mc-id-fw-agent__pick-single {
  position: absolute;
  inset: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 32px;
  box-sizing: border-box;
  opacity: 0;
  transform: scale(0.94);
  transition: opacity 0.4s ease, transform 0.4s cubic-bezier(0.34, 1.2, 0.64, 1);
  pointer-events: none;
}

.mc-id-fw-agent__pick-single.is-visible {
  opacity: 1;
  transform: scale(1);
  pointer-events: auto;
}

.mc-id-fw-agent__pick-single .mc-id-fw-media-img {
  display: block;
  width: auto;
  height: auto;
  max-width: min(100%, 360px);
  max-height: min(100%, 360px);
  aspect-ratio: 1;
  object-fit: contain;
  object-position: center;
  border-radius: 8px;
  box-shadow: 0 18px 40px rgba(15, 23, 42, 0.14);
}

/* Scene 3 - partner ticks */
.mc-id-fw-agent__partners-card {
  width: 100%;
  height: 100%;
  min-height: 100%;
  padding: 48px 32px;
  border-radius: 8px;
  background: #1a1a1a;
  display: flex;
  align-items: center;
  justify-content: center;
  position: relative;
  box-sizing: border-box;
}

.mc-id-fw-agent__partner {
  position: absolute;
  inset: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 12px;
  opacity: 0;
  visibility: hidden;
  transform: translateY(8px);
  transition: opacity 0.35s ease, visibility 0.35s ease, transform 0.35s ease;
}

.mc-id-fw-agent__partner.is-active {
  opacity: 1;
  visibility: visible;
  transform: translateY(0);
}

.mc-id-fw-agent__partner-label {
  margin: 0;
  font-family: var(--font-display);
  font-size: clamp(2rem, 5vw, 3.5rem);
  font-weight: 500;
  line-height: 1;
  letter-spacing: -0.03em;
  color: #fff;
}

.mc-id-fw-agent__partner-tick {
  width: 28px;
  height: 28px;
  border-radius: 6px;
  border: 2px solid rgba(255, 255, 255, 0.28);
  background: transparent;
  flex-shrink: 0;
  position: relative;
  transition: background 0.28s ease, border-color 0.28s ease, transform 0.28s cubic-bezier(0.34, 1.4, 0.64, 1);
}

.mc-id-fw-agent__partner.is-approved .mc-id-fw-agent__partner-tick {
  background: var(--est-blue);
  border-color: var(--est-blue);
  transform: scale(1.06);
}

.mc-id-fw-agent__partner.is-approved .mc-id-fw-agent__partner-tick::after {
  content: "";
  position: absolute;
  left: 7px;
  top: 4px;
  width: 7px;
  height: 12px;
  border: solid #fff;
  border-width: 0 2px 2px 0;
  transform: rotate(45deg);
}

.mc-id-fw-canvas--dark {
  background: #eceae4;
  padding: 24px;
}

.mc-id-fw-dark {
  position: relative;
  width: min(100%, 640px);
  min-height: clamp(240px, 36vw, 320px);
  padding: 48px 32px;
  border-radius: 8px;
  background: #1a1a1a;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 12px;
}

.mc-id-fw-dark__label {
  margin: 0;
  font-family: var(--font-display);
  font-size: clamp(2.5rem, 6vw, 4.5rem);
  font-weight: 500;
  line-height: 1;
  letter-spacing: -0.03em;
  color: #fff;
}

.mc-id-fw-dark__accent {
  width: 28px;
  height: 28px;
  border-radius: 6px;
  background: var(--est-blue);
  flex-shrink: 0;
}

.mc-id-fw-story__body {
  display: grid;
  grid-template-columns: minmax(0, 518px) minmax(0, 518px);
  gap: 30px;
  align-items: start;
  max-width: var(--mc-content-max);
  margin: 0;
  padding: 0;
}

.mc-id-fw-story__headline {
  margin: 0;
  max-width: 518px;
  grid-column: 1;
  font-family: var(--font-display-vi);
  font-size: clamp(1.375rem, 3.2vw, 2.625rem);
  font-weight: 300;
  line-height: 1;
  letter-spacing: -0.01em;
  color: #111110;
}

.mc-id-fw-story__copy {
  margin: 0;
  max-width: 518px;
  grid-column: 2;
  padding-left: 28px;
  border-left: 1px solid rgba(17, 17, 16, 0.12);
  font-family: var(--font-body);
  font-size: 18px;
  font-weight: 300;
  line-height: 23.4px;
  color: #111110;
}

.mc-id-fw-story__copy p {
  margin: 0 0 16px;
}

.mc-id-fw-story__copy p:last-child {
  margin-bottom: 0;
}

@media (max-width: 960px) {
  .mc-id-fw-context,
  .mc-id-fw-story__body {
    grid-template-columns: 1fr;
    gap: 24px;
  }

  .mc-id-doc__rule.mc-id-fw-context__rule {
    height: auto;
    min-height: 0;
    margin: 24px 0 32px;
    padding: 12px 0;
  }

  .mc-id-fw-context__intro,
  .mc-id-fw-story__copy {
    padding-left: 0;
    border-left: none;
  }

  .mc-id-fw-story__headline,
  .mc-id-fw-story__copy {
    max-width: none;
    grid-column: 1;
  }

  .mc-id-fw-canvas {
    min-height: clamp(280px, 48vw, 460px);
    height: auto;
    padding: 24px 14px;
    margin: 24px 0 28px;
  }

  .mc-id-fw-canvas--orbit .mc-id-fw-orbit-stage {
    transform: scale(0.9);
    transform-origin: center center;
  }

  .mc-id-fw-canvas--connect .mc-id-fw-connect__board {
    transform: scale(0.92);
    transform-origin: top center;
  }

  .mc-id-fw-canvas--agent .mc-id-fw-agent__scene {
    transform: scale(0.9);
    transform-origin: top center;
  }

  .mc-id-fw-agent__pick-grid {
    gap: 10px;
    width: min(100%, 360px);
    padding: 20px;
  }

  .mc-id-fw-agent__partners-card {
    padding: 36px 20px;
  }

  .mc-id-fw-agent__partner-label {
    font-size: clamp(1.75rem, 8vw, 2.5rem);
  }

  .mc-id-fw-connect__board {
    grid-template-columns: 1fr 1fr;
  }

  .mc-id-fw-connect__photos {
    grid-column: 1 / span 2;
    grid-row: 1;
  }

  .mc-id-fw-connect__type {
    grid-column: 1;
    grid-row: 2;
  }

  .mc-id-fw-connect__colors {
    grid-column: 2;
    grid-row: 2;
  }

  .mc-id-fw-connect__assets {
    grid-column: 1 / span 2;
    grid-row: 3;
    flex-direction: row;
  }

  .mc-id-fw-story__headline,
  .mc-id-fw-story__copy {
    margin-left: 0;
    max-width: none;
    width: 100%;
  }
}

@media (prefers-reduced-motion: reduce) {
  .mc-id-fw-canvas--orbit:not(.is-reduced-motion) .mc-id-fw-orbit__swirl,
  .mc-id-fw-canvas--orbit:not(.is-reduced-motion) .mc-id-fw-orbit__cluster,
  .mc-id-fw-canvas--orbit:not(.is-reduced-motion) .mc-id-fw-orbit__trail,
  .mc-id-fw-canvas--orbit:not(.is-reduced-motion) .mc-id-fw-orbit,
  .mc-id-fw-canvas--orbit:not(.is-reduced-motion) .mc-id-fw-orbit__vector {
    animation: none;
  }

  .mc-id-fw-canvas--connect .mc-id-fw-connect__cursor,
  .mc-id-fw-canvas--connect .mc-id-fw-connect__select-box,
  .mc-id-fw-canvas--connect .mc-id-fw-connect__drag-ghost,
  .mc-id-fw-canvas--connect .mc-id-fw-connect__cmd-hint {
    opacity: 0 !important;
  }

  .mc-id-fw-canvas--agent .mc-id-fw-agent__scene {
    transition: none;
  }

  .mc-id-fw-canvas__progress-fill {
    transition: none;
  }

  .mc-id-fw-agent__chart-line,
  .mc-id-fw-agent__chart-dot {
    animation: none !important;
    stroke-dashoffset: 0;
    opacity: 1;
  }
}

@media (max-width: 640px) {
  .mc-id-fw-canvas {
    min-height: clamp(220px, 62vw, 320px);
    padding: 14px 8px 18px;
    margin: 18px 0 22px;
  }

  .mc-id-fw-canvas--orbit .mc-id-fw-orbit-stage {
    transform: scale(0.78);
  }

  .mc-id-fw-canvas--connect .mc-id-fw-connect__board {
    transform: scale(0.82);
  }

  .mc-id-fw-canvas--agent .mc-id-fw-agent__scene {
    transform: scale(0.8);
  }

  .mc-id-fw-connect__board {
    grid-template-columns: 1fr;
  }

  .mc-id-fw-connect__photos,
  .mc-id-fw-connect__type,
  .mc-id-fw-connect__colors,
  .mc-id-fw-connect__assets {
    grid-column: 1;
    grid-row: auto;
  }

  .mc-id-fw-connect__cursor,
  .mc-id-fw-connect__select-box,
  .mc-id-fw-connect__cmd-hint {
    display: none;
  }
}

/* Brand vision hub + own every moment (Frameworks hub spec) */
.mc-id-bv-hub__head {
  display: grid;
  grid-template-columns: minmax(0, 518px) minmax(0, 518px);
  gap: 30px;
  align-items: start;
  max-width: var(--mc-content-max);
  margin-bottom: 0;
}

.mc-id-bv-hub__title {
  margin: 0 0 10px;
  max-width: 518px;
  font-family: var(--font-display-vi);
  font-size: clamp(2rem, 5.2vw, 4.5rem);
  font-weight: 300;
  line-height: 1;
  letter-spacing: -0.01em;
  color: #111110;
}

.mc-id-bv-hub__intro {
  margin: 0;
  max-width: 518px;
  padding-left: 28px;
  border-left: 1px solid rgba(17, 17, 16, 0.12);
}

.mc-id-bv-hub__tagline {
  margin: 0 0 var(--mc-bv-hub-tagline-body-gap);
  font-family: var(--font-display-vi);
  font-size: clamp(1.375rem, 3.2vw, 2.625rem);
  font-weight: 300;
  line-height: 1;
  letter-spacing: -0.01em;
  color: #111110;
}

.mc-id-bv-hub__body {
  margin: 0;
  font-family: var(--font-body);
  font-size: 18px;
  font-weight: 300;
  line-height: 23.4px;
  color: #111110;
}

.mc-id-bv-hub__rule.mc-id-fw-context__rule {
  height: var(--mc-doc-foot-divider-size);
  min-height: var(--mc-doc-foot-divider-size);
  margin-top: calc(
    var(--mc-bv-hub-to-story-gap) - var(--mc-doc-foot-divider-size) - var(--mc-bv-rule-to-story)
  );
  margin-bottom: var(--mc-bv-rule-to-story);
  padding: 0;
}

.mc-id-bv-hub__featured-title {
  margin: 0 0 10px;
  max-width: var(--mc-content-max);
  font-family: var(--font-display-vi);
  font-size: clamp(1.875rem, 4vw, 4rem);
  font-weight: 300;
  line-height: 1;
  letter-spacing: -0.01em;
  color: #111110;
}

.mc-id-bv-hub__cta {
  margin: 24px 0 0;
  text-align: center;
}

.mc-id-bv-hub__cta a {
  font-size: 0.875rem;
  font-weight: 650;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  color: var(--mc-ink);
}

.mc-id-fw-canvas--letters {
  align-items: stretch;
  padding: clamp(28px, 4vw, 44px);
  min-height: clamp(440px, 58vw, 600px);
}

.mc-id-fw-letter-stage {
  position: relative;
  flex: 1;
  width: 100%;
  min-height: clamp(400px, 52vw, 540px);
  display: flex;
  align-items: center;
  justify-content: center;
}

.mc-id-fw-letter-grid {
  --mc-letter-cell: clamp(40px, 4.8vw, 54px);
  --mc-letter-gap: clamp(10px, 1.3vw, 14px);
  --mc-letter-cols: 12;
  --mc-letter-rows: 8;
  width: calc(
    var(--mc-letter-cols) * var(--mc-letter-cell) +
    (var(--mc-letter-cols) - 1) * var(--mc-letter-gap)
  );
  height: calc(
    var(--mc-letter-rows) * var(--mc-letter-cell) +
    (var(--mc-letter-rows) - 1) * var(--mc-letter-gap)
  );
  display: grid;
  grid-template-columns: repeat(var(--mc-letter-cols), var(--mc-letter-cell));
  grid-template-rows: repeat(var(--mc-letter-rows), var(--mc-letter-cell));
  gap: var(--mc-letter-gap);
  margin: 0 auto;
  align-content: center;
  justify-content: center;
}

.mc-id-fw-letter-grid__cell {
  display: flex;
  align-items: center;
  justify-content: center;
  width: var(--mc-letter-cell);
  height: var(--mc-letter-cell);
  min-width: 0;
  min-height: 0;
  box-sizing: border-box;
  transition: transform 0.28s cubic-bezier(0.34, 1.2, 0.64, 1), color 0.22s ease, opacity 0.22s ease;
}

.mc-id-fw-letter-grid__cell--letter {
  font-family: var(--font-headline);
  font-size: clamp(1rem, 1.2vw, 1.3125rem);
  font-weight: 600;
  color: rgba(15, 23, 42, 0.55);
  letter-spacing: 0.02em;
  line-height: 1;
}

.mc-id-fw-letter-grid__cell--letter.is-letter-active.is-letter-tone-orange {
  color: #ea580c;
  transform: scale(1.12);
}

.mc-id-fw-letter-grid__cell--letter.is-letter-active.is-letter-tone-purple {
  color: #a855f7;
  transform: scale(1.12);
}

.mc-id-fw-letter-grid__cell--letter.is-letter-active.is-letter-tone-neutral {
  color: #111110;
  transform: scale(1.08);
}

.mc-id-fw-letter-grid__cell.is-letter-zoomed {
  opacity: 0.15;
}

.mc-id-fw-letter-grid__cell--dot {
  width: 14px;
  height: 14px;
  min-width: 14px;
  min-height: 14px;
  flex-shrink: 0;
  border-radius: 50%;
  background: var(--mc-dot, #253224);
  align-self: center;
  justify-self: center;
}

.mc-id-fw-letter-grid__cell--thumb {
  width: calc(var(--mc-letter-cell) - 6px);
  height: calc(var(--mc-letter-cell) - 6px);
  min-width: calc(var(--mc-letter-cell) - 6px);
  min-height: calc(var(--mc-letter-cell) - 6px);
  flex-shrink: 0;
  border-radius: 6px;
  overflow: hidden;
  background: #f8f7f4;
  box-shadow: 0 1px 0 rgba(15, 23, 42, 0.06);
}

.mc-id-fw-letter-grid__cell--thumb .mc-id-fw-media-img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  border-radius: 6px;
}

.mc-id-fw-letter-grid__cell--icon {
  width: calc(var(--mc-letter-cell) - 10px);
  height: calc(var(--mc-letter-cell) - 10px);
  min-width: calc(var(--mc-letter-cell) - 10px);
  min-height: calc(var(--mc-letter-cell) - 10px);
  flex-shrink: 0;
  border-radius: 50%;
  border: 1px solid rgba(15, 23, 42, 0.12);
  position: relative;
  background: rgba(15, 23, 42, 0.04);
}

.mc-id-fw-letter-grid__cell--icon::after {
  content: "";
  position: absolute;
  inset: 7px;
  border-radius: 3px;
  background:
    linear-gradient(#94a3b8, #94a3b8) 50% 35% / 60% 40% no-repeat,
    linear-gradient(#cbd5e1, #cbd5e1) 50% 72% / 44% 18% no-repeat;
}

.mc-id-fw-letter__query {
  position: absolute;
  padding: 8px 16px;
  border-radius: 999px;
  background: #fff;
  border: 1px solid rgba(15, 23, 42, 0.1);
  box-shadow: 0 10px 24px rgba(15, 23, 42, 0.1);
  font-family: var(--font-headline);
  font-size: 0.8125rem;
  font-weight: 650;
  letter-spacing: 0.08em;
  color: #111110;
  opacity: 0;
  pointer-events: none;
  z-index: 12;
  white-space: nowrap;
}

.mc-id-fw-letter__ring {
  position: absolute;
  border: 2.5px solid #ea580c;
  border-radius: 999px;
  opacity: 0;
  pointer-events: none;
  z-index: 10;
  box-sizing: border-box;
  transition: opacity 0.2s ease;
}

.mc-id-fw-letter__ring.is-vertical {
  border-radius: 999px;
}

.mc-id-fw-letter__ring.is-horizontal {
  border-radius: 999px;
}

.mc-id-fw-letter__ring.is-tone-purple {
  border-color: #a855f7;
}

.mc-id-fw-letter__ring.is-tone-neutral {
  border-color: rgba(15, 23, 42, 0.28);
}

.mc-id-fw-letter__format {
  position: absolute;
  transform: translateX(-50%);
  padding: 4px 10px;
  border-radius: 5px;
  background: #111110;
  color: #fff;
  font-size: 0.6875rem;
  font-weight: 700;
  letter-spacing: 0.06em;
  opacity: 0;
  pointer-events: none;
  z-index: 11;
}

.mc-id-fw-letter__zoom {
  position: absolute;
  opacity: 0;
  pointer-events: none;
  z-index: 14;
  transform-origin: center center;
  transition: opacity 0.24s ease, transform 0.24s ease;
}

.mc-id-fw-letter__zoom .mc-id-fw-letter-grid__cell {
  width: 100%;
  height: 100%;
  min-height: 0;
  min-width: 0;
}

.mc-id-fw-letter__zoom .mc-id-fw-letter-grid__cell--thumb {
  width: 100%;
  height: 100%;
  min-width: 0;
  min-height: 0;
  border-radius: 8px;
  box-shadow: 0 16px 36px rgba(15, 23, 42, 0.18);
  overflow: hidden;
}

.mc-id-fw-letter__zoom .mc-id-fw-letter-grid__cell--thumb .mc-id-fw-media-img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center;
}

.mc-id-fw-letter__zoom .mc-id-fw-letter-grid__cell--icon {
  width: 100%;
  height: 100%;
  min-width: 0;
  min-height: 0;
  border-radius: 8px;
}

.mc-id-fw-letter__formats {
  position: absolute;
  left: 50%;
  bottom: 12px;
  transform: translateX(-50%) translateY(8px);
  display: inline-flex;
  gap: 8px;
  padding: 8px 14px;
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.94);
  border: 1px solid rgba(15, 23, 42, 0.08);
  box-shadow: 0 8px 24px rgba(15, 23, 42, 0.08);
  opacity: 0;
  visibility: hidden;
  transition: opacity 0.25s ease, transform 0.25s ease, visibility 0.25s ease;
  z-index: 13;
}

.mc-id-fw-letter__formats.is-visible {
  opacity: 1;
  visibility: visible;
  transform: translateX(-50%) translateY(0);
}

.mc-id-fw-letter__formats span {
  padding: 6px 14px;
  border-radius: 999px;
  font-size: 0.75rem;
  font-weight: 650;
  letter-spacing: 0.04em;
  color: rgba(15, 23, 42, 0.45);
}

.mc-id-fw-letter__formats span.is-active {
  background: #111110;
  color: #fff;
}

.mc-id-fw-canvas--letters.is-outview .mc-id-fw-letter__ring,
.mc-id-fw-canvas--letters.is-outview .mc-id-fw-letter__query,
.mc-id-fw-canvas--letters.is-outview .mc-id-fw-letter__zoom {
  opacity: 0 !important;
}

.mc-id-doc--bv-story .mc-id-bv-hub__head {
  margin-bottom: 0;
}

.mc-id-bv-story__title {
  margin: 0 0 10px;
  max-width: var(--mc-content-max);
  font-family: var(--font-display-vi);
  font-size: clamp(1.875rem, 4vw, 4rem);
  font-weight: 300;
  line-height: 1;
  letter-spacing: -0.01em;
  color: #111110;
}

.mc-id-doc--bv-story .mc-id-bv-story__title {
  margin-top: 0;
}

.mc-id-bv-story__split {
  display: grid;
  grid-template-columns: minmax(0, 518px) minmax(0, 518px);
  gap: var(--mc-bv-story-split-gap);
  align-items: start;
  max-width: var(--mc-content-max);
  margin-top: 55px;
}

.mc-id-bv-story__aside {
  min-height: 1px;
}

.mc-id-bv-story__copy {
  max-width: 518px;
}

.mc-id-bv-story__sections {
  display: flex;
  flex-direction: column;
  gap: var(--mc-bv-section-stack-gap);
  margin: 0;
  max-width: 518px;
}

.mc-id-bv-section__title {
  margin: 0 0 var(--mc-bv-section-title-gap);
  font-family: var(--font-body);
  font-size: clamp(1.375rem, 2.4vw, var(--mc-bv-section-title-size));
  font-weight: 300;
  line-height: 1.1;
  letter-spacing: 0;
  color: #111110;
}

.mc-id-bv-section__body {
  margin: 0;
  font-family: var(--font-body);
  font-size: 18px;
  font-weight: 300;
  line-height: 23.4px;
  color: #111110;
}

.mc-id-bv-story__closing {
  margin: var(--mc-bv-section-stack-gap) 0 0;
  max-width: 518px;
  font-family: var(--font-body);
  font-size: clamp(1.375rem, 2.4vw, var(--mc-bv-section-title-size));
  font-weight: 300;
  line-height: 1.1;
  letter-spacing: 0;
  color: #111110;
}

@media (min-width: 961px) {
  .mc-id-bv-hub__title {
    font-size: 4.5rem;
    line-height: 4.5rem;
    letter-spacing: -0.72px;
  }

  .mc-id-bv-hub__tagline {
    font-size: 2.625rem;
    line-height: 2.625rem;
    letter-spacing: -0.42px;
  }

  .mc-id-bv-hub__featured-title,
  .mc-id-bv-story__title {
    font-size: 4rem;
    line-height: 4rem;
    letter-spacing: -0.64px;
    margin: 0 0 10px;
  }

  .mc-id-bv-section__title,
  .mc-id-bv-story__closing {
    font-size: var(--mc-bv-section-title-size);
    line-height: var(--mc-bv-section-title-lh);
  }
}

@media (max-width: 960px) {
  .mc-id-bv-hub__head {
    grid-template-columns: 1fr;
    gap: 24px;
  }

  .mc-id-bv-hub__intro {
    padding-left: 0;
    border-left: none;
  }

  .mc-id-bv-hub__tagline {
    margin-bottom: 24px;
  }

  .mc-id-bv-hub__rule.mc-id-fw-context__rule {
    height: auto;
    min-height: 0;
    margin: 32px 0 32px;
    padding: 12px 0;
  }

  .mc-id-fw-letter-grid {
    --mc-letter-cell: clamp(28px, 7.2vw, 38px);
    --mc-letter-gap: 7px;
  }

  .mc-id-fw-canvas--letters {
    min-height: clamp(360px, 88vw, 480px);
    padding: 20px 16px 24px;
  }

  .mc-id-fw-letter-stage {
    min-height: clamp(320px, 80vw, 420px);
  }

  .mc-id-bv-story__split {
    grid-template-columns: 1fr;
    gap: 0;
    margin-top: 40px;
  }

  .mc-id-bv-story__aside {
    display: none;
  }

  .mc-id-bv-story__copy,
  .mc-id-bv-story__sections,
  .mc-id-bv-story__closing {
    max-width: none;
  }
}

@media (max-width: 640px) {
  .mc-id-fw-letter-grid {
    --mc-letter-cell: clamp(20px, 5.8vw, 28px);
    --mc-letter-gap: 5px;
  }

  .mc-id-fw-canvas--letters {
    min-height: clamp(240px, 68vw, 340px);
    padding: 14px 8px 18px;
  }

  .mc-id-fw-letter-stage {
    min-height: clamp(200px, 58vw, 280px);
  }

  .mc-id-fw-letter__formats {
    flex-wrap: wrap;
    justify-content: center;
    max-width: 92%;
    gap: 6px;
    padding: 6px 10px;
  }

  .mc-id-fw-letter__formats span {
    padding: 5px 10px;
    font-size: 0.6875rem;
  }
}

@media (prefers-reduced-motion: reduce) {
  .mc-id-fw-canvas--letters .mc-id-fw-letter__ring,
  .mc-id-fw-canvas--letters .mc-id-fw-letter__query,
  .mc-id-fw-canvas--letters .mc-id-fw-letter__zoom,
  .mc-id-fw-canvas--letters .mc-id-fw-letter__formats {
    display: none;
  }
}

/* Culture - Our approach (Spec: 518+30 grid, title 72/300, body 18/300/23.4) */
.mc-id-culture-head {
  display: grid;
  grid-template-columns: minmax(0, 518px) minmax(0, 518px);
  gap: 30px;
  align-items: start;
  max-width: var(--mc-content-max);
  margin-bottom: var(--mc-culture-head-to-gallery);
}

.mc-id-culture-head__title {
  margin: 0 0 10px;
  max-width: 518px;
  font-family: var(--font-display-vi);
  font-size: clamp(2rem, 5.2vw, 4.5rem);
  font-weight: 300;
  line-height: 1;
  letter-spacing: -0.72px;
  color: #111110;
}

.mc-id-culture-head__body {
  margin: 0;
  max-width: 518px;
  padding-left: 28px;
  border-left: 1px solid rgba(17, 17, 16, 0.12);
}

.mc-id-culture-head__body p {
  margin: 0 0 23px;
  font-family: var(--font-body);
  font-size: 18px;
  font-weight: 300;
  line-height: 23.4px;
  color: #111110;
}

.mc-id-culture-head__body p:last-child {
  margin-bottom: 0;
}

.mc-id-culture-head__closing {
  margin-top: 0 !important;
  color: #111110 !important;
  font-weight: 500;
}

.mc-id-culture-gallery {
  max-width: var(--mc-content-max);
  margin-bottom: 32px;
  padding: 16px 0;
  box-sizing: border-box;
}

.mc-id-culture-gallery__row {
  display: flex;
  gap: var(--mc-culture-gallery-gap);
  align-items: stretch;
  min-height: calc(var(--mc-culture-gallery-height) - 32px);
}

.mc-id-culture-photo {
  position: relative;
  flex: var(--mc-photo-flex, 1) 1 0;
  min-width: 0;
  margin: 0;
  border-radius: 8px;
  overflow: hidden;
  min-height: clamp(200px, 28vw, 320px);
  background: #111110;
  opacity: 0;
  transform: translateY(14px);
  transition:
    opacity 0.55s ease,
    transform 0.55s cubic-bezier(0.22, 1, 0.36, 1);
  transition-delay: calc(var(--mc-photo-i, 0) * 90ms);
}

.mc-id-culture-gallery.is-ready .mc-id-culture-photo {
  opacity: 1;
  transform: translateY(0);
}

.mc-id-culture-scene {
  position: absolute;
  inset: 0;
  display: grid;
  place-items: center;
}

.mc-id-culture-scene--swatches {
  background: linear-gradient(155deg, #1a1a1a 0%, #2d2d2d 100%);
}

.mc-id-culture-scene__glow {
  position: absolute;
  inset: 10% 8%;
  border-radius: 50%;
  background: radial-gradient(circle, rgba(0, 48, 222, 0.22) 0%, transparent 68%);
  animation: mc-id-culture-glow 4.8s ease-in-out infinite;
}

.mc-id-culture-palette {
  position: relative;
  z-index: 1;
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 8px;
  width: min(62%, 120px);
  aspect-ratio: 1;
  padding: 10px;
  border-radius: 6px;
  background: rgba(255, 255, 255, 0.06);
  border: 1px solid rgba(255, 255, 255, 0.1);
  box-shadow: 0 16px 32px rgba(0, 0, 0, 0.28);
}

.mc-id-culture-swatch {
  border-radius: 4px;
  background: var(--swatch, #0030de);
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.18);
}

.mc-id-culture-scene__chip {
  position: absolute;
  left: 50%;
  bottom: 12%;
  z-index: 2;
  transform: translateX(-50%);
  width: 36px;
  height: 36px;
  display: grid;
  place-items: center;
  border-radius: 10px;
  background: rgba(255, 255, 255, 0.96);
  box-shadow: 0 8px 20px rgba(0, 0, 0, 0.22);
}

.mc-id-culture-scene__chip svg {
  display: block;
  width: 18px;
  height: 18px;
}

.mc-id-culture-scene--desk {
  background: linear-gradient(180deg, #f5f3ee 0%, #e8e4dc 100%);
}

.mc-id-culture-desk {
  position: relative;
  width: min(78%, 200px);
  padding: 10px;
  border-radius: 10px;
  background: #fff;
  border: 1px solid rgba(15, 23, 42, 0.1);
  box-shadow: 0 18px 36px rgba(15, 23, 42, 0.14);
}

.mc-id-culture-desk__chrome {
  display: block;
  height: 8px;
  margin-bottom: 8px;
  border-radius: 999px;
  background: linear-gradient(90deg, rgba(15, 23, 42, 0.08), rgba(15, 23, 42, 0.04));
}

.mc-id-culture-desk__grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 6px;
}

.mc-id-culture-desk__tile {
  aspect-ratio: 1;
  border-radius: 5px;
  overflow: hidden;
  border: 1px solid rgba(15, 23, 42, 0.08);
  background: #f8fafc;
}

.mc-id-culture-desk__tile--type {
  display: grid;
  place-items: center;
  font-family: var(--font-display-vi);
  font-size: clamp(1rem, 3vw, 1.35rem);
  font-weight: 500;
  color: #0f172a;
  background: linear-gradient(145deg, #fff, #eceae4);
}

.mc-id-culture-desk__tile--photo img {
  display: block;
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.mc-id-culture-desk__tile--mark {
  background:
    linear-gradient(145deg, var(--est-blue) 0 42%, transparent 42% 100%),
    linear-gradient(225deg, #0f172a 0 38%, transparent 38% 100%),
    #f2f1ed;
}

.mc-id-culture-desk__tile--palette {
  background:
    linear-gradient(135deg, #0030de 0 50%, #fceec8 50% 100%);
}

.mc-id-culture-desk__cursor {
  position: absolute;
  right: 14%;
  bottom: 18%;
  width: 14px;
  height: 14px;
  border-radius: 2px;
  background: var(--est-blue);
  transform: rotate(12deg);
  box-shadow: 0 0 0 2px #fff;
  animation: mc-id-culture-cursor 3.6s ease-in-out infinite;
}

.mc-id-culture-scene--hands {
  padding: 10px;
  background: linear-gradient(160deg, #0a0a0a 0%, #1a1a1a 100%);
}

.mc-id-culture-mosaic {
  position: relative;
  display: grid;
  grid-template-columns: 1fr 1fr;
  grid-template-rows: 1fr 1fr;
  gap: 6px;
  width: min(88%, 220px);
  height: min(88%, 220px);
}

.mc-id-culture-mosaic__cell {
  display: grid;
  place-items: center;
  border-radius: 6px;
  color: rgba(15, 23, 42, 0.72);
  animation: mc-id-culture-cell 4.2s ease-in-out infinite;
  animation-delay: calc(var(--mc-photo-i, 0) * 120ms);
}

.mc-id-culture-mosaic__cell svg {
  width: 42%;
  height: auto;
}

.mc-id-culture-mosaic__cell--listen {
  background: linear-gradient(145deg, #3d4b5e, #0f172a);
  color: var(--est-pahkla);
}

.mc-id-culture-mosaic__cell--collab {
  background: linear-gradient(145deg, #cee2fd, #8eb8f0);
}

.mc-id-culture-mosaic__cell--craft {
  background: linear-gradient(145deg, #fceec8, #e8d89a);
}

.mc-id-culture-mosaic__cell--grow {
  background: linear-gradient(145deg, #f2f1ed, #d8d4cc);
}

.mc-id-culture-mosaic__core {
  position: absolute;
  left: 50%;
  top: 50%;
  width: 14px;
  height: 14px;
  transform: translate(-50%, -50%);
  border-radius: 999px;
  background: var(--est-blue);
  box-shadow: 0 0 0 6px rgba(0, 48, 222, 0.18);
  animation: mc-id-culture-core 2.8s ease-in-out infinite;
}

.mc-id-culture-scene--abstract {
  background: linear-gradient(165deg, #e9b0e3 0%, #83b5de 42%, #253224 100%);
}

.mc-id-culture-bridge {
  display: flex;
  align-items: stretch;
  justify-content: center;
  gap: 10px;
  width: min(72%, 140px);
  height: min(78%, 260px);
}

.mc-id-culture-bridge__pillar {
  flex: 1;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: flex-start;
  gap: 8px;
  padding: 14px 8px;
  border-radius: 8px;
  background: rgba(255, 255, 255, 0.14);
  border: 1px solid rgba(255, 255, 255, 0.22);
  backdrop-filter: blur(6px);
}

.mc-id-culture-bridge__tag {
  font-size: 0.625rem;
  font-weight: 600;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  color: rgba(255, 255, 255, 0.92);
}

.mc-id-culture-bridge__dot {
  width: 10px;
  height: 10px;
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.75);
}

.mc-id-culture-bridge__bar {
  width: 70%;
  height: 6px;
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.55);
}

.mc-id-culture-bridge__orbit {
  position: relative;
  width: 18px;
  flex-shrink: 0;
  display: flex;
  align-items: center;
  justify-content: center;
}

.mc-id-culture-bridge__link {
  position: absolute;
  inset: 12% 50%;
  width: 2px;
  transform: translateX(-50%);
  background: repeating-linear-gradient(
    180deg,
    rgba(255, 255, 255, 0.9) 0 4px,
    transparent 4px 8px
  );
  animation: mc-id-culture-link 2.4s linear infinite;
}

.mc-id-culture-bridge__node {
  width: 10px;
  height: 10px;
  border-radius: 999px;
  background: #fff;
  box-shadow: 0 0 0 4px rgba(255, 255, 255, 0.25);
}

@keyframes mc-id-culture-glow {
  0%, 100% { opacity: 0.55; transform: scale(1); }
  50% { opacity: 1; transform: scale(1.06); }
}

@keyframes mc-id-culture-cursor {
  0%, 100% { transform: translate(0, 0) rotate(12deg); }
  45% { transform: translate(-18px, -22px) rotate(8deg); }
  70% { transform: translate(-8px, -10px) rotate(10deg); }
}

@keyframes mc-id-culture-core {
  0%, 100% { transform: translate(-50%, -50%) scale(1); }
  50% { transform: translate(-50%, -50%) scale(1.12); }
}

@keyframes mc-id-culture-cell {
  0%, 100% { transform: translateY(0); }
  50% { transform: translateY(-2px); }
}

@keyframes mc-id-culture-link {
  to { background-position: 0 12px; }
}

.mc-id-culture-photo--tall {
  min-height: clamp(260px, 38vw, 400px);
  align-self: stretch;
}

.mc-id-culture-photo--narrow {
  flex: 0.55 1 0;
  min-height: clamp(200px, 28vw, 320px);
}

@media (prefers-reduced-motion: reduce) {
  .mc-id-culture-photo {
    opacity: 1;
    transform: none;
    transition: none;
  }

  .mc-id-culture-scene__glow,
  .mc-id-culture-desk__cursor,
  .mc-id-culture-mosaic__core,
  .mc-id-culture-mosaic__cell,
  .mc-id-culture-bridge__link {
    animation: none;
  }
}

@media (max-width: 960px) {
  .mc-id-culture-head {
    grid-template-columns: 1fr;
    gap: 24px;
  }

  .mc-id-culture-head__body,
  .mc-id-culture-head__intro {
    padding-left: 0;
    border-left: none;
  }

  .mc-id-culture-gallery__row {
    flex-wrap: wrap;
    min-height: 0;
  }

  .mc-id-culture-photo,
  .mc-id-culture-photo--narrow,
  .mc-id-culture-photo--tall {
    flex: 1 1 calc(50% - 5px);
    min-height: 200px;
  }
}

@media (max-width: 640px) {
  .mc-id-culture-gallery__row {
    flex-direction: column;
  }

  .mc-id-culture-photo,
  .mc-id-culture-photo--narrow,
  .mc-id-culture-photo--tall {
    flex: 1 1 auto;
    width: 100%;
    min-height: 180px;
  }
}

/* Culture - Connecting our values */
.mc-id-culture-head--values {
  margin-bottom: var(--mc-culture-head-to-gallery);
}

.mc-id-culture-head__intro {
  margin: 0;
  max-width: 518px;
  padding-left: 28px;
  border-left: 1px solid rgba(17, 17, 16, 0.12);
  font-family: var(--font-body);
  font-size: 18px;
  font-weight: 300;
  line-height: 23.4px;
  color: #111110;
}

.mc-id-values-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 12px;
  margin-bottom: 32px;
}

.mc-id-value-card {
  position: relative;
  min-height: clamp(220px, 32vw, 320px);
  padding: 28px 32px;
  border: none;
  border-radius: 8px;
  background: #111;
  color: #fff;
  text-align: left;
  cursor: pointer;
  transition: background 0.3s ease, color 0.3s ease;
  overflow: hidden;
}

.mc-id-value-card:hover:not(.is-expanded) {
  background: #1a1a1a;
}

.mc-id-value-card.is-expanded {
  background: #eceae4;
  color: var(--mc-ink);
  cursor: default;
}

.mc-id-value-card__label {
  display: block;
  font-family: var(--font-display);
  font-size: clamp(1.5rem, 3vw, 2.25rem);
  font-weight: 500;
  line-height: 1.1;
  letter-spacing: -0.03em;
  max-width: 14ch;
  transition: opacity 0.25s ease;
}

.mc-id-value-card.is-expanded .mc-id-value-card__label {
  opacity: 0;
  pointer-events: none;
  position: absolute;
}

.mc-id-value-card__detail {
  display: none;
  flex-direction: column;
  gap: 16px;
  max-width: 42ch;
}

.mc-id-value-card.is-expanded .mc-id-value-card__detail {
  display: flex;
}

.mc-id-value-card__detail-title {
  font-family: var(--font-headline);
  font-size: clamp(1.0625rem, 2vw, 1.25rem);
  font-weight: 650;
  letter-spacing: -0.02em;
  line-height: 1.3;
}

.mc-id-value-card__detail-body {
  font-size: 1rem;
  line-height: 1.65;
  color: var(--mc-ink-muted);
}

@media (max-width: 960px) {
  .mc-id-culture-head__intro {
    padding-left: 0;
    border-left: none;
  }

  .mc-id-values-grid {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 640px) {
  .mc-id-value-card {
    min-height: 200px;
    padding: 24px;
  }
}

/* Culture - Connecting competencies */
.mc-id-doc--competencies-hub .mc-id-culture-head--values {
  max-width: var(--mc-content-max);
  margin-bottom: 0;
}

.mc-id-competencies-hub__rule.mc-id-fw-context__rule {
  max-width: var(--mc-content-max);
  height: var(--mc-doc-foot-divider-size);
  min-height: var(--mc-doc-foot-divider-size);
  margin: var(--mc-competencies-intro-to-rule) 0 var(--mc-competencies-after-divider);
  padding: 0;
}

.mc-id-competencies-list {
  max-width: var(--mc-content-max);
}

.mc-id-competency {
  margin-bottom: 0;
}

.mc-id-competency[id] {
  scroll-margin-top: calc(var(--mc-nav-height) + 56px);
}

.mc-id-competency--bordered {
  margin-top: var(--mc-competency-section-gap);
  padding-top: var(--mc-competencies-after-divider);
  border-top: 1px solid rgba(17, 17, 16, 0.12);
}

.mc-id-competency__title {
  margin: 0 0 var(--mc-competency-title-to-split);
  max-width: var(--mc-content-max);
  font-family: var(--font-display-vi);
  font-size: clamp(1.875rem, 4vw, var(--mc-competency-title-size));
  font-weight: 300;
  line-height: 1;
  letter-spacing: -0.64px;
  color: #111110;
}

.mc-id-competency__split {
  display: grid;
  grid-template-columns: minmax(0, 518px) minmax(0, 518px);
  gap: 30px;
  align-items: start;
}

.mc-id-competency-photo {
  position: relative;
  margin: 0;
  width: 100%;
  max-width: 518px;
  min-height: var(--mc-competency-photo-height);
  aspect-ratio: 518 / 345;
  border-radius: 8px;
  overflow: hidden;
}

.mc-id-competency-photo--ownership {
  background: linear-gradient(180deg, #f5f3ee 0%, #e8e4dc 100%);
}

.mc-id-competency-photo--ownership::before {
  content: "";
  position: absolute;
  inset: 12% 10% 18%;
  border-radius: 6px;
  background: linear-gradient(145deg, #fff 0%, #f0ede6 100%);
  box-shadow: 0 12px 32px rgba(15, 23, 42, 0.1);
}

.mc-id-competency-photo--ownership::after {
  content: "";
  position: absolute;
  bottom: 22%;
  left: 16%;
  width: 44%;
  height: 28%;
  border-radius: 4px;
  background: linear-gradient(160deg, #d4c4a8, #9a8870);
  opacity: 0.85;
}

.mc-id-competency-photo--execution {
  background: linear-gradient(180deg, #f8f6f2 0%, #eceae4 100%);
}

.mc-id-competency-photo--execution::before {
  content: "";
  position: absolute;
  top: 18%;
  left: 12%;
  width: 76%;
  height: 52%;
  border-radius: 8px;
  background: linear-gradient(160deg, #c8d0d8, #9aa4b0);
  box-shadow: 0 16px 40px rgba(15, 23, 42, 0.12);
}

.mc-id-competency-photo--execution::after {
  content: "";
  position: absolute;
  bottom: 16%;
  right: 14%;
  width: 32%;
  height: 8%;
  border-radius: 999px;
  background: #111;
  opacity: 0.75;
}

.mc-id-competency-photo--communication {
  background: linear-gradient(145deg, #e8dfd6 0%, #c9b8a8 100%);
}

.mc-id-competency-photo--communication::before,
.mc-id-competency-photo--communication::after {
  content: "";
  position: absolute;
  top: 22%;
  width: 38%;
  height: 58%;
  border-radius: 999px 999px 30% 30%;
}

.mc-id-competency-photo--communication::before {
  left: 10%;
  background: linear-gradient(180deg, #c45a32 0%, #8b3a22 100%);
}

.mc-id-competency-photo--communication::after {
  right: 12%;
  background: linear-gradient(180deg, #f5f3ee 0%, #ddd8d0 100%);
}

.mc-id-competency-photo--collaboration {
  background: linear-gradient(160deg, #eceae4 0%, #d4cec4 100%);
}

.mc-id-competency-photo--collaboration::before {
  content: "";
  position: absolute;
  inset: 20% 8% 14%;
  border-radius: 12px;
  background: linear-gradient(145deg, #f5f0e8, #ddd4c8);
  box-shadow: 0 12px 28px rgba(15, 23, 42, 0.08);
}

.mc-id-competency-photo--collaboration::after {
  content: "";
  position: absolute;
  top: 38%;
  left: 22%;
  width: 56%;
  height: 32%;
  border-radius: 6px;
  background: linear-gradient(160deg, #9aa4b0, #6b7580);
  opacity: 0.9;
}

.mc-id-competency-photo__chip {
  position: absolute;
  left: 50%;
  bottom: 14px;
  transform: translateX(-50%);
  width: 36px;
  height: 36px;
  border-radius: 10px;
  border: 1px solid rgba(15, 23, 42, 0.1);
  background: var(--mc-surface);
  display: flex;
  align-items: center;
  justify-content: center;
  box-shadow: var(--mc-shadow-soft);
  z-index: 1;
}

.mc-id-competency__body {
  margin: 0 0 23px;
  max-width: 518px;
  font-family: var(--font-body);
  font-size: 18px;
  font-weight: 300;
  line-height: 23.4px;
  color: #111110;
}

.mc-id-competency__skills-label {
  margin: 0 0 0;
  max-width: 518px;
  font-family: var(--font-body);
  font-size: 18px;
  font-weight: 300;
  line-height: 23.4px;
  color: #111110;
  text-align: left;
}

.mc-id-competency__skills-list {
  margin: 0;
  padding: 0;
  list-style: none;
  display: flex;
  flex-direction: column;
  gap: 0;
  max-width: 518px;
}

.mc-id-competency__skills-list li {
  font-family: var(--font-body);
  font-size: 18px;
  font-weight: 300;
  line-height: 23.4px;
  color: #111110;
  text-align: left;
}

.mc-id-competency__skills-list li::before {
  content: "\2022";
  margin-right: 10px;
  color: var(--mc-ink-soft);
}

@media (max-width: 960px) {
  .mc-id-competency__split {
    grid-template-columns: 1fr;
  }

  .mc-id-competency-photo {
    min-height: clamp(220px, 50vw, var(--mc-competency-photo-height));
    aspect-ratio: auto;
  }
}
