/* AUTO-GENERATED from make_video/cloudspects-hero-demo.html — keep in sync */
.cs-hero-demo,
.cs-hero-demo * {
  box-sizing: border-box;
}

.cs-hero-demo {
  font-family: Inter, ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
  color: var(--white);
}

.cs-hero-demo {
      --navy: #0B1124;
      --panel: rgba(12, 24, 49, .68);
      --panel-strong: rgba(16, 33, 63, .86);
      --line: rgba(0, 212, 255, .28);
      --cyan: #00D4FF;
      --teal: #20E6C3;
      --green: #5EFFA8;
      --red: #FF5A6E;
      --white: #F7FBFF;
      --muted: #9BB4CF;
      --shadow: 0 26px 80px rgba(0, 0, 0, .32);
    }

    .cs-hero-demo {
      position: relative;
      width: 100%;
      max-width: 100%;
      height: min(100vh, 900px);
      min-height: 620px;
      overflow: hidden;
      background:
        radial-gradient(circle at 72% 20%, rgba(0, 212, 255, .13), transparent 28%),
        radial-gradient(circle at 18% 84%, rgba(32, 230, 195, .11), transparent 32%),
        linear-gradient(135deg, #081025 0%, #0B1124 48%, #08162E 100%);
      isolation: isolate;
    }

    .cs-hero-demo canvas {
      position: absolute;
      inset: 0;
      width: 100%;
      height: 100%;
      z-index: 0;
    }

    .cs-hero-demo .grid {
      position: absolute;
      inset: 0;
      z-index: 1;
      opacity: .42;
      background-image:
        linear-gradient(rgba(0, 212, 255, .095) 1px, transparent 1px),
        linear-gradient(90deg, rgba(0, 212, 255, .095) 1px, transparent 1px);
      background-size: 56px 56px;
      mask-image: radial-gradient(circle at 50% 47%, black 0%, transparent 73%);
      transform: perspective(900px) rotateX(58deg) translateY(22vh) scale(1.35);
      transform-origin: 50% 100%;
    }

    .cs-hero-demo .vignette {
      position: absolute;
      inset: 0;
      z-index: 2;
      pointer-events: none;
      background:
        linear-gradient(90deg, rgba(11, 17, 36, .86), transparent 18%, transparent 82%, rgba(11, 17, 36, .84)),
        linear-gradient(180deg, rgba(11, 17, 36, .46), transparent 42%, rgba(11, 17, 36, .7));
    }

    .cs-hero-demo .stage {
      position: relative;
      z-index: 3;
      display: grid;
      width: min(1500px, calc(100% - 72px));
      height: min(900px, calc(100% - 56px));
      min-height: 560px;
      margin: 28px auto;
      place-items: center;
    }

    .cs-hero-demo .scene {
      position: absolute;
      inset: 0;
      display: grid;
      place-items: center;
      opacity: 0;
      transform: translateY(18px) scale(.985);
      pointer-events: none;
      transition: opacity .75s ease, transform .75s ease;
    }

    .cs-hero-demo .scene.active {
      opacity: 1;
      transform: translateY(0) scale(1);
      pointer-events: auto;
    }

    .cs-hero-demo .brand-lockup {
      display: grid;
      justify-items: center;
      gap: 22px;
      text-align: center;
    }

    .cs-hero-demo .logo-mark {
      display: flex;
      align-items: center;
      gap: 22px;
      filter: drop-shadow(0 18px 48px rgba(0, 212, 255, .18));
    }

    .cs-hero-demo .cloud-icon {
      width: clamp(78px, 7vw, 118px);
      height: clamp(58px, 5.2vw, 86px);
      color: var(--cyan);
    }

    .cs-hero-demo .wordmark {
      margin: 0;
      font-size: clamp(44px, 7vw, 112px);
      line-height: .9;
      font-weight: 800;
      letter-spacing: 0;
      color: #fff;
    }

    .cs-hero-demo .tagline {
      margin: 0;
      color: #D8F7FF;
      font-size: clamp(17px, 1.7vw, 28px);
      font-weight: 600;
      opacity: .92;
    }

    .cs-hero-demo .process-wrap {
      display: grid;
      width: 100%;
      gap: 48px;
      align-content: center;
    }

    .cs-hero-demo .section-title {
      margin: 0;
      text-align: center;
      color: #F8FCFF;
      font-size: clamp(28px, 4.2vw, 66px);
      line-height: 1;
      font-weight: 800;
      letter-spacing: 0;
    }

    .cs-hero-demo .section-kicker {
      display: block;
      margin-bottom: 12px;
      color: var(--cyan);
      font-size: clamp(13px, 1.2vw, 17px);
      font-weight: 700;
      text-transform: uppercase;
      letter-spacing: .16em;
    }

    .cs-hero-demo .process {
      position: relative;
      display: grid;
      grid-template-columns: repeat(3, minmax(0, 1fr));
      align-items: stretch;
      gap: clamp(18px, 4vw, 72px);
      width: min(1180px, 100%);
      margin: 0 auto;
    }

    .cs-hero-demo .flow-line {
      position: absolute;
      top: 50%;
      left: 15%;
      right: 15%;
      height: 3px;
      transform: translateY(-50%);
      background: rgba(0, 212, 255, .14);
      overflow: hidden;
      z-index: -1;
    }

    .cs-hero-demo .flow-line::after {
      content: "";
      position: absolute;
      inset: 0;
      width: 42%;
      background: linear-gradient(90deg, transparent, var(--cyan), var(--teal), transparent);
      filter: drop-shadow(0 0 14px rgba(0, 212, 255, .7));
      animation: flow 2.6s linear infinite;
    }

    .cs-hero-demo .step-card,
    .cs-hero-demo .stat-card,
    .cs-hero-demo .trust-card {
      border: 1px solid rgba(118, 232, 255, .18);
      background: linear-gradient(180deg, rgba(20, 39, 75, .86), rgba(10, 22, 46, .7));
      box-shadow: var(--shadow);
      backdrop-filter: blur(14px);
    }

    .cs-hero-demo .step-card {
      display: grid;
      min-height: 248px;
      padding: clamp(22px, 3vw, 38px);
      border-radius: 8px;
      align-content: center;
      justify-items: center;
      gap: 18px;
      text-align: center;
    }

    .cs-hero-demo .step-icon {
      display: grid;
      width: clamp(72px, 7vw, 106px);
      aspect-ratio: 1;
      place-items: center;
      border-radius: 8px;
      background: rgba(0, 212, 255, .1);
      color: var(--cyan);
      box-shadow: inset 0 0 0 1px rgba(0, 212, 255, .24), 0 0 34px rgba(0, 212, 255, .16);
    }

    .cs-hero-demo .step-card h3,
    .cs-hero-demo .stat-card h3,
    .cs-hero-demo .trust-card h3 {
      margin: 0;
      font-size: clamp(21px, 2vw, 33px);
      line-height: 1.05;
      letter-spacing: 0;
    }

    .cs-hero-demo .step-card p,
    .cs-hero-demo .stat-card p,
    .cs-hero-demo .trust-card p {
      margin: 0;
      color: var(--muted);
      font-size: clamp(13px, 1.1vw, 17px);
      line-height: 1.5;
    }

    .cs-hero-demo .stats-grid {
      display: grid;
      grid-template-columns: repeat(4, minmax(0, 1fr));
      gap: 18px;
      width: min(1220px, 100%);
      margin: 42px auto 0;
    }

    .cs-hero-demo .stat-card {
      display: grid;
      min-height: 210px;
      padding: 28px;
      border-radius: 8px;
      align-content: space-between;
      gap: 18px;
      transform-origin: 50% 60%;
    }

    .cs-hero-demo .stat-icon {
      display: grid;
      width: 48px;
      aspect-ratio: 1;
      place-items: center;
      border-radius: 8px;
      background: rgba(255, 255, 255, .06);
    }

    .cs-hero-demo .warning {
      color: var(--red);
    }

    .cs-hero-demo .price {
      color: var(--cyan);
    }

    .cs-hero-demo .success {
      color: var(--green);
    }

    .cs-hero-demo .trust-layout {
      display: grid;
      grid-template-columns: 1fr 1.05fr 1fr;
      gap: clamp(18px, 2.5vw, 34px);
      width: min(1160px, 100%);
      margin: 42px auto 0;
      align-items: center;
    }

    .cs-hero-demo .trust-card {
      position: relative;
      display: grid;
      min-height: 320px;
      padding: 30px;
      border-radius: 8px;
      overflow: hidden;
      align-content: end;
      gap: 12px;
    }

    .cs-hero-demo .badge-ring,
    .cs-hero-demo .avatar,
    .cs-hero-demo .globe {
      position: absolute;
      top: 28px;
      left: 50%;
      transform: translateX(-50%);
    }

    .cs-hero-demo .badge-ring {
      display: grid;
      width: 138px;
      aspect-ratio: 1;
      place-items: center;
      border: 2px solid rgba(0, 212, 255, .5);
      border-radius: 50%;
      color: var(--cyan);
      background: radial-gradient(circle, rgba(0, 212, 255, .18), transparent 66%);
    }

    .cs-hero-demo .badge-ring::before,
    .cs-hero-demo .badge-ring::after {
      content: "";
      position: absolute;
      inset: -12px;
      border: 1px solid rgba(0, 212, 255, .22);
      border-radius: 50%;
      animation: orbit 5.5s linear infinite;
    }

    .cs-hero-demo .badge-ring::after {
      inset: -24px;
      animation-duration: 7s;
      animation-direction: reverse;
    }

    .cs-hero-demo .avatar {
      display: grid;
      width: 150px;
      aspect-ratio: 1;
      place-items: center;
      border-radius: 50%;
      background:
        radial-gradient(circle at 50% 38%, #DCEBFF 0 12%, transparent 13%),
        radial-gradient(circle at 50% 72%, #00D4FF 0 28%, transparent 29%),
        linear-gradient(145deg, rgba(0, 212, 255, .18), rgba(32, 230, 195, .08));
      border: 1px solid rgba(118, 232, 255, .35);
      box-shadow: 0 0 42px rgba(0, 212, 255, .16);
    }

    .cs-hero-demo .avatar::after {
      content: "";
      position: absolute;
      right: 13px;
      bottom: 24px;
      width: 34px;
      aspect-ratio: 1;
      border-radius: 50%;
      background: var(--green);
      box-shadow: 0 0 22px rgba(94, 255, 168, .55);
    }

    .cs-hero-demo .globe {
      width: 170px;
      aspect-ratio: 1;
      border: 1px solid rgba(0, 212, 255, .35);
      border-radius: 50%;
      background:
        linear-gradient(90deg, transparent 48%, rgba(0, 212, 255, .24) 49% 51%, transparent 52%),
        linear-gradient(0deg, transparent 48%, rgba(0, 212, 255, .18) 49% 51%, transparent 52%),
        repeating-radial-gradient(circle, transparent 0 24px, rgba(0, 212, 255, .18) 25px 26px),
        radial-gradient(circle, rgba(0, 212, 255, .14), transparent 68%);
      box-shadow: inset 0 0 32px rgba(0, 212, 255, .12), 0 0 46px rgba(0, 212, 255, .14);
      animation: breathe 3.8s ease-in-out infinite;
    }

    .cs-hero-demo .dot {
      position: absolute;
      width: 9px;
      aspect-ratio: 1;
      border-radius: 50%;
      background: var(--green);
      box-shadow: 0 0 18px rgba(94, 255, 168, .82);
    }

    .cs-hero-demo .dot.one {
      top: 40px;
      left: 54px;
    }

    .cs-hero-demo .dot.two {
      top: 84px;
      right: 34px;
      animation-delay: .35s;
    }

    .cs-hero-demo .dot.three {
      bottom: 42px;
      left: 82px;
      animation-delay: .7s;
    }

    .cs-hero-demo .cta-wrap {
      display: grid;
      justify-items: center;
      gap: clamp(24px, 3.5vw, 44px);
      text-align: center;
    }

    .cs-hero-demo .cta-title {
      max-width: 980px;
      margin: 0;
      font-size: clamp(40px, 7vw, 104px);
      line-height: .95;
      font-weight: 800;
      letter-spacing: 0;
    }

    .cs-hero-demo .cta-copy {
      margin: 0;
      color: #C7EAF4;
      font-size: clamp(17px, 1.6vw, 27px);
      font-weight: 600;
    }

    .cs-hero-demo .cta-button {
      position: relative;
      display: inline-flex;
      min-height: 64px;
      align-items: center;
      justify-content: center;
      gap: 12px;
      padding: 0 34px;
      border: 0;
      border-radius: 8px;
      background: linear-gradient(135deg, var(--cyan), var(--teal));
      color: #041120;
      box-shadow: 0 18px 58px rgba(0, 212, 255, .32);
      font-size: clamp(17px, 1.25vw, 22px);
      font-weight: 800;
      text-decoration: none;
      animation: pulse 1.8s ease-in-out infinite;
    }

    .cs-hero-demo .cta-button::before {
      content: "";
      position: absolute;
      inset: -10px;
      border: 1px solid rgba(0, 212, 255, .36);
      border-radius: 12px;
      opacity: .75;
      animation: halo 1.8s ease-in-out infinite;
    }

    .cs-hero-demo .orbiting-ping {
      position: absolute;
      width: 7px;
      aspect-ratio: 1;
      border-radius: 50%;
      background: var(--cyan);
      box-shadow: 0 0 22px var(--cyan);
      animation: ping 1.8s ease-in-out infinite;
    }

    .cs-hero-demo .reveal-part {
      opacity: 0;
      transform: translateY(18px) scale(.96);
    }

    .cs-hero-demo .line-art {
      width: 58%;
      height: 58%;
    }

    @keyframes flow {
      from { transform: translateX(-105%); }
      to { transform: translateX(245%); }
    }

    @keyframes pulse {
      0%, 100% { transform: translateY(0) scale(1); }
      50% { transform: translateY(-2px) scale(1.035); }
    }

    @keyframes halo {
      0%, 100% { transform: scale(.98); opacity: .55; }
      50% { transform: scale(1.08); opacity: .12; }
    }

    @keyframes orbit {
      to { transform: rotate(360deg); }
    }

    @keyframes breathe {
      0%, 100% { transform: translateX(-50%) scale(1); }
      50% { transform: translateX(-50%) scale(1.045); }
    }

    @keyframes ping {
      0%, 100% { opacity: .4; transform: scale(.78); }
      50% { opacity: 1; transform: scale(1.15); }
    }

    @media (max-width: 920px) {
      .cs-hero-demo {
        min-height: 760px;
      }

      .cs-hero-demo .stage {
        width: min(calc(100% - 34px), 720px);
        min-height: 710px;
        height: calc(100vh - 36px);
        margin: 18px auto;
      }

      .cs-hero-demo .logo-mark {
        flex-direction: column;
        gap: 16px;
      }

      .cs-hero-demo .process,
      .cs-hero-demo .stats-grid,
      .cs-hero-demo .trust-layout {
        grid-template-columns: 1fr;
        gap: 12px;
      }

      .cs-hero-demo .process-wrap {
        gap: 22px;
      }

      .cs-hero-demo .flow-line {
        display: none;
      }

      .cs-hero-demo .step-card {
        min-height: 132px;
        grid-template-columns: 74px 1fr;
        justify-items: start;
        text-align: left;
        padding: 18px;
      }

      .cs-hero-demo .step-icon {
        width: 62px;
      }

      .cs-hero-demo .stats-grid {
        margin-top: 24px;
      }

      .cs-hero-demo .stat-card {
        min-height: 108px;
        grid-template-columns: 52px 1fr;
        align-content: center;
        align-items: center;
        padding: 18px;
      }

      .cs-hero-demo .trust-layout {
        margin-top: 24px;
      }

      .cs-hero-demo .trust-card {
        min-height: 142px;
        padding: 18px 18px 18px 142px;
      }

      .cs-hero-demo .badge-ring,
      .cs-hero-demo .avatar,
      .cs-hero-demo .globe {
        top: 23px;
        left: 70px;
        width: 86px;
      }

      .cs-hero-demo .avatar,
      .cs-hero-demo .globe {
        width: 92px;
      }
    }

    @media (max-width: 560px) {
      .cs-hero-demo {
        min-height: 700px;
      }

      .cs-hero-demo .stage {
        min-height: 660px;
      }

      .cs-hero-demo .section-kicker {
        letter-spacing: .1em;
      }

      .cs-hero-demo .wordmark {
        font-size: clamp(40px, 13vw, 64px);
      }

      .cs-hero-demo .step-card h3,
      .cs-hero-demo .stat-card h3,
      .cs-hero-demo .trust-card h3 {
        font-size: 20px;
      }

      .cs-hero-demo .step-card p,
      .cs-hero-demo .stat-card p,
      .cs-hero-demo .trust-card p {
        font-size: 12px;
      }

      .cs-hero-demo .cta-button {
        width: min(100%, 310px);
        min-height: 58px;
      }
    }

/* ── Anti site-wide style pollution (home.bundle / site-public-light) ── */
/* Use #main-content ID so we beat section:not(...)×6 !important white rule in home.bundle */
#main-content > section.cs-hero-demo,
section.cs-hero-demo.gradient-hero,
section.cs-hero-demo {
  padding: 0 !important;
  border-bottom: none !important;
  background:
    radial-gradient(circle at 72% 20%, rgba(0, 212, 255, 0.13), transparent 28%),
    radial-gradient(circle at 18% 84%, rgba(32, 230, 195, 0.11), transparent 32%),
    linear-gradient(135deg, #081025 0%, #0b1124 48%, #08162e 100%) !important;
  background-color: #0b1124 !important;
  color: #f7fbff !important;
}

section.cs-hero-demo > section.stage,
.cs-hero-demo .stage,
.cs-hero-demo .scene,
.cs-hero-demo .process-wrap,
.cs-hero-demo .brand-lockup,
.cs-hero-demo .cta-wrap {
  background: transparent !important;
  background-color: transparent !important;
  box-shadow: none !important;
}

.cs-hero-demo .stage {
  padding: 0 !important;
  border: none !important;
}

.cs-hero-demo h1,
.cs-hero-demo h2,
.cs-hero-demo h3,
.cs-hero-demo .wordmark,
.cs-hero-demo .section-title,
.cs-hero-demo .cta-title {
  color: #fff !important;
  -webkit-text-fill-color: #fff !important;
  background: none !important;
  text-shadow: none !important;
}

.cs-hero-demo p,
.cs-hero-demo .tagline,
.cs-hero-demo .cta-copy,
.cs-hero-demo .section-kicker {
  background: none !important;
}

html.nzy-site--light #main-content > section.cs-hero-demo,
html.nzy-site--light section.cs-hero-demo.gradient-hero,
html.nzy-site--light section.cs-hero-demo,
html.nzy-ds.nzy-site--light #main-content > section.cs-hero-demo,
html.nzy-ds.nzy-site--light section.cs-hero-demo {
  background:
    radial-gradient(circle at 72% 20%, rgba(0, 212, 255, 0.13), transparent 28%),
    radial-gradient(circle at 18% 84%, rgba(32, 230, 195, 0.11), transparent 32%),
    linear-gradient(135deg, #081025 0%, #0b1124 48%, #08162e 100%) !important;
  border-bottom: none !important;
}

html.nzy-site--light section.cs-hero-demo h1,
html.nzy-site--light section.cs-hero-demo .wordmark,
html.nzy-site--light section.cs-hero-demo h2,
html.nzy-site--light section.cs-hero-demo h3 {
  color: #fff !important;
  -webkit-text-fill-color: #fff !important;
}

html.nzy-site--light section.cs-hero-demo .tagline,
html.nzy-site--light section.cs-hero-demo p {
  color: inherit !important;
}

.cs-hero-demo .step-card,
.cs-hero-demo .stat-card,
.cs-hero-demo .trust-card {
  background: linear-gradient(180deg, rgba(20, 39, 75, 0.86), rgba(10, 22, 46, 0.7)) !important;
  border: 1px solid rgba(118, 232, 255, 0.18) !important;
}
