.case-detail-hero {
  padding-top: 122px;
  padding-bottom: 58px;
}

.cd-crumbs {
  display: flex;
  align-items: center;
  gap: 14px;
  margin-bottom: clamp(30px, 5vw, 64px);
  font-family: var(--f-mono);
  font-size: 11px;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--ink-mute);
}

.cd-crumbs .dash {
  width: 18px;
  height: 1px;
  flex: 0 0 18px;
  background: var(--line-strong);
}

.cd-hero-grid {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(310px, 420px);
  gap: clamp(42px, 6vw, 92px);
  align-items: end;
}

.case-detail-hero--learning .cd-hero-grid {
  align-items: start;
}

.case-detail-hero--screen .cd-hero-grid {
  align-items: start;
}

.case-detail-hero--travel .cd-hero-grid {
  align-items: start;
}

.case-detail-hero--flexicar .cd-hero-grid {
  align-items: start;
}

.cd-hero-title {
  max-width: 10.5ch;
  margin-top: 22px;
  font-family: var(--f-display);
  font-size: clamp(60px, 8.4vw, 122px);
  line-height: 0.92;
  letter-spacing: -0.04em;
}

.case-detail-hero--broker .cd-hero-title {
  max-width: 13.4ch;
}

.cd-hero-title em {
  color: var(--brand);
  font-style: italic;
}

.cd-hero-lede {
  max-width: 68ch;
  margin-top: 28px;
  color: var(--ink-soft);
  font-size: clamp(18px, 1.4vw, 22px);
  line-height: 1.5;
}

.cd-hero-tags {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin-top: 28px;
}

.cd-hero-tags span,
.cd-info-card__num,
.cd-column-label,
.cd-list-card span,
.cd-flow-step span {
  font-family: var(--f-mono);
  font-size: 10px;
  letter-spacing: 0.11em;
  text-transform: uppercase;
}

.cd-hero-tags span {
  display: inline-flex;
  min-height: 30px;
  align-items: center;
  padding: 0 11px;
  border: 1px solid rgba(10, 18, 32, 0.1);
  border-radius: 6px;
  color: var(--ink-mute);
  background: rgba(255, 255, 255, 0.48);
}

.cd-hero-visual {
  position: relative;
  width: 100%;
}

.cd-hero-visual[data-cd-tilt-hero] {
  --cd-tilt-rx: 0deg;
  --cd-tilt-ry: 0deg;
  --cd-tilt-x: 0px;
  --cd-tilt-y: 0px;
  --cd-pointer-x: 50%;
  --cd-pointer-y: 50%;
  perspective: 1100px;
}

.case-detail-hero--learning .cd-hero-visual {
  margin-top: clamp(54px, 5vw, 82px);
}

.case-detail-hero--screen .cd-hero-visual {
  margin-top: clamp(42px, 4.2vw, 68px);
}

.case-detail-hero--broker .cd-hero-visual {
  margin-top: clamp(34px, 3.6vw, 60px);
}

.case-detail-hero--flexicar .cd-hero-visual {
  margin-top: 0;
}

.cd-logo-ticker {
  position: relative;
  z-index: 3;
  width: 100%;
  height: 38px;
  margin-bottom: 12px;
  overflow: hidden;
  border: 1px solid rgba(10, 18, 32, 0.08);
  border-radius: 8px;
  background: rgba(255, 255, 255, 0.66);
  box-shadow: 0 16px 44px rgba(10, 18, 32, 0.06);
}

.cd-logo-ticker::before,
.cd-logo-ticker::after {
  content: "";
  position: absolute;
  top: 0;
  bottom: 0;
  z-index: 2;
  width: 64px;
  pointer-events: none;
}

