:root {
  --bg: #070908;
  --bg-soft: #0c0f0e;
  --panel: #101311;
  --panel-2: #151813;
  --text: #f3f0e8;
  --muted: #a8a79f;
  --subtle: #73766d;
  --line: rgba(235, 232, 221, .12);
  --line-bright: rgba(202, 225, 24, .28);
  --lime: #cae118;
  --lime-soft: rgba(202, 225, 24, .13);
  --max: 1280px;
  --serif: 'Instrument Serif', Georgia, serif;
  --sans: 'Inter', Arial, sans-serif;
}
* { box-sizing: border-box; }
html { scroll-behavior: smooth; background: var(--bg); }
body { margin: 0; color: var(--text); background: var(--bg); font-family: var(--sans); -webkit-font-smoothing: antialiased; }
a { color: inherit; text-decoration: none; }
img { max-width: 100%; display: block; }
p { margin: 0; }
.container { width: min(var(--max), calc(100% - clamp(42px, 8vw, 104px))); margin-inline: auto; }
.eyebrow { color: var(--lime); text-transform: uppercase; font-size: 11px; font-weight: 600; letter-spacing: .35em; margin: 0 0 24px; }
.button { display: inline-flex; align-items: center; justify-content: center; gap: 12px; min-height: 54px; border: 1px solid var(--lime); background: var(--lime); color: #090b08; padding: 17px 27px; letter-spacing: .13em; text-transform: uppercase; font-size: 11px; font-weight: 700; transition: transform .28s ease, box-shadow .28s ease, background .28s ease; }
.button::after { content: '→'; font-size: 16px; }
.button:hover { transform: translateY(-3px); box-shadow: 0 18px 52px rgba(202,225,24,.19); }

.site-header { position: fixed; inset: 0 0 auto; z-index: 80; display: flex; align-items: center; justify-content: space-between; padding: 28px clamp(21px,4vw,58px); transition: background .35s ease, padding .35s ease, border-color .35s ease; border-bottom: 1px solid transparent; }
.site-header.scrolled { padding-top: 17px; padding-bottom: 17px; background: rgba(7,9,8,.73); backdrop-filter: blur(18px); border-color: var(--line); }
.brand { height: 34px; display: flex; align-items: center; }
.brand-logo { height: 34px; width: auto; max-width: 172px; object-fit: contain; }
.brand-fallback { font-weight: 700; color: var(--text); letter-spacing: -.08em; font-size: 22px; }
.brand-fallback span { color: var(--lime); margin-left: 3px; font-size: 17px; }
.site-nav { display: flex; align-items: center; gap: clamp(18px,3.1vw,42px); color: rgba(243,240,232,.74); font-size: 12px; font-weight: 500; letter-spacing: .14em; text-transform: uppercase; }
.site-nav a:not(.nav-cta) { position: relative; }
.site-nav a:not(.nav-cta)::after { content: ''; position: absolute; bottom: -9px; left: 0; width: 100%; height: 1px; transform: scaleX(0); transform-origin: left; background: var(--lime); transition: transform .28s ease; }
.site-nav a:not(.nav-cta):hover::after { transform: scaleX(1); }
.nav-cta { border: 1px solid rgba(202,225,24,.42); padding: 14px 20px; color: var(--text); transition: background .28s ease; }
.nav-cta:hover { background: var(--lime-soft); }

/* Hero video: preserve scrub implementation */
.film { height: 410vh; position: relative; background: #050605; }
.film-sticky { position: sticky; top: 0; height: 100vh; overflow: hidden; }
.hero-video { width: 100%; height: 100%; position: absolute; inset: 0; object-fit: cover; }
.hero-shade { position: absolute; inset: 0; background: linear-gradient(90deg, rgba(5,7,6,.94) 0%, rgba(5,7,6,.76) 25%, rgba(5,7,6,.22) 54%, rgba(5,7,6,.16) 100%); }
.hero-noise { position: absolute; inset: 0; pointer-events: none; opacity: .11; mix-blend-mode: soft-light; background-image: radial-gradient(rgba(255,255,255,.32) .6px, transparent .6px); background-size: 4px 4px; }
.hero-content { position: relative; z-index: 2; height: 100%; display: flex; flex-direction: column; justify-content: center; padding-top: 80px; }
.copy-stage { position: relative; min-height: min(505px, 57vh); max-width: 515px; }
.hero-copy { position: absolute; inset: 0 auto auto 0; opacity: 0; transform: translateY(24px); pointer-events: none; transition: opacity .62s ease, transform .62s ease; }
.hero-copy.is-active { opacity: 1; transform: none; pointer-events: auto; }
.hero-copy h1, .hero-copy h2 { margin: 0 0 24px; font-family: var(--serif); font-weight: 400; font-size: clamp(54px, 6vw, 92px); line-height: .9; letter-spacing: -.055em; }
.hero-copy h2 span { color: var(--lime); }
.hero-copy p { max-width: 405px; color: var(--muted); line-height: 1.72; font-size: clamp(15px, 1.1vw, 17px); margin: 0 0 36px; }
.scroll-guide { position: absolute; z-index: 3; left: clamp(22px,4vw,58px); bottom: 34px; display: flex; align-items: center; gap: 15px; color: rgba(243,240,232,.48); text-transform: uppercase; letter-spacing: .28em; font-size: 10px; }
.track { width: 104px; height: 1px; background: rgba(243,240,232,.22); }
.track-fill { height: 100%; width: 0; background: var(--lime); }

.bridge { position: relative; padding: clamp(104px, 12vw, 188px) clamp(24px, 6vw, 80px) clamp(112px, 14vw, 205px); text-align: center; overflow: hidden; }
.bridge::before { content: ''; position: absolute; inset: auto 20% 0; height: 260px; background: radial-gradient(ellipse at center, rgba(202,225,24,.07), transparent 68%); pointer-events: none; }
.bridge-line { height: 1px; width: min(160px, 30vw); margin: 0 auto 48px; background: linear-gradient(90deg, transparent, var(--lime), transparent); }
.bridge h2 { max-width: 1060px; margin: 0 auto; font-family: var(--serif); font-size: clamp(41px, 5vw, 72px); line-height: 1.05; font-weight: 400; letter-spacing: -.045em; }
.bridge h2 span { color: var(--lime); }

.journey { height: 390vh; position: relative; }
.journey-sticky { height: 100vh; position: sticky; top: 0; overflow: hidden; border-block: 1px solid var(--line); }
.journey-media { position: absolute; inset: 0; }
.journey-media img { height: 100%; width: 100%; object-fit: cover; object-position: center; transform: scale(1.04); transition: transform .18s linear, filter .18s linear; }
.journey-media-shade { position: absolute; inset: 0; background: linear-gradient(90deg, rgba(7,9,8,.98) 0%, rgba(7,9,8,.94) 36%, rgba(7,9,8,.47) 53%, rgba(7,9,8,.20) 100%), linear-gradient(0deg, rgba(7,9,8,.36), transparent 45%); }
.journey-layout { height: 100%; position: relative; z-index: 2; display: grid; grid-template-columns: minmax(380px, .82fr) 1fr; gap: 68px; align-items: center; }
.journey-copy { max-width: 510px; }
.journey-stages { position: relative; min-height: 440px; }
.journey-stage { position: absolute; inset: 0; opacity: 0; transform: translateY(27px); pointer-events: none; transition: opacity .52s ease, transform .52s ease; }
.journey-stage.is-active { opacity: 1; transform: translateY(0); pointer-events: auto; }
.journey-stage .number { color: var(--lime); font-size: 12px; letter-spacing: .34em; font-weight: 600; margin-bottom: 32px; }
.journey-stage h2 { font-family: var(--serif); font-size: clamp(48px, 5vw, 73px); line-height: .96; letter-spacing: -.055em; font-weight: 400; margin: 0 0 28px; }
.journey-stage h2 span { color: var(--lime); }
.journey-stage .description { color: var(--muted); line-height: 1.72; max-width: 397px; margin-bottom: 36px; }
.journey-system { align-self: end; justify-self: end; margin-bottom: clamp(60px, 8vw, 92px); width: min(365px, 100%); padding: 22px; border: 1px solid rgba(243,240,232,.13); background: rgba(9,11,10,.55); backdrop-filter: blur(15px); }
.journey-system-label { font-size: 10px; color: var(--subtle); text-transform: uppercase; letter-spacing: .29em; margin-bottom: 18px; }
.pipeline { display: grid; gap: 8px; }
.pipeline-item { display: grid; grid-template-columns: 38px 1fr; grid-template-rows: auto auto; column-gap: 13px; padding: 15px 14px; border: 1px solid transparent; opacity: .45; transition: opacity .35s ease, border-color .35s ease, background .35s ease; }
.pipeline-item span { grid-row: 1 / 3; color: var(--lime); font-size: 11px; letter-spacing: .2em; margin-top: 4px; }
.pipeline-item strong { font-size: 13px; font-weight: 500; }
.pipeline-item small { color: var(--muted); font-size: 11px; margin-top: 5px; }
.pipeline-item.is-active, .pipeline-item.is-complete { opacity: 1; }
.pipeline-item.is-active { border-color: rgba(202,225,24,.35); background: rgba(202,225,24,.055); }
.journey-progress { position: absolute; z-index: 3; bottom: 0; left: 0; height: 2px; width: 100%; background: rgba(243,240,232,.08); }
.journey-progress div { height: 100%; width: 0; background: var(--lime); }

.section-heading { display: flex; justify-content: space-between; gap: clamp(42px, 8vw, 104px); align-items: end; margin-bottom: clamp(46px, 7vw, 78px); }
.section-heading h2 { font-family: var(--serif); font-size: clamp(42px, 4.6vw, 66px); font-weight: 400; line-height: .99; letter-spacing: -.048em; margin: 0; }
.lede { max-width: 430px; color: var(--muted); font-size: 15px; line-height: 1.78; }
.system { padding-block: clamp(100px, 11vw, 166px); }
.system-grid { display: grid; grid-template-columns: repeat(4, 1fr); border-left: 1px solid var(--line); }
.system-card { position: relative; min-height: 306px; padding: 31px 27px; border-top: 1px solid var(--line); border-right: 1px solid var(--line); border-bottom: 1px solid var(--line); transition: background .32s ease, border-color .32s ease; }
.system-card:hover { background: linear-gradient(180deg, rgba(202,225,24,.06), transparent); border-color: var(--line-bright); }
.card-index { color: var(--lime); font-size: 11px; letter-spacing: .25em; }
.system-card h3 { font-family: var(--serif); font-weight: 400; font-size: 31px; line-height: 1.08; margin: 86px 0 16px; }
.system-card p { color: var(--muted); font-size: 14px; line-height: 1.68; }

.work { padding-block: clamp(100px, 11vw, 162px); background: var(--bg-soft); border-block: 1px solid var(--line); }
.work-grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: clamp(20px, 2.2vw, 30px); }
.case { border: 1px solid var(--line); overflow: hidden; background: #0d100f; transition: transform .4s ease, border-color .4s ease; }
.case:hover { transform: translateY(-6px); border-color: rgba(202,225,24,.35); }
.case-image { overflow: hidden; aspect-ratio: 16 / 9.1; background: #0c0d0d; }
.case-image img { width: 100%; height: 100%; object-fit: cover; object-position: top center; transition: transform .65s cubic-bezier(.2,.7,.1,1); }
.case:hover .case-image img { transform: scale(1.035); }
.case-meta { padding: 25px 27px 29px; }
.case-meta span { color: var(--lime); font-size: 10px; text-transform: uppercase; letter-spacing: .27em; }
.case-meta h3 { margin: 12px 0 10px; font-family: var(--serif); font-size: 33px; font-weight: 400; }
.case-meta p { color: var(--muted); font-size: 14px; }

.founder { display: grid; grid-template-columns: .86fr 1.04fr; align-items: center; gap: clamp(48px, 8vw, 118px); padding-block: clamp(105px, 13vw, 192px); }
.founder-visual { position: relative; max-width: 470px; }
.founder-visual img { width: 100%; aspect-ratio: .88; object-fit: cover; object-position: center 28%; filter: saturate(.92) contrast(1.05); }
.founder-frame { position: absolute; inset: -18px 19px 19px -18px; border-left: 1px solid var(--lime); border-top: 1px solid rgba(202,225,24,.38); z-index: -1; }
.founder-copy h2 { font-family: var(--serif); font-size: clamp(56px, 5.5vw, 83px); line-height: .9; font-weight: 400; letter-spacing: -.052em; margin: 0 0 28px; }
.founder-role { display: flex; align-items: center; gap: 13px; color: var(--lime); font-size: 14px; margin-bottom: 28px; }
.founder-role i { width: 3px; height: 3px; background: var(--lime); border-radius: 50%; }
.founder-body { color: var(--muted); font-size: clamp(16px, 1.35vw, 18px); line-height: 1.8; max-width: 540px; margin-bottom: 34px; }
.founder-tags { display: flex; flex-wrap: wrap; gap: 10px; margin-bottom: 48px; }
.founder-tags span { border: 1px solid var(--line); padding: 11px 15px; color: rgba(243,240,232,.76); font-size: 12px; text-transform: uppercase; letter-spacing: .14em; }
.founder-sign { padding-top: 24px; border-top: 1px solid var(--line); font-size: 14px; color: var(--muted); letter-spacing: .13em; text-transform: uppercase; }
.founder-sign strong { color: var(--text); }

.contact { position: relative; overflow: hidden; text-align: center; padding: clamp(110px, 15vw, 210px) 24px clamp(104px, 14vw, 194px); border-top: 1px solid var(--line); }
.contact-glow { pointer-events: none; position: absolute; width: min(880px, 92vw); height: 400px; left: 50%; top: 50%; transform: translate(-50%, -20%); background: radial-gradient(ellipse, rgba(202,225,24,.11), transparent 64%); }
.contact > *:not(.contact-glow) { position: relative; z-index: 1; }
.contact h2 { font-family: var(--serif); font-size: clamp(56px, 7vw, 104px); font-weight: 400; line-height: .9; letter-spacing: -.055em; margin: 0 auto 30px; }
.contact > p:not(.eyebrow) { max-width: 585px; color: var(--muted); margin: 0 auto 47px; line-height: 1.75; }
.button-large { padding-inline: 34px; min-height: 61px; }
.site-footer { border-top: 1px solid var(--line); padding: 29px clamp(22px,4vw,58px); display: flex; justify-content: space-between; align-items: center; gap: 24px; color: var(--muted); font-size: 12px; text-transform: uppercase; letter-spacing: .17em; }
.site-footer .brand-fallback { font-size: 18px; }

.reveal { opacity: 0; transform: translateY(28px); transition: opacity .72s ease, transform .72s cubic-bezier(.16,1,.3,1); }
.reveal.is-visible { opacity: 1; transform: none; }

@media (max-width: 1024px) {
  .site-nav a:not(.nav-cta) { display: none; }
  .hero-video { object-position: 66% center; }
  .journey-layout { grid-template-columns: 1fr; align-items: center; }
  .journey-system { position: absolute; bottom: 22px; left: 0; right: 0; width: 100%; margin: 0; padding: 16px; }
  .pipeline { grid-template-columns: repeat(4, 1fr); gap: 5px; }
  .pipeline-item { display: block; padding: 10px; }
  .pipeline-item span, .pipeline-item strong, .pipeline-item small { display: block; }
  .pipeline-item strong { margin-top: 9px; font-size: 11px; }
  .pipeline-item small { display: none; }
  .journey-stages { min-height: 400px; }
  .journey-media-shade { background: linear-gradient(90deg, rgba(7,9,8,.98) 0%, rgba(7,9,8,.86) 51%, rgba(7,9,8,.34)); }
  .system-grid { grid-template-columns: repeat(2, 1fr); }
  .founder { grid-template-columns: 1fr; }
  .founder-visual { max-width: 520px; }
}
@media (max-width: 680px) {
  .container { width: calc(100% - 40px); }
  .site-header { padding: 21px 20px; }
  .brand-logo { height: 29px; }
  .brand-fallback { font-size: 19px; }
  .nav-cta { padding: 12px 13px; font-size: 10px; }
  .film { height: 340vh; }
  .hero-video { object-position: 70% center; }
  .hero-shade { background: linear-gradient(90deg, rgba(5,7,6,.9), rgba(5,7,6,.62)); }
  .hero-content { justify-content: flex-end; padding-bottom: 86px; }
  .copy-stage { min-height: 315px; }
  .hero-copy h1, .hero-copy h2 { font-size: clamp(47px, 15vw, 61px); }
  .scroll-guide { bottom: 24px; left: 20px; }
  .bridge { padding-block: 88px 112px; }
  .bridge h2 { font-size: clamp(37px, 11vw, 46px); }
  .journey { height: 360vh; }
  .journey-media img { object-position: 68% center; }
  .journey-media-shade { background: linear-gradient(0deg, rgba(7,9,8,.98) 0%, rgba(7,9,8,.95) 56%, rgba(7,9,8,.36) 100%); }
  .journey-layout { align-items: end; padding-bottom: 165px; }
  .journey-stages { min-height: 365px; }
  .journey-stage h2 { font-size: clamp(43px, 13vw, 55px); }
  .journey-system { bottom: 22px; }
  .pipeline-item strong { font-size: 10px; }
  .section-heading { display: block; margin-bottom: 43px; }
  .section-heading h2 { margin-bottom: 22px; }
  .system-grid, .work-grid { grid-template-columns: 1fr; }
  .system-grid { border-left: 0; }
  .system-card { min-height: 235px; border-left: 1px solid var(--line); }
  .system-card h3 { margin-top: 48px; }
  .founder { padding-block: 84px 110px; }
  .founder-copy h2 { font-size: clamp(49px, 15vw, 61px); }
  .founder-role { flex-wrap: wrap; }
  .contact h2 { font-size: clamp(49px, 15vw, 64px); }
  .site-footer { flex-direction: column; align-items: flex-start; line-height: 1.7; }
}

/* V3 — Segundo scroll cinematic + casos enlazados */
.journey { height: 550vh; }
.journey-media video { width: 100%; height: 100%; object-fit: cover; object-position: center; display: block; transform: scale(1.012); }
.journey-noise { position: absolute; inset: 0; opacity: .12; mix-blend-mode: soft-light; pointer-events: none; background-image: radial-gradient(rgba(255,255,255,.08) .5px, transparent .5px); background-size: 4px 4px; }
.journey-media-shade { background: linear-gradient(90deg, rgba(7,9,8,.96) 0%, rgba(7,9,8,.82) 31%, rgba(7,9,8,.2) 57%, rgba(7,9,8,.05) 100%), linear-gradient(0deg, rgba(7,9,8,.48), transparent 34%); }
.journey-layout { display: block; position: relative; height: 100%; }
.journey-copy { padding-top: clamp(132px, 17vh, 190px); max-width: 540px; }
.journey-stages { min-height: 400px; }
.journey-system { position: absolute; left: 0; right: 0; bottom: clamp(42px, 7vh, 74px); width: 100%; margin: 0; padding: 18px 21px 21px; background: rgba(7,9,8,.68); }
.pipeline { grid-template-columns: repeat(5, 1fr); gap: 9px; }
.pipeline-item { min-height: 74px; padding: 12px 12px; }
.pipeline-item strong { font-size: 12px; }
.pipeline-item small { font-size: 10px; }
.case { text-decoration: none; color: inherit; display: block; }
.case-meta b { display: inline-block; margin-top: 18px; color: var(--lime); font-size: 11px; letter-spacing: .19em; text-transform: uppercase; font-weight: 600; transition: transform .25s ease; }
.case:hover .case-meta b { transform: translateX(4px); }
.whatsapp-float { position: fixed; right: clamp(18px, 3vw, 34px); bottom: clamp(18px, 3vw, 30px); z-index: 20; display: inline-flex; align-items: center; gap: 10px; height: 54px; padding: 0 21px 0 17px; color: #10130f; font-size: 13px; font-weight: 700; text-decoration: none; background: var(--lime); border-radius: 999px; box-shadow: 0 14px 34px rgba(202,225,24,.21); transition: transform .24s ease, box-shadow .24s ease; }
.whatsapp-float:hover { transform: translateY(-3px); box-shadow: 0 18px 40px rgba(202,225,24,.29); }
.whatsapp-float svg { width: 22px; height: 22px; fill: currentColor; }
@media (max-width: 1024px) {
  .journey { height: 500vh; }
  .journey-copy { padding-top: 116px; }
  .journey-system { left: 0; bottom: 24px; width: 100%; padding: 13px; }
  .pipeline { grid-template-columns: repeat(5, minmax(108px, 1fr)); overflow-x: auto; scrollbar-width: none; }
  .pipeline::-webkit-scrollbar { display:none; }
  .journey-media-shade { background: linear-gradient(90deg, rgba(7,9,8,.98) 0%, rgba(7,9,8,.86) 42%, rgba(7,9,8,.25) 70%, rgba(7,9,8,.1)); }
}
@media (max-width: 680px) {
  .journey { height: 500vh; }
  .journey-media video { object-position: 68% center; }
  .journey-media-shade { background: linear-gradient(0deg, rgba(7,9,8,.99) 0%, rgba(7,9,8,.94) 55%, rgba(7,9,8,.24) 100%); }
  .journey-layout { display:flex; align-items:flex-end; padding-bottom: 151px; }
  .journey-copy { padding-top: 0; max-width: none; }
  .journey-stages { min-height: 343px; }
  .journey-system { bottom: 18px; }
  .pipeline-item { min-height: 64px; }
  .whatsapp-float span { display:none; }
  .whatsapp-float { width: 56px; height:56px; padding: 0; justify-content:center; }
}


/* V4 — Mobile-first rendering: exact image-sequence scrubbing, no video seeking on phones */
.mobile-sequence { display: none; position: absolute; inset: 0; width: 100%; height: 100%; object-fit: contain; background: #050605; }
@media (min-width: 821px) {
  /* Sweet spot: slightly shorter than the previous desktop scroll distance. */
  .film { height: 365vh; }
  .journey { height: 445vh; }
}
@media (max-width: 820px) {
  .film { height: 278svh; }
  .journey { height: 348svh; }
  .film-sticky, .journey-sticky { height: 100svh; }
  .hero-video, .journey-video { display: none !important; }
  .mobile-sequence { display: block; }
  .hero-mobile-sequence { background: #050605 url('assets/mobile/hero/frame-001.webp') center / contain no-repeat; }
  .journey-mobile-sequence { background: #050605 url('assets/mobile/journey/frame-001.webp') center / contain no-repeat; }

  .site-header { padding: 19px 18px; }
  .site-header.scrolled { padding-top: 13px; padding-bottom: 13px; }
  .brand-logo { height: 28px; max-width: 132px; }
  .nav-cta { min-height: 42px; padding: 12px 13px; font-size: 9px; letter-spacing: .12em; }

  .hero-shade {
    background:
      linear-gradient(0deg, rgba(5,7,6,1) 0%, rgba(5,7,6,.98) 34%, rgba(5,7,6,.75) 49%, rgba(5,7,6,.05) 68%, transparent 100%);
  }
  .hero-content { justify-content: flex-end; padding-top: 0; padding-bottom: calc(56px + env(safe-area-inset-bottom)); }
  .hero-content > .eyebrow { position: absolute; top: calc(78px + env(safe-area-inset-top)); left: 0; margin: 0; font-size: 9px; }
  .copy-stage { width: 100%; min-height: 252px; max-width: none; }
  .hero-copy h1, .hero-copy h2 { font-size: clamp(42px, 13.5vw, 53px); margin-bottom: 16px; line-height: .92; }
  .hero-copy p { max-width: 334px; font-size: 13.5px; line-height: 1.58; margin-bottom: 20px; }
  .hero-copy .button { min-height: 47px; padding: 13px 20px; font-size: 10px; }
  .scroll-guide { left: 20px; right: 20px; bottom: calc(16px + env(safe-area-inset-bottom)); }

  .bridge { padding-block: 80px 92px; padding-inline: 20px; }
  .bridge-line { margin-bottom: 34px; }
  .bridge .eyebrow { font-size: 9px; margin-bottom: 18px; }
  .bridge h2 { font-size: clamp(35px, 10.8vw, 45px); line-height: 1.02; }

  .journey-media-shade {
    background:
      linear-gradient(0deg, rgba(7,9,8,1) 0%, rgba(7,9,8,.99) 34%, rgba(7,9,8,.84) 47%, rgba(7,9,8,.10) 65%, transparent 100%);
  }
  .journey-layout { display: flex; align-items: flex-end; height: 100%; padding-bottom: calc(83px + env(safe-area-inset-bottom)); }
  .journey-copy { width: 100%; max-width: none; padding-top: 0; }
  .journey-copy > .eyebrow { font-size: 9px; margin-bottom: 14px; }
  .journey-stages { min-height: 240px; }
  .journey-stage .number { margin-bottom: 13px; font-size: 10px; }
  .journey-stage h2 { font-size: clamp(36px, 11.2vw, 46px); margin-bottom: 14px; line-height: .95; }
  .journey-stage .description { max-width: 342px; font-size: 13px; line-height: 1.55; margin-bottom: 17px; }
  .journey-stage .button { min-height: 45px; padding: 12px 17px; font-size: 9px; }
  .journey-system {
    left: 18px; right: 18px; width: auto; bottom: calc(13px + env(safe-area-inset-bottom));
    padding: 8px 9px 9px; background: rgba(7,9,8,.82); backdrop-filter: blur(14px);
  }
  .journey-system-label { display: none; }
  .pipeline { display: grid; grid-template-columns: repeat(5, 1fr); gap: 4px; overflow: visible; }
  .pipeline-item {
    display: block; min-width: 0; min-height: 48px; padding: 9px 5px 6px; text-align: center;
    border-top: 1px solid rgba(243,240,232,.12); border-right: 0; border-left: 0; border-bottom: 0;
  }
  .pipeline-item span { display: block; margin: 0; font-size: 10px; }
  .pipeline-item strong, .pipeline-item small { display: none; }
  .pipeline-item.is-active { border-top-color: var(--lime); background: rgba(202,225,24,.06); }
  .journey-progress { height: 1px; }

  .system, .work { padding-block: 82px; }
  .section-heading h2 { font-size: clamp(36px, 10vw, 46px); }
}
@media (prefers-reduced-motion: reduce) {
  .hero-copy, .journey-stage, .reveal, .case, .case-image img { transition-duration: .01ms !important; }
}
