/* Homepage conversational demo component. Keep selectors scoped to .rx-demo. */
.rx-demo {
  --bg: #f4f2ec;
  --line: #e5e0d1;
  --ink: #0c2f10;
  --ink-muted: #4a5550;
  --brand: #0f3e17;
  --paper: #ffffff;
  --imessage-blue: #0b93f6;
  --imessage-blue-light: #dcecfb;
  --imessage-blue-soft: #a9d2fb;

  display: flex;
  flex-direction: column;
  color: var(--ink);
  font-family: var(--font-sans);
}

.rx-demo .rx-thread {
  flex: 0 0 auto;
  display: flex;
  flex-direction: column;
  gap: 8px;
  padding: 6px 0 4px;
}

.rx-demo .rx-row {
  display: flex;
  align-items: center;
  gap: 8px;
}

.rx-demo .rx-row.system {
  justify-content: flex-start;
}

.rx-demo .rx-row.user {
  justify-content: flex-end;
}

.rx-demo .rx-bubble {
  max-width: 82%;
  background: var(--line);
  color: var(--ink);
  border: 0;
  border-radius: 20px 20px 20px 6px;
  padding: 11px 16px;
  font-size: 15px;
  line-height: 1.45;
  letter-spacing: 0;
}

.rx-demo .rx-bubble.enter {
  animation: rx-rise 0.21s cubic-bezier(0.2, 0.7, 0.2, 1) forwards;
}

.rx-demo .rx-bubble.user {
  background: var(--imessage-blue);
  color: #fff;
  border-radius: 20px 20px 6px 20px;
  cursor: pointer;
}

.rx-demo .rx-bubble.user.alt {
  background: var(--imessage-blue-light);
  color: var(--ink);
}

.rx-demo .rx-check {
  flex: 0 0 auto;
  width: 22px;
  height: 22px;
  border-radius: 999px;
  background: var(--imessage-blue);
  display: grid;
  place-items: center;
}

.rx-demo .rx-check.empty {
  background: transparent;
  border: 2px solid var(--imessage-blue-soft);
}

.rx-demo .rx-check svg {
  width: 13px;
  height: 13px;
  stroke: #fff;
  stroke-width: 2.4;
  fill: none;
}

.rx-demo .rx-check.empty svg {
  display: none;
}

.rx-demo .rx-choices {
  display: flex;
  flex-direction: column;
  gap: 10px;
}

.rx-demo .rx-option {
  display: flex;
  align-items: center;
  justify-content: flex-end;
  gap: 8px;
  width: 100%;
  margin: 0;
  padding: 0;
  background: none;
  border: 0;
  font: inherit;
  text-align: right;
  cursor: pointer;
  -webkit-tap-highlight-color: transparent;
}

.rx-demo .rx-option .rx-bubble {
  cursor: pointer;
}

.rx-demo .rx-option:focus-visible {
  outline: none;
}

.rx-demo .rx-option:focus-visible .rx-bubble {
  outline: 2px solid var(--imessage-blue);
  outline-offset: 3px;
}

.rx-demo .rx-typing {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  background: var(--line);
  border: 0;
  border-radius: 20px 20px 20px 6px;
  padding: 14px 16px;
}

.rx-demo .rx-typing.user {
  background: var(--imessage-blue);
  border-radius: 20px 20px 6px 20px;
}

.rx-demo .rx-typing.user span {
  background: #fff;
  opacity: 0.7;
}

.rx-demo .rx-typing span {
  width: 7px;
  height: 7px;
  border-radius: 999px;
  background: var(--ink-muted);
  opacity: 0.45;
  animation: rx-blink 1.2s infinite ease-in-out;
}

.rx-demo .rx-typing span:nth-child(2) {
  animation-delay: 0.18s;
}

.rx-demo .rx-typing span:nth-child(3) {
  animation-delay: 0.36s;
}

.rx-demo .rx-convert {
  display: flex;
  flex-direction: column;
  align-items: stretch;
  gap: 22px;
  padding: 12px 0;
  pointer-events: none;
  visibility: hidden;
}

.rx-demo .rx-convert > * {
  opacity: 0;
  transform: translateY(16px);
  will-change: opacity, transform;
}

.rx-demo .rx-convert.show {
  pointer-events: auto;
  visibility: visible;
}

