/* V2.2 brand alignment overrides */
.hero {
  min-height: calc(100svh - 68px);
  background: var(--purple);
}
.hero::after { display: none; }
.hero::before,
.hero-bg-lines,
.hero-brand-lines,
.orbit-ring {
  display: none;
}
.hero-bg-lines {
  opacity: .34;
  background-position: 52% 58%;
  background-size: min(900px, 78vw) auto;
}
.hero h1 {
  font-size: clamp(2.15rem, 4.6vw, 5rem);
  line-height: .94;
  letter-spacing: 0;
}
.hero-lead { max-width: 610px; }
.hero-visual { min-height: 455px; }
.hero-orbit { width: min(560px, 43vw); }
.hero-brand-lines {
  position: absolute;
  z-index: 1;
  left: -12%;
  bottom: 14%;
  width: 116%;
  max-width: none;
  opacity: .34;
  mix-blend-mode: screen;
  pointer-events: none;
}
.route-line { display: none; }

.about-grid h2,
.routes-heading h2,
.steps-copy h2,
.signup-copy h2,
.community-section h2,
.faq-heading h2,
.route-panel-copy h2,
.route-panel-card h3 {
  letter-spacing: -.025em;
}
.about-grid h2 { font-size: clamp(1.85rem, 3.6vw, 3.9rem); line-height: 1; }
.steps-copy h2 { font-size: clamp(1.9rem, 3.3vw, 3.65rem); line-height: 1; }
.signup-copy h2 { font-size: clamp(2rem, 3.8vw, 4.15rem); line-height: .98; }
.community-section h2 { font-size: clamp(1.9rem, 3.2vw, 3.25rem); line-height: 1.02; }
.faq-heading h2 { font-size: clamp(2.4rem, 4vw, 4.4rem); line-height: .95; }

.balloon-motion {
  position: relative;
  min-height: clamp(420px, 44vw, 620px);
  display: grid;
  align-items: start;
  overflow: hidden;
  color: var(--white);
  background: #121212;
}
.balloon-motion::after {
  content: "";
  position: absolute;
  inset: 0;
  z-index: 1;
  background:
    linear-gradient(90deg, rgba(0,0,0,.54), rgba(0,0,0,.22) 48%, rgba(0,0,0,.5)),
    linear-gradient(180deg, rgba(0,0,0,.36), rgba(0,0,0,.18) 48%, rgba(0,0,0,.72));
  pointer-events: none;
}
.balloon-bg {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  max-width: none;
  object-fit: cover;
  filter: grayscale(1) brightness(.34) contrast(1.2);
}
.balloon-copy {
  position: relative;
  z-index: 3;
  width: min(var(--max), calc(100% - 40px));
  margin: 0 auto;
  padding-top: clamp(58px, 8vw, 106px);
  padding-bottom: clamp(210px, 18vw, 280px);
}
.balloon-copy .eyebrow { color: var(--white); }
.balloon-copy h2 {
  max-width: 720px;
  margin: 0;
  color: var(--white);
  font-size: clamp(1.85rem, 3.3vw, 3.65rem);
  line-height: 1;
  letter-spacing: 0;
}
.about-road-scene {
  --bike-x: -60vw;
  position: absolute;
  left: 0;
  right: 0;
  bottom: 0;
  z-index: 2;
  height: clamp(310px, 31vw, 430px);
  overflow: hidden;
  pointer-events: none;
  filter: grayscale(1) brightness(.72) contrast(1.16);
}
.about-road {
  position: absolute;
  left: 0;
  right: 0;
  bottom: 0;
  width: 100%;
  height: clamp(96px, 9vw, 132px);
  max-width: none;
  object-fit: cover;
}
.about-cyclist {
  position: absolute;
  left: 0;
  bottom: clamp(58px, 5.8vw, 84px);
  width: clamp(220px, 22vw, 340px);
  max-width: none;
  transform: translate3d(var(--bike-x), 0, 0);
  will-change: transform;
}

