/* Extracted from index.html. section styles shared across pages */
/* Tweak overrides */
    .v-btn--lime {
      background: var(--tweak-cta-bg, var(--vaas-lime)) !important;
      color: var(--tweak-cta-fg, var(--vaas-blue-deep)) !important;
    }
    /* density */
    .v-hero { padding-top: calc(160px * var(--tweak-pad-scale, 1)); padding-bottom: calc(120px * var(--tweak-pad-scale, 1)); }
    .v-areas, .v-steps, .v-benefits, .v-dash, .v-testi, .v-cases, .v-cta { padding-top: calc(140px * var(--tweak-pad-scale, 1)); padding-bottom: calc(140px * var(--tweak-pad-scale, 1)); }

    /* ============ Trust bar. marquee of client logos ============ */
    .v-trust {
      background: #fff;
      padding: 64px 0 72px;
      border-bottom: 1px solid var(--border);
      overflow: hidden;
    }
    .v-trust__label {
      display: block;
      text-align: center;
      font-family: var(--font-sans);
      font-size: 15px;
      font-weight: 400;
      color: var(--fg-muted, #6b6f80);
      letter-spacing: 0;
      text-transform: none;
      line-height: 1.5;
      margin: 0 auto 44px;
      padding: 0 48px;
      max-width: 760px;
      text-wrap: balance;
    }
    .v-trust__label b { color: var(--vaas-blue-deep); font-weight: 600; }
    .v-marquee {
      position: relative;
      width: 100%;
      overflow: hidden;
      -webkit-mask-image: linear-gradient(90deg, transparent 0, #000 6%, #000 94%, transparent 100%);
              mask-image: linear-gradient(90deg, transparent 0, #000 6%, #000 94%, transparent 100%);
    }
    .v-marquee__track {
      display: flex;
      width: max-content;
      gap: 72px;
      align-items: center;
      animation: marquee 65s linear infinite;
    }
    .v-marquee--reverse .v-marquee__track { animation-direction: reverse; animation-duration: 75s; }
    .v-marquee:hover .v-marquee__track { animation-play-state: paused; }
    @keyframes marquee {
      from { transform: translateX(0); }
      to   { transform: translateX(-50%); }
    }
    .v-marquee + .v-marquee { margin-top: 36px; }
    .v-marquee__logo {
      flex-shrink: 0;
      width: 140px; height: 64px;
      display: flex; align-items: center; justify-content: center;
      opacity: .55;
      transition: opacity 240ms var(--ease-out), filter 240ms var(--ease-out);
      filter: grayscale(1) contrast(1.05) brightness(.4);
    }
    .v-marquee__logo:hover { opacity: 1; filter: grayscale(0) contrast(1); }
    .v-marquee__logo img {
      max-width: 100%; max-height: 100%;
      width: auto; height: auto;
      object-fit: contain; display: block;
    }
    .v-trust__metric {
      margin: 56px auto 0;
      max-width: 1200px;
      padding: 0 48px;
      display: flex; align-items: center; justify-content: center;
      gap: 48px; flex-wrap: wrap;
    }
    .v-trust__metric-item { display: flex; flex-direction: column; align-items: center; gap: 4px; }
    .v-trust__metric-k {
      font-family: var(--font-display);
      font-weight: 700;
      font-size: 32px;
      letter-spacing: -0.03em;
      color: var(--vaas-blue);
      line-height: 1;
      font-variant-numeric: tabular-nums;
    }
    .v-trust__metric-v {
      font-family: var(--font-mono);
      font-size: 11px;
      color: var(--vaas-gray-700);
      text-transform: uppercase;
      letter-spacing: 0.12em;
    }
    .v-trust__metric-sep { width: 1px; height: 32px; background: var(--border); }

    /* ============ Hero decision rich cards ============ */
    .v-hero__decision--rich {
      display: flex; flex-direction: column; gap: 6px;
      align-items: flex-start !important;
      padding: 12px 14px !important;
      text-align: left;
    }
    .v-hero__decision-row {
      display: flex; align-items: center; gap: 10px;
      justify-content: flex-start;
      width: 100%;
    }
    .v-hero__decision-kind {
      font-family: var(--font-mono);
      font-size: 11px;
      color: #fff;
      font-weight: 500;
      letter-spacing: 0.02em;
      text-align: left;
      white-space: nowrap;
      overflow: hidden;
      text-overflow: ellipsis;
      flex: 1 1 auto;
      min-width: 0;
    }
    .v-hero__decision-meta {
      display: flex; align-items: center; gap: 10px;
      padding-left: 18px;
      font-family: var(--font-mono);
      font-size: 10.5px;
      color: rgba(255,255,255,.55);
      letter-spacing: 0.02em;
      flex-wrap: wrap;
      justify-content: flex-start;
      width: 100%;
      text-align: left;
    }
    .v-hero__decision-meta > span {
      display: inline-flex; align-items: center; gap: 4px;
    }
    .v-hero__decision-meta > span + span::before {
      content: "·";
      margin-right: 8px;
      color: rgba(255,255,255,.25);
    }
    .v-hero__decision-risk b { font-weight: 600; }
    .v-hero__decision-risk--low b { color: var(--vaas-lime); }
    .v-hero__decision-risk--mid b { color: #ffc53d; }
    .v-hero__decision-risk--high b { color: #ff8080; }
    .v-hero__decision-verdict { color: rgba(255,255,255,.82); }
    .v-hero__decision-score { color: rgba(255,255,255,.6); }

    /* Hero bg. LQIP blur placeholder behind the real image */
    .v-hero {
      background-image: url("data:image/jpeg;base64,/9j/4AAQSkZJRgABAQAAAQABAAD/2wBDABALDA4MChAODQ4SERATGCgaGBYWGDEjJR0oOjM9PDkzODdASFxOQERXRTc4UG1RV19iZ2hnPk1xeXBkeFxlZ2P/2wBDARESEhgVGC8aGi9jQjhCY2NjY2NjY2NjY2NjY2NjY2NjY2NjY2NjY2NjY2NjY2NjY2NjY2NjY2NjY2NjY2NjY2P/wAARCAAOABgDASIAAhEBAxEB/8QAFwAAAwEAAAAAAAAAAAAAAAAAAAMFBv/EACIQAAICAgEDBQAAAAAAAAAAAAECAwQAEQUhQWESIjFS0f/EABUBAQEAAAAAAAAAAAAAAAAAAAID/8QAHhEAAgEDBQAAAAAAAAAAAAAAAQIAAxIhESIxYfD/2gAMAwEAAhEDEQA/AM5cu04ZatulVFWVVIdAT0Px+5NPITMrKT7XYs4+x84u7KZ7DSHp6jvXnEZd6hQ2rABrky3XuQ8jJWi5CYR14DsIq9Nd8Mk1mZZ1K63vvhlqaCsLjz7uFtuJ/9k=");
      background-size: cover;
      background-position: center;
    }
    .v-hero__bg-pic {
      position: absolute; inset: 0; z-index: 0;
      display: block;
    }
    .v-hero__bg-pic .v-hero__bg {
      width: 100%; height: 100%;
      object-fit: cover;
    }

    /* ============ DataHub. +40 partner sources ============ */
    .v-dhub {
      position: relative;
      background: var(--vaas-blue-deep);
      color: #fff;
      padding: 160px 0 140px;
      overflow: hidden;
      isolation: isolate;
    }
    .v-dhub__bg {
      position: absolute; inset: 0;
      background:
        radial-gradient(ellipse 60% 50% at 50% 0%, rgba(44, 73, 255, .35), transparent 70%),
        radial-gradient(ellipse 80% 60% at 50% 100%, rgba(206, 255, 31, .08), transparent 70%),
        var(--vaas-blue-deep);
      z-index: -1;
    }
    .v-dhub__bg::before {
      content: "";
      position: absolute; inset: 0;
      background-image:
        linear-gradient(rgba(255,255,255,.04) 1px, transparent 1px),
        linear-gradient(90deg, rgba(255,255,255,.04) 1px, transparent 1px);
      background-size: 48px 48px;
      mask-image: radial-gradient(ellipse at center, #000 40%, transparent 80%);
      -webkit-mask-image: radial-gradient(ellipse at center, #000 40%, transparent 80%);
    }
    .v-section-head--dark { color: #fff; }
    .v-section-title--light, .v-section-head--dark .v-section-title { color: #fff !important; }
    .v-section-title--light em, .v-section-head--dark .v-section-title em {
      color: var(--vaas-lime) !important;
      font-style: normal;
    }
    .v-section-sub--light, .v-section-head--dark .v-section-sub { color: rgba(255,255,255,.78) !important; }
    .v-eyebrow--light {
      color: var(--vaas-lime) !important;
    }
    .v-eyebrow--light::before, .v-eyebrow--light::after {
      background: rgba(206, 255, 31, .4) !important;
    }
    .v-dhub__count {
      color: var(--vaas-lime);
      font-variant-numeric: tabular-nums;
    }
    .v-dhub__stats {
      margin: 64px auto 0;
      max-width: 1200px;
      display: grid;
      grid-template-columns: repeat(6, 1fr);
      gap: 0;
      border-top: 1px solid rgba(255,255,255,.12);
      border-bottom: 1px solid rgba(255,255,255,.12);
    }
    .v-dhub__stat {
      padding: 28px 20px;
      text-align: center;
      border-right: 1px solid rgba(255,255,255,.12);
      display: flex; flex-direction: column; gap: 6px;
    }
    .v-dhub__stat:last-child { border-right: none; }
    .v-dhub__stat-v {
      font-family: var(--font-display);
      font-weight: 700;
      font-size: 36px;
      letter-spacing: -0.03em;
      color: #fff;
      line-height: 1;
      font-variant-numeric: tabular-nums;
    }
    .v-dhub__stat-k {
      font-family: var(--font-mono);
      font-size: 10px;
      letter-spacing: 0.12em;
      text-transform: uppercase;
      color: rgba(255,255,255,.6);
    }

    /* 3 rows of partner marquees */
    .v-dhub__marquees {
      margin-top: 72px;
      padding: 8px 0;
    }
    .v-dhub-marquee {
      position: relative;
      width: 100%;
      overflow: hidden;
      -webkit-mask-image: linear-gradient(90deg, transparent 0, #000 6%, #000 94%, transparent 100%);
              mask-image: linear-gradient(90deg, transparent 0, #000 6%, #000 94%, transparent 100%);
    }
    .v-dhub-marquee + .v-dhub-marquee { margin-top: 20px; }
    .v-dhub-marquee__track {
      display: flex;
      width: max-content;
      gap: 20px;
      align-items: stretch;
      animation: marquee linear infinite;
    }
    .v-dhub-marquee--reverse .v-dhub-marquee__track { animation-direction: reverse; animation-delay: -42.5s; }
    .v-dhub-marquee:hover .v-dhub-marquee__track { animation-play-state: paused; }

    .v-dhub-logo {
      flex-shrink: 0;
      width: 160px;
      height: 80px;
      background: #fff;
      border: 1px solid rgba(255,255,255,.1);
      display: flex; align-items: center; justify-content: center;
      padding: 14px 18px;
      transition: transform 240ms var(--ease-out), box-shadow 240ms var(--ease-out);
    }
    .v-dhub-logo:hover {
      transform: translateY(-4px);
      box-shadow: 0 14px 40px -12px rgba(0,0,0,.5), 0 0 0 2px var(--vaas-lime);
    }
    .v-dhub-logo img {
      max-width: 100%; max-height: 100%;
      width: auto; height: auto;
      object-fit: contain; display: block;
    }

    /* Foot: how-it-works + metrics */
    .v-dhub__foot {
      margin-top: 80px;
      padding: 40px;
      background: rgba(255,255,255,.04);
      border: 1px solid rgba(255,255,255,.12);
      display: grid;
      grid-template-columns: 1.1fr 1fr;
      gap: 56px;
      align-items: center;
      max-width: 1200px;
      margin-left: auto; margin-right: auto;
    }
    .v-dhub__foot-eyebrow {
      display: block;
      font-family: var(--font-mono);
      font-size: 11px;
      letter-spacing: 0.16em;
      text-transform: uppercase;
      color: var(--vaas-lime);
      margin-bottom: 12px;
    }
    .v-dhub__foot-copy p {
      font-family: var(--font-display);
      font-size: 22px;
      line-height: 1.4;
      letter-spacing: -0.015em;
      color: #fff;
      margin: 0;
    }
    .v-dhub__foot-copy p b { color: var(--vaas-lime); font-weight: 600; }
    .v-dhub__foot-metrics {
      display: flex; flex-direction: column;
      border-left: 1px solid rgba(255,255,255,.12);
      padding-left: 40px;
    }
    .v-dhub__foot-metric {
      padding: 14px 0;
      border-bottom: 1px solid rgba(255,255,255,.08);
      display: flex; justify-content: space-between; align-items: baseline;
      gap: 20px;
    }
    .v-dhub__foot-metric:last-child { border-bottom: none; }
    .v-dhub__foot-k {
      font-family: var(--font-display);
      font-weight: 700;
      font-size: 28px;
      letter-spacing: -0.02em;
      color: var(--vaas-lime);
      line-height: 1;
      font-variant-numeric: tabular-nums;
      white-space: nowrap;
    }
    .v-dhub__foot-v {
      font-size: 13px;
      color: rgba(255,255,255,.72);
      text-align: right;
    }

    /* ============ Testimonials (feature + aside) ============ */
    .v-testi {
      background: var(--vaas-gray-100, #f5f7fb);
      padding: 140px 0;
    }
    .v-testi__inner { max-width: 1200px; margin: 0 auto; padding: 0 48px; }

    .v-testi-feature {
      margin-top: 64px;
      display: grid;
      grid-template-columns: 1.5fr 1fr;
      gap: 48px;
      background: #fff;
      border: 1px solid var(--border);
      padding: 56px 56px 48px;
      position: relative;
      animation: testi-fade 400ms var(--ease-out);
    }
    @keyframes testi-fade { from { opacity: 0; transform: translateY(8px); } to { opacity: 1; transform: none; } }

    .v-testi-feature__quote-col {
      display: flex; flex-direction: column; gap: 32px;
      position: relative;
    }
    .v-testi-feature__mark {
      position: absolute;
      top: -28px; left: -8px;
      font-family: var(--font-display);
      font-size: 120px;
      line-height: 1;
      color: var(--vaas-lime);
      opacity: .6;
      pointer-events: none;
      font-weight: 700;
    }
    .v-testi-feature__quote {
      margin: 20px 0 0;
      font-family: var(--font-display);
      font-size: 24px;
      line-height: 1.45;
      letter-spacing: -0.015em;
      color: var(--vaas-blue-deep);
      font-weight: 500;
      position: relative;
    }
    .v-testi-feature__author {
      margin-top: auto;
      display: flex; justify-content: space-between; align-items: center;
      gap: 24px;
      padding-top: 28px;
      border-top: 1px solid var(--border);
    }
    .v-testi-feature__who { display: flex; flex-direction: column; gap: 2px; }
    .v-testi-feature__name {
      font-family: var(--font-display);
      font-weight: 600;
      font-size: 16px;
      color: var(--vaas-blue-deep);
      letter-spacing: -0.01em;
    }
    .v-testi-feature__role {
      font-family: var(--font-mono);
      font-size: 11px;
      color: var(--vaas-gray-700);
      letter-spacing: 0.06em;
      text-transform: uppercase;
    }
    .v-testi-feature__logo {
      width: 130px; height: 48px;
      display: flex; align-items: center; justify-content: flex-end;
    }
    .v-testi-feature__logo img {
      max-width: 100%; max-height: 100%;
      width: auto; height: auto;
      object-fit: contain;
      filter: grayscale(1) contrast(1.05) brightness(.5);
      opacity: .7;
    }

    .v-testi-feature__aside {
      border-left: 1px solid var(--border);
      padding-left: 48px;
      display: flex; flex-direction: column; gap: 16px;
    }
    .v-testi-feature__aside-eyebrow {
      font-family: var(--font-mono);
      font-size: 11px;
      letter-spacing: 0.14em;
      text-transform: uppercase;
      color: var(--vaas-gray-700);
    }
    .v-testi-feature__clients {
      list-style: none; margin: 0; padding: 0;
      display: flex; flex-direction: column;
    }
    .v-testi-feature__client {
      display: grid;
      grid-template-columns: 3px 1fr;
      grid-template-rows: auto auto;
      column-gap: 14px;
      padding: 12px 0;
      cursor: pointer;
      border-bottom: 1px solid var(--border);
      transition: background 120ms;
    }
    .v-testi-feature__client:hover { background: var(--vaas-gray-100, #f5f7fb); }
    .v-testi-feature__client:last-child { border-bottom: none; }
    .v-testi-feature__client-bar {
      grid-row: 1 / 3;
      background: transparent;
      transition: background 180ms var(--ease-out);
    }
    .v-testi-feature__client--active .v-testi-feature__client-bar { background: var(--vaas-blue); }
    .v-testi-feature__client--active .v-testi-feature__client-name { color: var(--vaas-blue); }
    .v-testi-feature__client-name {
      font-family: var(--font-display);
      font-weight: 600;
      font-size: 14px;
      color: var(--vaas-blue-deep);
      letter-spacing: -0.005em;
    }
    .v-testi-feature__client-who {
      font-size: 12px;
      color: var(--vaas-gray-700);
    }

    .v-testi__controls {
      margin-top: 32px;
      display: flex; justify-content: space-between; align-items: center;
    }
    .v-testi__dots { display: flex; gap: 8px; }
    .v-testi__dot {
      width: 36px; height: 2px;
      background: var(--border-strong, #d0d5e0);
      border: none; padding: 0; cursor: pointer;
      transition: background 180ms;
    }
    .v-testi__dot--active { background: var(--vaas-blue); }
    .v-testi__arrows { display: flex; gap: 8px; }
    .v-testi__arrow {
      width: 44px; height: 44px;
      background: #fff;
      border: 1px solid var(--border-strong, #d0d5e0);
      color: var(--vaas-blue-deep);
      font-size: 16px;
      cursor: pointer;
      transition: all 160ms;
    }
    .v-testi__arrow:hover { background: var(--vaas-blue); color: #fff; border-color: var(--vaas-blue); }

    /* ============ Cases (nav + panel) ============ */
    .v-cases {
      background: var(--vaas-blue-deep);
      color: #fff;
      padding: 140px 0;
      position: relative;
      overflow: hidden;
    }
    .v-cases::before {
      content: "";
      position: absolute; inset: 0;
      background-image: radial-gradient(ellipse 50% 40% at 80% 20%, rgba(206,255,31,.08), transparent 70%);
      pointer-events: none;
    }
    .v-cases__inner {
      max-width: 1200px; margin: 0 auto; padding: 0 48px;
      position: relative; z-index: 1;
    }
    .v-cases__head {
      margin: 0 auto 64px;
      max-width: 820px;
      text-align: center;
      justify-content: center;
    }
    .v-cases__head > div { width: 100%; text-align: center; }
    .v-cases-main {
      display: grid;
      grid-template-columns: 340px 1fr;
      gap: 48px;
      align-items: start;
    }
    .v-cases-nav {
      display: flex; flex-direction: column;
      border-top: 1px solid rgba(255,255,255,.12);
    }
    .v-cases-nav__item {
      display: grid;
      grid-template-columns: auto 1fr;
      column-gap: 16px;
      padding: 20px 20px 20px 0;
      background: transparent;
      border: none;
      border-bottom: 1px solid rgba(255,255,255,.12);
      color: rgba(255,255,255,.7);
      text-align: left;
      cursor: pointer;
      transition: all 200ms var(--ease-out);
      position: relative;
    }
    .v-cases-nav__item::before {
      content: "";
      position: absolute;
      left: 0; top: 0; bottom: 0;
      width: 2px;
      background: transparent;
      transition: background 200ms var(--ease-out);
    }
    .v-cases-nav__item:hover { color: #fff; }
    .v-cases-nav__item--active { color: #fff; padding-left: 16px; }
    .v-cases-nav__item--active::before { background: var(--vaas-lime); }
    .v-cases-nav__num {
      grid-row: 1 / 3;
      font-family: var(--font-mono);
      font-size: 11px;
      letter-spacing: 0.1em;
      color: var(--vaas-lime);
      padding-top: 2px;
    }
    .v-cases-nav__sector {
      font-family: var(--font-mono);
      font-size: 10px;
      letter-spacing: 0.14em;
      text-transform: uppercase;
      color: rgba(255,255,255,.5);
      display: block;
      margin-bottom: 4px;
    }
    .v-cases-nav__item--active .v-cases-nav__sector { color: var(--vaas-lime); }
    .v-cases-nav__head {
      font-family: var(--font-display);
      font-weight: 500;
      font-size: 15px;
      letter-spacing: -0.005em;
      display: block;
    }

    .v-cases-panel {
      background: rgba(255,255,255,.04);
      border: 1px solid rgba(255,255,255,.12);
      padding: 48px;
      animation: testi-fade 400ms var(--ease-out);
    }
    .v-cases-panel__h {
      padding-bottom: 28px;
      border-bottom: 1px solid rgba(255,255,255,.12);
      margin-bottom: 32px;
    }
    .v-cases-panel__sector {
      font-family: var(--font-mono);
      font-size: 11px;
      letter-spacing: 0.14em;
      text-transform: uppercase;
      color: var(--vaas-lime);
      display: block;
      margin-bottom: 10px;
    }
    .v-cases-panel__title {
      font-family: var(--font-display);
      font-weight: 600;
      font-size: 32px;
      letter-spacing: -0.02em;
      color: #fff;
      margin: 0;
      line-height: 1.2;
    }
    .v-cases-panel__body {
      display: grid;
      grid-template-columns: 1.3fr 1fr;
      gap: 32px;
      margin-bottom: 40px;
    }
    .v-cases-panel__label {
      font-family: var(--font-mono);
      font-size: 10px;
      letter-spacing: 0.16em;
      text-transform: uppercase;
      color: rgba(255,255,255,.5);
      display: block;
      margin-bottom: 10px;
    }
    .v-cases-panel__text {
      font-size: 15px;
      line-height: 1.55;
      color: rgba(255,255,255,.88);
      margin: 0;
    }
    .v-cases-panel__solution {
      font-family: var(--font-display);
      font-weight: 600;
      font-size: 18px;
      color: #fff;
      letter-spacing: -0.01em;
      margin: 0;
    }
    .v-cases-panel__results { border-top: 1px solid rgba(255,255,255,.12); padding-top: 32px; }
    .v-cases-results {
      list-style: none; margin: 0; padding: 0;
      display: grid;
      grid-template-columns: repeat(auto-fit, minmax(160px, 1fr));
      gap: 24px 40px;
    }
    .v-cases-result {
      display: flex; flex-direction: column; gap: 6px;
    }
    .v-cases-result__k {
      font-family: var(--font-display);
      font-weight: 700;
      font-size: 40px;
      letter-spacing: -0.03em;
      color: var(--vaas-lime);
      line-height: 1;
      font-variant-numeric: tabular-nums;
    }
    .v-cases-result__v {
      font-size: 13px;
      line-height: 1.4;
      color: rgba(255,255,255,.7);
    }

    /* Section head helpers */
    .v-section-head {
      text-align: center;
      max-width: 820px;
      margin: 0 auto;
    }
    .v-eyebrow {
      display: inline-block;
      font-family: var(--font-mono);
      font-size: 11px;
      font-weight: 500;
      letter-spacing: 0.16em;
      text-transform: uppercase;
      color: var(--vaas-blue);
      margin-bottom: 20px;
    }
    .v-eyebrow--center::before, .v-eyebrow--center::after {
      content: "";
      display: inline-block;
      width: 24px; height: 1px;
      background: currentColor;
      vertical-align: middle;
      margin: 0 10px;
      opacity: .4;
    }
    .v-section-title {
      font-family: var(--font-display);
      font-weight: 600;
      font-size: 56px;
      letter-spacing: -0.03em;
      line-height: 1.05;
      color: var(--vaas-blue-deep);
      margin: 0;
      text-wrap: balance;
    }
    .v-section-title em {
      color: var(--vaas-blue);
      font-style: normal;
      font-weight: 600;
    }
    .v-section-sub {
      font-size: 17px;
      line-height: 1.5;
      color: var(--vaas-gray-700);
      margin: 20px auto 0;
      max-width: 640px;
      text-wrap: pretty;
    }

    /* ============ Agents AI ============ */
    .v-agents {
      background: #f6f6f6;
      color: var(--vaas-blue-deep);
      padding: 140px 0 120px;
      position: relative;
      overflow: hidden;
    }
    .v-agents .v-container { position: relative; z-index: 1; }
    .v-agents__grid {
      display: grid;
      grid-template-columns: 1.35fr 1fr;
      grid-template-rows: auto auto;
      gap: 20px;
      margin-top: 72px;
    }
    .v-agents__card {
      background: #fff;
      border: 1px solid rgba(7, 9, 20, 0.08);
      border-radius: 20px;
      padding: 36px;
      position: relative;
      overflow: hidden;
      box-shadow: 0 1px 2px rgba(7, 9, 20, 0.02);
    }
    .v-agents__card--library { grid-column: 1 / 3; grid-row: 1; padding: 24px 0 22px; }
    .v-agents__card--library .v-agents__card-head {
      display: flex;
      align-items: baseline;
      gap: 24px;
      padding: 0 32px;
      margin-bottom: 18px;
      flex-wrap: wrap;
    }
    .v-agents__card--library .v-agents__card-kicker { margin-bottom: 0; flex-shrink: 0; }
    .v-agents__card--library .v-agents__card-title {
      font-size: 22px;
      line-height: 1.1;
      margin: 0;
      flex-shrink: 0;
    }
    .v-agents__card--library .v-agents__card-sub {
      font-size: 13px;
      margin: 0;
      flex: 1;
      min-width: 220px;
      color: rgba(7, 9, 20, 0.55);
    }
    .v-agents__card--custom  { grid-column: 1; grid-row: 2; }
    .v-agents__card--analyst { grid-column: 2; grid-row: 2; }
    .v-agents__card--chat    { grid-column: 1 / 3; grid-row: 3; }

    .v-agents__card-kicker {
      display: inline-block;
      font-family: var(--font-mono);
      font-size: 10px;
      font-weight: 600;
      letter-spacing: 0.16em;
      text-transform: uppercase;
      color: var(--vaas-blue);
      margin-bottom: 16px;
    }
    .v-agents__card-title {
      font-family: var(--font-display);
      font-weight: 600;
      font-size: 28px;
      line-height: 1.1;
      letter-spacing: -0.02em;
      color: var(--vaas-blue-deep);
      margin: 0 0 10px;
    }
    .v-agents__card-sub {
      font-size: 14px;
      line-height: 1.5;
      color: rgba(7, 9, 20, 0.6);
      margin: 0 0 28px;
      max-width: 440px;
    }
    .v-agents__card-head { margin-bottom: 8px; }

    /* Library grid */
    .v-agents__library {
      position: relative;
      overflow: hidden;
      margin-top: 4px;
      -webkit-mask-image: linear-gradient(to right, transparent 0, #000 8%, #000 92%, transparent 100%);
              mask-image: linear-gradient(to right, transparent 0, #000 8%, #000 92%, transparent 100%);
    }
    .v-agents__lib-track {
      display: flex;
      gap: 10px;
      width: max-content;
      animation: v-agents-scroll 60s linear infinite;
    }
    .v-agents__library:hover .v-agents__lib-track { animation-play-state: paused; }
    @keyframes v-agents-scroll {
      from { transform: translateX(0); }
      to   { transform: translateX(-50%); }
    }
    .v-agents__lib-item {
      flex-shrink: 0;
      display: inline-flex;
      align-items: center;
      gap: 10px;
      padding: 10px 14px 10px 10px;
      background: #FAF8F2;
      border: 1px solid rgba(7, 9, 20, 0.08);
      border-radius: 999px;
      transition: background 180ms var(--ease-out), border-color 180ms var(--ease-out);
    }
    .v-agents__lib-item:hover {
      background: #fff;
      border-color: var(--vaas-blue);
    }
    .v-agents__lib-icon {
      font-size: 14px;
      width: 26px; height: 26px;
      display: grid; place-items: center;
      background: rgba(44, 73, 255, .12);
      border-radius: 50%;
      flex-shrink: 0;
    }
    .v-agents__lib-name {
      font-size: 13px;
      font-weight: 500;
      color: var(--vaas-blue-deep);
      letter-spacing: -0.005em;
      white-space: nowrap;
    }
    .v-agents__lib-tag {
      font-family: var(--font-mono);
      font-size: 10px;
      letter-spacing: 0.08em;
      text-transform: uppercase;
      color: var(--vaas-blue);
      padding: 3px 7px;
      background: rgba(44, 73, 255, .06);
      border: 1px solid rgba(44, 73, 255, .18);
      border-radius: 4px;
      white-space: nowrap;
    }

    /* Custom agent builder */
    .v-agents__builder {
      background: #FAF8F2;
      border: 1px solid rgba(7, 9, 20, 0.08);
      border-radius: 14px;
      padding: 18px;
      display: flex; flex-direction: column; gap: 12px;
    }
    .v-agents__builder-header {
      display: flex; align-items: center; gap: 10px;
      padding: 12px 14px;
      background: rgba(4, 52, 244, 0.08);
      border: 1px solid rgba(4, 52, 244, 0.18);
      border-radius: 8px;
      font-family: var(--font-display);
      font-weight: 600;
      font-size: 14.5px;
      color: var(--vaas-blue);
    }
    .v-agents__builder-plus {
      display: inline-grid; place-items: center;
      width: 22px; height: 22px;
      background: var(--vaas-blue);
      color: #fff;
      border-radius: 5px;
      flex-shrink: 0;
    }
    .v-agents__builder-field {
      display: flex;
      flex-direction: column;
      gap: 6px;
    }
    .v-agents__builder-lbl {
      font-family: var(--font-mono);
      font-size: 10px;
      font-weight: 600;
      letter-spacing: 0.1em;
      text-transform: uppercase;
      color: rgba(7, 9, 20, 0.5);
    }
    .v-agents__builder-val {
      font-size: 13px;
      color: var(--vaas-blue-deep);
      line-height: 1.5;
      padding: 10px 12px;
      background: #fff;
      border: 1px solid rgba(7, 9, 20, 0.08);
      border-radius: 6px;
    }
    .v-agents__builder-val--long {
      color: rgba(7, 9, 20, 0.72);
      min-height: 52px;
    }
    .v-agents__builder-val code {
      font-family: var(--font-mono);
      font-size: 12px;
      color: var(--vaas-blue);
      font-weight: 500;
      background: none;
      padding: 0;
      border-radius: 0;
    }
    .v-agents__builder-tags {
      display: flex; gap: 6px; flex-wrap: wrap;
      padding-top: 4px;
    }
    .v-agents__builder-tags span {
      font-family: var(--font-sans);
      font-size: 12px;
      font-weight: 500;
      letter-spacing: 0;
      padding: 4px 12px;
      background: rgba(4, 52, 244, 0.08);
      border: 1px solid rgba(4, 52, 244, 0.20);
      border-radius: 999px;
      color: var(--vaas-blue);
    }
    .v-agents__builder-btn {
      margin-top: 4px;
      padding: 12px 18px;
      font-size: 14px;
      font-weight: 600;
      font-family: var(--font-display);
      background: var(--vaas-blue-deep);
      color: #fff;
      border: none;
      border-radius: 8px;
      cursor: pointer;
      transition: transform 140ms var(--ease-out), background 140ms var(--ease-out);
      width: 100%;
      display: inline-flex; align-items: center; justify-content: center; gap: 6px;
    }
    .v-agents__builder-btn:hover { transform: translateY(-1px); background: #001270; }

    /* Analyst card */
    .v-agents__analyst {
      background: #FAF8F2;
      border: 1px solid rgba(7, 9, 20, 0.08);
      border-radius: 14px;
      padding: 18px;
      display: flex; flex-direction: column; gap: 14px;
    }
    .v-agents__analyst-head {
      display: flex; align-items: center; gap: 12px;
      padding-bottom: 14px;
      border-bottom: 1px solid rgba(7, 9, 20, 0.08);
    }
    .v-agents__analyst-avatar {
      width: 44px; height: 44px;
      border-radius: 50%;
      background: linear-gradient(135deg, #2C49FF, #6580ff);
      display: grid; place-items: center;
      font-family: var(--font-display);
      font-weight: 600;
      font-size: 14px;
      color: #fff;
      flex-shrink: 0;
    }
    .v-agents__analyst-ident { flex: 1; min-width: 0; }
    .v-agents__analyst-name {
      font-family: var(--font-display);
      font-weight: 600;
      font-size: 14px;
      color: var(--vaas-blue-deep);
      letter-spacing: -0.005em;
    }
    .v-agents__analyst-meta {
      font-family: var(--font-mono);
      font-size: 11px;
      color: rgba(7, 9, 20, 0.5);
      margin-top: 2px;
    }
    .v-agents__analyst-score {
      display: flex; flex-direction: column; align-items: flex-end;
      padding-left: 14px;
      border-left: 1px solid rgba(7, 9, 20, 0.1);
    }
    .v-agents__analyst-score-v {
      font-family: var(--font-display);
      font-weight: 700;
      font-size: 28px;
      letter-spacing: -0.03em;
      color: #D94545;
      line-height: 1;
      font-variant-numeric: tabular-nums;
    }
    .v-agents__analyst-score-k {
      font-family: var(--font-mono);
      font-size: 9px;
      letter-spacing: 0.12em;
      text-transform: uppercase;
      color: rgba(7, 9, 20, 0.5);
      margin-top: 3px;
    }
    .v-agents__analyst-flags {
      display: flex; gap: 6px; flex-wrap: wrap;
    }
    .v-agents__flag {
      font-family: var(--font-mono);
      font-size: 10px;
      letter-spacing: 0.06em;
      text-transform: uppercase;
      padding: 4px 10px;
      border-radius: 4px;
      border: 1px solid;
    }
    .v-agents__flag--high {
      background: rgba(217, 69, 69, .08);
      border-color: rgba(217, 69, 69, .3);
      color: #B13838;
    }
    .v-agents__flag--warn {
      background: rgba(217, 155, 46, .08);
      border-color: rgba(217, 155, 46, .3);
      color: #9C6A1F;
    }
    .v-agents__analyst-parecer {
      background: rgba(44, 73, 255, .05);
      border: 1px solid rgba(44, 73, 255, .18);
      border-radius: 10px;
      padding: 14px;
    }
    .v-agents__parecer-title {
      font-family: var(--font-mono);
      font-size: 10px;
      letter-spacing: 0.12em;
      text-transform: uppercase;
      color: var(--vaas-blue);
      margin-bottom: 6px;
      font-weight: 600;
    }
    .v-agents__analyst-parecer p {
      font-size: 13px;
      line-height: 1.55;
      color: rgba(7, 9, 20, 0.78);
      margin: 0;
    }
    .v-agents__analyst-parecer b { color: var(--vaas-blue-deep); font-weight: 600; }

    /* Chat card */
    .v-agents__chat {
      display: flex; flex-direction: column; gap: 10px;
      background: #FAF8F2;
      border: 1px solid rgba(7, 9, 20, 0.08);
      border-radius: 14px;
      padding: 22px;
    }
    .v-agents__chat-row {
      display: flex;
    }
    .v-agents__chat-row--user { justify-content: flex-end; }
    .v-agents__chat-row--ai { justify-content: flex-start; }
    .v-agents__bubble {
      max-width: 70%;
      padding: 10px 16px;
      border-radius: 14px;
      font-size: 14px;
      line-height: 1.45;
      background: var(--vaas-blue);
      color: #fff;
      border-bottom-right-radius: 4px;
    }
    .v-agents__bubble--ai {
      background: #fff;
      color: var(--vaas-blue-deep);
      border: 1px solid rgba(7, 9, 20, 0.08);
      border-bottom-left-radius: 4px;
      border-bottom-right-radius: 14px;
    }
    .v-agents__bubble--ai b { color: var(--vaas-blue); font-weight: 600; }
    .v-agents__bubble--ai a { color: var(--vaas-blue); text-decoration: none; font-weight: 500; }
    .v-agents__bubble--ai a:hover { text-decoration: underline; }

    .v-agents__cta {
      margin-top: 48px;
      text-align: center;
    }

    /* ========== Custom builder. typing + tags pop-in (one-shot, on reveal) ========== */
    .v-agents__card--custom .v-agents__builder-val--long {
      position: relative;
      overflow: hidden;
      white-space: normal;
    }
    .v-agents__card--custom.v-revealed .v-agents__builder-val--long::after {
      content: '';
      position: absolute;
      top: 2px; right: -2px; bottom: 2px;
      width: 2px;
      background: var(--vaas-lime);
      animation: v-agents-caret 1s steps(2) 1.8s 4;
    }
    @keyframes v-agents-caret {
      0%, 50% { opacity: 1; }
      51%, 100% { opacity: 0; }
    }
    .v-agents__card--custom .v-agents__builder-field {
      opacity: 0;
      transform: translateY(6px);
    }
    .v-agents__card--custom.v-revealed .v-agents__builder-field {
      animation: v-agents-field-in 600ms var(--ease-out) forwards;
    }
    .v-agents__card--custom.v-revealed .v-agents__builder-field:nth-child(2) { animation-delay: 0.3s; }
    .v-agents__card--custom.v-revealed .v-agents__builder-field:nth-child(3) { animation-delay: 0.9s; }
    .v-agents__card--custom.v-revealed .v-agents__builder-field:nth-child(4) { animation-delay: 2.0s; }
    @keyframes v-agents-field-in {
      from { opacity: 0; transform: translateY(6px); }
      to   { opacity: 1; transform: translateY(0); }
    }
    .v-agents__card--custom .v-agents__builder-tags span {
      opacity: 0;
      transform: scale(.85);
    }
    .v-agents__card--custom.v-revealed .v-agents__builder-tags span {
      animation: v-agents-tag-pop 500ms var(--ease-out) forwards;
    }
    .v-agents__card--custom.v-revealed .v-agents__builder-tags span:nth-child(1) { animation-delay: 2.7s; }
    .v-agents__card--custom.v-revealed .v-agents__builder-tags span:nth-child(2) { animation-delay: 2.9s; }
    .v-agents__card--custom.v-revealed .v-agents__builder-tags span:nth-child(3) { animation-delay: 3.1s; }
    .v-agents__card--custom.v-revealed .v-agents__builder-tags span:nth-child(4) { animation-delay: 3.3s; }
    @keyframes v-agents-tag-pop {
      0%   { opacity: 0; transform: scale(.85); }
      60%  { opacity: 1; transform: scale(1.08); }
      100% { opacity: 1; transform: scale(1); }
    }
    .v-agents__card--custom .v-agents__builder-btn {
      position: relative;
      overflow: hidden;
    }
    .v-agents__card--custom.v-revealed .v-agents__builder-btn::before {
      content: '';
      position: absolute;
      inset: 0;
      background: linear-gradient(120deg, transparent 30%, rgba(255,255,255,.35) 50%, transparent 70%);
      transform: translateX(-120%);
      animation: v-agents-btn-shimmer 900ms 3.8s ease-out forwards;
    }
    @keyframes v-agents-btn-shimmer {
      from { transform: translateX(-120%); }
      to   { transform: translateX(120%); }
    }

    /* ========== Analyst. score ring + flags (one-shot) ========== */
    .v-agents__card--analyst .v-agents__analyst-score {
      position: relative;
    }
    .v-agents__card--analyst.v-revealed .v-agents__analyst-score::before {
      content: '';
      position: absolute;
      inset: -4px;
      border-radius: inherit;
      border: 2px solid var(--vaas-lime);
      opacity: 0;
      animation: v-agents-score-ring 1.2s .5s var(--ease-out) forwards;
    }
    @keyframes v-agents-score-ring {
      0%   { opacity: 0; transform: scale(.85); }
      40%  { opacity: .9; transform: scale(1); }
      100% { opacity: 0; transform: scale(1.15); }
    }
    .v-agents__card--analyst .v-agents__analyst-score-v {
      display: inline-block;
    }
    .v-agents__card--analyst.v-revealed .v-agents__analyst-score-v {
      animation: v-agents-score-bump 700ms .6s var(--ease-out);
    }
    @keyframes v-agents-score-bump {
      0%, 100% { transform: scale(1); }
      40%      { transform: scale(1.18); }
    }
    .v-agents__card--analyst .v-agents__flag {
      opacity: 0;
      transform: translateY(4px);
    }
    .v-agents__card--analyst.v-revealed .v-agents__flag {
      animation: v-agents-flag-in 500ms var(--ease-out) forwards;
    }
    .v-agents__card--analyst.v-revealed .v-agents__flag:nth-child(1) { animation-delay: 1.0s; }
    .v-agents__card--analyst.v-revealed .v-agents__flag:nth-child(2) { animation-delay: 1.25s; }
    .v-agents__card--analyst.v-revealed .v-agents__flag:nth-child(3) { animation-delay: 1.5s; }
    @keyframes v-agents-flag-in {
      from { opacity: 0; transform: translateY(4px); }
      to   { opacity: 1; transform: translateY(0); }
    }
    .v-agents__card--analyst.v-revealed .v-agents__flag--high {
      animation: v-agents-flag-in 500ms 1.0s var(--ease-out) forwards,
                 v-agents-flag-alert 1.4s 1.6s ease-in-out;
    }
    @keyframes v-agents-flag-alert {
      0%, 100% { box-shadow: 0 0 0 0 rgba(255, 82, 82, 0); }
      50% { box-shadow: 0 0 0 5px rgba(255, 82, 82, .3); }
    }
    .v-agents__card--analyst .v-agents__analyst-parecer {
      position: relative;
      overflow: hidden;
    }
    .v-agents__card--analyst.v-revealed .v-agents__analyst-parecer::after {
      content: '';
      position: absolute;
      top: 0; bottom: 0;
      left: -30%;
      width: 30%;
      background: linear-gradient(90deg, transparent, rgba(206, 255, 31, .12), transparent);
      animation: v-agents-parecer-sweep 1.6s 2.2s ease-in-out forwards;
      pointer-events: none;
    }
    @keyframes v-agents-parecer-sweep {
      from { left: -30%; }
      to   { left: 130%; }
    }

    /* ========== Chat. sequenced conversation (one-shot, natural rhythm) ========== */
    .v-agents__card--chat .v-agents__chat-row {
      opacity: 0;
      transform: translateY(6px);
    }
    .v-agents__card--chat.v-revealed .v-agents__chat-row {
      animation: v-agents-bubble-in 450ms var(--ease-out) forwards;
    }
    /* Conversation timing. user asks, AI shows typing, then AI replies */
    .v-agents__card--chat.v-revealed .v-agents__chat-row:nth-child(1) { animation-delay: 0.5s; }   /* user Q1 */
    .v-agents__card--chat.v-revealed .v-agents__chat-row:nth-child(2) { animation-delay: 1.3s; }   /* typing-t1 appears */
    .v-agents__card--chat.v-revealed .v-agents__chat-row:nth-child(3) { animation-delay: 3.2s; }   /* AI A1 (after typing settles) */
    .v-agents__card--chat.v-revealed .v-agents__chat-row:nth-child(4) { animation-delay: 5.0s; }   /* user Q2. reads AI reply then types */
    .v-agents__card--chat.v-revealed .v-agents__chat-row:nth-child(5) { animation-delay: 5.8s; }   /* typing-t2 appears */
    .v-agents__card--chat.v-revealed .v-agents__chat-row:nth-child(6) { animation-delay: 7.7s; }   /* AI A2 */
    @keyframes v-agents-bubble-in {
      from { opacity: 0; transform: translateY(6px); }
      to   { opacity: 1; transform: translateY(0); }
    }
    .v-agents__card--chat .v-agents__chat-row--user .v-agents__bubble {
      transform-origin: right bottom;
    }
    .v-agents__card--chat .v-agents__chat-row--ai .v-agents__bubble {
      transform-origin: left bottom;
    }

    /* Typing indicator: shown BEFORE each AI reply, inside the user-row spot */
    .v-agents__typing {
      display: inline-flex;
      gap: 4px;
      padding: 10px 14px;
      background: #fff;
      border: 1px solid rgba(7, 9, 20, 0.08);
      border-radius: 14px;
      opacity: 0;
    }
    .v-agents__typing span {
      width: 6px; height: 6px;
      border-radius: 50%;
      background: rgba(7, 9, 20, 0.4);
    }
    .v-agents__card--chat.v-revealed .v-agents__typing--t1 {
      animation: v-agents-typing-show 1.9s 1.3s ease-out forwards;
    }
    .v-agents__card--chat.v-revealed .v-agents__typing--t2 {
      animation: v-agents-typing-show 1.9s 5.8s ease-out forwards;
    }
    @keyframes v-agents-typing-show {
      0%   { opacity: 0; transform: translateY(4px); }
      10%  { opacity: 1; transform: translateY(0); }
      88%  { opacity: 1; transform: translateY(0); }
      100% { opacity: 0; transform: translateY(-4px); height: 0; padding: 0; margin: 0; border: 0; }
    }
    .v-agents__card--chat.v-revealed .v-agents__typing span {
      animation: v-agents-typing-dot 1s infinite ease-in-out;
    }
    .v-agents__card--chat.v-revealed .v-agents__typing span:nth-child(2) { animation-delay: .15s; }
    .v-agents__card--chat.v-revealed .v-agents__typing span:nth-child(3) { animation-delay: .3s; }
    @keyframes v-agents-typing-dot {
      0%, 100% { opacity: .4; transform: translateY(0); }
      50% { opacity: 1; transform: translateY(-3px); }
    }

    @media (prefers-reduced-motion: reduce) {
      .v-agents__lib-track,
      .v-agents__card--custom .v-agents__builder-field,
      .v-agents__card--custom .v-agents__builder-tags span,
      .v-agents__card--custom .v-agents__builder-val--long::after,
      .v-agents__card--custom .v-agents__builder-btn::before,
      .v-agents__card--analyst .v-agents__analyst-score-v,
      .v-agents__card--analyst .v-agents__analyst-score::before,
      .v-agents__card--analyst .v-agents__flag,
      .v-agents__card--analyst .v-agents__analyst-parecer::after,
      .v-agents__card--chat .v-agents__chat-row,
      .v-agents__card--chat .v-agents__typing {
        animation: none !important;
        opacity: 1 !important;
        transform: none !important;
      }
      .v-agents__card--chat .v-agents__typing { display: none !important; }
    }

    @media (max-width: 900px) {
      .v-agents__grid { grid-template-columns: 1fr; }
      .v-agents__card--library { grid-column: 1; grid-row: auto; }
      .v-agents__card--custom  { grid-column: 1; grid-row: auto; }
      .v-agents__card--analyst { grid-column: 1; grid-row: auto; }
      .v-agents__card--chat    { grid-column: 1; grid-row: auto; }
      .v-agents__library { grid-template-columns: 1fr; }
    }

    /* ============ Monitoring. Radar ============ */
    .v-mon {
      position: relative;
      padding: 140px 0 160px;
      background: var(--vaas-black);
      color: #fff;
      overflow: hidden;
    }
    .v-mon__bg {
      position: absolute; inset: 0;
      background:
        radial-gradient(ellipse 60% 60% at 50% 30%, rgba(206, 255, 31, .06), transparent 65%),
        radial-gradient(ellipse 80% 50% at 50% 100%, rgba(44, 73, 255, .10), transparent 70%);
      pointer-events: none;
    }
    .v-mon__head {
      max-width: 760px;
      margin: 0 auto 60px;
      text-align: center;
      position: relative; z-index: 2;
    }
    .v-mon__cta {
      display: flex;
      justify-content: center;
      margin-top: 60px;
      position: relative; z-index: 2;
    }

    .v-radar {
      position: relative;
      width: 100%;
      max-width: 1180px;
      margin: 0 auto;
      aspect-ratio: 16 / 10;
      min-height: 560px;
    }
    .v-radar__ring {
      position: absolute;
      left: 50%; top: 50%;
      transform: translate(-50%, -50%);
      border-radius: 50%;
      border: 1px solid rgba(255, 255, 255, .08);
      pointer-events: none;
    }
    .v-radar__ring--1 { width: 22%; aspect-ratio: 1; border-color: rgba(255,255,255,.14); }
    .v-radar__ring--2 { width: 44%; aspect-ratio: 1; }
    .v-radar__ring--3 { width: 66%; aspect-ratio: 1; }
    .v-radar__ring--4 { width: 88%; aspect-ratio: 1; border-style: dashed; border-color: rgba(255,255,255,.05); }

    .v-radar__cross {
      position: absolute;
      left: 50%; top: 50%;
      background: rgba(255,255,255,.05);
      pointer-events: none;
    }
    .v-radar__cross--h { width: 88%; height: 1px; transform: translate(-50%, -50%); }
    .v-radar__cross--v { width: 1px; height: 88%; transform: translate(-50%, -50%); }

    /* Radar sweep. animação puramente CSS (sem JS)
       width/aspect-ratio dimensionam a "lâmina" do radar: 88% × 44% =
       altura igual ao raio do anel externo, então o feixe varre toda a
       área coberta pelos anéis. */
    .v-radar__sweep {
      position: absolute;
      left: 50%; top: 50%;
      width: 88%;
      aspect-ratio: 2 / 1;
      transform-origin: bottom center;
      pointer-events: none;
      z-index: 1;
      transform: translate(-50%, -100%) rotate(0deg);
      animation: v-radar-sweep 6s linear infinite;
      will-change: transform;
      /* Recorta o feixe para o círculo do anel externo (raio = altura do
         retângulo), evitando que os cantos vazem para fora do radar. */
      clip-path: circle(farthest-side at 50% 100%);
    }
    @keyframes v-radar-sweep {
      from { transform: translate(-50%, -100%) rotate(0deg); }
      to   { transform: translate(-50%, -100%) rotate(360deg); }
    }
    .v-radar__sweep-beam {
      width: 100%; height: 100%;
      background: conic-gradient(
        from 270deg at 50% 100%,
        transparent 0deg,
        rgba(206, 255, 31, 0) 40deg,
        rgba(206, 255, 31, .04) 65deg,
        rgba(206, 255, 31, .14) 82deg,
        rgba(206, 255, 31, .35) 90deg,
        transparent 91deg
      );
    }

    /* Center card */
    .v-radar__center {
      position: absolute;
      left: 50%; top: 50%;
      transform: translate(-50%, -50%);
      width: 320px;
      z-index: 3;
    }
    .v-radar__center-pulse {
      position: absolute;
      left: 50%; top: 50%;
      width: 8px; height: 8px;
      border-radius: 50%;
      background: var(--vaas-lime);
      transform: translate(-50%, -50%);
      box-shadow: 0 0 0 0 rgba(206, 255, 31, .6);
      animation: v-radar-center-pulse 2.2s infinite;
      z-index: 2;
    }
    @keyframes v-radar-center-pulse {
      0%   { box-shadow: 0 0 0 0 rgba(206, 255, 31, .5); }
      70%  { box-shadow: 0 0 0 40px rgba(206, 255, 31, 0); }
      100% { box-shadow: 0 0 0 0 rgba(206, 255, 31, 0); }
    }
    .v-radar__center-card {
      position: relative;
      background: linear-gradient(180deg, rgba(255,255,255,.05), rgba(255,255,255,.02));
      border: 1px solid rgba(255,255,255,.14);
      border-radius: 16px;
      padding: 22px 24px;
      backdrop-filter: blur(8px);
      text-align: left;
      box-shadow: 0 24px 60px -20px rgba(0,0,0,.5);
    }
    .v-radar__center-kicker {
      display: inline-flex; align-items: center; gap: 8px;
      font-family: var(--font-mono);
      font-size: 10px;
      letter-spacing: 0.14em;
      text-transform: uppercase;
      color: var(--vaas-lime);
      margin-bottom: 12px;
    }
    .v-radar__live-dot {
      width: 7px; height: 7px;
      border-radius: 50%;
      background: var(--vaas-lime);
      box-shadow: 0 0 0 0 var(--vaas-lime);
      animation: v-mon-pulse 1.8s infinite;
    }
    @keyframes v-mon-pulse {
      0%   { box-shadow: 0 0 0 0 rgba(206, 255, 31, .7); }
      70%  { box-shadow: 0 0 0 8px rgba(206, 255, 31, 0); }
      100% { box-shadow: 0 0 0 0 rgba(206, 255, 31, 0); }
    }
    .v-radar__center-title {
      font-family: var(--font-display);
      font-weight: 600;
      font-size: 24px;
      letter-spacing: -0.02em;
      color: #fff;
      margin-bottom: 6px;
    }
    .v-radar__center-sub {
      font-size: 13px;
      line-height: 1.5;
      color: rgba(255,255,255,.7);
      margin-bottom: 18px;
    }
    .v-radar__center-stats {
      display: grid;
      grid-template-columns: repeat(3, 1fr);
      gap: 4px;
      border-top: 1px solid rgba(255,255,255,.1);
      padding-top: 14px;
    }
    .v-radar__center-stats > div {
      display: flex; flex-direction: column; gap: 2px;
    }
    .v-radar__center-stats b {
      font-family: var(--font-display);
      font-weight: 700;
      font-size: 20px;
      color: var(--vaas-lime);
      letter-spacing: -0.02em;
      font-variant-numeric: tabular-nums;
    }
    .v-radar__center-stats span {
      font-family: var(--font-mono);
      font-size: 9px;
      letter-spacing: 0.1em;
      text-transform: uppercase;
      color: rgba(255,255,255,.5);
    }

    /* Event cards on radar. revelados pelo sweep via animation-delay
       (sincronizado com o keyframe do sweep, 6s). animation-fill-mode: both
       mantém o card visível depois que o sweep passa, até o próximo ciclo. */
    .v-radar__evt {
      position: absolute;
      width: 180px;
      z-index: 4;
      opacity: 0;
      transform: scale(.92);
      pointer-events: none;
      animation: v-radar-evt-in 6s linear infinite both;
      will-change: opacity, transform;
    }
    @keyframes v-radar-evt-in {
      0%   { opacity: 0; transform: scale(.92); }
      3%   { opacity: 1; transform: scale(1); }
      95%  { opacity: 1; transform: scale(1); }
      100% { opacity: 0; transform: scale(.92); }
    }
    @media (prefers-reduced-motion: reduce) {
      .v-radar__sweep { animation: none; }
      .v-radar__evt   { animation: none; opacity: 1; transform: scale(1); }
    }
    /* Anchor corner based on quadrant */
    .v-radar__evt.align-l { transform-origin: left center; }
    .v-radar__evt.align-r { transform-origin: right center; margin-left: -180px; }
    .v-radar__evt.align-t { }
    .v-radar__evt.align-b { }

    .v-radar__evt-pin {
      position: absolute;
      left: 0; top: 50%;
      width: 8px; height: 8px;
      border-radius: 50%;
      transform: translate(-50%, -50%);
      background: currentColor;
      box-shadow: 0 0 0 4px rgba(255,255,255,.05), 0 0 14px currentColor;
    }
    .v-radar__evt.align-r .v-radar__evt-pin { left: 100%; }

    .v-radar__evt-body {
      background: rgba(20, 20, 24, .88);
      border: 1px solid rgba(255,255,255,.1);
      border-radius: 8px;
      padding: 9px 11px;
      backdrop-filter: blur(6px);
      box-shadow: 0 10px 24px -10px rgba(0,0,0,.6);
      margin-left: 12px;
    }
    .v-radar__evt.align-r .v-radar__evt-body { margin-left: 0; margin-right: 12px; text-align: right; }

    .v-radar__evt-type {
      display: flex; align-items: center; gap: 6px;
      font-size: 11.5px;
      font-weight: 500;
      color: #fff;
      letter-spacing: -0.005em;
      margin-bottom: 2px;
      line-height: 1.25;
    }
    .v-radar__evt.align-r .v-radar__evt-type { justify-content: flex-end; flex-direction: row-reverse; }
    .v-radar__evt-dot {
      width: 6px; height: 6px;
      border-radius: 50%;
      flex-shrink: 0;
    }
    .v-radar__evt-dot--critical { background: #ff5c5c; box-shadow: 0 0 8px #ff5c5c; }
    .v-radar__evt-dot--high     { background: #ff9a50; box-shadow: 0 0 8px #ff9a50; }
    .v-radar__evt-dot--elevated { background: #ffc53d; box-shadow: 0 0 8px #ffc53d; }
    .v-radar__evt-dot--moderate { background: rgba(206, 255, 31, .8); box-shadow: 0 0 8px rgba(206, 255, 31, .5); }

    .v-radar__evt-subject {
      font-family: var(--font-mono);
      font-size: 10px;
      color: rgba(255,255,255,.55);
      letter-spacing: 0.005em;
      margin-bottom: 5px;
      line-height: 1.35;
    }
    .v-radar__evt-meta { color: rgba(255,255,255,.4); }

    .v-radar__evt-risk {
      display: flex; align-items: center; gap: 8px;
      font-family: var(--font-mono);
      font-size: 10px;
      letter-spacing: 0.06em;
      text-transform: uppercase;
      color: rgba(255,255,255,.55);
    }
    .v-radar__evt.align-r .v-radar__evt-risk { justify-content: flex-end; }
    .v-radar__evt-risk b { font-weight: 600; margin-left: 2px; }
    .v-radar__evt--critical .v-radar__evt-risk b { color: #ff8080; }
    .v-radar__evt--high     .v-radar__evt-risk b { color: #ffa166; }
    .v-radar__evt--elevated .v-radar__evt-risk b { color: #ffc53d; }
    .v-radar__evt--moderate .v-radar__evt-risk b { color: rgba(206,255,31,.9); }

    .v-radar__evt-dots { display: inline-flex; gap: 3px; }
    .v-radar__evt-dots i {
      width: 5px; height: 5px;
      border-radius: 50%;
      background: rgba(255,255,255,.15);
    }
    .v-radar__evt--critical .v-radar__evt-dots i.on { background: #ff5c5c; }
    .v-radar__evt--high     .v-radar__evt-dots i.on { background: #ff9a50; }
    .v-radar__evt--elevated .v-radar__evt-dots i.on { background: #ffc53d; }
    .v-radar__evt--moderate .v-radar__evt-dots i.on { background: rgba(206,255,31,.9); }

    @media (max-width: 960px) {
      .v-radar { min-height: 720px; aspect-ratio: auto; height: auto; }
      .v-radar__evt { width: 200px; }
      .v-radar__center { width: 260px; }
    }
    @media (max-width: 720px) {
      .v-mon { padding: 100px 0 120px; }

      /* No mobile, abandona o layout radial: o card central vira hero da
         seção e os eventos viram um feed vertical logo abaixo. */
      .v-radar {
        min-height: 0;
        height: auto;
        aspect-ratio: auto;
        display: flex;
        flex-direction: column;
        gap: 12px;
        padding: 0;
      }
      /* Decoração do radar fica oculta. visual fica pequeno demais e atrapalha
         a legibilidade dos cards. */
      .v-radar__ring,
      .v-radar__cross,
      .v-radar__sweep { display: none !important; }

      /* Card central. full width, no topo do feed */
      .v-radar__center {
        position: static !important;
        width: 100% !important;
        transform: none !important;
        margin-bottom: 8px;
      }
      .v-radar__center-pulse { display: none; }
      .v-radar__center-title { font-size: 22px; }
      .v-radar__center-stats {
        grid-template-columns: repeat(3, 1fr);
        gap: 12px;
      }

      /* Cards de evento. saem do posicionamento absoluto e viram lista */
      .v-radar__evt {
        position: static !important;
        width: 100% !important;
        margin: 0 !important;
        animation: none !important;
        opacity: 1 !important;
        transform: none !important;
      }
      .v-radar__evt-pin { display: none !important; }
      .v-radar__evt-body {
        margin: 0 !important;
        text-align: left !important;
      }
      .v-radar__evt.align-r .v-radar__evt-type {
        flex-direction: row !important;
        justify-content: flex-start !important;
      }
      .v-radar__evt.align-r .v-radar__evt-risk {
        justify-content: flex-start !important;
      }
    }

    /* ============ Monitoring. Light variant (white bg, blue/gray) ============ */
    .v-mon--light { background: #fff; color: var(--vaas-blue-deep); }
    .v-mon--light .v-mon__bg {
      background:
        radial-gradient(ellipse 60% 60% at 50% 30%, rgba(4, 52, 244, .05), transparent 65%),
        radial-gradient(ellipse 80% 50% at 50% 100%, rgba(4, 52, 244, .04), transparent 70%);
    }
    .v-mon--light .v-radar__ring { border-color: rgba(7, 9, 20, .08); }
    .v-mon--light .v-radar__ring--1 { border-color: rgba(7, 9, 20, .14); }
    .v-mon--light .v-radar__ring--4 { border-color: rgba(7, 9, 20, .06); }
    .v-mon--light .v-radar__cross { background: rgba(7, 9, 20, .05); }

    /* Sweep beam. usa azul em vez do lime */
    .v-mon--light .v-radar__sweep-beam {
      background: conic-gradient(
        from 270deg at 50% 100%,
        transparent 0deg,
        rgba(4, 52, 244, 0) 50deg,
        rgba(4, 52, 244, .02) 70deg,
        rgba(4, 52, 244, .06) 84deg,
        rgba(4, 52, 244, .12) 90deg,
        transparent 91deg
      );
      -webkit-mask-image: radial-gradient(circle at 50% 100%, #000 0%, #000 55%, transparent 95%);
              mask-image: radial-gradient(circle at 50% 100%, #000 0%, #000 55%, transparent 95%);
    }

    /* Center card */
    .v-mon--light .v-radar__center-pulse {
      background: var(--vaas-blue);
      box-shadow: 0 0 0 0 rgba(4, 52, 244, .5);
      animation-name: v-radar-center-pulse-light;
    }
    @keyframes v-radar-center-pulse-light {
      0%   { box-shadow: 0 0 0 0 rgba(4, 52, 244, .4); }
      70%  { box-shadow: 0 0 0 40px rgba(4, 52, 244, 0); }
      100% { box-shadow: 0 0 0 0 rgba(4, 52, 244, 0); }
    }
    .v-mon--light .v-radar__center-card {
      background: #fff;
      border: 1px solid var(--border);
      box-shadow: 0 24px 60px -20px rgba(7, 9, 20, .18);
      backdrop-filter: none;
    }
    .v-mon--light .v-radar__center-kicker { color: var(--vaas-blue); }
    .v-mon--light .v-radar__live-dot {
      background: var(--vaas-blue);
      animation-name: v-mon-pulse-light;
    }
    @keyframes v-mon-pulse-light {
      0%   { box-shadow: 0 0 0 0 rgba(4, 52, 244, .6); }
      70%  { box-shadow: 0 0 0 8px rgba(4, 52, 244, 0); }
      100% { box-shadow: 0 0 0 0 rgba(4, 52, 244, 0); }
    }
    .v-mon--light .v-radar__center-title { color: var(--vaas-blue-deep); }
    .v-mon--light .v-radar__center-sub { color: rgba(7, 9, 20, .65); }
    .v-mon--light .v-radar__center-stats {
      border-top: 1px solid var(--border);
    }
    .v-mon--light .v-radar__center-stats b { color: var(--vaas-blue); }
    .v-mon--light .v-radar__center-stats span { color: rgba(7, 9, 20, .45); }

    /* Event cards */
    .v-mon--light .v-radar__evt-pin {
      box-shadow: 0 0 0 4px rgba(7, 9, 20, .04), 0 0 14px currentColor;
    }
    .v-mon--light .v-radar__evt-body {
      background: #fff;
      border: 1px solid var(--border);
      box-shadow: 0 10px 24px -10px rgba(7, 9, 20, .18);
      backdrop-filter: none;
    }
    .v-mon--light .v-radar__evt-type { color: var(--vaas-blue-deep); }
    .v-mon--light .v-radar__evt-subject { color: rgba(7, 9, 20, .55); }
    .v-mon--light .v-radar__evt-meta    { color: rgba(7, 9, 20, .4); }
    .v-mon--light .v-radar__evt-risk    { color: rgba(7, 9, 20, .5); }
    .v-mon--light .v-radar__evt-dots i  { background: rgba(7, 9, 20, .12); }
    .v-mon--light .v-radar__evt--critical .v-radar__evt-risk b { color: #c84141; }
    .v-mon--light .v-radar__evt--high     .v-radar__evt-risk b { color: #c97a30; }
    .v-mon--light .v-radar__evt--elevated .v-radar__evt-risk b { color: #b58912; }
    .v-mon--light .v-radar__evt--moderate .v-radar__evt-risk b { color: var(--vaas-blue); }
    .v-mon--light .v-radar__evt--moderate .v-radar__evt-dot { background: var(--vaas-blue); box-shadow: 0 0 8px rgba(4, 52, 244, .5); }
    .v-mon--light .v-radar__evt--moderate .v-radar__evt-dots i.on { background: var(--vaas-blue); }


/* Mobile: shrink DataHub marquee logos 50% */
@media (max-width: 720px) {
  .v-dhub-logo {
    width: 110px !important;
    height: auto !important;
    padding: 12px 14px !important;
  }
  .v-dhub-logo img {
    max-height: 24px !important;
  }
  .v-dhub-marquee__track { gap: 12px !important; }
  .v-dhub-marquee + .v-dhub-marquee { margin-top: 10px !important; }
  .v-dhub__marquees { margin-top: 36px !important; }
}


/* Hide Monitoring (Central de Risco) section on mobile */
@media (max-width: 980px) {
  #monitoramento.v-mon,
  .v-mon { display: none !important; }
}
