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

:root {
      --bg: #050507;
      --panel: rgba(255,255,255,.045);
      --panel-strong: rgba(255,255,255,.075);
      --line: rgba(255,255,255,.10);
      --indigo: #6366f1;
      --violet: #a855f7;
      --cyan: #22d3ee;
      --emerald: #34d399;
    }

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

    body {
      margin: 0;
      color: white;
      font-family: Inter, system-ui, sans-serif;
      overflow-x: hidden;
      background:
        radial-gradient(circle at 14% 8%, rgba(99,102,241,.23), transparent 30rem),
        radial-gradient(circle at 88% 5%, rgba(168,85,247,.21), transparent 32rem),
        radial-gradient(circle at 50% 110%, rgba(34,211,238,.09), transparent 34rem),
        var(--bg);
    }

    .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,.36);
    }

    .glass-strong {
      background: var(--panel-strong);
      border: 1px solid rgba(255,255,255,.13);
      backdrop-filter: blur(28px);
      box-shadow: 0 28px 100px rgba(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,.07) 1px, transparent 1px),
        linear-gradient(90deg, rgba(99,102,241,.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: 650px; left: -90px; }
    .orb-three { width: 260px; height: 260px; background: #22d3ee; top: 1450px; right: -90px; 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,.48);
      background: rgba(255,255,255,.07);
      box-shadow: 0 30px 110px rgba(99,102,241,.14);
    }

    .pulse-dot {
      width: 8px;
      height: 8px;
      background: var(--emerald);
      border-radius: 99px;
      animation: pulse 2s infinite;
    }

    @keyframes pulse {
      0% { box-shadow: 0 0 0 0 rgba(52,211,153,.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;
      filter: drop-shadow(0 0 16px rgba(99,102,241,.65)) drop-shadow(0 0 30px rgba(168,85,247,.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; }
    .nova-brand-eyes { z-index: 2; animation: novaEyesBlink 5.8s infinite; transform-origin: center; }

    @keyframes novaOrbSpin { from { transform: rotate(0deg); } to { transform: rotate(360deg); } }
    @keyframes novaEyesBlink {
      0%,86%,100% { transform: scale(.78,.78); opacity: 1; }
      88% { transform: scale(.78,.08); opacity: .75; }
      90% { transform: scale(.78,.78); opacity: 1; }
      94% { transform: scale(.78,.08); opacity: .75; }
      96% { transform: scale(.78,.78); opacity: 1; }
    }

    /* NEW UNIQUE PRICING 3D: MONOLITH CHAMBER */
    .pricing-chamber {
      position: relative;
      min-height: 640px;
      perspective: 1400px;
      transform-style: preserve-3d;
      overflow: hidden;
    }

    .chamber-stage {
      position: absolute;
      inset: 34px;
      border-radius: 2.4rem;
      background:
        radial-gradient(circle at 50% 35%, rgba(99,102,241,.16), transparent 18rem),
        radial-gradient(circle at 50% 78%, rgba(34,211,238,.10), transparent 23rem),
        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;
    }

    .chamber-floor {
      position: absolute;
      left: 50%;
      bottom: 42px;
      width: 700px;
      height: 320px;
      transform: translateX(-50%) rotateX(70deg);
      border-radius: 2rem;
      background:
        radial-gradient(circle at center, rgba(34,211,238,.12), transparent 36%),
        linear-gradient(rgba(129,140,248,.18) 1px, transparent 1px),
        linear-gradient(90deg, rgba(129,140,248,.18) 1px, transparent 1px);
      background-size: auto, 34px 34px, 34px 34px;
      mask-image: radial-gradient(circle at center, black 0%, black 48%, transparent 78%);
      opacity: .72;
      animation: chamberFloor 6s ease-in-out infinite;
    }

    @keyframes chamberFloor {
      0%,100% { transform: translateX(-50%) rotateX(70deg) translateY(0); opacity: .54; }
      50% { transform: translateX(-50%) rotateX(70deg) translateY(-12px); opacity: .86; }
    }

    .price-beam {
      position: absolute;
      left: 50%;
      top: 45%;
      width: 26px;
      height: 350px;
      transform: translate(-50%, -50%);
      background: linear-gradient(to bottom, rgba(34,211,238,0), rgba(34,211,238,.75), rgba(168,85,247,.26), rgba(34,211,238,0));
      filter: blur(6px);
      opacity: .78;
      z-index: 4;
      animation: priceBeam 3.2s ease-in-out infinite;
    }

    @keyframes priceBeam {
      0%,100% { height: 310px; opacity: .45; }
      50% { height: 380px; opacity: 1; }
    }

    .price-nova-node {
      position: absolute;
      left: 50%;
      top: 30%;
      width: 178px;
      height: 178px;
      transform: translate(-50%, -50%);
      border-radius: 999px;
      display: grid;
      place-items: center;
      z-index: 12;
      animation: priceNodeFloat 5s ease-in-out infinite;
    }

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

    .price-node-halo {
      position: absolute;
      inset: -26px;
      border-radius: 999px;
      background: conic-gradient(from 0deg, rgba(34,211,238,0), rgba(34,211,238,.58), rgba(168,85,247,.5), rgba(99,102,241,.45), rgba(34,211,238,0));
      filter: blur(11px);
      animation: priceHaloSpin 8s linear infinite;
      opacity: .75;
    }

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

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

    .monolith {
      position: absolute;
      width: 126px;
      height: 210px;
      border-radius: 1.6rem;
      background:
        linear-gradient(160deg, rgba(255,255,255,.18), rgba(255,255,255,.035)),
        linear-gradient(90deg, rgba(99,102,241,.22), rgba(34,211,238,.08));
      border: 1px solid rgba(255,255,255,.16);
      box-shadow: 0 24px 90px rgba(0,0,0,.42), inset 0 0 34px rgba(34,211,238,.07);
      overflow: hidden;
      z-index: 7;
      animation: monolithFloat 5.8s ease-in-out infinite;
      transition: border-color .25s ease, filter .25s ease;
    }

    .monolith:hover { border-color: rgba(129,140,248,.75); filter: brightness(1.12); }

    .monolith::before {
      content: "";
      position: absolute;
      inset: 0;
      background: linear-gradient(90deg, transparent, rgba(255,255,255,.17), transparent);
      transform: translateX(-120%);
      animation: monolithScan 4.3s ease-in-out infinite;
    }

    @keyframes monolithScan {
      0%,100% { transform: translateX(-130%); opacity: 0; }
      20%,68% { opacity: 1; }
      72% { transform: translateX(130%); opacity: 0; }
    }

    @keyframes monolithFloat {
      0%,100% { translate: 0 0; }
      50% { translate: 0 -14px; }
    }

    .monolith-inner {
      position: relative;
      z-index: 2;
      height: 100%;
      padding: 18px 14px;
      display: flex;
      flex-direction: column;
      justify-content: space-between;
    }

    .monolith-label { font-size: 10px; letter-spacing: .16em; text-transform: uppercase; color: #a5b4fc; }
    .monolith-name { margin-top: 8px; font-family: "Space Grotesk"; font-size: 22px; line-height: 1; font-weight: 800; }
    .monolith-price { font-size: 23px; line-height: 1; font-weight: 900; font-variant-numeric: tabular-nums; }
    .monolith-status {
      display: inline-flex;
      width: fit-content;
      padding: 7px 9px;
      border-radius: 999px;
      font-size: 10px;
      font-weight: 900;
      letter-spacing: .09em;
      text-transform: uppercase;
      background: rgba(255,255,255,.08);
      border: 1px solid rgba(255,255,255,.13);
      color: #d4d4d8;
    }

    .mono-free { left: 7%; bottom: 18%; animation-delay: 0s; }
    .mono-lite { left: 29%; bottom: 10%; animation-delay: .7s; }
    .mono-premium {
      right: 29%;
      bottom: 10%;
      animation-delay: 1.4s;
      border-color: rgba(129,140,248,.52);
      box-shadow: 0 28px 105px rgba(99,102,241,.25), inset 0 0 34px rgba(34,211,238,.07);
    }
    .mono-super { right: 7%; bottom: 18%; animation-delay: 2.1s; }

    .mono-premium .monolith-status {
      background: rgba(99,102,241,.18);
      border-color: rgba(129,140,248,.32);
      color: #c7d2fe;
    }

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

    .path-1 { width: 250px; left: 20%; top: 42%; transform: rotate(20deg); }
    .path-2 { width: 210px; left: 36%; top: 54%; transform: rotate(-18deg); }
    .path-3 { width: 210px; right: 36%; top: 54%; transform: rotate(198deg); }
    .path-4 { width: 250px; right: 20%; top: 42%; transform: rotate(160deg); }

    @keyframes pathPulse {
      0%,100% { opacity: .16; }
      50% { opacity: .82; }
    }

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

    .pricing-command i { color: #22d3ee; }

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

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

    .product-card { position: relative; overflow: hidden; }
    .product-card::before {
      content: "";
      position: absolute;
      inset: 0;
      background: linear-gradient(135deg, rgba(99,102,241,.14), transparent 38%, rgba(34,211,238,.08));
      opacity: 0;
      transition: opacity .25s ease;
      pointer-events: none;
    }
    .product-card:hover::before, .product-card.featured::before { opacity: 1; }
    .product-card > * { position: relative; z-index: 2; }

    .feature-row {
      display: grid;
      grid-template-columns: 1.5fr repeat(4, 1fr);
      gap: 1px;
      background: rgba(255,255,255,.08);
      border-radius: 1.25rem;
      overflow: hidden;
      border: 1px solid rgba(255,255,255,.10);
    }

    .feature-cell {
      background: rgba(5,5,7,.72);
      padding: 18px;
      min-height: 68px;
      display: flex;
      align-items: center;
      color: #d4d4d8;
      font-size: 14px;
    }

    .feature-cell.center {
      justify-content: center;
      text-align: center;
      font-weight: 700;
    }

    @media (max-width: 1000px) {
      .pricing-chamber { min-height: 720px; }
      .chamber-stage { inset: 16px; }
      .chamber-floor { width: 520px; height: 280px; bottom: 84px; }
      .price-nova-node { top: 26%; }
      .price-nova-node .nova-brand-logo { width: 116px; height: 116px; }
      .monolith { width: 116px; height: 178px; }
      .monolith-name { font-size: 18px; }
      .monolith-price { font-size: 20px; }
      .mono-free { left: 5%; bottom: 28%; }
      .mono-lite { left: 20%; bottom: 7%; }
      .mono-premium { right: 20%; bottom: 7%; }
      .mono-super { right: 5%; bottom: 28%; }
      .price-path { display: none; }
      .pricing-command {
        width: calc(100% - 48px);
        justify-content: center;
        text-align: center;
        white-space: normal;
        bottom: 28px;
      }
      .feature-row { grid-template-columns: 1fr; }
      .feature-cell { min-height: auto; }
    }