.cd-logo-ticker::before {
  left: 0;
  background: linear-gradient(90deg, #fbfaf7 0%, rgba(251, 250, 247, 0) 100%);
}

.cd-logo-ticker::after {
  right: 0;
  background: linear-gradient(270deg, #fbfaf7 0%, rgba(251, 250, 247, 0) 100%);
}

.cd-logo-ticker__track {
  display: flex;
  width: max-content;
  height: 100%;
  align-items: center;
  animation: cdLogoTicker 13s linear infinite;
}

.cd-hero-visual:hover .cd-logo-ticker__track,
.cd-hero-visual.is-visual-active .cd-logo-ticker__track {
  animation-duration: 8.5s;
}

.cd-logo-ticker__group {
  display: flex;
  height: 100%;
  align-items: center;
  gap: 30px;
  padding: 0 30px;
  flex: 0 0 auto;
}

.cd-logo-ticker__item {
  display: inline-flex;
  width: 92px;
  align-items: center;
  justify-content: center;
  flex: 0 0 auto;
}

.cd-logo-ticker__item img {
  display: block;
  width: auto;
  max-width: 82px;
  max-height: 18px;
  opacity: .86;
  filter: drop-shadow(0 8px 12px rgba(10, 18, 32, 0.08));
}

.cd-logo-ticker__item--asr img {
  max-width: 56px;
  max-height: 17px;
}

.cd-logo-ticker__item--wake img {
  max-width: 92px;
  max-height: 17px;
}

.cd-logo-ticker__item--acn img {
  max-width: 44px;
  max-height: 11px;
}

.cd-visual-card {
  position: relative;
  z-index: 1;
  overflow: hidden;
  display: grid;
  gap: 0;
  padding: 28px;
  border: 1px solid rgba(10, 18, 32, 0.1);
  border-radius: 8px;
  background: rgba(255, 255, 255, 0.62);
  box-shadow: 0 26px 76px rgba(10, 18, 32, 0.08);
}

.cd-hero-visual[data-cd-tilt-hero] .cd-visual-card {
  transform:
    translate3d(var(--cd-tilt-x), var(--cd-tilt-y), 0)
    rotateX(var(--cd-tilt-rx))
    rotateY(var(--cd-tilt-ry));
  transform-style: preserve-3d;
  transition: box-shadow .28s ease;
  will-change: transform;
}

.cd-hero-visual[data-cd-tilt-hero] .cd-visual-card::after {
  content: "";
  position: absolute;
  inset: 0;
  border-radius: inherit;
  background: radial-gradient(circle at var(--cd-pointer-x) var(--cd-pointer-y), rgba(255, 255, 255, 0.38), transparent 42%);
  opacity: .68;
  pointer-events: none;
  mix-blend-mode: screen;
}

.cd-hero-visual[data-cd-tilt-hero]:hover .cd-visual-card,
.cd-hero-visual[data-cd-tilt-hero].is-visual-active .cd-visual-card {
  box-shadow: 0 34px 86px rgba(10, 18, 32, 0.12);
}

.cd-visual-card--ski .cd-visual-logo {
  max-width: 158px;
  max-height: 58px;
}

.cd-visual-card--ski {
  overflow: visible;
}

.cd-visual-card--learning .cd-visual-logo {
  max-width: 146px;
  max-height: 44px;
}

.cd-visual-card--learning {
  overflow: visible;
}

.case-detail-hero--learning .cd-visual-card--learning {
  padding-top: 24px;
}

.cd-visual-card::before {
  content: "";
  position: absolute;
  inset: 0;
  background-image:
    linear-gradient(to right, rgba(29, 103, 108, 0.05) 1px, transparent 1px),
    linear-gradient(to bottom, rgba(29, 103, 108, 0.05) 1px, transparent 1px);
  background-size: 42px 42px;
  pointer-events: none;
}

.cd-visual-card > * {
  position: relative;
}

.cd-visual-logo {
  width: auto;
  max-width: 148px;
  max-height: 52px;
}

.cd-visual-photo {
  min-height: 244px;
  margin-top: 16px;
  display: grid;
  place-items: center;
  position: relative;
  isolation: isolate;
}

.cd-visual-photo--ski {
  min-height: 230px;
  margin-top: 10px;
}

.cd-visual-photo--learning {
  min-height: 284px;
  margin-top: 6px;
}

.cd-visual-circles {
  position: absolute;
  z-index: 0;
  width: min(82%, 270px);
  animation: cdPulse 4.8s ease-in-out infinite;
}

.cd-visual-arms {
  position: absolute;
  z-index: 1;
  width: min(138%, 382px);
  max-height: 360px;
  object-fit: contain;
  opacity: 0;
  transform: translateY(4px) rotate(-18deg) scale(.72);
  filter: drop-shadow(0 20px 28px rgba(10, 18, 32, 0.16));
  transition: opacity .48s ease, transform .72s cubic-bezier(.16,1,.3,1);
  pointer-events: none;
}

.cd-visual-person {
  position: relative;
  z-index: 6;
  width: min(70%, 202px);
  max-height: 248px;
  object-fit: contain;
  transform: translateY(6px);
  filter: drop-shadow(0 22px 30px rgba(10, 18, 32, 0.18));
  transition: transform .42s cubic-bezier(.2,.85,.25,1), filter .42s ease;
}

.cd-visual-person--ski {
  width: min(94%, 310px);
  max-height: 218px;
  transform: translateY(12px) rotate(-2deg);
  filter: drop-shadow(0 22px 28px rgba(10, 18, 32, 0.2));
}

.cd-visual-person--learning {
  width: min(118%, 452px);
  max-height: 318px;
  transform: translate(6px, 0);
  filter: drop-shadow(0 22px 30px rgba(10, 18, 32, 0.16));
}

.cd-visual-card--flexicar {
  overflow: hidden;
  padding-bottom: 214px;
}

.cd-visual-logo--flexicar {
  position: relative;
  z-index: 10;
  max-width: 142px;
  max-height: 42px;
}

.cd-visual-photo--flexicar {
  min-height: 244px;
  margin-top: 6px;
}

.cd-visual-photo--flexicar .cd-visual-circles {
  width: min(104%, 352px);
  transform: translateY(-6px);
  opacity: .86;
}

.cd-visual-person--flexicar {
  width: min(90%, 324px);
  max-height: 226px;
  transform: translate(0, -18px) scale(1);
  filter: drop-shadow(0 22px 30px rgba(10, 18, 32, 0.22));
}

.cd-flex-shields {
  position: absolute;
  inset: 0;
  z-index: 5;
  pointer-events: none;
}

.cd-flex-shield {
  position: absolute;
  width: var(--flex-shield-size, 58px);
  height: var(--flex-shield-size, 58px);
  background: url("assets/embedded-hero/escudo.png") center / contain no-repeat;
  opacity: 0;
  transform: translate3d(var(--flex-enter-x, 0), var(--flex-enter-y, 0), 0) rotate(var(--flex-rot, 0deg)) scale(.7);
  transition: opacity .34s ease, transform .52s cubic-bezier(.2,.85,.25,1);
  transition-delay: var(--flex-delay, 0s);
}

.cd-flex-shield svg {
  display: none;
}

.cd-flex-shield--1 { top: 12%; left: 18%; --flex-shield-size: 64px; --flex-enter-x: -28px; --flex-enter-y: -12px; --flex-rot: -10deg; --flex-delay: .00s; }
.cd-flex-shield--2 { top: 26%; right: 14%; --flex-shield-size: 56px; --flex-enter-x: 24px; --flex-enter-y: -10px; --flex-rot: 12deg; --flex-delay: .05s; }
.cd-flex-shield--3 { top: 46%; left: 10%; --flex-shield-size: 50px; --flex-enter-x: -24px; --flex-enter-y: 8px; --flex-rot: -7deg; --flex-delay: .10s; }
.cd-flex-shield--4 { top: 52%; right: 10%; --flex-shield-size: 54px; --flex-enter-x: 26px; --flex-enter-y: 6px; --flex-rot: 8deg; --flex-delay: .14s; }
.cd-flex-shield--5 { top: 66%; left: 24%; --flex-shield-size: 46px; --flex-enter-x: -18px; --flex-enter-y: 16px; --flex-rot: 10deg; --flex-delay: .18s; }
.cd-flex-shield--6 { top: 70%; right: 26%; --flex-shield-size: 48px; --flex-enter-x: 18px; --flex-enter-y: 14px; --flex-rot: -10deg; --flex-delay: .22s; }

.cd-visual-photo--learning .cd-visual-circles {
  width: min(138%, 520px);
  transform: translate(0, 18px);
  opacity: .82;
}

.cd-hero-visual:hover .cd-visual-person,
.cd-hero-visual.is-visual-active .cd-visual-person,
.cd-visual-card:hover .cd-visual-person {
  transform: translateY(2px) scale(1.04);
  filter: drop-shadow(0 28px 36px rgba(10, 18, 32, 0.24));
}

.cd-hero-visual:hover .cd-visual-person--ski,
.cd-hero-visual.is-visual-active .cd-visual-person--ski,
.cd-visual-card:hover .cd-visual-person--ski {
  transform: translateY(4px) rotate(-6deg) scale(1.05);
}

.cd-hero-visual:hover .cd-visual-person--learning,
.cd-hero-visual.is-visual-active .cd-visual-person--learning,
.cd-visual-card:hover .cd-visual-person--learning {
  transform: translate(6px, -6px) scale(1.035);
}

.cd-hero-visual:hover .cd-visual-person--flexicar,
.cd-hero-visual.is-visual-active .cd-visual-person--flexicar,
.cd-visual-card:hover .cd-visual-person--flexicar {
  transform: translate(0, -24px) scale(1.03);
}

.cd-hero-visual:hover .cd-flex-shield,
.cd-hero-visual.is-visual-active .cd-flex-shield,
.cd-visual-card:hover .cd-flex-shield {
  opacity: 1;
  transform: translate3d(0, 0, 0) rotate(var(--flex-rot, 0deg)) scale(1);
  animation: cdFlexShieldFloat 3.4s ease-in-out infinite;
}

.cd-hero-visual:hover .cd-flex-shield:nth-child(2n),
.cd-hero-visual.is-visual-active .cd-flex-shield:nth-child(2n),
.cd-visual-card:hover .cd-flex-shield:nth-child(2n) {
  animation-duration: 3.9s;
}

.cd-visual-card--broker {
  overflow: visible;
  background:
    radial-gradient(circle at 72% 30%, rgba(29, 219, 183, 0.14), transparent 34%),
    linear-gradient(180deg, rgba(255, 255, 255, .94), rgba(251, 250, 247, .8));
}

.cd-visual-logo--asr {
  position: relative;
  z-index: 10;
  max-width: 88px;
  max-height: 30px;
}

.cd-visual-photo--broker {
  min-height: 252px;
  margin-top: 14px;
}

.cd-visual-person--broker {
  width: min(116%, 354px);
  max-height: 250px;
  transform: translateY(2px) scale(1);
}

.cd-visual-photo--broker .cd-visual-circles {
  width: min(126%, 368px);
  opacity: .8;
}

.cd-hero-visual:hover .cd-visual-person--broker,
.cd-hero-visual.is-visual-active .cd-visual-person--broker,
.cd-visual-card:hover .cd-visual-person--broker {
  transform: translateY(-5px) scale(1.045);
}

.cd-hero-visual:hover .cd-visual-arms,
.cd-hero-visual.is-visual-active .cd-visual-arms,
.cd-visual-card:hover .cd-visual-arms {
  opacity: 1;
  transform: translateY(4px) rotate(0deg) scale(1);
  animation: cdArmsRotate 14s linear infinite .42s;
}

.cd-hero-visual:hover .cd-visual-circles,
.cd-hero-visual.is-visual-active .cd-visual-circles,
.cd-visual-card:hover .cd-visual-circles {
  animation-duration: 1.7s;
}

.cd-snowfall {
  position: absolute;
  inset: -58px -46px -46px;
  z-index: 14;
  overflow: visible;
  opacity: 0;
  pointer-events: none;
  transition: opacity .28s ease;
}

.cd-snowfall span {
  position: absolute;
  top: -28px;
  left: var(--snow-x);
  width: var(--snow-size);
  aspect-ratio: 1;
  background: url("assets/cases/copo.svg") center / contain no-repeat;
  opacity: .82;
  filter: drop-shadow(0 5px 8px rgba(59, 130, 246, 0.2));
  transform: translate3d(0, -28px, 0) rotate(0deg);
  animation: cdSnowfall var(--snow-speed) linear infinite;
  animation-delay: var(--snow-delay);
  animation-play-state: paused;
}

.cd-snowfall span:nth-child(1) { --snow-x: 4%; --snow-size: 12px; --snow-speed: 3.7s; --snow-delay: -.4s; --snow-drift: 28px; }
.cd-snowfall span:nth-child(2) { --snow-x: 12%; --snow-size: 18px; --snow-speed: 4.8s; --snow-delay: -1.8s; --snow-drift: -16px; }
.cd-snowfall span:nth-child(3) { --snow-x: 20%; --snow-size: 26px; --snow-speed: 4.2s; --snow-delay: -2.7s; --snow-drift: 22px; }
.cd-snowfall span:nth-child(4) { --snow-x: 28%; --snow-size: 12px; --snow-speed: 5.1s; --snow-delay: -.9s; --snow-drift: -28px; }
.cd-snowfall span:nth-child(5) { --snow-x: 36%; --snow-size: 18px; --snow-speed: 3.9s; --snow-delay: -2.1s; --snow-drift: 26px; }
.cd-snowfall span:nth-child(6) { --snow-x: 44%; --snow-size: 26px; --snow-speed: 4.6s; --snow-delay: -1.1s; --snow-drift: -20px; }
.cd-snowfall span:nth-child(7) { --snow-x: 52%; --snow-size: 12px; --snow-speed: 4.1s; --snow-delay: -3.2s; --snow-drift: 30px; }
.cd-snowfall span:nth-child(8) { --snow-x: 60%; --snow-size: 18px; --snow-speed: 5.4s; --snow-delay: -2.4s; --snow-drift: -22px; }
.cd-snowfall span:nth-child(9) { --snow-x: 68%; --snow-size: 26px; --snow-speed: 3.8s; --snow-delay: -1.5s; --snow-drift: 20px; }
.cd-snowfall span:nth-child(10) { --snow-x: 76%; --snow-size: 12px; --snow-speed: 4.9s; --snow-delay: -.7s; --snow-drift: -26px; }
.cd-snowfall span:nth-child(11) { --snow-x: 84%; --snow-size: 18px; --snow-speed: 4.3s; --snow-delay: -2.9s; --snow-drift: 16px; }
.cd-snowfall span:nth-child(12) { --snow-x: 92%; --snow-size: 26px; --snow-speed: 5.2s; --snow-delay: -3.6s; --snow-drift: -18px; }
.cd-snowfall span:nth-child(13) { --snow-x: 100%; --snow-size: 12px; --snow-speed: 4.5s; --snow-delay: -1.3s; --snow-drift: -30px; }
.cd-snowfall span:nth-child(14) { --snow-x: -3%; --snow-size: 18px; --snow-speed: 5s; --snow-delay: -2.2s; --snow-drift: 32px; }
.cd-snowfall span:nth-child(15) { --snow-x: 108%; --snow-size: 26px; --snow-speed: 4s; --snow-delay: -3.1s; --snow-drift: -34px; }

.cd-hero-visual:hover .cd-snowfall,
.cd-hero-visual.is-visual-active .cd-snowfall,
.cd-visual-card--ski:hover .cd-snowfall,
.cd-visual-card--ski:focus-within .cd-snowfall {
  opacity: 1;
}

.cd-hero-visual:hover .cd-snowfall span,
.cd-hero-visual.is-visual-active .cd-snowfall span,
.cd-visual-card--ski:hover .cd-snowfall span,
.cd-visual-card--ski:focus-within .cd-snowfall span {
  animation-play-state: running;
}

.cd-visual-mini {
  position: relative;
  z-index: 8;
  height: 150px;
  margin-top: -12px;
  overflow: hidden;
  border: 1px solid rgba(10, 18, 32, 0.07);
  border-radius: 8px;
  background: #fbfaf7;
  box-shadow: 0 -12px 26px rgba(251, 250, 247, 0.72);
}

.cd-visual-mini svg {
  width: 100%;
  height: 100%;
  display: block;
}

.cd-visual-mini--case-icon {
  --case-accent: var(--brand);
}

.cd-visual-mini--ski {
  --case-accent: #3b82f6;
}

.cd-visual-mini--learning {
  --case-accent: #f0b429;
}

.cd-visual-mini--screen {
  --case-accent: #1DDBB7;
}

.cd-visual-mini--broker {
  --case-accent: #7c6ee6;
}

.cd-visual-mini--travel {
  --case-accent: #1DDBB7;
}

.cd-visual-mini--flexicar {
  --case-accent: #1DDBB7;
  position: absolute;
  left: 50%;
  transform: translateX(-50%);
  top: auto;
  bottom: 24px;
  width: min(86%, 520px);
  height: 168px;
  margin-top: 0;
  z-index: 12;
  background: rgba(255, 255, 255, 0.82);
  box-shadow: 0 20px 34px rgba(10, 18, 32, 0.1);
}

.cd-visual-mini--flexicar .case-svg__flex-route {
  fill: none;
  stroke: rgba(24, 108, 114, 0.9);
  stroke-width: 2.5;
  stroke-linecap: round;
  stroke-dasharray: 7 8;
  animation: cdFlexRouteFlow 3.8s linear infinite;
}

.cd-visual-mini--flexicar .case-svg__flex-route--soft {
  stroke: rgba(29, 219, 183, 0.26);
  stroke-width: 5;
  stroke-dasharray: none;
}

.cd-visual-mini--flexicar .case-svg__flex-dot {
  fill: rgba(24, 108, 114, 0.8);
  stroke: rgba(255, 255, 255, 0.94);
  stroke-width: 2;
  animation: cdFlexDotPulse 2.2s ease-in-out infinite;
}

.cd-visual-mini--flexicar .case-svg__flex-dot:nth-of-type(2) { animation-delay: .2s; }
.cd-visual-mini--flexicar .case-svg__flex-dot:nth-of-type(3) { animation-delay: .4s; }
.cd-visual-mini--flexicar .case-svg__flex-dot:nth-of-type(4) { animation-delay: .6s; }

.cd-visual-mini--flexicar .case-svg__flex-card rect {
  fill: rgba(255, 255, 255, 0.74);
  stroke: rgba(10, 18, 32, 0.1);
}

.cd-visual-mini--flexicar .case-svg__flex-card path {
  fill: none;
  stroke: rgba(24, 108, 114, 0.78);
  stroke-linecap: round;
  stroke-width: 3;
}

.cd-visual-mini--flexicar .case-svg__flex-card--q {
  animation: cdFlexCardFloat 3.6s ease-in-out infinite;
}

.cd-visual-mini--flexicar .case-svg__flex-card--kpi {
  animation: cdFlexCardFloat 4s ease-in-out infinite .28s;
}

@keyframes cdFlexRouteFlow {
  from { stroke-dashoffset: 0; }
  to { stroke-dashoffset: -58; }
}

@keyframes cdFlexDotPulse {
  0%, 100% { transform: scale(1); opacity: .86; }
  50% { transform: scale(1.22); opacity: 1; }
}

@keyframes cdFlexCardFloat {
  0%, 100% { transform: translateY(0); }
  50% { transform: translateY(-4px); }
}

@keyframes cdFlexShieldFloat {
  0%, 100% { transform: translate3d(0, 0, 0) rotate(var(--flex-rot, 0deg)) scale(1); }
  50% { transform: translate3d(0, -8px, 0) rotate(calc(var(--flex-rot, 0deg) + 4deg)) scale(1.04); }
}

.cd-visual-card--screen {
  overflow: visible;
  background:
    radial-gradient(circle at 72% 24%, rgba(29, 219, 183, 0.16), transparent 34%),
    linear-gradient(180deg, rgba(255,255,255,.92), rgba(251,250,247,.78));
}

.cd-visual-crack {
  position: absolute;
  left: -52%;
  top: -12%;
  z-index: 20;
  width: 624.66px;
  height: 512.2px;
  max-width: none;
  object-fit: fill;
  opacity: 0;
  mix-blend-mode: normal;
  pointer-events: none;
  transform: translate3d(-8px, 6px, 0) scale(.985) rotate(-1deg);
  transform-origin: 48% 42%;
  filter:
    saturate(1.08)
    contrast(1.02)
    drop-shadow(0 10px 16px rgba(29, 103, 108, .08));
  transition:
    opacity .42s ease,
    transform .62s cubic-bezier(.16, 1, .3, 1),
    filter .42s ease;
}

.cd-hero-visual:hover .cd-visual-crack,
.cd-hero-visual.is-visual-active .cd-visual-crack,
.cd-visual-card--screen:hover .cd-visual-crack {
  opacity: 1;
  transform: translate3d(0, 0, 0) scale(1.018) rotate(-1deg);
  filter:
    saturate(1.18)
    contrast(1.12)
    drop-shadow(0 16px 24px rgba(29, 103, 108, .14));
  animation: cdScreenCrackHero .56s cubic-bezier(.2, .85, .25, 1) both;
}

.cd-visual-logo--caser {
  position: relative;
  z-index: 9;
  max-width: 118px;
  max-height: 34px;
}

.cd-visual-photo--screen {
  position: relative;
  z-index: 8;
  min-height: 260px;
}

.cd-visual-person--screen {
  width: min(132%, 410px);
  max-height: 246px;
  transform: translateY(-4px) scale(1);
}

.cd-visual-photo--screen .cd-visual-circles {
  width: min(128%, 380px);
  opacity: .82;
}

.cd-hero-visual:hover .cd-visual-person--screen,
.cd-hero-visual.is-visual-active .cd-visual-person--screen,
.cd-visual-card:hover .cd-visual-person--screen {
  transform: translateY(-8px) scale(1.045);
}

.case-detail-hero--travel .cd-hero-visual {
  margin-top: clamp(26px, 3vw, 54px);
}

.cd-visual-card--travel {
  overflow: visible;
  isolation: isolate;
  background:
    radial-gradient(circle at 62% 40%, rgba(29, 219, 183, 0.17), transparent 36%),
    linear-gradient(180deg, rgba(255,255,255,.94), rgba(251,250,247,.8));
}

.cd-travel-peek {
  position: absolute;
  left: -68px;
  bottom: 58px;
  z-index: 7;
  width: clamp(198px, 20vw, 276px);
  max-width: none;
  pointer-events: none;
  opacity: 0;
  transform: translate3d(58px, 14px, 0) rotate(-14deg) scale(.84);
  transform-origin: 68% 48%;
  filter: drop-shadow(0 22px 28px rgba(10, 18, 32, .12));
  transition:
    opacity .42s ease,
    transform .72s cubic-bezier(.16, 1, .3, 1),
    filter .42s ease;
}

.cd-hero-visual:hover .cd-travel-peek,
.cd-hero-visual.is-visual-active .cd-travel-peek,
.cd-visual-card--travel:hover .cd-travel-peek {
  opacity: .96;
  transform: translate3d(-46px, -6px, 0) rotate(-10deg) scale(1);
  filter: drop-shadow(0 30px 34px rgba(10, 18, 32, .16));
}

.cd-visual-logo--nautalia {
  position: relative;
  z-index: 10;
  max-width: 146px;
  max-height: 46px;
}

.cd-visual-photo--travel {
  position: relative;
  z-index: 8;
  min-height: 318px;
  display: grid;
  place-items: center;
}

.cd-visual-person--travel {
  width: min(144%, 470px);
  max-height: 386px;
  object-fit: contain;
  transform: translateY(-10px) scale(1);
  filter: drop-shadow(0 26px 34px rgba(10, 18, 32, .14));
  transition: transform .62s cubic-bezier(.16, 1, .3, 1), filter .42s ease;
}

.cd-visual-photo--travel .cd-visual-circles {
  width: min(140%, 430px);
  opacity: .84;
}

.cd-travel-orbits {
  position: absolute;
  inset: 76px 18px 158px;
  z-index: 7;
  pointer-events: none;
}

.cd-travel-orbits span {
  position: absolute;
  border: 1px solid rgba(29, 103, 108, .22);
  border-radius: 50%;
  opacity: .55;
  transform: scale(.94);
  transition: opacity .45s ease;
  animation: cdTravelOrbitPulse 5.8s ease-in-out infinite;
}

.cd-travel-orbits span:nth-child(1) {
  inset: 16% 18%;
}

.cd-travel-orbits span:nth-child(2) {
  inset: 4% 8%;
  animation-delay: -1.9s;
}

.cd-travel-orbits span:nth-child(3) {
  inset: 28% 28%;
  animation-delay: -3.8s;
}

.cd-hero-visual:hover .cd-visual-person--travel,
.cd-hero-visual.is-visual-active .cd-visual-person--travel,
.cd-visual-card:hover .cd-visual-person--travel {
  transform: translateY(-18px) scale(1.035);
  filter: drop-shadow(0 34px 42px rgba(10, 18, 32, .18));
}

.cd-hero-visual:hover .cd-travel-orbits span,
.cd-hero-visual.is-visual-active .cd-travel-orbits span,
.cd-visual-card--travel:hover .cd-travel-orbits span {
  opacity: .82;
}

.cd-visual-mini--case-icon .case-svg__ski-line {
  fill: none;
  stroke: var(--case-accent);
  stroke-width: 2.2;
  stroke-linecap: round;
  stroke-dasharray: 9 10;
  animation: cdDash 5.5s linear infinite;
}

.cd-visual-mini--case-icon .case-svg__ticket,
.cd-visual-mini--case-icon .case-svg__policy {
  animation: cdFloat 7s ease-in-out infinite;
}

.cd-visual-mini--case-icon .case-svg__policy {
  animation-delay: -2.2s;
}

.cd-visual-mini--case-icon .case-svg__ticket rect,
.cd-visual-mini--case-icon .case-svg__policy rect {
  fill: rgba(251, 250, 247, 0.9);
  stroke: rgba(10, 18, 32, 0.12);
}

.cd-visual-mini--case-icon .case-svg__ticket path,
.cd-visual-mini--case-icon .case-svg__policy path {
  fill: none;
  stroke: var(--case-accent);
  stroke-width: 2;
  stroke-linecap: round;
  stroke-linejoin: round;
}

.cd-visual-mini--case-icon .case-svg__mountain {
  fill: color-mix(in srgb, var(--case-accent) 12%, white);
  stroke: rgba(10, 18, 32, 0.1);
}

.cd-visual-mini--learning .case-svg__screen,
.cd-visual-mini--learning .case-svg__badge {
  animation: cdFloat 7s ease-in-out infinite;
}

.cd-visual-mini--learning .case-svg__badge {
  animation-delay: -2.4s;
}

.cd-visual-mini--learning .case-svg__screen rect {
  fill: rgba(251, 250, 247, 0.92);
  stroke: rgba(10, 18, 32, 0.12);
}

.cd-visual-mini--learning .case-svg__learning-lines,
.cd-visual-mini--learning .case-svg__learning-check,
.cd-visual-mini--learning .case-svg__learning-ribbon {
  fill: none;
  stroke: var(--case-accent);
  stroke-width: 2.2;
  stroke-linecap: round;
  stroke-linejoin: round;
}

.cd-visual-mini--learning .case-svg__learning-lines {
  stroke-dasharray: 92;
  animation: cdLearningLines 3.8s ease-in-out infinite;
}

.cd-visual-mini--learning .case-svg__learning-dot {
  fill: var(--case-accent);
  opacity: .72;
  animation: cdDot 2.2s ease-in-out infinite;
}

.cd-visual-mini--learning .case-svg__badge circle {
  fill: rgba(240, 180, 41, 0.08);
  stroke: var(--case-accent);
  stroke-width: 2;
}

.cd-visual-mini--screen .case-svg__phone {
  animation: cdFloat 6.8s ease-in-out infinite;
}

.cd-visual-mini--screen .case-svg__phone rect {
  fill: rgba(251, 250, 247, 0.92);
  stroke: rgba(10, 18, 32, 0.12);
}

.cd-visual-mini--screen .case-svg__phone path,
.cd-visual-mini--screen .case-svg__scan path,
.cd-visual-mini--screen .case-svg__scan line {
  fill: none;
  stroke: var(--case-accent);
  stroke-width: 2.2;
  stroke-linecap: round;
  stroke-linejoin: round;
}

.cd-visual-mini--screen .case-svg__phone circle {
  fill: var(--case-accent);
  opacity: .72;
  animation: cdDot 2.2s ease-in-out infinite;
}

.cd-visual-mini--screen .case-svg__scan {
  animation: cdScreenScanFrame 3.2s ease-in-out infinite;
}

.cd-visual-mini--screen .case-svg__scan line {
  stroke-dasharray: 88 220;
  animation: cdScreenScanLine 2.6s linear infinite;
}

.cd-visual-mini--travel .case-svg__route path {
  fill: none;
  stroke: var(--case-accent);
  stroke-width: 2.2;
  stroke-linecap: round;
  stroke-dasharray: 9 10;
  animation: cdDash 5.5s linear infinite;
}

.cd-visual-mini--travel .case-svg__route circle {
  fill: var(--case-accent);
  filter: drop-shadow(0 8px 16px color-mix(in srgb, var(--case-accent) 38%, transparent));
  animation: cdDot 2.4s ease-in-out infinite;
  transform-box: fill-box;
  transform-origin: center;
}

.cd-visual-mini--travel .case-svg__route circle:nth-of-type(2) {
  animation-delay: -.6s;
}

.cd-visual-mini--travel .case-svg__travel-card {
  animation: cdFloat 7s ease-in-out infinite;
  animation-delay: -2.2s;
}

.cd-visual-mini--travel .case-svg__travel-card rect {
  fill: rgba(251, 250, 247, .88);
  stroke: rgba(10, 18, 32, .12);
}

.cd-visual-mini--travel .case-svg__travel-card path,
.cd-visual-mini--travel .case-svg__globe path {
  fill: none;
  stroke: var(--case-accent);
  stroke-width: 2;
  stroke-linecap: round;
  stroke-linejoin: round;
}

.cd-visual-mini--travel .case-svg__globe {
  animation: cdFloat 8s ease-in-out infinite;
}

.cd-visual-mini--travel .case-svg__globe circle {
  fill: color-mix(in srgb, var(--case-accent) 9%, white);
  stroke: var(--case-accent);
  stroke-width: 1.8;
}

.cd-visual-mini--travel .case-svg__travel-route {
  fill: none;
  stroke: var(--case-accent);
  stroke-width: 3;
  stroke-linecap: round;
  stroke-dasharray: 10 12;
  animation: cdTravelDash 5.6s linear infinite;
}

.cd-visual-mini--travel .case-svg__travel-route--soft {
  stroke: rgba(29, 103, 108, .16);
  stroke-width: 12;
  stroke-dasharray: none;
  animation: none;
}

.cd-visual-mini--travel .case-svg__travel-pin,
.cd-visual-mini--travel .case-svg__travel-policy,
.cd-visual-mini--travel .case-svg__travel-plane {
  animation: cdFloat 7s ease-in-out infinite;
}

.cd-visual-mini--travel .case-svg__travel-policy {
  animation-delay: -2.2s;
}

.cd-visual-mini--travel .case-svg__travel-plane {
  animation-delay: -4.2s;
}

.cd-visual-mini--travel .case-svg__travel-pin circle {
  fill: rgba(29, 219, 183, .1);
  stroke: var(--case-accent);
  stroke-width: 2;
}

.cd-visual-mini--travel .case-svg__travel-dot {
  fill: var(--case-accent);
  opacity: .82;
  animation: cdDot 2.6s ease-in-out infinite;
  transform-box: fill-box;
  transform-origin: center;
}

.cd-visual-mini--travel .case-svg__travel-dot:nth-of-type(2) {
  animation-delay: -.7s;
}

.cd-visual-mini--travel .case-svg__travel-dot:nth-of-type(3) {
  animation-delay: -1.4s;
}

.cd-visual-mini--travel .case-svg__travel-pin path,
.cd-visual-mini--travel .case-svg__travel-policy path,
.cd-visual-mini--travel .case-svg__travel-plane path {
  fill: none;
  stroke: var(--case-accent);
  stroke-width: 2.2;
  stroke-linecap: round;
  stroke-linejoin: round;
}

.cd-visual-mini--travel .case-svg__travel-policy rect {
  fill: rgba(251, 250, 247, .92);
  stroke: rgba(10, 18, 32, .12);
}

.cd-visual-mini--broker .case-svg__broker-route {
  fill: none;
  stroke: var(--case-accent);
  stroke-width: 2.4;
  stroke-linecap: round;
  stroke-dasharray: 10 12;
  animation: cdBrokerRoute 5.4s linear infinite;
}

.cd-visual-mini--broker .case-svg__broker-route--soft {
  stroke: rgba(29, 103, 108, .13);
  stroke-width: 12;
  stroke-dasharray: none;
  animation: none;
}

.cd-visual-mini--broker .case-svg__broker-dot {
  fill: var(--case-accent);
  opacity: .86;
  transform-box: fill-box;
  transform-origin: center;
  animation: cdBrokerDot 2.6s ease-in-out infinite;
}

.cd-visual-mini--broker .case-svg__broker-dot:nth-of-type(2) {
  animation-delay: -.7s;
}

.cd-visual-mini--broker .case-svg__broker-dot:nth-of-type(3) {
  animation-delay: -1.4s;
}

.cd-visual-mini--broker .case-svg__broker-card,
.cd-visual-mini--broker .case-svg__broker-hub {
  animation: cdFloat 7s ease-in-out infinite;
}

.cd-visual-mini--broker .case-svg__nodes {
  animation: cdFloat 8s ease-in-out infinite;
}

.cd-visual-mini--broker .case-svg__nodes circle {
  fill: color-mix(in srgb, var(--case-accent) 9%, white);
  stroke: var(--case-accent);
  stroke-width: 1.8;
}

.cd-visual-mini--broker .case-svg__nodes path {
  fill: none;
  stroke: var(--case-accent);
  stroke-width: 2;
  stroke-linecap: round;
  stroke-linejoin: round;
}

.cd-visual-mini--broker .case-svg__broker-hub {
  animation-delay: -1.2s;
}

.cd-visual-mini--broker .case-svg__broker-card--alt {
  animation-delay: -2.2s;
}

.cd-visual-mini--broker .case-svg__broker-card--docs {
  animation-delay: -2.4s;
}

.cd-visual-mini--broker .case-svg__broker-card--settlement {
  animation-delay: -3.6s;
}

.cd-visual-mini--broker .case-svg__broker-card rect {
  fill: rgba(251, 250, 247, .92);
  stroke: rgba(10, 18, 32, .12);
}

.cd-visual-mini--broker .case-svg__broker-card path,
.cd-visual-mini--broker .case-svg__broker-hub path {
  fill: none;
  stroke: var(--case-accent);
  stroke-width: 2.1;
  stroke-linecap: round;
  stroke-linejoin: round;
}

.cd-visual-mini--broker .case-svg__broker-card circle {
  fill: color-mix(in srgb, var(--case-accent) 12%, white);
  stroke: var(--case-accent);
  stroke-width: 1.8;
}

.cd-visual-mini--broker .case-svg__broker-hub circle {
  fill: color-mix(in srgb, var(--case-accent) 10%, white);
  stroke: var(--case-accent);
  stroke-width: 2;
  animation: cdBrokerHub 3.4s ease-in-out infinite;
  transform-box: fill-box;
  transform-origin: center;
}

.cd-visual-mini--broker .case-svg__broker-check {
  stroke-dasharray: 44;
  animation: cdBrokerCheck 3.8s ease-in-out infinite;
}

.cd-flow-line {
  fill: none;
  stroke: var(--brand);
  stroke-width: 2.2;
  stroke-linecap: round;
  stroke-dasharray: 9 10;
  animation: cdDash 5.2s linear infinite;
}

.cd-flow-dot {
  fill: var(--brand);
  animation: cdDot 2.6s ease-in-out infinite;
}

.cd-flow-dot--two { animation-delay: -.5s; }
.cd-flow-dot--three { animation-delay: -1s; }
.cd-flow-dot--four { animation-delay: -1.5s; }

.cd-mini-panel {
  animation: cdFloat 6.4s ease-in-out infinite;
}

.cd-mini-panel--late {
  animation-delay: -2s;
}

.cd-mini-panel rect {
  fill: rgba(251, 250, 247, 0.92);
  stroke: rgba(10, 18, 32, 0.12);
}

.cd-mini-panel path {
  fill: none;
  stroke: var(--brand);
  stroke-width: 2;
  stroke-linecap: round;
}

.cd-stats {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 1px;
  padding-top: 24px;
  padding-bottom: 84px;
}

.cd-stat {
  padding: clamp(24px, 3.2vw, 38px);
  border: 1px solid var(--line);
  background: rgba(255, 255, 255, 0.42);
}

.cd-stat span {
  display: block;
  color: var(--brand);
  font-family: var(--f-display);
  font-size: clamp(52px, 6vw, 86px);
  line-height: 0.92;
  letter-spacing: -0.04em;
}

.cd-stat p {
  margin-top: 10px;
  color: var(--ink-soft);
  font-size: 16px;
}

.cd-brief,
.cd-live,
.cd-flow,
.cd-next {
  padding-top: 58px;
  padding-bottom: 92px;
}

.cd-live {
  position: relative;
  overflow: hidden;
  margin-top: 12px;
  padding-top: clamp(72px, 8vw, 112px);
  padding-bottom: clamp(76px, 8vw, 118px);
  color: var(--bg);
  background:
    radial-gradient(circle at 12% 12%, rgba(29, 219, 183, 0.2), transparent 30%),
    radial-gradient(circle at 88% 80%, rgba(29, 103, 108, 0.3), transparent 34%),
    var(--ink);
}

.cd-live::before {
  content: "";
  position: absolute;
  inset: 0;
  background-image:
    linear-gradient(to right, rgba(251, 250, 247, 0.045) 1px, transparent 1px),
    linear-gradient(to bottom, rgba(251, 250, 247, 0.045) 1px, transparent 1px);
  background-size: 72px 72px;
  mask-image: linear-gradient(to bottom, transparent, #000 18%, #000 84%, transparent);
  pointer-events: none;
}

.cd-live-inner {
  position: relative;
  z-index: 1;
}

.cd-live-head {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(280px, 390px);
  gap: clamp(24px, 4vw, 56px);
  align-items: end;
  max-width: none;
  margin-bottom: clamp(24px, 3.4vw, 38px);
}

.cd-live .eyebrow {
  grid-column: 1 / -1;
  color: rgba(251, 250, 247, 0.62);
}

.cd-live .eyebrow::before {
  background: var(--accent);
}

.cd-live-head h2 {
  margin-top: 18px;
  font-family: var(--f-display);
  font-size: clamp(42px, 4.5vw, 66px);
  line-height: 0.95;
  letter-spacing: -0.035em;
}

.cd-live-head p {
  max-width: 58ch;
  margin-top: 0;
  padding-bottom: 6px;
  color: rgba(251, 250, 247, 0.68);
  font-size: clamp(18px, 1.6vw, 22px);
  line-height: 1.45;
}

.cd-live-stage {
  position: relative;
  overflow: hidden;
  border-radius: 8px;
  border: 1px solid rgba(251, 250, 247, 0.16);
  background:
    radial-gradient(circle at 18% 20%, rgba(29, 219, 183, 0.2), transparent 34%),
    radial-gradient(circle at 82% 72%, rgba(251, 250, 247, 0.08), transparent 32%),
    rgba(255, 255, 255, 0.035);
  box-shadow: 0 34px 86px rgba(0, 0, 0, 0.24);
  transition: transform .45s cubic-bezier(.2,.85,.25,1), border-color .45s ease;
}

.cd-live-stage:hover {
  transform: translateY(-4px);
  border-color: rgba(29, 219, 183, 0.34);
}

.cd-live-stage svg {
  width: 100%;
  height: clamp(390px, 44vw, 540px);
  display: block;
}

.cd-live-rail {
  fill: none;
  stroke: rgba(251, 250, 247, 0.16);
  stroke-width: 2;
  stroke-linecap: round;
}

.cd-live-rail-glow {
  fill: none;
  stroke: url(#cdLiveGlow);
  stroke-width: 4;
  stroke-linecap: round;
  stroke-dasharray: 190 760;
  animation: cdLiveRail 4.8s linear infinite;
}

.cd-live-node circle {
  fill: rgba(251, 250, 247, 0.05);
  stroke: rgba(29, 219, 183, 0.52);
  stroke-width: 2;
  animation: cdLiveNode 2.6s ease-in-out infinite;
}

.cd-live-node:nth-of-type(2) circle { animation-delay: -.45s; }
.cd-live-node:nth-of-type(3) circle { animation-delay: -.9s; }
.cd-live-node:nth-of-type(4) circle { animation-delay: -1.35s; }

.cd-live-node text,
.cd-live-panel text {
  fill: rgba(251, 250, 247, 0.56);
  font-family: var(--f-mono);
  font-size: 11px;
  letter-spacing: .16em;
  text-anchor: middle;
  text-transform: uppercase;
}

.cd-live-card {
  transform: translate(20px, 318px);
  animation: cdLiveCard 7.2s cubic-bezier(.45,0,.2,1) infinite;
}

.cd-live-card--two {
  animation-delay: -2.4s;
}

.cd-live-card--three {
  animation-delay: -4.8s;
}

.cd-live-card rect {
  fill: rgba(251, 250, 247, 0.92);
  stroke: rgba(29, 219, 183, 0.22);
  filter: drop-shadow(0 22px 28px rgba(0, 0, 0, 0.18));
}

.cd-live-card path {
  fill: none;
  stroke: rgba(10, 18, 32, 0.42);
  stroke-width: 3;
  stroke-linecap: round;
}

.cd-live-card circle {
  fill: var(--brand);
  animation: cdLiveCardDot 1.6s ease-in-out infinite;
}

.cd-live-panel--left {
  transform: translate(84px, 72px);
  animation: cdLivePanelLeft 7s ease-in-out infinite;
}

.cd-live-panel--right {
  transform: translate(850px, 330px);
  animation: cdLivePanelRight 7s ease-in-out infinite;
  animation-delay: -2.4s;
}

.cd-live-panel rect,
.cd-live-metric rect {
  fill: rgba(255, 255, 255, 0.045);
  stroke: rgba(251, 250, 247, 0.13);
}

.cd-live-panel path {
  fill: none;
  stroke: rgba(29, 219, 183, 0.55);
  stroke-width: 3;
  stroke-linecap: round;
  stroke-dasharray: 64 16;
  animation: cdLivePanelLine 3s ease-in-out infinite;
}

.cd-live-panel text {
  text-anchor: start;
}

.cd-live-metric {
  animation: cdLiveMetric 3.6s ease-in-out infinite;
}

.cd-live-metric--one {
  transform: translate(492px, 76px);
}

.cd-live-metric--two {
  transform: translate(636px, 76px);
  animation-delay: -1.2s;
}

.cd-live-metric text {
  fill: #1DDBB7;
  font-family: var(--f-display);
  font-size: 28px;
  letter-spacing: -0.03em;
}

.cd-live-metric path {
  fill: none;
  stroke: rgba(251, 250, 247, 0.22);
  stroke-width: 3;
  stroke-linecap: round;
}

.cd-live-stage:hover .cd-live-rail-glow {
  animation-duration: 3.2s;
}

.cd-live-stage:hover .cd-live-card {
  animation-duration: 5.4s;
}

.cd-live-stage:hover .cd-live-node circle,
.cd-live-stage:hover .cd-live-card circle,
.cd-live-stage:hover .cd-live-metric {
  animation-duration: 1.8s;
}

.cd-live-stage--ski {
  background:
    radial-gradient(circle at 18% 18%, rgba(167, 216, 255, 0.18), transparent 32%),
    radial-gradient(circle at 82% 70%, rgba(29, 219, 183, 0.14), transparent 36%),
    linear-gradient(145deg, rgba(255, 255, 255, 0.05), rgba(255, 255, 255, 0.015));
}

.cd-live-stage--ski:hover {
  border-color: rgba(167, 216, 255, 0.34);
}

.cd-ski-live-ridge {
  fill: url(#cdSkiSnowRidge);
}

.cd-ski-live-ridge--back {
  opacity: .55;
}

.cd-ski-live-ridge--front {
  opacity: .9;
}

.cd-ski-live-track {
  fill: none;
  stroke: rgba(251, 250, 247, 0.22);
  stroke-width: 3;
  stroke-linecap: round;
  stroke-dasharray: 12 16;
}

.cd-ski-live-track-glow {
  fill: none;
  stroke: url(#cdSkiPathGlow);
  stroke-width: 6;
  stroke-linecap: round;
  stroke-dasharray: 210 820;
  filter: drop-shadow(0 0 18px rgba(167, 216, 255, 0.4));
  animation: cdSkiTrack 5.4s linear infinite;
}

.cd-ski-live-node circle {
  fill: rgba(10, 18, 32, 0.92);
  stroke: rgba(29, 219, 183, 0.7);
  stroke-width: 2;
  filter: drop-shadow(0 18px 26px rgba(0, 0, 0, 0.28)) drop-shadow(0 0 18px rgba(29, 219, 183, 0.16));
  animation: cdSkiNodePulse 2.8s ease-in-out infinite;
}

.cd-ski-live-node--pass circle { animation-delay: -.45s; }
.cd-ski-live-node--cover circle { animation-delay: -.9s; }
.cd-ski-live-node--api circle { animation-delay: -1.35s; }
.cd-ski-live-node--policy circle { animation-delay: -1.8s; }

.cd-ski-live-node path {
  fill: none;
  stroke: var(--accent);
  stroke-width: 3;
  stroke-linecap: round;
  stroke-linejoin: round;
}

.cd-ski-live-node text,
.cd-ski-live-card text,
.cd-ski-live-metric-label {
  fill: rgba(251, 250, 247, 0.64);
  font-family: var(--f-mono);
  font-size: 11px;
  letter-spacing: .16em;
  text-anchor: middle;
  text-transform: uppercase;
}

.cd-ski-live-card {
  opacity: .34;
  transform-box: fill-box;
  transform-origin: center;
  translate: 0 8px;
  scale: .98;
  animation: cdSkiCardSequence 9s ease-in-out infinite;
}

.cd-ski-live-card--pass {
  transform: translate(82px, 88px);
}

.cd-ski-live-card--api {
  transform: translate(706px, 78px);
  animation-delay: 3s;
}

.cd-ski-live-card--policy {
  transform: translate(840px, 382px);
  animation-delay: 6s;
}

.cd-ski-live-card rect {
  fill: rgba(251, 250, 247, 0.92);
  stroke: rgba(167, 216, 255, 0.24);
  filter: drop-shadow(0 24px 30px rgba(0, 0, 0, 0.22));
}

.cd-ski-live-card text {
  fill: rgba(10, 18, 32, 0.58);
  text-anchor: start;
}

.cd-ski-live-card path {
  fill: none;
  stroke: rgba(29, 103, 108, 0.68);
  stroke-width: 3;
  stroke-linecap: round;
  stroke-linejoin: round;
}

.cd-ski-live-code-card text {
  fill: rgba(10, 18, 32, 0.58);
  font-family: var(--f-mono);
  font-size: 11px;
  letter-spacing: .08em;
  text-anchor: start;
  text-transform: none;
}

.cd-ski-live-code-card text:first-child {
  fill: var(--brand);
}

.cd-ski-live-code-loading__bar {
  fill: rgba(29, 219, 183, 0.22);
  transform: scaleX(0);
  transform-box: fill-box;
  transform-origin: left center;
}

.cd-ski-live-code-loading__bar--one {
  animation: cdSkiCodeLoadOne 9s ease-in-out infinite;
}

.cd-ski-live-code-loading__bar--two {
  animation: cdSkiCodeLoadTwo 9s ease-in-out infinite;
}

.cd-ski-live-code-loading__bar--three {
  animation: cdSkiCodeLoadThree 9s ease-in-out infinite;
}

.cd-ski-live-code-card circle {
  fill: var(--accent);
  animation: cdLiveCardDot 1.6s ease-in-out infinite;
}

.cd-ski-live-code-card circle:nth-of-type(2) {
  animation-delay: -.8s;
}

.cd-ski-live-card > circle {
  fill: var(--brand);
  animation: cdLiveCardDot 1.6s ease-in-out infinite;
}

.cd-ski-live-code-icon path,
.cd-ski-live-pass-icon path {
  stroke-width: 1.5;
}

.cd-ski-live-check {
  stroke: var(--brand) !important;
  stroke-dasharray: 56;
  stroke-dashoffset: 56;
  animation: cdSkiCheckSequence 9s ease-in-out infinite 6s;
}

.cd-ski-live-metric {
  transform-box: fill-box;
  animation: cdSkiMetric 3.8s ease-in-out infinite;
}

.cd-ski-live-metric--one {
  transform: translate(464px, 462px);
}

.cd-ski-live-metric--two {
  transform: translate(626px, 462px);
  animation-delay: -1.3s;
}

.cd-ski-live-metric-value {
  fill: #A7D8FF;
  font-family: var(--f-display);
  font-size: 36px;
  letter-spacing: -0.03em;
  text-transform: none;
}

.cd-ski-live-metric path {
  fill: none;
  stroke: rgba(251, 250, 247, 0.22);
  stroke-width: 3;
  stroke-linecap: round;
}

.cd-ski-live-metric-icon {
  animation: cdSkiMetricIcon 2.6s ease-in-out infinite;
}

.cd-ski-live-metric-icon--sync {
  animation-delay: -1.2s;
}

.cd-ski-live-metric-icon path {
  stroke: #A7D8FF;
  stroke-width: 2.4;
  stroke-linecap: round;
  stroke-linejoin: round;
  filter: drop-shadow(0 8px 12px rgba(167, 216, 255, 0.18));
}

.cd-ski-live-metric-icon--sync path {
  stroke-dasharray: 54;
  animation: cdSkiMetricSync 2.6s ease-in-out infinite;
}

.cd-ski-live-metric-label {
  text-anchor: start;
}

.cd-ski-live-snow circle {
  fill: rgba(251, 250, 247, 0.68);
  animation: cdSkiSnow 5s linear infinite;
}

.cd-ski-live-snow circle:nth-child(2n) {
  animation-duration: 6.2s;
  animation-delay: -1.4s;
}

.cd-ski-live-snow circle:nth-child(3n) {
  animation-duration: 4.4s;
  animation-delay: -2.6s;
}

.cd-live-stage--ski:hover .cd-ski-live-track-glow {
  animation-duration: 3.7s;
}

.cd-live-stage--ski:hover .cd-ski-live-node circle,
.cd-live-stage--ski:hover .cd-ski-live-metric,
.cd-live-stage--ski:hover .cd-ski-live-card circle {
  animation-duration: 1.8s;
}

.cd-live-stage--learning {
  background:
    radial-gradient(circle at 30% 26%, rgba(163, 231, 252, 0.12), transparent 34%),
    radial-gradient(circle at 78% 70%, rgba(29, 219, 183, 0.12), transparent 34%),
    var(--ink);
}

.cd-live-stage--learning .cd-learning-seq-mobile {
  display: none;
}

.cd-learning-seq-halo {
  fill: none;
  stroke: rgba(163, 231, 252, 0.28);
  stroke-width: 2;
  stroke-linecap: round;
  stroke-dasharray: 4 14;
  animation: cdDash 14s linear infinite reverse;
}

.cd-learning-seq-outer-glow {
  fill: none;
  stroke: url(#cdLearningSeqGlow);
  stroke-width: 5;
  stroke-linecap: round;
  stroke-dasharray: 230 1180;
  animation: cdLearningSeqGlow 9.6s linear infinite;
  opacity: .72;
}

.cd-learning-seq-track,
.cd-learning-seq-vertical {
  fill: none;
  stroke: rgba(163, 231, 252, 0.74);
  stroke-width: 2.2;
  stroke-linecap: round;
  stroke-dasharray: 4 8;
}

.cd-learning-seq-dot {
  fill: #0A1220;
  stroke: rgba(29, 219, 183, 0.74);
  stroke-width: 2;
}

.cd-learning-seq-employee-aura {
  fill: rgba(29, 219, 183, 0.06);
  stroke: rgba(29, 219, 183, 0.74);
  stroke-width: 2;
  transform-box: fill-box;
  transform-origin: center;
}

.cd-learning-seq-dot {
  opacity: 1;
}

.cd-learning-seq-employee-aura {
  opacity: .5;
  animation: cdLearningEmployeeGlow 4.8s ease-in-out infinite;
}

.cd-learning-seq-employee-core {
  fill: rgba(29, 219, 183, 0.1);
  stroke: rgba(29, 219, 183, 0.36);
  stroke-width: 2;
}

.cd-learning-seq-employee text,
.cd-learning-seq-rrhh text,
.cd-learning-seq-follow text,
.cd-learning-seq-panel-num {
  fill: rgba(163, 231, 252, 0.72);
  font-family: var(--f-mono);
  font-size: 10px;
  letter-spacing: .14em;
  text-anchor: middle;
  text-transform: uppercase;
}

.cd-learning-seq-follow circle {
  fill: var(--accent);
  stroke: none;
}

.cd-learning-seq-sync-dot {
  transform-box: fill-box;
  transform-origin: center;
  animation: cdLearningSeqSyncDot 5.2s ease-in-out infinite;
}

.cd-learning-seq-follow text {
  fill: rgba(251, 250, 247, 0.72);
  font-size: 15px;
  letter-spacing: .12em;
  text-anchor: start;
}

.cd-learning-seq-follow text:first-of-type {
  text-anchor: end;
}

.cd-learning-seq-phase {
  opacity: 0;
  animation: cdLearningSeqPhase 12s ease-in-out infinite;
}

.cd-learning-seq-phase--exam {
  animation-delay: 4s;
}

.cd-learning-seq-phase--certificate {
  animation-delay: 8s;
}

.cd-learning-seq-progress {
  fill: none;
  stroke: var(--accent);
  stroke-width: 7;
  stroke-linecap: round;
  filter: drop-shadow(0 0 14px rgba(29, 219, 183, .24));
}

.cd-learning-seq-active-dot {
  fill: var(--accent);
  stroke: rgba(29, 219, 183, 0.28);
  stroke-width: 14;
}

.cd-learning-seq-active-num {
  fill: #fff;
  font-family: var(--f-sans);
  font-size: 24px;
  font-weight: 600;
  text-anchor: middle;
}

.cd-learning-seq-connector {
  fill: none;
  stroke: rgba(163, 231, 252, .95);
  stroke-width: 2.2;
  stroke-linecap: round;
  stroke-dasharray: 5 8;
  animation: cdDash 4.4s linear infinite;
}

.cd-learning-seq-panel {
  filter: drop-shadow(0 28px 38px rgba(0, 0, 0, .2));
}

.cd-learning-seq-panel rect {
  fill: rgba(251, 250, 247, 0.06);
  stroke: rgba(163, 231, 252, 0.24);
  stroke-width: 1;
}

.cd-learning-seq-panel--exam rect,
.cd-learning-seq-panel--certificate rect {
  stroke: rgba(29, 219, 183, .8);
}

.cd-learning-seq-panel-title {
  fill: #fff;
  font-family: var(--f-display);
  font-size: 38px;
  line-height: 1;
  letter-spacing: 0;
  text-transform: uppercase;
}

.cd-learning-seq-panel-line {
  fill: rgba(251, 250, 247, 0.7);
  font-family: var(--f-sans);
  font-size: 16px;
  text-transform: uppercase;
}

.cd-learning-seq-float {
  transform-box: fill-box;
  transform-origin: center;
  animation: cdLearningSeqFloat 3.2s ease-in-out infinite;
}

.cd-learning-seq-float--two,
.cd-learning-seq-float--check-two {
  animation-delay: -.9s;
}

.cd-learning-seq-float--three,
.cd-learning-seq-float--check-three {
  animation-delay: -1.8s;
}

.cd-live-stage--learning:hover .cd-learning-seq-phase {
  animation-duration: 9s;
}

.cd-live-stage--learning:hover .cd-learning-seq-float {
  animation-duration: 2.1s;
}

.cd-learning-seq-panel-num {
  text-anchor: start;
  fill: var(--accent);
}

.cd-learning-seq-rrhh text {
  fill: rgba(163, 231, 252, 0.74);
}

.cd-learning-seq-rrhh image,
.cd-learning-seq-follow image,
.cd-learning-seq-employee image,
.cd-learning-seq-panel image,
.cd-learning-seq-float {
  pointer-events: none;
}

.cd-learning-seq-panel image {
  opacity: .95;
}

.cd-learning-seq-track,
.cd-learning-seq-vertical,
.cd-learning-seq-panel-line,
.cd-learning-seq-panel-title {
  letter-spacing: 0;
}

.cd-learning-seq-panel-line,
.cd-learning-seq-panel-title {
  text-anchor: start;
}

.cd-learning-seq-panel-title,
.cd-learning-seq-panel-line {
  dominant-baseline: auto;
}

.cd-learning-seq-panel text,
.cd-learning-seq-active-num {
  paint-order: stroke;
  stroke: transparent;
}

.cd-learning-seq-employee image,
.cd-learning-seq-rrhh image,
.cd-learning-seq-follow image {
  opacity: .95;
}

.cd-learning-seq-follow {
  opacity: .9;
}

.cd-learning-seq-panel--course .cd-learning-seq-panel-title {
  font-size: 40px;
}

.cd-learning-seq-panel--certificate .cd-learning-seq-panel-title {
  font-size: 34px;
}

.cd-learning-seq-track,
.cd-learning-seq-halo {
  vector-effect: non-scaling-stroke;
}

.cd-learning-seq-active-dot,
.cd-learning-seq-progress,
.cd-learning-seq-connector {
  transform-box: fill-box;
  transform-origin: center;
}

.cd-learning-seq-active-dot {
  animation: cdLearningSeqPop 12s ease-in-out infinite;
}

.cd-learning-seq-phase--exam .cd-learning-seq-active-dot {
  animation-delay: 4s;
}

.cd-learning-seq-phase--certificate .cd-learning-seq-active-dot {
  animation-delay: 8s;
}

.cd-learning-mobile-orbit {
  fill: none;
  stroke: rgba(163, 231, 252, 0.9);
  stroke-width: 2;
  stroke-linecap: round;
  stroke-dasharray: 4 8;
}

.cd-learning-mobile-orbit-glow {
  fill: none;
  stroke: url(#cdLearningMobileGlow);
  stroke-width: 5;
  stroke-linecap: round;
  stroke-dasharray: 58 220;
  animation: cdLearningMobileOrbit 3s linear infinite;
}

.cd-learning-mobile-orbit-dot {
  fill: var(--accent);
  filter: drop-shadow(0 0 10px rgba(29, 219, 183, .42));
}

.cd-learning-mobile-phase {
  opacity: 0;
  animation: cdLearningMobilePhase 9s ease-in-out infinite;
}

.cd-learning-mobile-phase--exam {
  animation-delay: 3s;
}

.cd-learning-mobile-phase--certificate {
  animation-delay: 6s;
}

.cd-learning-mobile-step-dot {
  fill: var(--accent);
  stroke: rgba(29, 219, 183, 0.22);
  stroke-width: 10;
  filter: drop-shadow(0 12px 22px rgba(29, 219, 183, .22));
}

.cd-learning-mobile-step-num {
  fill: #fff;
  font-family: var(--f-sans);
  font-size: 24px;
  font-weight: 600;
  text-anchor: middle;
}

.cd-learning-mobile-panel rect {
  fill: rgba(251, 250, 247, 0.06);
  stroke: rgba(163, 231, 252, 0.22);
}

.cd-learning-mobile-panel .cd-learning-seq-panel-title {
  font-size: 37px;
}

.cd-learning-mobile-panel--certificate .cd-learning-seq-panel-title {
  font-size: 30px;
}

.cd-learning-mobile-panel .cd-learning-seq-panel-line {
  font-size: 13px;
}

.cd-learning-mobile-follow text {
  font-size: 8px;
  letter-spacing: .08em;
}

.cd-learning-mobile-follow .cd-learning-mobile-sync-dot {
  animation: cdLearningMobileSyncDot 4.6s ease-in-out infinite;
}

.cd-learning-mobile-vertical {
  stroke: rgba(251, 250, 247, 0.34);
  stroke-width: 2;
  stroke-dasharray: 8 9;
}

.cd-learning-mobile-check {
  transform-box: fill-box;
  transform-origin: center;
  animation: cdLearningMobileCheck 1.8s ease-in-out infinite;
  filter: drop-shadow(0 8px 14px rgba(29, 219, 183, .18));
}

.cd-learning-mobile-check--two,
.cd-learning-mobile-check--four {
  animation-delay: -.7s;
}

.cd-live-stage--screen {
  background:
    radial-gradient(circle at 48% 24%, rgba(29, 219, 183, 0.14), transparent 32%),
    radial-gradient(circle at 76% 68%, rgba(163, 231, 252, 0.10), transparent 34%),
    var(--ink);
}

.cd-screen-live-rail {
  fill: none;
  stroke: rgba(163, 231, 252, 0.72);
  stroke-width: 2.2;
  stroke-linecap: round;
  stroke-dasharray: 4 8;
}

.cd-screen-live-rail-glow {
  fill: none;
  stroke: url(#cdScreenScanGlow);
  stroke-width: 7;
  stroke-linecap: round;
  stroke-dasharray: 220 1100;
  animation: cdScreenRail 7.8s linear infinite;
}

.cd-screen-live-node circle {
  fill: #0A1220;
  stroke: rgba(29, 219, 183, 0.72);
  stroke-width: 2;
  animation: cdScreenNodePulse 4.2s ease-in-out infinite;
  transform-box: fill-box;
  transform-origin: center;
}

.cd-screen-live-node:nth-of-type(2) circle { animation-delay: -.7s; }
.cd-screen-live-node:nth-of-type(3) circle { animation-delay: -1.4s; }
.cd-screen-live-node:nth-of-type(4) circle { animation-delay: -2.1s; }
.cd-screen-live-node:nth-of-type(5) circle { animation-delay: -2.8s; }

.cd-screen-live-node path {
  fill: none;
  stroke: var(--accent);
  stroke-width: 2.2;
  stroke-linecap: round;
  stroke-linejoin: round;
}

.cd-screen-live-node-icon,
.cd-travel-live-node-icon,
.cd-screen-live-card-icon {
  filter: brightness(0) saturate(100%) invert(84%) sepia(70%) saturate(2154%) hue-rotate(107deg) brightness(92%) contrast(89%);
  opacity: .94;
}

.cd-screen-live-node text,
.cd-screen-live-card text,
.cd-screen-live-metric text:last-of-type {
  fill: rgba(251, 250, 247, .64);
  font-family: var(--f-mono);
  font-size: 13px;
  letter-spacing: .16em;
  text-anchor: middle;
  text-transform: uppercase;
}

.cd-screen-live-phone {
  filter: drop-shadow(0 28px 42px rgba(0,0,0,.26));
  animation: cdScreenPhoneFloat 5.8s ease-in-out infinite;
}

.cd-screen-live-phone rect {
  fill: rgba(251, 250, 247, 0.06);
  stroke: rgba(29, 219, 183, .68);
  stroke-width: 2;
}

.cd-screen-live-phone rect:nth-child(2) {
  fill: rgba(10, 18, 32, .62);
  stroke: rgba(163, 231, 252, .32);
}

.cd-screen-live-crack {
  fill: none;
  stroke: rgba(163, 231, 252, .76);
  stroke-width: 2.4;
  stroke-linecap: round;
  stroke-linejoin: round;
  stroke-dasharray: 120;
  animation: cdScreenCrack 4.6s ease-in-out infinite;
}

.cd-screen-live-scan {
  fill: none;
  stroke: var(--accent);
  stroke-width: 7;
  stroke-linecap: round;
  stroke-dasharray: 92 190;
  animation: cdScreenPhoneScan 2.7s ease-in-out infinite;
}

.cd-screen-live-phone circle {
  fill: var(--accent);
  opacity: .72;
}

.cd-screen-live-card {
  transform-box: fill-box;
  filter: drop-shadow(0 24px 34px rgba(0,0,0,.22));
  animation: cdScreenCard 9s ease-in-out infinite;
}

.cd-screen-live-card--channel {
  transform: translate(86px, 142px);
}

.cd-screen-live-card--test {
  transform: translate(466px, 142px);
  animation-delay: -3s;
}

.cd-screen-live-card--policy {
  transform: translate(846px, 142px);
  animation-delay: -6s;
}

.cd-screen-live-card rect {
  fill: rgba(251, 250, 247, .06);
  stroke: rgba(163, 231, 252, .22);
  stroke-width: 1.2;
}

.cd-screen-live-card path {
  fill: none;
  stroke: rgba(29, 219, 183, .82);
  stroke-width: 2.4;
  stroke-linecap: round;
  stroke-linejoin: round;
}

.cd-screen-live-card circle {
  fill: var(--accent);
  animation: cdLiveCardDot 2.4s ease-in-out infinite;
  transform-box: fill-box;
  transform-origin: center;
}

.cd-screen-live-card-title {
  text-anchor: start;
}

.cd-screen-live-loading {
  stroke-width: 9 !important;
  stroke: rgba(29, 219, 183, .24) !important;
  animation: cdScreenLoading 3s ease-in-out infinite;
  transform-box: fill-box;
  transform-origin: left center;
}

.cd-screen-live-loading--two {
  animation-delay: -.45s;
}

.cd-screen-live-loading--three {
  animation-delay: -.9s;
}

.cd-screen-live-check {
  stroke-dasharray: 56;
  animation: cdSkiCheckSequence 3.8s ease-in-out infinite;
}

.cd-screen-live-metric {
  opacity: .78;
  animation: cdLiveMetric 3.4s ease-in-out infinite;
}

.cd-screen-live-metric--one {
  transform: translate(448px, 446px);
}

.cd-screen-live-metric--two {
  transform: translate(732px, 446px);
  animation-delay: -1.2s;
}

.cd-screen-live-metric text:first-of-type {
  fill: #A3E7FC;
  font-family: var(--f-display);
  font-size: 52px;
  text-anchor: middle;
}

.cd-screen-live-metric path {
  fill: none;
  stroke: rgba(251, 250, 247, .24);
  stroke-width: 3;
  stroke-linecap: round;
}

.cd-live-stage--travel {
  background:
    radial-gradient(circle at 42% 22%, rgba(29, 219, 183, .14), transparent 32%),
    radial-gradient(circle at 78% 66%, rgba(163, 231, 252, .1), transparent 34%),
    var(--ink);
}

.cd-travel-live-orbit {
  fill: none;
  stroke: rgba(163, 231, 252, .18);
  stroke-width: 2;
  stroke-dasharray: 5 13;
  animation: cdTravelDash 18s linear infinite;
}

.cd-travel-live-route {
  fill: none;
  stroke: rgba(163, 231, 252, .7);
  stroke-width: 2.2;
  stroke-linecap: round;
  stroke-dasharray: 5 10;
}

.cd-travel-live-route-glow {
  fill: none;
  stroke: url(#cdTravelRouteGlow);
  stroke-width: 7;
  stroke-linecap: round;
  stroke-dasharray: 220 1100;
  animation: cdTravelRouteGlow 7.8s linear infinite;
}

.cd-travel-cursor-plane {
  position: absolute;
  left: 0;
  top: 0;
  z-index: 6;
  width: 42px;
  height: 42px;
  pointer-events: none;
  opacity: 0;
  transform:
    translate3d(var(--travel-plane-x, 560px), var(--travel-plane-y, 176px), 0)
    translate(-50%, -50%)
    rotate(var(--travel-plane-rot, -8deg))
    scale(var(--travel-plane-scale, .86));
  transform-origin: center;
  transition: opacity .24s ease;
  filter:
    brightness(0) saturate(100%)
    invert(84%) sepia(70%) saturate(2154%)
    hue-rotate(107deg) brightness(92%) contrast(89%)
    drop-shadow(0 16px 20px rgba(29, 219, 183, .18));
}

.cd-live-stage--travel.is-plane-active .cd-travel-cursor-plane {
  opacity: .94;
  --travel-plane-scale: 1;
}

.cd-travel-live-node circle {
  fill: #0A1220;
  stroke: rgba(29, 219, 183, .72);
  stroke-width: 2;
  animation: cdScreenNodePulse 4.2s ease-in-out infinite;
  transform-box: fill-box;
  transform-origin: center;
}

.cd-travel-live-node:nth-of-type(2) circle { animation-delay: -.7s; }
.cd-travel-live-node:nth-of-type(3) circle { animation-delay: -1.4s; }
.cd-travel-live-node:nth-of-type(4) circle { animation-delay: -2.1s; }
.cd-travel-live-node:nth-of-type(5) circle { animation-delay: -2.8s; }

.cd-travel-live-node path {
  fill: none;
  stroke: var(--accent);
  stroke-width: 2.2;
  stroke-linecap: round;
  stroke-linejoin: round;
}

.cd-travel-live-node text,
.cd-travel-live-card text,
.cd-travel-live-metric text:last-of-type {
  fill: rgba(251, 250, 247, .64);
  font-family: var(--f-mono);
  font-size: 13px;
  letter-spacing: .16em;
  text-anchor: middle;
  text-transform: uppercase;
}

.cd-travel-live-card {
  transform-box: fill-box;
  filter: drop-shadow(0 24px 34px rgba(0,0,0,.22));
  animation: cdScreenCard 9s ease-in-out infinite;
}

.cd-travel-live-card--recommend {
  transform: translate(170px, 88px);
}

.cd-travel-live-card--issue {
  transform: translate(642px, 86px);
  animation-delay: -3s;
}

.cd-travel-live-card--dashboard {
  transform: translate(790px, 354px);
  animation-delay: -6s;
}

.cd-travel-live-card rect {
  fill: rgba(251, 250, 247, .06);
  stroke: rgba(163, 231, 252, .22);
  stroke-width: 1.2;
}

.cd-travel-live-card path {
  fill: none;
  stroke: rgba(29, 219, 183, .82);
  stroke-width: 2.4;
  stroke-linecap: round;
  stroke-linejoin: round;
}

.cd-travel-live-card circle {
  fill: var(--accent);
  animation: cdLiveCardDot 2.4s ease-in-out infinite;
  transform-box: fill-box;
  transform-origin: center;
}

.cd-travel-live-card text {
  text-anchor: start;
}

.cd-travel-live-loading {
  stroke-width: 9 !important;
  stroke: rgba(29, 219, 183, .24) !important;
  animation: cdScreenLoading 3s ease-in-out infinite;
  transform-box: fill-box;
  transform-origin: left center;
}

.cd-travel-live-loading--two {
  animation-delay: -.45s;
}

.cd-travel-live-check {
  stroke-dasharray: 56;
  animation: cdSkiCheckSequence 3.8s ease-in-out infinite;
}

.cd-travel-live-metric {
  opacity: .78;
  animation: cdLiveMetric 3.4s ease-in-out infinite;
}

.cd-travel-live-metric--one {
  transform: translate(442px, 448px);
}

.cd-travel-live-metric--two {
  transform: translate(734px, 448px);
  animation-delay: -1.2s;
}

.cd-travel-live-metric text:first-of-type {
  fill: #A3E7FC;
  font-family: var(--f-display);
  font-size: 52px;
  text-anchor: middle;
}

.cd-travel-live-metric path {
  fill: none;
  stroke: rgba(251, 250, 247, .24);
  stroke-width: 3;
  stroke-linecap: round;
}

.cd-travel-mobile {
  display: none;
}

.cd-screen-mobile {
  display: none;
}

.cd-next-screen-icons {
  position: absolute;
  inset: -10%;
  z-index: 1;
  pointer-events: none;
}

.cd-next-screen-icons span {
  position: absolute;
  width: var(--screen-w, 56px);
  height: var(--screen-h, 82px);
  border: 2px solid rgba(29, 219, 183, .44);
  border-radius: 16px;
  opacity: 0;
  transform: translate3d(var(--screen-x), var(--screen-y), 0) rotate(var(--screen-r)) scale(.72);
  transition: opacity .5s ease, transform .82s cubic-bezier(.16, 1, .3, 1);
  filter: drop-shadow(0 18px 24px rgba(29, 219, 183, .08));
}

.cd-next-screen-icons span::before,
.cd-next-screen-icons span::after {
  content: "";
  position: absolute;
  left: 50%;
  transform: translateX(-50%);
  background: rgba(163, 231, 252, .46);
}

.cd-next-screen-icons span::before {
  top: 8px;
  width: 18px;
  height: 2px;
  border-radius: 99px;
}

.cd-next-screen-icons span::after {
  bottom: 7px;
  width: 7px;
  aspect-ratio: 1;
  border-radius: 50%;
}

.cd-next-screen-icons span:nth-child(1) { top: 8%; left: 2.4%; --screen-w: 58px; --screen-h: 86px; --screen-x: -72px; --screen-y: -4px; --screen-r: -9deg; transition-delay: .00s; }
.cd-next-screen-icons span:nth-child(2) { top: 18%; left: 13.5%; --screen-w: 50px; --screen-h: 74px; --screen-x: -58px; --screen-y: 6px; --screen-r: 11deg; transition-delay: .04s; }
.cd-next-screen-icons span:nth-child(3) { top: 31%; left: 4.8%; --screen-w: 52px; --screen-h: 76px; --screen-x: -62px; --screen-y: -2px; --screen-r: -6deg; transition-delay: .08s; }
.cd-next-screen-icons span:nth-child(4) { top: 43%; left: 15.8%; --screen-w: 48px; --screen-h: 72px; --screen-x: -48px; --screen-y: 8px; --screen-r: 13deg; transition-delay: .12s; }
.cd-next-screen-icons span:nth-child(5) { top: 62%; left: 7.2%; --screen-w: 54px; --screen-h: 80px; --screen-x: -56px; --screen-y: 14px; --screen-r: -10deg; transition-delay: .16s; }
.cd-next-screen-icons span:nth-child(6) { top: 78%; left: 20.5%; --screen-w: 48px; --screen-h: 70px; --screen-x: -46px; --screen-y: 22px; --screen-r: 4deg; transition-delay: .20s; }
.cd-next-screen-icons span:nth-child(7) { top: 50%; left: 1.8%; --screen-w: 46px; --screen-h: 68px; --screen-x: -60px; --screen-y: 0; --screen-r: 8deg; transition-delay: .24s; }
.cd-next-screen-icons span:nth-child(8) { top: 70%; left: 28%; --screen-w: 44px; --screen-h: 66px; --screen-x: -42px; --screen-y: 18px; --screen-r: -7deg; transition-delay: .28s; }
.cd-next-screen-icons span:nth-child(9) { top: 6%; right: 5.2%; --screen-w: 56px; --screen-h: 82px; --screen-x: 74px; --screen-y: -6px; --screen-r: 10deg; transition-delay: .00s; }
.cd-next-screen-icons span:nth-child(10) { top: 23%; right: 15%; --screen-w: 48px; --screen-h: 72px; --screen-x: 58px; --screen-y: 4px; --screen-r: -8deg; transition-delay: .04s; }
.cd-next-screen-icons span:nth-child(11) { top: 31%; right: 4.4%; --screen-w: 52px; --screen-h: 78px; --screen-x: 64px; --screen-y: -3px; --screen-r: -13deg; transition-delay: .08s; }
.cd-next-screen-icons span:nth-child(12) { top: 51%; right: 16.8%; --screen-w: 50px; --screen-h: 74px; --screen-x: 52px; --screen-y: 8px; --screen-r: 5deg; transition-delay: .12s; }
.cd-next-screen-icons span:nth-child(13) { top: 61%; right: 4.2%; --screen-w: 54px; --screen-h: 80px; --screen-x: 66px; --screen-y: 14px; --screen-r: -11deg; transition-delay: .16s; }
.cd-next-screen-icons span:nth-child(14) { top: 79%; right: 15.5%; --screen-w: 48px; --screen-h: 72px; --screen-x: 54px; --screen-y: 22px; --screen-r: -6deg; transition-delay: .20s; }
.cd-next-screen-icons span:nth-child(15) { top: 79%; right: 3.8%; --screen-w: 46px; --screen-h: 68px; --screen-x: 48px; --screen-y: 18px; --screen-r: 8deg; transition-delay: .24s; }
.cd-next-screen-icons span:nth-child(16) { top: 44%; right: 27%; --screen-w: 44px; --screen-h: 66px; --screen-x: 44px; --screen-y: 0; --screen-r: -5deg; transition-delay: .28s; }

.cd-next-inner:hover .cd-next-screen-icons span,
.cd-next-inner:focus-within .cd-next-screen-icons span,
.cd-next-inner.is-screen-active .cd-next-screen-icons span {
  opacity: .72;
  transform: translate3d(0, 0, 0) rotate(var(--screen-r)) scale(1);
  animation: cdScreenIconFloat 4s ease-in-out infinite;
}

.cd-next-inner:hover .cd-next-screen-icons span:nth-child(2n),
.cd-next-inner:focus-within .cd-next-screen-icons span:nth-child(2n),
.cd-next-inner.is-screen-active .cd-next-screen-icons span:nth-child(2n) {
  animation-delay: -1.2s;
}


.cd-section-head {
  max-width: 860px;
  margin-bottom: 36px;
}

.cd-section-head h2,
.cd-next h2 {
  margin-top: 24px;
  font-family: var(--f-display);
  font-size: clamp(42px, 5vw, 76px);
  line-height: 0.96;
  letter-spacing: -0.035em;
}

.cd-brief-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 16px;
}

.cd-info-card {
  position: relative;
  min-height: 300px;
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  isolation: isolate;
  overflow: hidden;
  padding: 40px 34px 34px;
  border: 1px solid rgba(10, 18, 32, 0.1);
  border-radius: 8px;
  background: rgba(255, 255, 255, 0.72);
  color: var(--ink);
  text-decoration: none;
  cursor: default;
  transition: color .45s, border-color .45s, transform .45s;
}

.cd-info-card > :not(.cd-info-card__bg) {
  position: relative;
  z-index: 1;
}

.cd-info-card__bg {
  position: absolute;
  inset: 0;
  z-index: 0;
  background: var(--ink);
  transform: translateY(100%);
  transition: transform .7s cubic-bezier(.2, .85, .25, 1);
}

.cd-info-card:hover,
.cd-info-card:focus,
.cd-info-card:focus-visible {
  color: var(--bg);
  border-color: rgba(10, 18, 32, 0.22);
  transform: translateY(-2px);
}

.cd-info-card:hover .cd-info-card__bg,
.cd-info-card:focus .cd-info-card__bg,
.cd-info-card:focus-visible .cd-info-card__bg {
  transform: translateY(0);
}

.cd-info-card:focus-visible {
  outline: 2px solid rgba(29, 219, 183, 0.55);
  outline-offset: 4px;
}

.cd-info-card__head {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  margin-bottom: 60px;
}

.cd-info-card__num {
  color: var(--ink-mute);
  transition: color .4s;
}

.cd-info-card__icon {
  width: 44px;
  height: 44px;
  display: grid;
  place-items: center;
  border: 1px solid currentColor;
  border-radius: 50%;
  color: currentColor;
  opacity: .86;
  transition: transform .5s cubic-bezier(.2, .85, .25, 1), opacity .4s;
}

.cd-info-card:hover .cd-info-card__num,
.cd-info-card:focus .cd-info-card__num,
.cd-info-card:focus-visible .cd-info-card__num {
  color: var(--blue-glow);
}

.cd-info-card:hover .cd-info-card__icon,
.cd-info-card:focus .cd-info-card__icon,
.cd-info-card:focus-visible .cd-info-card__icon {
  opacity: 1;
  transform: rotate(-12deg) scale(1.1);
}

.cd-info-card__title {
  max-width: 8ch;
  font-family: var(--f-display);
  font-size: clamp(34px, 3.2vw, 48px);
  line-height: .96;
  letter-spacing: -0.02em;
}

.cd-info-card__desc {
  margin-top: 22px;
  color: var(--ink-soft);
  font-size: 15px;
  line-height: 1.46;
  transition: color .4s;
}

.cd-info-card:hover .cd-info-card__desc,
.cd-info-card:focus .cd-info-card__desc,
.cd-info-card:focus-visible .cd-info-card__desc {
  color: rgba(255, 255, 255, 0.65);
}

.cd-diagnosis {
  padding: 104px 0;
  background: var(--ink);
  color: var(--bg);
}

.cd-section-head--light .eyebrow {
  color: rgba(251, 250, 247, 0.56);
}

.cd-section-head--light .eyebrow::before {
  background: var(--accent);
}

.cd-section-head--light h2 {
  color: var(--bg);
}

.cd-columns {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 18px;
}

.cd-column {
  display: grid;
  gap: 12px;
}

.cd-column-label {
  color: rgba(251, 250, 247, 0.52);
  margin-bottom: 4px;
}

.cd-list-card {
  min-height: 184px;
  padding: 24px;
  border: 1px solid rgba(251, 250, 247, 0.12);
  border-radius: 8px;
  background: rgba(255, 255, 255, 0.045);
}

.cd-list-card--solution {
  border-color: rgba(29, 219, 183, 0.24);
  background: rgba(29, 219, 183, 0.06);
}

.cd-list-card span {
  color: var(--accent);
}

.cd-list-card h3,
.cd-flow-step h3 {
  margin-top: 32px;
  font-family: var(--f-display);
  font-size: clamp(30px, 3vw, 44px);
  line-height: 1;
  letter-spacing: -0.03em;
}

.cd-list-card p {
  margin-top: 14px;
  color: rgba(251, 250, 247, 0.68);
  font-size: 16px;
  line-height: 1.48;
}

.cd-flow-steps {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  border: 1px solid rgba(10, 18, 32, 0.1);
  border-radius: 8px;
  overflow: hidden;
}

.cd-flow-step {
  min-height: 250px;
  padding: 26px;
  border-right: 1px solid rgba(10, 18, 32, 0.1);
  background: rgba(255, 255, 255, 0.5);
}

.cd-flow-step:last-child {
  border-right: 0;
}

.cd-flow-step span {
  color: var(--brand);
}

.cd-flow-step p {
  margin-top: 16px;
  color: var(--ink-soft);
  font-size: 16px;
  line-height: 1.48;
}

.cd-next {
  padding-bottom: 122px;
}

.cd-next-inner {
  position: relative;
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(240px, 360px) max-content;
  gap: clamp(24px, 5vw, 64px);
  align-items: end;
  padding: clamp(32px, 4.8vw, 58px);
  border-radius: 8px;
  background: var(--ink);
  color: var(--bg);
  overflow: hidden;
  isolation: isolate;
}

.cd-next-inner::before {
  content: "";
  position: absolute;
  inset: 0;
  z-index: 0;
  background-image:
    linear-gradient(to right, rgba(255,255,255,0.045) 1px, transparent 1px),
    linear-gradient(to bottom, rgba(255,255,255,0.045) 1px, transparent 1px);
  background-size: 52px 52px;
  mask-image: linear-gradient(90deg, rgba(0,0,0,0.68), transparent 76%);
  pointer-events: none;
}

.cd-next-inner > :not(.cd-next-shields):not(.cd-next-screen-icons):not(.cd-next-network) {
  position: relative;
  z-index: 2;
}

.cd-next--network .cd-next-inner {
  grid-template-columns: minmax(0, 1.05fr) minmax(280px, 430px) max-content;
}

.cd-next-network {
  position: absolute;
  inset: 0;
  z-index: 1;
  overflow: hidden;
  pointer-events: none;
}

.cd-next-network svg {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
}

.cd-next-network__line {
  fill: none;
  stroke: rgba(29, 219, 183, .42);
  stroke-width: 2.2;
  stroke-linecap: round;
  stroke-linejoin: round;
  stroke-dasharray: 1;
  stroke-dashoffset: 1;
  opacity: 0;
  transition:
    opacity .34s ease,
    stroke-dashoffset 1.15s cubic-bezier(.16, 1, .3, 1);
}

.cd-next-network__line--two {
  stroke: rgba(163, 231, 252, .34);
  transition-delay: .08s;
}

.cd-next-network__line--three {
  stroke: rgba(251, 250, 247, .22);
  transition-delay: .16s;
}

.cd-next-network__dot {
  fill: rgba(29, 219, 183, .78);
  opacity: 0;
  transform: scale(.45);
  transform-box: fill-box;
  transform-origin: center;
  transition:
    opacity .38s ease,
    transform .72s cubic-bezier(.16, 1, .3, 1);
  filter: drop-shadow(0 10px 18px rgba(29, 219, 183, .16));
}

.cd-next-network__dot:nth-of-type(3n + 1) {
  fill: rgba(163, 231, 252, .78);
}

.cd-next-network__dot:nth-of-type(3n) {
  fill: rgba(251, 250, 247, .62);
}

.cd-next-network__dot--two { transition-delay: .04s; }
.cd-next-network__dot--three { transition-delay: .08s; }
.cd-next-network__dot--four { transition-delay: .12s; }
.cd-next-network__dot--five { transition-delay: .16s; }
.cd-next-network__dot--six { transition-delay: .20s; }
.cd-next-network__dot--seven { transition-delay: .24s; }
.cd-next-network__dot--eight { transition-delay: .28s; }
.cd-next-network__dot--nine { transition-delay: .32s; }

.cd-next-inner:hover .cd-next-network__line,
.cd-next-inner:focus-within .cd-next-network__line,
.cd-next-inner.is-network-active .cd-next-network__line {
  opacity: 1;
  stroke-dashoffset: 0;
}

.cd-next-inner:hover .cd-next-network__dot,
.cd-next-inner:focus-within .cd-next-network__dot,
.cd-next-inner.is-network-active .cd-next-network__dot {
  opacity: 1;
  transform: scale(1);
  animation: cdNextNetworkPulse 3.2s ease-in-out infinite;
}

.cd-next-shields {
  position: absolute;
  inset: -10%;
  z-index: 1;
  pointer-events: none;
}

.cd-next-shield {
  position: absolute;
  width: var(--shield-size, 94px);
  height: var(--shield-size, 94px);
  opacity: 0;
  --shield-enter-x: 0px;
  --shield-enter-y: 0px;
  --shield-rot: 0deg;
  transform:
    translate3d(var(--shield-enter-x), var(--shield-enter-y), 0)
    rotate(var(--shield-rot))
    scale(.78);
  transform-origin: center;
  transition:
    opacity .58s ease,
    transform .92s cubic-bezier(.16, 1, .3, 1);
  filter: drop-shadow(0 18px 28px rgba(29, 219, 183, .08));
}

.cd-next-shield svg {
  width: 100%;
  height: 100%;
  display: block;
}

.cd-next-shield path {
  fill: none;
  stroke: rgba(29, 219, 183, .52);
  stroke-width: 2.35;
  stroke-linecap: round;
  stroke-linejoin: round;
}

.cd-next-shield:nth-child(3n + 2) path {
  stroke: rgba(163, 231, 252, .42);
}

.cd-next-shield:nth-child(3n) path {
  stroke: rgba(251, 250, 247, .28);
}

.cd-next--learning .cd-next-shield {
  filter: drop-shadow(0 18px 28px rgba(29, 219, 183, .08));
}

.cd-next--learning .cd-next-shield svg {
  display: none;
}

.cd-next--learning .cd-next-shield::before {
  content: "";
  display: block;
  width: 100%;
  height: 100%;
  background: rgba(29, 219, 183, .58);
  mask: url("assets/cases/elearning.svg?v=2") center / contain no-repeat;
  -webkit-mask: url("assets/cases/elearning.svg?v=2") center / contain no-repeat;
}

.cd-next--learning .cd-next-shield:nth-child(3n + 2)::before {
  background: rgba(163, 231, 252, .46);
}

.cd-next--learning .cd-next-shield:nth-child(3n)::before {
  background: rgba(251, 250, 247, .32);
}

.cd-next-shield--l1 { top: -4%; left: -2%; --shield-size: 118px; --shield-enter-x: -74px; --shield-enter-y: -8px; --shield-rot: -10deg; transition-delay: .00s; }
.cd-next-shield--l2 { top: 18%; left: 6%; --shield-size: 92px; --shield-enter-x: -58px; --shield-enter-y: 10px; --shield-rot: 12deg; transition-delay: .04s; }
.cd-next-shield--l3 { top: 45%; left: -1%; --shield-size: 86px; --shield-enter-x: -64px; --shield-enter-y: 2px; --shield-rot: -6deg; transition-delay: .08s; }
.cd-next-shield--l4 { bottom: -9%; left: 12%; --shield-size: 104px; --shield-enter-x: -58px; --shield-enter-y: 22px; --shield-rot: 8deg; transition-delay: .12s; }
.cd-next-shield--l5 { top: 35%; left: 23%; --shield-size: 74px; --shield-enter-x: -44px; --shield-enter-y: -8px; --shield-rot: 14deg; transition-delay: .16s; }
.cd-next-shield--l6 { bottom: 16%; left: 29%; --shield-size: 82px; --shield-enter-x: -40px; --shield-enter-y: 12px; --shield-rot: -9deg; transition-delay: .20s; }
.cd-next-shield--l7 { top: 8%; left: 17%; --shield-size: 58px; --shield-enter-x: -34px; --shield-enter-y: -18px; --shield-rot: -16deg; transition-delay: .24s; }
.cd-next-shield--l8 { top: 66%; left: 4%; --shield-size: 70px; --shield-enter-x: -52px; --shield-enter-y: 18px; --shield-rot: 11deg; transition-delay: .28s; }
.cd-next-shield--l9 { bottom: 6%; left: 40%; --shield-size: 62px; --shield-enter-x: -34px; --shield-enter-y: 18px; --shield-rot: -7deg; transition-delay: .32s; }

.cd-next-shield--r1 { top: -5%; right: 5%; --shield-size: 112px; --shield-enter-x: 72px; --shield-enter-y: -10px; --shield-rot: 10deg; transition-delay: .00s; }
.cd-next-shield--r2 { top: 21%; right: -1%; --shield-size: 90px; --shield-enter-x: 58px; --shield-enter-y: 6px; --shield-rot: -8deg; transition-delay: .04s; }
.cd-next-shield--r3 { top: 48%; right: 9%; --shield-size: 96px; --shield-enter-x: 60px; --shield-enter-y: -2px; --shield-rot: 13deg; transition-delay: .08s; }
.cd-next-shield--r4 { bottom: -10%; right: 20%; --shield-size: 106px; --shield-enter-x: 62px; --shield-enter-y: 24px; --shield-rot: -12deg; transition-delay: .12s; }
.cd-next-shield--r5 { top: 33%; right: 28%; --shield-size: 76px; --shield-enter-x: 42px; --shield-enter-y: -8px; --shield-rot: 6deg; transition-delay: .16s; }
.cd-next-shield--r6 { bottom: 17%; right: 35%; --shield-size: 82px; --shield-enter-x: 40px; --shield-enter-y: 14px; --shield-rot: -5deg; transition-delay: .20s; }
.cd-next-shield--r7 { top: 10%; right: 20%; --shield-size: 60px; --shield-enter-x: 42px; --shield-enter-y: -16px; --shield-rot: 16deg; transition-delay: .24s; }
.cd-next-shield--r8 { top: 67%; right: 5%; --shield-size: 72px; --shield-enter-x: 50px; --shield-enter-y: 18px; --shield-rot: -10deg; transition-delay: .28s; }
.cd-next-shield--r9 { bottom: 7%; right: 45%; --shield-size: 62px; --shield-enter-x: 34px; --shield-enter-y: 18px; --shield-rot: 8deg; transition-delay: .32s; }

.cd-next-shield--m1 { top: 5%; left: 48%; --shield-size: 54px; --shield-enter-x: 0px; --shield-enter-y: -36px; --shield-rot: 7deg; transition-delay: .34s; }
.cd-next-shield--m2 { bottom: 3%; left: 55%; --shield-size: 58px; --shield-enter-x: 0px; --shield-enter-y: 36px; --shield-rot: -9deg; transition-delay: .38s; }

.cd-next-inner:hover .cd-next-shield,
.cd-next-inner:focus-within .cd-next-shield,
.cd-next-inner.is-shields-active .cd-next-shield {
  opacity: .68;
  transform: translate3d(0, 0, 0) rotate(var(--shield-rot)) scale(1);
  animation: cdNextShieldPulse 3.6s ease-in-out infinite;
}

.cd-next-inner:hover .cd-next-shield:nth-child(2n),
.cd-next-inner:focus-within .cd-next-shield:nth-child(2n),
.cd-next-inner.is-shields-active .cd-next-shield:nth-child(2n) {
  animation-delay: -1.1s;
}

.cd-next--learning .cd-next-inner:hover .cd-next-shield,
.cd-next--learning .cd-next-inner:focus-within .cd-next-shield,
.cd-next--learning .cd-next-inner.is-shields-active .cd-next-shield {
  opacity: .72;
  animation: cdNextLearningFloat 4.4s ease-in-out infinite;
}

.cd-next .eyebrow {
  color: rgba(251, 250, 247, 0.56);
}

.cd-next .eyebrow::before {
  background: var(--accent);
}

.cd-next h2 {
  max-width: 12ch;
}

.cd-next--network h2 {
  max-width: 15.5ch;
}

.cd-next p {
  color: rgba(251, 250, 247, 0.68);
  font-size: 18px;
  line-height: 1.52;
}

.cd-next--network p {
  max-width: 40ch;
}

.cd-next-actions {
  display: flex;
  align-items: flex-end;
  justify-content: flex-start;
  min-width: max-content;
}

.cd-next .btn {
  min-width: max-content;
  white-space: nowrap;
  flex: 0 0 auto;
  background: var(--bg);
  color: var(--ink);
  transform: none !important;
}

.cd-next .btn__fill {
  background: var(--accent);
}

.cd-next--screen .cd-next-inner {
  grid-template-columns: minmax(0, 1fr) minmax(320px, 430px);
  align-items: center;
  min-height: 430px;
  padding: clamp(42px, 5vw, 72px) clamp(30px, 5.4vw, 78px);
}

.cd-next--screen .cd-next-screen-icons {
  position: absolute;
  inset: -10%;
  z-index: 1;
}

.cd-next--screen h2 {
  max-width: 760px;
  font-size: clamp(46px, 4.5vw, 70px);
  line-height: .94;
  letter-spacing: 0;
}

.cd-next-copy {
  display: grid;
  gap: 24px;
  align-self: center;
  justify-items: start;
  transform: translateY(20px);
}

.cd-next-copy p {
  max-width: 415px;
  margin: 0;
}

.cd-next-copy .cd-next-actions {
  min-width: 0;
}

@keyframes cdDash {
  to { stroke-dashoffset: -76; }
}

@keyframes cdTravelDash {
  to { stroke-dashoffset: -160; }
}

@keyframes cdBrokerRoute {
  to { stroke-dashoffset: -44; }
}

@keyframes cdBrokerDot {
  0%, 100% { opacity: .44; transform: scale(.84); }
  50% { opacity: 1; transform: scale(1.16); }
}

@keyframes cdBrokerHub {
  0%, 100% { transform: scale(.96); }
  50% { transform: scale(1.04); }
}

@keyframes cdBrokerCheck {
  0% { stroke-dashoffset: 44; opacity: .2; }
  38%, 72% { stroke-dashoffset: 0; opacity: 1; }
  100% { stroke-dashoffset: -44; opacity: .35; }
}

@keyframes cdLearningLines {
  0%, 100% { stroke-dashoffset: 0; opacity: .72; }
  50% { stroke-dashoffset: -24; opacity: 1; }
}

@keyframes cdDot {
  0%, 100% { opacity: .72; transform: scale(1); }
  50% { opacity: 1; transform: scale(1.28); }
}

@keyframes cdFloat {
  0%, 100% { transform: translateY(0); }
  50% { transform: translateY(-6px); }
}

@keyframes cdPulse {
  0%, 100% { transform: scale(.94) rotate(-1deg); opacity: .78; }
  50% { transform: scale(1.03) rotate(2deg); opacity: .96; }
}

@keyframes cdArmsRotate {
  from { transform: translateY(4px) rotate(0deg) scale(1); }
  to { transform: translateY(4px) rotate(360deg) scale(1); }
}

@keyframes cdSnowfall {
  0% {
    opacity: 0;
    transform: translate3d(0, -28px, 0) rotate(0deg) scale(.72);
  }
  12% {
    opacity: .86;
  }
  72% {
    opacity: .86;
  }
  100% {
    opacity: 0;
    transform: translate3d(var(--snow-drift), 620px, 0) rotate(260deg) scale(1);
  }
}

@keyframes cdLogoTicker {
  from { transform: translateX(0); }
  to { transform: translateX(-50%); }
}

@keyframes cdNextShieldPulse {
  0%, 100% {
    opacity: .5;
    filter: drop-shadow(0 18px 28px rgba(29, 219, 183, .08));
  }
  50% {
    opacity: .82;
    filter: drop-shadow(0 22px 34px rgba(29, 219, 183, .18));
  }
}

@keyframes cdNextLearningFloat {
  0%, 100% {
    opacity: .46;
    transform: translate3d(0, 0, 0) rotate(var(--shield-rot)) scale(.92);
    filter: drop-shadow(0 18px 28px rgba(163, 231, 252, .08));
  }
  50% {
    opacity: .88;
    transform: translate3d(0, -12px, 0) rotate(calc(var(--shield-rot) + 5deg)) scale(1.08);
    filter: drop-shadow(0 24px 36px rgba(29, 219, 183, .18));
  }
}

@keyframes cdNextNetworkPulse {
  0%, 100% { opacity: .76; transform: scale(.94); }
  50% { opacity: 1; transform: scale(1.12); }
}

@keyframes cdLiveRail {
  to { stroke-dashoffset: -950; }
}

@keyframes cdLiveNode {
  0%, 100% { r: 38; opacity: .76; }
  50% { r: 44; opacity: 1; }
}

@keyframes cdLiveCard {
  0% { transform: translate(20px, 318px); opacity: 0; }
  8% { opacity: 1; }
  28% { transform: translate(236px, 204px); }
  54% { transform: translate(514px, 318px); }
  78% { transform: translate(824px, 204px); opacity: 1; }
  100% { transform: translate(972px, 318px); opacity: 0; }
}

@keyframes cdLiveCardDot {
  0%, 100% { opacity: .44; transform: scale(.82); }
  50% { opacity: 1; transform: scale(1.18); }
}

@keyframes cdLivePanelLine {
  0%, 100% { stroke-dashoffset: 0; opacity: .46; }
  50% { stroke-dashoffset: -80; opacity: 1; }
}

@keyframes cdLivePanelLeft {
  0%, 100% { transform: translate(84px, 72px); }
  50% { transform: translate(84px, 62px); }
}

@keyframes cdLivePanelRight {
  0%, 100% { transform: translate(850px, 330px); }
  50% { transform: translate(850px, 320px); }
}

@keyframes cdLiveMetric {
  0%, 100% { opacity: .68; }
  50% { opacity: 1; }
}

@keyframes cdSkiTrack {
  to { stroke-dashoffset: -1030; }
}

@keyframes cdSkiNodePulse {
  0%, 100% { opacity: .8; transform: scale(1); }
  50% { opacity: 1; transform: scale(1.08); }
}

@keyframes cdSkiCardSequence {
  0%, 24% {
    opacity: 1;
    translate: 0 -8px;
    scale: 1.02;
  }
  34%, 100% {
    opacity: .34;
    translate: 0 8px;
    scale: .98;
  }
}

@keyframes cdSkiMetric {
  0%, 100% { opacity: .72; }
  50% { opacity: 1; }
}

@keyframes cdSkiMetricIcon {
  0%, 100% { opacity: .72; }
  50% { opacity: 1; }
}

@keyframes cdSkiMetricSync {
  0%, 100% { stroke-dashoffset: 0; }
  50% { stroke-dashoffset: -18; }
}

@keyframes cdLearningLiveRail {
  to { stroke-dashoffset: -1060; }
}

@keyframes cdLearningSeqGlow {
  to { stroke-dashoffset: -1180; }
}

@keyframes cdLearningSeqPhase {
  0%, 30% {
    opacity: 1;
  }
  36%, 100% {
    opacity: 0;
  }
}

@keyframes cdLearningSeqPop {
  0%, 7% {
    transform: translateY(8px) scale(.96);
  }
  12%, 30% {
    transform: translateY(0) scale(1);
  }
  36%, 100% {
    transform: translateY(8px) scale(.96);
  }
}

@keyframes cdLearningNodePulse {
  0%, 100% { opacity: .78; }
  50% { opacity: 1; }
}

@keyframes cdLearningSystemOrbit {
  to { transform: rotate(360deg); }
}

@keyframes cdLearningSystemCounter {
  to { transform: rotate(-360deg); }
}

@keyframes cdLearningEmployeeGlow {
  0%, 100% {
    opacity: .5;
    transform: scale(.9);
  }
  50% {
    opacity: .86;
    transform: scale(1);
  }
}

@keyframes cdLearningSeqFloat {
  0%, 100% { opacity: .7; transform: translateY(0) scale(.96); }
  50% { opacity: 1; transform: translateY(-8px) scale(1.04); }
}

@keyframes cdLearningSeqSyncDot {
  0%, 100% { transform: translateY(46px); }
  50% { transform: translateY(-100px); }
}

@keyframes cdLearningMobileSyncDot {
  0%, 100% { transform: translateY(48px); }
  50% { transform: translateY(-38px); }
}

@keyframes cdLearningMobilePhase {
  0%, 29% { opacity: 1; }
  34%, 100% { opacity: 0; }
}

@keyframes cdLearningMobileOrbit {
  to { stroke-dashoffset: -220; }
}

@keyframes cdLearningMobileCheck {
  0%, 100% {
    opacity: .74;
    transform: translateY(0) scale(.96);
  }
  50% {
    opacity: 1;
    transform: translateY(-5px) scale(1.04);
  }
}

@keyframes cdScreenScanFrame {
  0%, 100% { opacity: .58; transform: scale(.98); }
  50% { opacity: 1; transform: scale(1.02); }
}

@keyframes cdScreenScanLine {
  to { stroke-dashoffset: -260; }
}

@keyframes cdScreenCrackHero {
  0% {
    clip-path: polygon(0 0, 0 0, 0 100%, 0 100%);
  }
  62% {
    clip-path: polygon(0 0, 74% 0, 92% 100%, 0 100%);
  }
  100% {
    clip-path: polygon(0 0, 100% 0, 100% 100%, 0 100%);
  }
}

@keyframes cdScreenRail {
  to { stroke-dashoffset: -1100; }
}

@keyframes cdScreenNodePulse {
  0%, 100% { opacity: .86; transform: scale(1); }
  50% { opacity: 1; transform: scale(1.08); }
}

@keyframes cdScreenPhoneFloat {
  0%, 100% { transform: translateY(0); }
  50% { transform: translateY(-10px); }
}

@keyframes cdScreenCrack {
  0%, 18% { stroke-dashoffset: 120; opacity: .28; }
  34%, 76% { stroke-dashoffset: 0; opacity: .92; }
  100% { stroke-dashoffset: -120; opacity: .28; }
}

@keyframes cdScreenPhoneScan {
  0%, 100% { transform: translateY(-34px); opacity: .28; }
  48% { transform: translateY(86px); opacity: 1; }
}

@keyframes cdScreenMobileScan {
  0%, 100% { transform: translateY(-14px); opacity: .28; }
  48% { transform: translateY(36px); opacity: 1; }
}

@keyframes cdScreenCard {
  0%, 24% { opacity: 1; }
  34%, 100% { opacity: .34; }
}

@keyframes cdScreenLoading {
  0%, 100% { opacity: .42; transform: scaleX(.2); }
  45%, 68% { opacity: 1; transform: scaleX(1); }
}

@keyframes cdScreenIconFloat {
  0%, 100% {
    filter: drop-shadow(0 18px 24px rgba(29, 219, 183, .08));
    transform: translate3d(0, 0, 0) rotate(var(--screen-r)) scale(1);
  }
  50% {
    filter: drop-shadow(0 24px 32px rgba(29, 219, 183, .18));
    transform: translate3d(0, -10px, 0) rotate(calc(var(--screen-r) + 5deg)) scale(1.05);
  }
}

@keyframes cdTravelRouteGlow {
  to { stroke-dashoffset: -1100; }
}

@keyframes cdTravelOrbitPulse {
  0%, 100% {
    opacity: .44;
    transform: scale(.94);
  }
  50% {
    opacity: .78;
    transform: scale(1.06);
  }
}

@keyframes cdSkiCodeLoadOne {
  0%, 32%, 66%, 100% { opacity: 0; transform: scaleX(0); }
  36%, 58% { opacity: 1; transform: scaleX(1); }
}

@keyframes cdSkiCodeLoadTwo {
  0%, 37%, 68%, 100% { opacity: 0; transform: scaleX(0); }
  42%, 60% { opacity: 1; transform: scaleX(1); }
}

@keyframes cdSkiCodeLoadThree {
  0%, 42%, 70%, 100% { opacity: 0; transform: scaleX(0); }
  48%, 62% { opacity: 1; transform: scaleX(1); }
}

@keyframes cdSkiCheck {
  0%, 32% { stroke-dashoffset: 56; }
  50%, 82% { stroke-dashoffset: 0; }
  100% { stroke-dashoffset: -56; }
}

@keyframes cdSkiCheckSequence {
  0%, 8% { stroke-dashoffset: 56; }
  18%, 34% { stroke-dashoffset: 0; }
  48%, 100% { stroke-dashoffset: -56; }
}

@keyframes cdSkiSnow {
  0% { opacity: 0; transform: translateY(-22px); }
  14% { opacity: .74; }
  88% { opacity: .74; }
  100% { opacity: 0; transform: translateY(96px); }
}

@media (max-width: 980px) {
  .cd-hero-grid,
  .cd-brief-grid,
  .cd-columns,
  .cd-live-head,
  .cd-next-inner {
    grid-template-columns: 1fr;
  }

  .cd-hero-title {
    max-width: 12ch;
  }

  .cd-hero-visual {
    max-width: 420px;
  }

  .case-detail-hero--learning .cd-hero-visual {
    max-width: 480px;
    margin-top: 0;
  }

  .cd-logo-ticker {
    height: 34px;
    margin-bottom: 10px;
  }

  .cd-logo-ticker__group {
    gap: 22px;
    padding: 0 24px;
  }

  .cd-logo-ticker__item {
    width: 78px;
  }

  .cd-live-stage--ski svg,
  .cd-live-stage--learning svg,
  .cd-live-stage--screen svg,
  .cd-live-stage--travel svg {
    height: clamp(420px, 58vw, 520px);
  }

  .cd-flow-steps {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .cd-flow-step:nth-child(2) {
    border-right: 0;
  }

  .cd-flow-step:nth-child(-n + 2) {
    border-bottom: 1px solid rgba(10, 18, 32, 0.1);
  }
}

@media (max-width: 680px) {
  .case-detail-hero {
    padding-top: 108px;
  }

  .cd-hero-title {
    font-size: clamp(50px, 15vw, 74px);
  }

  .case-detail-hero--broker .cd-hero-title {
    max-width: 100%;
    font-size: 50px;
  }

  .cd-visual-photo--learning {
    min-height: 236px;
  }

  .cd-visual-person--learning {
    width: min(118%, 390px);
    max-height: 252px;
  }

  .cd-stats {
    grid-template-columns: 1fr;
    padding-bottom: 56px;
  }

  .cd-live-stage--ski,
  .cd-live-stage--learning,
  .cd-live-stage--screen,
  .cd-live-stage--travel {
    overflow-x: auto;
    overflow-y: hidden;
    overscroll-behavior-x: contain;
    -webkit-overflow-scrolling: touch;
    scrollbar-width: thin;
  }

  .cd-live-stage--ski svg,
  .cd-live-stage--learning svg,
  .cd-live-stage--screen svg,
  .cd-live-stage--travel svg {
    width: 920px;
    max-width: none;
    height: 484px;
  }

  .cd-live-stage--learning {
    width: min(100%, 390px);
    margin-inline: auto;
    overflow: hidden;
    scrollbar-width: none;
  }

  .cd-live-stage--learning::-webkit-scrollbar {
    display: none;
  }

  .cd-live-stage--learning .cd-learning-seq-desktop {
    display: none;
  }

  .cd-live-stage--learning .cd-learning-seq-mobile {
    display: block;
    width: 100%;
    max-width: 100%;
    height: auto;
  }

  .cd-live-stage--screen {
    width: min(100%, 390px);
    margin-inline: auto;
    overflow: hidden;
    padding: 14px;
    scrollbar-width: none;
  }

  .cd-live-stage--screen::-webkit-scrollbar {
    display: none;
  }

  .cd-live-stage--screen > svg {
    display: none;
  }

  .cd-live-stage--travel {
    width: min(100%, 390px);
    margin-inline: auto;
    overflow: hidden;
    padding: 14px;
    scrollbar-width: none;
  }

  .cd-live-stage--travel::-webkit-scrollbar {
    display: none;
  }

  .cd-live-stage--travel > svg {
    display: none;
  }

  .cd-travel-cursor-plane {
    display: none;
  }

  .cd-travel-mobile {
    display: grid;
    gap: 14px;
  }

  .cd-travel-mobile-step {
    position: relative;
    overflow: hidden;
    display: grid;
    gap: 14px;
    padding: 18px 16px 16px;
    border: 1px solid rgba(163, 231, 252, .18);
    border-radius: 8px;
    background:
      radial-gradient(circle at 50% 8%, rgba(29, 219, 183, .12), transparent 38%),
      linear-gradient(to right, rgba(251,250,247,.045) 1px, transparent 1px),
      linear-gradient(to bottom, rgba(251,250,247,.045) 1px, transparent 1px),
      rgba(10, 18, 32, .66);
    background-size: auto, 36px 36px, 36px 36px, auto;
  }

  .cd-travel-mobile-step::after {
    content: "";
    position: absolute;
    right: -34px;
    top: -42px;
    width: 118px;
    aspect-ratio: 1;
    border: 1px dashed rgba(163, 231, 252, .2);
    border-radius: 50%;
    pointer-events: none;
  }

  .cd-travel-mobile-num {
    position: absolute;
    top: 14px;
    left: 14px;
    color: var(--accent);
    font-family: var(--f-mono);
    font-size: 11px;
    letter-spacing: .16em;
  }

  .cd-travel-mobile-card {
    position: relative;
    z-index: 1;
    width: 100%;
    min-height: 156px;
    display: grid;
    align-content: end;
    padding: 28px 16px 16px;
    border: 1px solid rgba(163, 231, 252, .2);
    border-radius: 8px;
    background: rgba(251, 250, 247, .055);
    box-shadow: 0 18px 30px rgba(0,0,0,.16);
  }

  .cd-travel-mobile-card h3 {
    margin: 0 0 8px;
    color: #fff;
    font-family: var(--f-display);
    font-size: clamp(30px, 9vw, 40px);
    font-weight: 400;
    line-height: .95;
  }

  .cd-travel-mobile-card p {
    margin: 0;
    color: rgba(251, 250, 247, .66);
    font-size: 14px;
    line-height: 1.45;
  }

  .cd-travel-mobile-icons {
    position: relative;
    z-index: 1;
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    gap: 10px;
    width: 100%;
  }

  .cd-travel-mobile-icons span {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    min-width: 0;
    padding: 8px 10px;
    border: 1px solid rgba(29, 219, 183, .24);
    border-radius: 999px;
    color: rgba(251, 250, 247, .72);
    font-family: var(--f-mono);
    font-size: 10px;
    letter-spacing: .12em;
    text-transform: uppercase;
  }

  .cd-travel-mobile-icons img {
    width: 18px;
    height: 18px;
    filter: brightness(0) saturate(100%) invert(84%) sepia(70%) saturate(2154%) hue-rotate(107deg) brightness(92%) contrast(89%);
  }

  .cd-travel-mobile-icons--single span {
    padding-inline: 18px;
  }

  .cd-travel-mobile-metrics {
    position: relative;
    z-index: 1;
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 12px;
    width: 100%;
    padding-top: 2px;
  }

  .cd-travel-mobile-metrics span {
    display: grid;
    justify-items: center;
    gap: 6px;
    color: rgba(251, 250, 247, .58);
    font-family: var(--f-mono);
    font-size: 9px;
    letter-spacing: .12em;
    text-align: center;
    text-transform: uppercase;
  }

  .cd-travel-mobile-metrics strong {
    color: #A3E7FC;
    font-family: var(--f-display);
    font-size: 34px;
    font-weight: 400;
    letter-spacing: 0;
    line-height: .9;
    text-transform: none;
  }

  .cd-travel-mobile-metrics i {
    display: block;
    width: 72px;
    height: 3px;
    border-radius: 999px;
    background: rgba(251, 250, 247, .22);
  }

  .cd-screen-mobile {
    display: grid;
    gap: 14px;
  }

  .cd-screen-mobile-step {
    position: relative;
    overflow: hidden;
    display: grid;
    justify-items: center;
    gap: 14px;
    padding: 18px 16px 16px;
    border: 1px solid rgba(163, 231, 252, .18);
    border-radius: 8px;
    background:
      radial-gradient(circle at 50% 14%, rgba(29, 219, 183, .13), transparent 36%),
      linear-gradient(to right, rgba(251,250,247,.045) 1px, transparent 1px),
      linear-gradient(to bottom, rgba(251,250,247,.045) 1px, transparent 1px),
      rgba(10, 18, 32, .66);
    background-size: auto, 36px 36px, 36px 36px, auto;
  }

  .cd-screen-mobile-num {
    position: absolute;
    top: 14px;
    left: 14px;
    color: var(--accent);
    font-family: var(--f-mono);
    font-size: 11px;
    letter-spacing: .16em;
  }

  .cd-screen-mobile-phone {
    position: relative;
    width: 72px;
    height: 108px;
    border: 2px solid rgba(29, 219, 183, .72);
    border-radius: 18px;
    background: rgba(251, 250, 247, .055);
    box-shadow: 0 20px 34px rgba(0,0,0,.18);
    animation: cdScreenPhoneFloat 5.8s ease-in-out infinite;
  }

  .cd-screen-mobile-phone::before {
    content: "";
    position: absolute;
    top: 8px;
    left: 50%;
    width: 22px;
    height: 5px;
    border-radius: 999px;
    background: rgba(251, 250, 247, .2);
    transform: translateX(-50%);
  }

  .cd-screen-mobile-screen {
    position: absolute;
    inset: 20px 9px 16px;
    border: 1px solid rgba(163, 231, 252, .28);
    border-radius: 8px;
    background: rgba(10, 18, 32, .62);
  }

  .cd-screen-mobile-scan {
    position: absolute;
    left: 11px;
    right: 11px;
    top: 42px;
    height: 5px;
    border-radius: 999px;
    background: linear-gradient(90deg, transparent, var(--accent), transparent);
    animation: cdScreenMobileScan 2.7s ease-in-out infinite;
  }

  .cd-screen-mobile-crack {
    position: absolute;
    left: 26px;
    top: 38px;
    width: 23px;
    height: 42px;
  }

  .cd-screen-mobile-crack::before {
    content: "";
    position: absolute;
    inset: 0;
    background:
      linear-gradient(120deg, transparent 0 46%, rgba(163,231,252,.82) 47% 50%, transparent 51%),
      linear-gradient(34deg, transparent 0 52%, rgba(163,231,252,.72) 53% 56%, transparent 57%);
    clip-path: polygon(46% 0, 58% 31%, 42% 47%, 53% 67%, 38% 100%, 34% 70%, 44% 48%, 31% 26%);
    animation: cdScreenCrack 4.6s ease-in-out infinite;
  }

  .cd-screen-mobile-home {
    position: absolute;
    left: 50%;
    bottom: 6px;
    width: 6px;
    height: 6px;
    border-radius: 50%;
    background: var(--accent);
    opacity: .72;
    transform: translateX(-50%);
  }

  .cd-screen-mobile-card {
    width: 100%;
    padding: 14px 16px;
    border: 1px solid rgba(163, 231, 252, .2);
    border-radius: 8px;
    background: rgba(251, 250, 247, .055);
    box-shadow: 0 18px 30px rgba(0,0,0,.16);
  }

  .cd-screen-mobile-card span {
    display: block;
    margin-bottom: 8px;
    color: var(--accent);
    font-family: var(--f-mono);
    font-size: 10px;
    letter-spacing: .16em;
  }

  .cd-screen-mobile-card h3 {
    margin: 0 0 8px;
    color: #fff;
    font-family: var(--f-display);
    font-size: clamp(30px, 9vw, 40px);
    font-weight: 400;
    line-height: .95;
  }

  .cd-screen-mobile-card p {
    margin: 0;
    color: rgba(251, 250, 247, .66);
    font-size: 14px;
    line-height: 1.45;
  }

  .cd-screen-mobile-icons {
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    gap: 10px;
    width: 100%;
  }

  .cd-screen-mobile-icons span {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    min-width: 0;
    padding: 8px 10px;
    border: 1px solid rgba(29, 219, 183, .24);
    border-radius: 999px;
    color: rgba(251, 250, 247, .72);
    font-family: var(--f-mono);
    font-size: 10px;
    letter-spacing: .12em;
    text-transform: uppercase;
  }

  .cd-screen-mobile-icons img {
    width: 18px;
    height: 18px;
    filter: brightness(0) saturate(100%) invert(84%) sepia(70%) saturate(2154%) hue-rotate(107deg) brightness(92%) contrast(89%);
  }

  .cd-screen-mobile-icons--single span {
    padding-inline: 18px;
  }

  .cd-screen-mobile-metrics {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 12px;
    width: 100%;
    padding-top: 2px;
  }

  .cd-screen-mobile-metrics span {
    display: grid;
    justify-items: center;
    gap: 6px;
    color: rgba(251, 250, 247, .58);
    font-family: var(--f-mono);
    font-size: 9px;
    letter-spacing: .12em;
    text-align: center;
    text-transform: uppercase;
  }

  .cd-screen-mobile-metrics strong {
    color: #A3E7FC;
    font-family: var(--f-display);
    font-size: 34px;
    font-weight: 400;
    letter-spacing: 0;
    line-height: .9;
    text-transform: none;
  }

  .cd-screen-mobile-metrics i {
    display: block;
    width: 72px;
    height: 3px;
    border-radius: 999px;
    background: rgba(251, 250, 247, .22);
  }

  .cd-ski-live-card {
    animation-duration: 7.8s;
  }

  .cd-ski-live-card--api {
    animation-delay: 2.6s;
  }

  .cd-ski-live-card--policy {
    animation-delay: 5.2s;
  }

  .cd-ski-live-check {
    animation-duration: 7.8s;
    animation-delay: 5.2s;
  }

  .cd-ski-live-node text,
  .cd-ski-live-card text,
  .cd-ski-live-metric-label,
  .cd-screen-live-node text,
  .cd-screen-live-card text,
  .cd-screen-live-metric text:last-of-type {
    font-size: 13px;
  }

  .cd-info-card {
    min-height: 280px;
    padding: 30px 26px 28px;
  }

  .cd-info-card__head {
    margin-bottom: 44px;
  }

  .cd-info-card__title {
    font-size: clamp(32px, 10vw, 42px);
  }

  .cd-flow-steps {
    grid-template-columns: 1fr;
  }

  .cd-flow-step,
  .cd-flow-step:nth-child(2),
  .cd-flow-step:nth-child(-n + 2) {
    border-right: 0;
    border-bottom: 1px solid rgba(10, 18, 32, 0.1);
  }

  .cd-flow-step:last-child {
    border-bottom: 0;
  }

  .cd-next {
    padding-bottom: 84px;
  }

  .cd-next-shield {
    --shield-size: 68px !important;
  }

  .cd-next-shield--l2,
  .cd-next-shield--l5,
  .cd-next-shield--l6,
  .cd-next-shield--l7,
  .cd-next-shield--l8,
  .cd-next-shield--l9,
  .cd-next-shield--m1,
  .cd-next-shield--m2,
  .cd-next-shield--r2,
  .cd-next-shield--r5,
  .cd-next-shield--r6,
  .cd-next-shield--r7,
  .cd-next-shield--r8,
  .cd-next-shield--r9 {
    display: none;
  }

  .cd-next-screen-icons span:nth-child(2n) {
    display: none;
  }
}

@media (prefers-reduced-motion: reduce) {
  .cd-flow-line,
  .cd-flow-dot,
  .cd-mini-panel,
  .cd-visual-circles,
  .cd-visual-arms,
  .cd-logo-ticker__track,
  .cd-next-shield,
  .cd-live-rail-glow,
  .cd-live-node circle,
  .cd-live-card,
  .cd-live-card circle,
  .cd-live-panel,
  .cd-live-panel path,
  .cd-live-metric,
  .cd-snowfall span,
  .cd-ski-live-track-glow,
  .cd-ski-live-node circle,
  .cd-ski-live-card,
  .cd-ski-live-card circle,
  .cd-ski-live-check,
  .cd-ski-live-metric,
  .cd-ski-live-metric-icon,
  .cd-ski-live-metric-icon--sync path,
  .cd-ski-live-code-loading__bar,
  .cd-ski-live-snow circle,
  .cd-visual-mini--learning .case-svg__screen,
  .cd-visual-mini--learning .case-svg__badge,
  .cd-visual-mini--learning .case-svg__learning-lines,
  .cd-visual-mini--learning .case-svg__learning-dot,
  .cd-learning-live-orbit,
  .cd-learning-live-track-glow,
  .cd-learning-live-node circle,
  .cd-learning-live-card,
  .cd-learning-live-card circle,
  .cd-learning-live-check,
  .cd-learning-live-metric,
  .cd-learning-system-hr-halo,
  .cd-learning-system-hr-glow,
  .cd-learning-system-scan,
  .cd-learning-system-orbiting,
  .cd-learning-system-node-upright,
  .cd-learning-system-sphere,
  .cd-learning-system-small circle,
  .cd-learning-system-hr circle,
  .cd-learning-system-employee-glow,
  .cd-learning-seq-halo,
  .cd-learning-seq-outer-glow,
  .cd-learning-seq-phase,
  .cd-learning-seq-active-dot,
  .cd-learning-seq-connector,
  .cd-learning-seq-employee-aura,
  .cd-learning-seq-float,
  .cd-learning-mobile-phase,
  .cd-learning-mobile-orbit-glow,
  .cd-learning-mobile-check,
  .cd-screen-live-rail-glow,
  .cd-screen-live-node circle,
  .cd-screen-live-phone,
  .cd-screen-live-crack,
  .cd-screen-live-scan,
  .cd-screen-live-card,
  .cd-screen-live-card circle,
  .cd-screen-live-loading,
  .cd-screen-live-check,
  .cd-screen-live-metric,
  .cd-travel-orbits span,
  .cd-visual-mini--travel .case-svg__travel-route,
  .cd-visual-mini--travel .case-svg__travel-pin,
  .cd-visual-mini--travel .case-svg__travel-policy,
  .cd-visual-mini--travel .case-svg__travel-plane,
  .cd-visual-mini--broker .case-svg__broker-route,
  .cd-visual-mini--broker .case-svg__broker-dot,
  .cd-visual-mini--broker .case-svg__nodes,
  .cd-visual-mini--broker .case-svg__broker-card,
  .cd-visual-mini--broker .case-svg__broker-hub,
  .cd-visual-mini--broker .case-svg__broker-check,
  .cd-travel-live-orbit,
  .cd-travel-live-route-glow,
  .cd-travel-live-node circle,
  .cd-travel-live-card,
  .cd-travel-live-card circle,
  .cd-travel-live-loading,
  .cd-travel-live-check,
  .cd-travel-live-metric,
  .cd-screen-mobile-phone,
  .cd-screen-mobile-scan,
  .cd-screen-mobile-crack::before,
  .cd-next-screen-icons span {
    animation: none !important;
  }

  .cd-learning-seq-phase {
    opacity: 0;
  }

  .cd-learning-seq-phase--course {
    opacity: 1;
  }

  .cd-learning-mobile-phase--course {
    opacity: 1;
  }

  .cd-info-card,
  .cd-info-card__bg,
  .cd-info-card__icon {
    transition: none;
  }

  .cd-next-shield {
    transition: none;
  }

  .cd-next-inner:hover .cd-next-shield,
  .cd-next-inner:focus-within .cd-next-shield,
  .cd-next-inner.is-shields-active .cd-next-shield {
    animation: none;
  }

  .cd-next-network__line,
  .cd-next-network__dot,
  .cd-next-inner:hover .cd-next-network__dot,
  .cd-next-inner:focus-within .cd-next-network__dot,
  .cd-next-inner.is-network-active .cd-next-network__dot {
    animation: none;
    transition: none;
  }

  .cd-live-stage {
    transition: none;
  }

  .cd-ski-live-card {
    opacity: 1;
    translate: 0 0;
    scale: 1;
  }

  .cd-ski-live-check {
    stroke-dashoffset: 0;
  }

  .cd-info-card:hover,
  .cd-info-card:focus,
  .cd-info-card:focus-visible {
    transform: none;
  }

  .cd-live-stage:hover {
    transform: none;
  }
}