.rx-demo .rx-convert.show > * {
  opacity: 1;
  transform: none;
  transition:
    opacity 0.7s cubic-bezier(0.16, 1, 0.3, 1),
    transform 0.7s cubic-bezier(0.16, 1, 0.3, 1);
}

.rx-demo .rx-convert.show .rx-cta {
  animation: rx-ctaFloat 3.4s ease-in-out 1.4s infinite;
  transition-delay: 0.4s;
}

.rx-demo .rx-cta {
  display: block;
  width: 100%;
  background: var(--brand);
  color: var(--bg);
  text-align: center;
  font-weight: 600;
  font-size: 16px;
  padding: 16px 24px;
  border: 0;
  border-radius: 999px;
  cursor: pointer;
  transition: background 0.16s ease;
}

.rx-demo .rx-cta:hover {
  background: var(--ink);
}

.rx-demo .rx-convert.show .rx-cta:hover,
.rx-demo .rx-convert.show .rx-cta:focus-visible {
  animation: none;
}

.rx-demo .rx-cta:focus-visible {
  outline: 2px solid var(--brand);
  outline-offset: 3px;
}

.rx-demo .rx-footer {
  margin: 6px 0 0;
  padding: 6px 0 10px;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 14px;
  visibility: hidden;
}

.rx-demo .rx-footer > * {
  opacity: 0;
  transform: translateY(16px);
  will-change: opacity, transform;
}

.rx-demo .rx-footer.show {
  visibility: visible;
}

.rx-demo .rx-footer.show > * {
  opacity: 1;
  transform: none;
  transition:
    opacity 0.7s cubic-bezier(0.16, 1, 0.3, 1),
    transform 0.7s cubic-bezier(0.16, 1, 0.3, 1);
}

.rx-demo .rx-footer.show .rx-yc {
  transition-delay: 0.5s;
}

.rx-demo .rx-footer.show .rx-trust {
  transition-delay: 0.8s;
}

.rx-demo .rx-yc {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  font-size: 13px;
  color: var(--ink-muted);
}

.rx-demo .rx-yc-mark {
  width: 20px;
  height: 20px;
  border-radius: 4px;
  display: block;
  flex: 0 0 auto;
}

.rx-demo .rx-yc b {
  color: var(--ink);
  font-weight: 600;
}

.rx-demo .rx-trust {
  width: 100%;
  display: flex;
  justify-content: center;
}

.rx-demo .rx-trust-item {
  display: flex;
  align-items: center;
  gap: 9px;
  text-align: left;
}

.rx-demo .rx-trust-ico {
  flex: 0 0 auto;
  align-self: stretch;
  display: grid;
  place-items: center;
}

.rx-demo .rx-trust-item svg {
  stroke: var(--ink-muted);
  width: 34px;
  height: 34px;
  opacity: 0.78;
}

.rx-demo .rx-trust-label {
  display: flex;
  flex-direction: column;
  justify-content: center;
  font-weight: 500;
  font-size: 15px;
  line-height: 1.2;
  color: var(--ink-muted);
  white-space: nowrap;
}

.rx-demo .rx-trust-label small {
  font-size: 13px;
  font-weight: 500;
  color: var(--ink-muted);
  opacity: 0.8;
  margin-top: 2px;
  white-space: nowrap;
}

@keyframes rx-rise {
  from {
    opacity: 0;
    transform: translateY(10px);
  }
  to {
    opacity: 1;
    transform: none;
  }
}

@keyframes rx-blink {
  0%,
  100% {
    opacity: 0.25;
    transform: translateY(0);
  }
  50% {
    opacity: 0.85;
    transform: translateY(-2px);
  }
}

@keyframes rx-ctaFloat {
  0%,
  100% {
    transform: translateY(0);
  }
  50% {
    transform: translateY(-5px);
  }
}

@media (prefers-reduced-motion: reduce) {
  .rx-demo .rx-bubble.enter {
    animation-duration: 1ms;
  }

  .rx-demo .rx-convert > *,
  .rx-demo .rx-convert.show > *,
  .rx-demo .rx-footer > *,
  .rx-demo .rx-footer.show > * {
    transform: none;
  }

  .rx-demo .rx-convert.show .rx-cta {
    animation: none;
  }
}