.routes-horizontal {
  background: var(--pink);
}
.route-panel-intro { background: var(--pink); }
.route-panel-card.capital { background: var(--purple); }
.route-panel-card.mercado { background: var(--pink); }
.route-panel-card.digital { background: var(--green); }
.route-panel-card.talento { background: var(--deep-purple); }
.route-panel::before {
  inset: 10% -18% auto;
  height: 14px;
  background: rgba(255,255,255,.72);
  box-shadow:
    0 74px 0 rgba(255,255,255,.52),
    0 148px 0 rgba(255,255,255,.36),
    0 222px 0 rgba(255,255,255,.24);
  transform: rotate(-10deg);
  animation: white-lines-motion 8s linear infinite alternate;
}
@keyframes white-lines-motion {
  from { transform: translateX(-4vw) rotate(-10deg); }
  to { transform: translateX(5vw) rotate(-10deg); }
}
.route-panel-copy h2 {
  font-size: clamp(2.2rem, 4.35vw, 4.9rem);
  line-height: .95;
}
.route-panel-copy p:not(.eyebrow) { max-width: 580px; }
.route-orbit { width: min(560px, 46vw); }
.route-panel-card h3 {
  max-width: 600px;
  font-size: clamp(2.1rem, 4.3vw, 4.7rem);
  line-height: .95;
}
.route-panel-card p { max-width: 500px; }
.route-panel-card::after {
  display: none;
}
.route-panel-card .logo-cluster {
  position: absolute;
  z-index: 3;
  right: clamp(42px, 9vw, 140px);
  top: 50%;
  width: min(390px, 31vw);
  transform: translateY(-50%);
  display: flex;
  align-content: center;
  justify-content: center;
  gap: 12px;
  padding: 24px;
  border: 1px solid rgba(255,255,255,.42);
  border-radius: 28px;
  background: rgba(255,255,255,.14);
  box-shadow: 0 24px 58px rgba(0,0,0,.14);
}
.route-panel-card .logo-cluster span {
  min-height: 52px;
  min-width: 112px;
  border-radius: 14px;
  background: var(--white);
  color: var(--deep-purple);
  box-shadow: 0 12px 28px rgba(0,0,0,.12);
  font-size: .9rem;
}

.train-motion {
  position: relative;
  height: clamp(150px, 17vw, 245px);
  overflow: hidden;
  background: #161616;
}
.train-motion img {
  position: absolute;
  top: 0;
  left: 50%;
  width: auto;
  height: 100%;
  max-width: none;
  transform: translateX(-50%);
  animation: train-advance 9s ease-in-out infinite alternate;
}
@keyframes train-advance {
  from { transform: translateX(calc(-50% - 90px)); }
  to { transform: translateX(calc(-50% + 90px)); }
}

.community-section {
  position: relative;
  overflow: hidden;
  min-height: 360px;
  background: var(--pink);
}
.community-brand-lines {
  position: absolute;
  left: 0;
  right: 0;
  bottom: 18px;
  width: 100%;
  max-width: none;
  opacity: .5;
  pointer-events: none;
}
.community-section > div,
.community-section .social-row { position: relative; z-index: 2; }

@media (max-width: 1040px) {
  .hero-orbit { width: min(560px, 82vw); }
  .route-panel-card .logo-cluster {
    position: relative;
    right: auto;
    top: auto;
    transform: none;
    width: min(520px, 100%);
    margin-top: 26px;
    justify-content: flex-start;
  }
}

@media (max-width: 760px) {
  .hero h1 { font-size: clamp(2.15rem, 10.5vw, 3.4rem); }
  .hero-visual { min-height: 250px; }
  .hero-brand-lines { display: none; }
  .route-orbit {
    width: min(360px, 90vw);
    margin-top: 22px;
  }
  .route-orbit span {
    min-height: 34px;
    padding-inline: 10px;
    font-size: .7rem;
  }
  .balloon-motion { min-height: 560px; }
  .balloon-copy {
    padding-top: 56px;
    padding-bottom: 260px;
  }
  .about-road-scene { height: 340px; }
  .about-road { height: 112px; }
  .about-cyclist {
    bottom: 58px;
    width: min(270px, 72vw);
  }
  .route-panel::before { opacity: .32; }
  .route-panel-card .logo-cluster { padding: 16px; }
  .route-panel-card .logo-cluster span { min-width: auto; min-height: 42px; }
  .train-motion { height: 150px; }
}

/* Real partner logos */
.route-panel-card .logo-cluster .partner-logo-chip {
  min-height: 64px;
  min-width: 132px;
  padding: 10px 14px;
}
.partner-logo-chip img {
  display: block;
  width: 100%;
  max-width: 128px;
  height: 44px;
  object-fit: contain;
}
.route-panel-card .logo-cluster .partner-logo-text {
  color: var(--deep-purple);
  font-weight: 900;
}
@media (max-width: 760px) {
  .route-panel-card .logo-cluster .partner-logo-chip { min-width: 96px; min-height: 46px; }
  .partner-logo-chip img { max-width: 100px; height: 30px; }
}

