/* =========================================================
   Extracted from views/info.ejs on 20260604-120850
========================================================= */

:root {
      --bg: #050507;
      --panel: rgba(255, 255, 255, 0.045);
      --panel-strong: rgba(255, 255, 255, 0.075);
      --line: rgba(255, 255, 255, 0.10);
      --muted: #a1a1aa;
      --indigo: #6366f1;
      --violet: #a855f7;
      --cyan: #22d3ee;
      --emerald: #34d399;
      --amber: #f59e0b;
    }

    * { box-sizing: border-box; }
    html { scroll-behavior: smooth; }

    body {
      margin: 0;
      background:
        radial-gradient(circle at 15% 8%, rgba(99,102,241,0.22), transparent 30rem),
        radial-gradient(circle at 86% 10%, rgba(168,85,247,0.18), transparent 32rem),
        radial-gradient(circle at 50% 110%, rgba(34,211,238,0.08), transparent 34rem),
        var(--bg);
      color: white;
      font-family: Inter, system-ui, sans-serif;
      overflow-x: hidden;
    }

    .font-display { font-family: 'Space Grotesk', Inter, system-ui, sans-serif; }

    .glass {
      background: var(--panel);
      border: 1px solid var(--line);
      backdrop-filter: blur(24px);
      box-shadow: 0 24px 90px rgba(0,0,0,0.36);
    }

    .glass-strong {
      background: var(--panel-strong);
      border: 1px solid rgba(255,255,255,0.13);
      backdrop-filter: blur(28px);
      box-shadow: 0 28px 100px rgba(0,0,0,0.42);
    }

    .nova-gradient {
      background: linear-gradient(90deg, #93c5fd, #818cf8, #c084fc, #22d3ee);
      -webkit-background-clip: text;
      -webkit-text-fill-color: transparent;
      background-clip: text;
    }

    .grid-bg {
      background-image:
        linear-gradient(rgba(99,102,241,0.07) 1px, transparent 1px),
        linear-gradient(90deg, rgba(99,102,241,0.07) 1px, transparent 1px);
      background-size: 64px 64px;
      mask-image: linear-gradient(to bottom, black, transparent 80%);
    }

    .orb {
      position: absolute;
      border-radius: 999px;
      filter: blur(54px);
      opacity: .5;
      pointer-events: none;
    }

    .orb-one { width: 340px; height: 340px; background: #6366f1; top: 70px; right: 6%; }
    .orb-two { width: 280px; height: 280px; background: #a855f7; top: 600px; left: -80px; }
    .orb-three { width: 260px; height: 260px; background: #22d3ee; top: 1380px; right: -80px; opacity: .2; }

    .hover-lift {
      transition: transform .25s ease, border-color .25s ease, background .25s ease, box-shadow .25s ease;
    }

    .hover-lift:hover {
      transform: translateY(-7px);
      border-color: rgba(129,140,248,0.48);
      background: rgba(255,255,255,0.07);
      box-shadow: 0 30px 110px rgba(99,102,241,0.14);
    }

    .pulse-dot {
      width: 8px;
      height: 8px;
      background: var(--emerald);
      border-radius: 99px;
      box-shadow: 0 0 0 rgba(52,211,153,0.55);
      animation: pulse 2s infinite;
    }

    @keyframes pulse {
      0% { box-shadow: 0 0 0 0 rgba(52,211,153,0.55); }
      70% { box-shadow: 0 0 0 12px rgba(52,211,153,0); }
      100% { box-shadow: 0 0 0 0 rgba(52,211,153,0); }
    }

    .nova-brand-logo {
      position: relative;
      width: 64px;
      height: 64px;
      border-radius: 999px;
      flex: 0 0 auto;
      display: flex;
      align-items: center;
      justify-content: center;
      overflow: visible;
      filter:
        drop-shadow(0 0 16px rgba(99,102,241,0.65))
        drop-shadow(0 0 30px rgba(168,85,247,0.28));
    }

    .nova-brand-orb,
    .nova-brand-eyes {
      position: absolute;
      inset: 0;
      width: 100%;
      height: 100%;
      object-fit: contain;
      display: block;
    }

    .nova-brand-orb {
      z-index: 1;
      animation: novaOrbSpin 42s linear infinite;
      transform-origin: center center;
    }

    .nova-brand-eyes {
      z-index: 2;
      animation: novaEyesBlink 5.8s infinite;
      transform-origin: center center;
    }

    @keyframes novaOrbSpin {
      from { transform: rotate(0deg); }
      to { transform: rotate(360deg); }
    }

    @keyframes novaEyesBlink {
      0%, 86%, 100% { transform: scale(0.78, 0.78); opacity: 1; }
      88% { transform: scale(0.78, 0.08); opacity: 0.75; }
      90% { transform: scale(0.78, 0.78); opacity: 1; }
      94% { transform: scale(0.78, 0.08); opacity: 0.75; }
      96% { transform: scale(0.78, 0.78); opacity: 1; }
    }

    /* =========================================================
       UNIQUE INFO ANIMATION: 3D KNOWLEDGE PRISM
       Different from Core chip, Engine pipeline and Proof ledger.
    ========================================================= */

    .info-prism-wrap {
      position: relative;
      min-height: 620px;
      perspective: 1400px;
      transform-style: preserve-3d;
      overflow: hidden;
    }

    .prism-stage {
      position: absolute;
      inset: 34px;
      border-radius: 2.4rem;
      background:
        radial-gradient(circle at 50% 28%, rgba(34,211,238,.10), transparent 18rem),
        radial-gradient(circle at 50% 80%, rgba(99,102,241,.12), transparent 24rem),
        linear-gradient(145deg, rgba(255,255,255,.075), rgba(255,255,255,.015));
      border: 1px solid rgba(255,255,255,.12);
      transform-style: preserve-3d;
      overflow: hidden;
    }

    .prism-floor {
      position: absolute;
      left: 50%;
      bottom: 44px;
      width: 560px;
      height: 280px;
      transform: translateX(-50%) rotateX(70deg) rotateZ(-6deg);
      background:
        linear-gradient(rgba(99,102,241,.16) 1px, transparent 1px),
        linear-gradient(90deg, rgba(99,102,241,.16) 1px, transparent 1px);
      background-size: 32px 32px;
      border-radius: 2rem;
      mask-image: radial-gradient(circle at center, black 0%, black 48%, transparent 76%);
      opacity: .72;
      animation: floorDrift 6s ease-in-out infinite;
    }

    @keyframes floorDrift {
      0%, 100% { transform: translateX(-50%) rotateX(70deg) rotateZ(-6deg) translateY(0); }
      50% { transform: translateX(-50%) rotateX(70deg) rotateZ(-6deg) translateY(-10px); }
    }

    .data-beam-vertical {
      position: absolute;
      left: 50%;
      top: 45%;
      width: 18px;
      height: 280px;
      transform: translate(-50%, -50%);
      background: linear-gradient(to bottom, rgba(34,211,238,0), rgba(34,211,238,.72), rgba(99,102,241,.15), rgba(34,211,238,0));
      filter: blur(4px);
      opacity: .8;
      z-index: 4;
      animation: beamBreath 3.4s ease-in-out infinite;
    }

    @keyframes beamBreath {
      0%, 100% { opacity: .46; height: 260px; }
      50% { opacity: .95; height: 300px; }
    }

    .prism-shell {
      position: absolute;
      left: 50%;
      top: 54%;
      width: 250px;
      height: 250px;
      transform-style: preserve-3d;
      transform: translate(-50%, -50%) rotateX(68deg) rotateZ(45deg);
      z-index: 6;
      animation: prismRotate 14s linear infinite;
    }

    @keyframes prismRotate {
      from { transform: translate(-50%, -50%) rotateX(68deg) rotateZ(0deg); }
      to { transform: translate(-50%, -50%) rotateX(68deg) rotateZ(360deg); }
    }

    .prism-face {
      position: absolute;
      inset: 0;
      border: 1px solid rgba(255,255,255,.16);
      background:
        linear-gradient(135deg, rgba(255,255,255,.11), rgba(255,255,255,.02)),
        linear-gradient(90deg, rgba(99,102,241,.12), rgba(34,211,238,.08));
      border-radius: 1.8rem;
      box-shadow:
        0 20px 70px rgba(0,0,0,.32),
        inset 0 0 30px rgba(34,211,238,.05);
    }

    .prism-face.face-a { transform: translateZ(46px); }
    .prism-face.face-b { transform: translateZ(-46px); opacity: .55; }
    .prism-face.face-c { transform: rotateY(90deg) translateZ(46px); opacity: .62; }
    .prism-face.face-d { transform: rotateY(90deg) translateZ(-46px); opacity: .42; }

    .info-orb-node {
      position: absolute;
      left: 50%;
      top: 33%;
      width: 180px;
      height: 180px;
      transform: translate(-50%, -50%);
      border-radius: 999px;
      display: grid;
      place-items: center;
      z-index: 9;
      animation: orbHover 5s ease-in-out infinite;
    }

    @keyframes orbHover {
      0%, 100% { transform: translate(-50%, -50%) translateY(0); }
      50% { transform: translate(-50%, -50%) translateY(-12px); }
    }

    .info-orb-glow {
      position: absolute;
      inset: -24px;
      border-radius: 999px;
      background:
        radial-gradient(circle, rgba(34,211,238,.20), transparent 56%),
        radial-gradient(circle, rgba(168,85,247,.22), transparent 66%);
      filter: blur(12px);
      animation: nodeGlow 3.2s ease-in-out infinite;
    }

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

    .info-orb-node .nova-brand-logo {
      width: 142px;
      height: 142px;
    }

    .info-panel {
      position: absolute;
      width: 152px;
      min-height: 92px;
      border-radius: 1.2rem;
      padding: 14px;
      background: rgba(8, 8, 14, .78);
      border: 1px solid rgba(255,255,255,.13);
      backdrop-filter: blur(16px);
      box-shadow: 0 18px 60px rgba(0,0,0,.35);
      z-index: 8;
      animation: infoPanelFloat 6s ease-in-out infinite;
    }

    .info-panel .eyebrow {
      font-size: 10px;
      text-transform: uppercase;
      letter-spacing: .16em;
      color: #a5b4fc;
    }

    .info-panel .headline {
      margin-top: 5px;
      font-size: 22px;
      line-height: 1;
      font-weight: 900;
    }

    .info-panel .caption {
      margin-top: 6px;
      font-size: 11px;
      color: #a1a1aa;
      line-height: 1.4;
    }

    .panel-a { left: 6%; top: 16%; animation-delay: 0s; }
    .panel-b { right: 6%; top: 18%; animation-delay: .8s; }
    .panel-c { left: 8%; bottom: 15%; animation-delay: 1.6s; }
    .panel-d { right: 8%; bottom: 15%; animation-delay: 2.2s; }

    @keyframes infoPanelFloat {
      0%, 100% { transform: translateY(0) translateZ(0); }
      50% { transform: translateY(-14px) translateZ(18px); }
    }

    .info-link {
      position: absolute;
      height: 2px;
      background: linear-gradient(90deg, transparent, rgba(34,211,238,.75), transparent);
      opacity: .6;
      z-index: 5;
      transform-origin: left center;
      filter: drop-shadow(0 0 10px rgba(34,211,238,.4));
      animation: linkPulse 3s ease-in-out infinite;
    }

    .link-a { width: 240px; left: 22%; top: 28%; transform: rotate(12deg); }
    .link-b { width: 240px; right: 22%; top: 30%; transform: rotate(168deg); }
    .link-c { width: 240px; left: 22%; bottom: 29%; transform: rotate(-16deg); }
    .link-d { width: 240px; right: 22%; bottom: 29%; transform: rotate(196deg); }

    @keyframes linkPulse {
      0%, 100% { opacity: .18; }
      50% { opacity: .88; }
    }

    .insight-band {
      position: absolute;
      left: 50%;
      bottom: 36px;
      transform: translateX(-50%);
      display: flex;
      align-items: center;
      gap: 12px;
      padding: 13px 18px;
      border-radius: 999px;
      background: rgba(5,5,7,.74);
      border: 1px solid rgba(255,255,255,.12);
      backdrop-filter: blur(18px);
      box-shadow: 0 14px 50px rgba(0,0,0,.35);
      z-index: 10;
      font-size: 13px;
      color: #d4d4d8;
      white-space: nowrap;
    }

    .insight-band i { color: #22d3ee; }

    .mobile-menu {
      max-height: 0;
      overflow: hidden;
      transition: max-height .25s ease;
    }

    .mobile-menu.open { max-height: 520px; }

    .mini-terminal-line {
      font-family: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, monospace;
      font-size: 13px;
      color: #d4d4d8;
      opacity: 0;
      transform: translateY(8px);
      animation: lineIn .7s ease forwards;
    }

    .mini-terminal-line:nth-child(1) { animation-delay: .2s; }
    .mini-terminal-line:nth-child(2) { animation-delay: .7s; }
    .mini-terminal-line:nth-child(3) { animation-delay: 1.2s; }
    .mini-terminal-line:nth-child(4) { animation-delay: 1.7s; }

    @keyframes lineIn {
      to { opacity: 1; transform: translateY(0); }
    }

    .product-card.active {
      border-color: rgba(129,140,248,0.58);
      box-shadow: 0 0 0 1px rgba(129,140,248,0.18), 0 25px 80px rgba(99,102,241,0.18);
      background: rgba(255,255,255,.07);
    }

    @media (max-width: 900px) {
      .info-prism-wrap { min-height: 660px; }
      .prism-stage { inset: 16px; }
      .prism-floor { width: 460px; height: 250px; }
      .prism-shell { width: 210px; height: 210px; top: 56%; }
      .info-orb-node { top: 31%; }
      .info-orb-node .nova-brand-logo { width: 118px; height: 118px; }
      .info-panel { width: 130px; padding: 12px; }
      .info-panel .headline { font-size: 18px; }
      .panel-a { left: 4%; top: 13%; }
      .panel-b { right: 4%; top: 13%; }
      .panel-c { left: 4%; bottom: 12%; }
      .panel-d { right: 4%; bottom: 12%; }
      .info-link { display: none; }
      .insight-band {
        width: calc(100% - 48px);
        justify-content: center;
        text-align: center;
        white-space: normal;
        bottom: 28px;
      }
    }
