/* ================================
   Vee Companion Blocks
   Reusable page CTA for Vee as a signal companion
================================ */

.vee-companion-section {
  position: relative;
}

.vee-companion-card {
  position: relative;
  display: grid;
  grid-template-columns: 0.95fr 1.05fr;
  gap: clamp(20px, 4vw, 42px);
  align-items: center;
  padding: clamp(24px, 4vw, 42px);
  border-radius: var(--radius-xl);
  overflow: hidden;
  isolation: isolate;
  background:
    radial-gradient(circle at 14% 18%, rgba(82, 255, 224, 0.20), transparent 28%),
    radial-gradient(circle at 82% 72%, rgba(185, 150, 255, 0.22), transparent 34%),
    linear-gradient(135deg, rgba(255,255,255,.105), rgba(255,255,255,.04));
  border: 1px solid rgba(255,255,255,.14);
  box-shadow: 0 24px 80px rgba(0,0,0,.28);
}

.vee-companion-card::before {
  content: "";
  position: absolute;
  inset: 18px;
  border-radius: calc(var(--radius-xl) - 10px);
  border: 1px solid rgba(82, 255, 224, 0.10);
  pointer-events: none;
  z-index: -1;
}

.vee-companion-copy h2 {
  margin-bottom: 14px;
}

.vee-companion-copy p {
  max-width: 720px;
}

.vee-companion-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
  margin-top: 22px;
}

.vee-companion-orb {
  position: relative;
  min-height: 260px;
  display: grid;
  place-items: center;
}

.vee-companion-orb::before,
.vee-companion-orb::after {
  content: "";
  position: absolute;
  left: 50%;
  top: 50%;
  width: min(420px, 88%);
  height: 160px;
  border: 1.8px solid rgba(244, 251, 255, 0.62);
  border-radius: 50%;
  transform: translate(-50%, -50%) rotate(22deg);
  box-shadow: 0 0 26px rgba(106, 242, 255, 0.16);
}

.vee-companion-orb::after {
  transform: translate(-50%, -50%) rotate(-28deg);
  border-color: rgba(185, 150, 255, 0.58);
}

.vee-companion-core {
  width: 128px;
  height: 128px;
  border-radius: 50%;
  position: relative;
  z-index: 2;
  display: grid;
  place-items: center;
  color: #07112c;
  font-weight: 950;
  font-size: 2rem;
  background:
    radial-gradient(circle at 34% 26%,
      rgba(255, 255, 255, 0.98) 0%,
      rgba(221, 251, 255, 0.98) 12%,
      rgba(106, 242, 255, 0.94) 31%,
      rgba(47, 109, 255, 0.92) 56%,
      rgba(138, 92, 255, 0.88) 77%,
      rgba(255, 123, 229, 0.84) 100%);
  box-shadow:
    0 0 42px rgba(106, 242, 255, 0.45),
    0 0 88px rgba(47, 109, 255, 0.36),
    0 0 128px rgba(138, 92, 255, 0.28),
    inset 0 0 28px rgba(255, 255, 255, 0.22);
  animation: veeCompanionPulse 4s ease-in-out infinite;
}

.vee-companion-prompt {
  position: absolute;
  right: 0;
  bottom: 0;
  z-index: 3;
  max-width: 330px;
  padding: 16px 18px;
  border-radius: 24px;
  background: rgba(5, 9, 25, 0.70);
  border: 1px solid rgba(82, 255, 224, 0.22);
  backdrop-filter: blur(14px);
  -webkit-backdrop-filter: blur(14px);
  box-shadow: 0 18px 50px rgba(0,0,0,.25);
}

.vee-companion-prompt strong {
  display: block;
  color: var(--text);
  margin-bottom: 5px;
}

.vee-companion-prompt span {
  display: block;
  color: var(--muted);
  line-height: 1.45;
  font-size: .95rem;
}

.vee-prompt-chips {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  margin-top: 18px;
}

.vee-prompt-chips span {
  padding: 9px 12px;
  border-radius: 999px;
  color: #dffef8;
  font-weight: 800;
  font-size: .88rem;
  background: rgba(82, 255, 224, 0.10);
  border: 1px solid rgba(82, 255, 224, 0.20);
}

@keyframes veeCompanionPulse {
  0%, 100% { transform: scale(1); filter: brightness(1) saturate(1); }
  50% { transform: scale(1.055); filter: brightness(1.13) saturate(1.22); }
}

@media (max-width: 860px) {
  .vee-companion-card {
    grid-template-columns: 1fr;
  }

  .vee-companion-orb {
    min-height: 230px;
    order: -1;
  }

  .vee-companion-prompt {
    position: relative;
    right: auto;
    bottom: auto;
    margin-top: 18px;
    max-width: none;
  }
}

@media (max-width: 560px) {
  .vee-companion-card {
    padding: 22px;
    border-radius: 28px;
  }

  .vee-companion-core {
    width: 106px;
    height: 106px;
    font-size: 1.65rem;
  }

  .vee-companion-orb::before,
  .vee-companion-orb::after {
    width: min(300px, 92vw);
    height: 120px;
  }
}

@media (prefers-reduced-motion: reduce) {
  .vee-companion-core {
    animation: none;
  }
}

.result-vee-prompt {
  margin-top: 16px;
  padding: 14px 16px;
  border-radius: 20px;
  background: rgba(82, 255, 224, 0.08);
  border: 1px solid rgba(82, 255, 224, 0.18);
}

.result-vee-prompt strong {
  display: block;
  color: var(--text);
  margin-bottom: 5px;
}

.result-vee-prompt span {
  display: block;
  color: var(--muted);
  line-height: 1.5;
}