.route-scroll {
  position: relative;
  height: 320svh;
  background: #EFE9FF;
}
.route-scroll-sticky {
  position: sticky;
  top: 68px;
  height: calc(100svh - 68px);
  overflow: hidden;
  color: var(--ink);
  background: #EFE9FF;
}
.route-scroll-track {
  --route-x: 0px;
  display: flex;
  width: 200vw;
  height: 100%;
  transform: translate3d(var(--route-x), 0, 0);
  will-change: transform;
}
.route-screen {
  position: relative;
  flex: 0 0 100vw;
  min-width: 0;
  height: 100%;
  display: grid;
  align-items: center;
  overflow: hidden;
  background: #EFE9FF;
}
.route-ecosystem-panel {
  padding: clamp(38px, 5vw, 72px) clamp(20px, 6vw, 78px);
}
.ecosystem-layout {
  position: relative;
  z-index: 2;
  width: min(1220px, 100%);
  margin: 0 auto;
  display: grid;
  grid-template-columns: minmax(250px, .72fr) minmax(0, 1.28fr);
  align-items: center;
  gap: clamp(28px, 5vw, 72px);
}
.ecosystem-heading {
  max-width: 430px;
}
.small-label {
  margin-bottom: 12px;
  font-size: .8rem;
  font-weight: 900;
  letter-spacing: 0;
  text-transform: uppercase;
}
.ecosystem-heading .small-label {
  color: var(--purple);
}
.ecosystem-heading h2 {
  margin-bottom: 18px;
  color: var(--deep-purple);
  font-size: clamp(1.85rem, 3.2vw, 3.3rem);
  line-height: 1.02;
}
.ecosystem-heading p:not(.small-label) {
  margin: 0;
  color: rgba(39,31,32,.68);
  font-size: clamp(.98rem, 1.2vw, 1.1rem);
  line-height: 1.42;
}
.ecosystem-routes {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: clamp(18px, 2.6vw, 34px);
}
.ecosystem-route {
  min-height: clamp(340px, 42vh, 470px);
  display: grid;
  grid-template-rows: auto 1fr;
  gap: 18px;
  padding: clamp(22px, 2.6vw, 34px);
  border: 1px solid rgba(51,5,89,.1);
  border-radius: 8px;
  background: rgba(255,255,255,.76);
  box-shadow: 0 20px 48px rgba(39,31,32,.11);
  backdrop-filter: blur(12px);
}
.route-card-copy span {
  display: block;
  margin-bottom: 8px;
  color: var(--deep-purple);
  font-size: clamp(1.16rem, 1.6vw, 1.48rem);
  font-weight: 900;
  line-height: 1.05;
}
.route-card-copy p {
  max-width: 330px;
  margin: 0;
  color: rgba(39,31,32,.64);
  font-size: clamp(.86rem, 1vw, .98rem);
  line-height: 1.34;
}
.logo-wall {
  display: flex;
  align-content: center;
  align-items: center;
  flex-wrap: wrap;
  gap: 12px;
}
.logo-chip {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 50px;
  padding: 11px 16px;
  border: 1px solid rgba(51,5,89,.08);
  border-radius: 8px;
  color: #241b2b;
  background: var(--white);
  box-shadow: 0 10px 22px rgba(39,31,32,.09);
  font-size: clamp(.96rem, 1.18vw, 1.16rem);
  font-weight: 900;
  line-height: 1;
  text-align: center;
}
.logo-bci {
  color: var(--white);
  background: var(--purple);
}
.logo-blue { color: #125bcb; }
.logo-salco { color: var(--pink); }
.logo-walmart { color: #0071ce; }
.logo-microsoft { color: #111111; }
.logo-uc { color: #1683ff; }
.ecosystem-beams {
  position: absolute;
  inset: 4% 2%;
  z-index: 1;
  opacity: .74;
  pointer-events: none;
}
.ecosystem-beams svg {
  width: 100%;
  height: 100%;
}
.ecosystem-beam-base,
.ecosystem-beam-pulse {
  fill: none;
  stroke-linecap: round;
}
.ecosystem-beam-base {
  stroke: rgba(51,5,89,.14);
  stroke-width: 1.4;
}
.ecosystem-beam-pulse {
  stroke-width: 3;
  stroke-dasharray: .16 .84;
  stroke-dashoffset: 1;
  animation: ecosystem-beam-flow 9s linear infinite;
}
.ecosystem-beam-pulse:nth-of-type(4) { animation-delay: -2.6s; }
.ecosystem-beam-pulse:nth-of-type(6) { animation-delay: -5.2s; }
.ecosystem-beam-pulse:nth-of-type(8) { animation-delay: -7.1s; }
.beam-purple { stroke: var(--purple); }
.beam-pink { stroke: var(--pink); }
.beam-green { stroke: var(--green); }
.beam-yellow { stroke: #d3c700; }
@keyframes ecosystem-beam-flow {
  to { stroke-dashoffset: 0; }
}

@media (max-width: 1040px) {
  .route-ecosystem-panel {
    padding: 40px 20px;
  }
  .ecosystem-layout {
    grid-template-columns: 1fr;
    align-content: center;
    gap: 24px;
  }
  .ecosystem-heading {
    max-width: 720px;
  }
  .ecosystem-heading h2 {
    font-size: clamp(1.85rem, 5vw, 3rem);
  }
  .ecosystem-routes {
    grid-template-columns: 1fr 1fr;
  }
  .ecosystem-route {
    min-height: 300px;
  }
}

@media (max-width: 760px) {
  .route-scroll {
    height: 320svh;
  }
  .route-scroll-sticky {
    top: 58px;
    height: calc(100svh - 58px);
  }
  .ecosystem-heading p:not(.small-label) {
    font-size: .9rem;
  }
  .ecosystem-routes {
    grid-template-columns: 1fr;
    gap: 14px;
  }
  .ecosystem-route {
    min-height: 0;
    gap: 12px;
    padding: 18px;
  }
  .route-card-copy span {
    font-size: 1.12rem;
  }
  .route-card-copy p {
    font-size: .84rem;
  }
  .logo-wall {
    gap: 8px;
  }
  .logo-chip {
    min-height: 38px;
    padding: 9px 11px;
    font-size: .86rem;
  }
}

.community-section.community {
  position: relative;
  min-height: 620px;
  display: block;
  padding: clamp(88px, 8vw, 116px) 20px 0;
  overflow: hidden;
  color: var(--white);
  text-align: center;
  background: var(--pink);
}
.community-section.community h2 {
  position: relative;
  z-index: 2;
  max-width: 1040px;
  margin: 0 auto 42px;
  color: var(--white);
  font-size: clamp(2.05rem, 2.75vw, 2.65rem);
  line-height: 1.18;
  letter-spacing: 0;
}
.community-section.community .social-row {
  position: relative;
  z-index: 2;
  display: flex;
  justify-content: center;
  align-items: center;
  gap: clamp(70px, 9vw, 126px);
}
.community-section.community .social-row a {
  display: grid;
  place-items: center;
  width: 64px;
  height: 64px;
  color: var(--white);
  background: transparent;
  border-radius: 0;
  font-size: 1rem;
  box-shadow: none;
}
.community-section.community .social-row svg {
  width: 100%;
  height: 100%;
}
.community-lines {
  position: absolute;
  left: 0;
  bottom: 42px;
  width: 100%;
  max-width: none;
  pointer-events: none;
}

@media (max-width: 760px) {
  .community-section.community {
    min-height: 460px;
    padding-top: 78px;
  }
  .community-section.community h2 {
    font-size: clamp(1.55rem, 6.4vw, 2rem);
  }
  .community-section.community .social-row {
    gap: 34px;
  }
  .community-section.community .social-row a {
    width: 44px;
    height: 44px;
  }
  .community-lines {
    bottom: 42px;
    width: 160%;
    left: -42%;
  }
}

.faq-section.testimonial {
  color: var(--white);
  background: var(--purple);
}
.testimonial-heading {
  width: min(980px, 100%);
  margin: 0 auto 42px;
  text-align: center;
}
.testimonial-heading h2 {
  margin: 0;
  color: var(--white);
  font-size: clamp(2.4rem, 6vw, 5.6rem);
  line-height: .95;
  letter-spacing: 0;
}
.faq-section.testimonial .faq-list {
  width: min(980px, 100%);
  margin: 0 auto;
  display: grid;
  grid-template-columns: 1fr;
  gap: 16px;
}
.faq-section.testimonial .faq-list article {
  padding: clamp(20px, 2.5vw, 30px);
  border: 1px solid rgba(255,255,255,.34);
  border-radius: 8px;
  background: rgba(255,255,255,.1);
}
.faq-section.testimonial .faq-list h3 {
  margin: 0 0 10px;
  color: #00C168;
  font-size: clamp(1.08rem, 1.7vw, 1.45rem);
  line-height: 1.15;
}
.faq-section.testimonial .faq-list p {
  margin: 0;
  color: rgba(255,255,255,.88);
  font-size: clamp(.98rem, 1.22vw, 1.12rem);
  line-height: 1.42;
}

h1,
h2,
h3 {
  font-family: "Rubik", Arial, Helvetica, sans-serif;
  font-weight: 700;
  letter-spacing: 0 !important;
}
