/* Rico aos Poucos — Card CTA de carteira no topo do artigo.
 *
 * Renderizado por assets/article-cta/cta.js logo após .article-header.
 * 4 estados (data-state): anon-fii, logged-not-owned, logged-owned, generic.
 *
 * Design: bloco com foto skyline noturna ao fundo, overlay azul institucional
 * da marca (#203A57) + acento dourado (#D6A42D). Compacto no mobile.
 */

.rap-cta-carteira {
  --rap-cta-blue:        #203A57;
  --rap-cta-blue-deep:   #15263a;
  --rap-cta-blue-bright: #4d7ab5;
  --rap-cta-gold:        #D6A42D;
  --rap-cta-gold-light:  #ECC25A;
  --rap-cta-gold-deep:   #a8801f;
  --rap-cta-text:        #f5f7fb;
  --rap-cta-muted:       #b3c2d6;

  position: relative;
  margin: 26px 0 32px;
  padding: 26px 28px 22px;
  border-radius: 18px;
  color: var(--rap-cta-text);
  overflow: hidden;
  isolation: isolate;
  background-color: var(--rap-cta-blue-deep);
  border: 1px solid rgba(214, 164, 45, 0.30);
  box-shadow:
    0 1px 0 rgba(255, 255, 255, 0.06) inset,
    0 22px 60px -30px rgba(15, 26, 50, 0.85),
    0 6px 18px -8px rgba(214, 164, 45, 0.18);
}

/* Imagem de fundo (skyline noturna) — pseudo-elemento atrás de tudo, com
   overlay azul institucional sobreposto pra manter contraste com texto. */
.rap-cta-carteira::before {
  content: "";
  position: absolute;
  inset: 0;
  z-index: -2;
  background-image: url("/assets/article-cta/bg/skyline-desktop.jpg");
  background-size: cover;
  background-position: center 30%;
  background-repeat: no-repeat;
  opacity: 0.55;
  filter: saturate(0.85) contrast(1.05);
}

.rap-cta-carteira::after {
  content: "";
  position: absolute;
  inset: 0;
  z-index: -1;
  background:
    linear-gradient(115deg,
      rgba(21, 38, 58, 0.94) 0%,
      rgba(32, 58, 87, 0.82) 45%,
      rgba(32, 58, 87, 0.62) 100%
    ),
    radial-gradient(120% 90% at 100% 0%, rgba(214, 164, 45, 0.16) 0%, transparent 55%);
}

/* Borda dourada animada bem sutil */
.rap-cta-carteira__inner {
  display: grid;
  grid-template-columns: auto 1fr;
  gap: 14px 20px;
  align-items: start;
}

.rap-cta-carteira__icon {
  width: 52px;
  height: 52px;
  border-radius: 14px;
  background: linear-gradient(135deg, rgba(214, 164, 45, 0.30), rgba(214, 164, 45, 0.10));
  border: 1px solid rgba(214, 164, 45, 0.55);
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  box-shadow: 0 4px 14px -4px rgba(214, 164, 45, 0.4);
}

.rap-cta-carteira__icon svg {
  width: 28px;
  height: 28px;
  color: var(--rap-cta-gold-light);
}

.rap-cta-carteira__head {
  display: flex;
  flex-direction: column;
  gap: 6px;
  min-width: 0;
}

.rap-cta-carteira__top {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 8px 14px;
  margin-bottom: 2px;
}

.rap-cta-carteira__eyebrow {
  font-size: 0.72rem;
  font-weight: 700;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--rap-cta-gold-light);
  display: inline-flex;
  align-items: center;
  gap: 8px;
}

.rap-cta-carteira__eyebrow::before {
  content: "";
  width: 6px;
  height: 6px;
  border-radius: 50%;
  background: var(--rap-cta-gold-light);
  box-shadow: 0 0 0 4px rgba(214, 164, 45, 0.20);
  animation: rap-cta-pulse 2.4s ease-out infinite;
}

@keyframes rap-cta-pulse {
  0%, 100% { box-shadow: 0 0 0 0 rgba(214, 164, 45, 0.55); }
  50%      { box-shadow: 0 0 0 6px rgba(214, 164, 45, 0); }
}

.rap-cta-carteira__social {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 4px 10px;
  border-radius: 999px;
  background: rgba(214, 164, 45, 0.14);
  border: 1px solid rgba(214, 164, 45, 0.40);
  font-size: 0.78rem;
  color: #fdf3d6;
  line-height: 1.2;
}

.rap-cta-carteira__social svg {
  width: 14px;
  height: 14px;
  color: var(--rap-cta-gold-light);
  flex-shrink: 0;
}

.rap-cta-carteira__social b {
  color: #fff;
  font-weight: 700;
}

.rap-cta-carteira__social[hidden] {
  display: none;
}

.rap-cta-carteira__title {
  font-size: 1.28rem;
  font-weight: 700;
  line-height: 1.25;
  color: #ffffff;
  margin: 0;
  text-shadow: 0 2px 8px rgba(0, 0, 0, 0.35);
}

.rap-cta-carteira__title strong {
  color: var(--rap-cta-gold-light);
  font-weight: 800;
}

.rap-cta-carteira__sub {
  font-size: 0.95rem;
  line-height: 1.55;
  color: #dbe4f0;
  margin: 2px 0 0;
}

.rap-cta-carteira__cta {
  grid-column: 1 / -1;
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
  align-items: center;
  margin-top: 8px;
}

.rap-cta-carteira__btn {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  padding: 13px 22px;
  border-radius: 12px;
  font-family: inherit;
  font-size: 1rem;
  font-weight: 700;
  letter-spacing: 0.01em;
  cursor: pointer;
  border: 1px solid transparent;
  text-decoration: none;
  transition: transform 0.15s ease, box-shadow 0.15s ease, background 0.15s ease;
  white-space: nowrap;
}

.rap-cta-carteira__btn--primary {
  background: linear-gradient(135deg, var(--rap-cta-gold) 0%, var(--rap-cta-gold-deep) 100%);
  color: #1a1a1a;
  box-shadow:
    0 10px 28px -8px rgba(214, 164, 45, 0.65),
    0 1px 0 rgba(255, 255, 255, 0.30) inset;
}

.rap-cta-carteira__btn--primary:hover {
  transform: translateY(-1px);
  background: linear-gradient(135deg, var(--rap-cta-gold-light) 0%, var(--rap-cta-gold) 100%);
  box-shadow:
    0 14px 36px -8px rgba(214, 164, 45, 0.75),
    0 1px 0 rgba(255, 255, 255, 0.35) inset;
  color: #1a1a1a;
}

.rap-cta-carteira__btn--owned {
  background: rgba(214, 164, 45, 0.14);
  color: var(--rap-cta-gold-light);
  border-color: rgba(214, 164, 45, 0.55);
}

.rap-cta-carteira__btn--owned:hover {
  background: rgba(214, 164, 45, 0.22);
  color: var(--rap-cta-gold-light);
}

.rap-cta-carteira__btn svg {
  width: 20px;
  height: 20px;
  stroke-width: 2.2;
}

.rap-cta-carteira__hint {
  font-size: 0.82rem;
  color: var(--rap-cta-muted);
  display: inline-flex;
  align-items: center;
  gap: 6px;
}

.rap-cta-carteira__hint b {
  color: #f0f4fa;
  font-weight: 600;
}

.rap-cta-carteira__hint svg {
  width: 14px;
  height: 14px;
  opacity: 0.7;
}

.rap-cta-carteira__perks {
  display: flex;
  flex-wrap: wrap;
  gap: 12px 20px;
  margin-top: 14px;
  padding-top: 14px;
  border-top: 1px dashed rgba(214, 164, 45, 0.25);
}

.rap-cta-carteira__perk {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  font-size: 0.84rem;
  color: #dbe4f0;
}

.rap-cta-carteira__perk svg {
  width: 16px;
  height: 16px;
  color: var(--rap-cta-gold-light);
  flex-shrink: 0;
}

/* Estado "já tem na carteira" — visual mais sereno, dourado mais discreto */
.rap-cta-carteira[data-state="logged-owned"]::after {
  background:
    linear-gradient(115deg,
      rgba(21, 38, 58, 0.92) 0%,
      rgba(32, 58, 87, 0.78) 45%,
      rgba(32, 58, 87, 0.58) 100%
    );
}

.rap-cta-carteira[data-state="logged-owned"] .rap-cta-carteira__title strong {
  color: var(--rap-cta-gold-light);
}

/* Mobile — bem mais compacto */
@media (max-width: 640px) {
  .rap-cta-carteira {
    padding: 16px 16px 14px;
    margin: 18px 0 24px;
    border-radius: 14px;
  }

  /* Mobile usa a versão menor da imagem (40KB) */
  .rap-cta-carteira::before {
    background-image: url("/assets/article-cta/bg/skyline-mobile.jpg");
    background-position: center 40%;
    opacity: 0.48;
  }

  .rap-cta-carteira__inner {
    grid-template-columns: 1fr;
    gap: 10px;
  }

  /* Esconde o ícone XL no mobile — o eyebrow + título já bastam */
  .rap-cta-carteira__icon {
    display: none;
  }

  .rap-cta-carteira__top {
    gap: 6px 10px;
    margin-bottom: 0;
  }

  .rap-cta-carteira__eyebrow {
    font-size: 0.66rem;
    letter-spacing: 0.14em;
  }

  .rap-cta-carteira__social {
    font-size: 0.72rem;
    padding: 3px 8px;
  }

  .rap-cta-carteira__title {
    font-size: 1.02rem;
    line-height: 1.22;
  }

  .rap-cta-carteira__sub {
    font-size: 0.86rem;
    line-height: 1.45;
  }

  .rap-cta-carteira__cta {
    margin-top: 4px;
    gap: 8px;
  }

  .rap-cta-carteira__btn {
    width: 100%;
    justify-content: center;
    padding: 12px 16px;
    font-size: 0.92rem;
  }

  .rap-cta-carteira__hint {
    width: 100%;
    justify-content: center;
    text-align: center;
    font-size: 0.76rem;
  }

  .rap-cta-carteira__perks {
    gap: 8px 14px;
    margin-top: 10px;
    padding-top: 10px;
  }

  .rap-cta-carteira__perk {
    font-size: 0.76rem;
  }

  .rap-cta-carteira__perk svg {
    width: 14px;
    height: 14px;
  }
}

/* Modal de cotas — também rebrand pra azul+dourado */
.rap-cta-modal-backdrop {
  position: fixed;
  inset: 0;
  background: rgba(13, 22, 36, 0.82);
  backdrop-filter: blur(4px);
  z-index: 10000;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 20px;
}

.rap-cta-modal {
  background: #1a273a;
  border: 1px solid rgba(214, 164, 45, 0.35);
  border-radius: 18px;
  width: 100%;
  max-width: 480px;
  padding: 28px 26px 24px;
  box-shadow: 0 24px 80px rgba(0, 0, 0, 0.6);
  color: #e6ecf5;
}

.rap-cta-modal h2 { margin: 0 0 6px; font-size: 1.2rem; font-weight: 700; color: #ffffff; }
.rap-cta-modal h2 strong { color: var(--rap-cta-gold-light, #ECC25A); }
.rap-cta-modal .rap-cta-modal-sub { font-size: 0.86rem; color: #a4b3c8; margin: 0 0 18px; }
.rap-cta-modal-row { display: flex; flex-direction: column; gap: 6px; margin-bottom: 14px; }
.rap-cta-modal-row.split { flex-direction: row; gap: 12px; }
.rap-cta-modal-row.split > div { flex: 1; display: flex; flex-direction: column; gap: 6px; }
.rap-cta-modal label { font-size: 0.78rem; color: #a4b3c8; font-weight: 500; letter-spacing: 0.04em; text-transform: uppercase; }
.rap-cta-modal input {
  background: rgba(255, 255, 255, 0.05);
  border: 1px solid rgba(255, 255, 255, 0.10);
  color: #f1f5f9;
  padding: 10px 12px;
  border-radius: 10px;
  font-family: inherit;
  font-size: 0.95rem;
  font-variant-numeric: tabular-nums;
  outline: none;
  transition: border-color .15s, background .15s;
}
.rap-cta-modal input:focus { border-color: rgba(214, 164, 45, 0.55); background: rgba(255, 255, 255, 0.08); }
.rap-cta-modal .rap-cta-modal-hint { font-size: 0.78rem; color: #76869c; margin-top: 2px; }
.rap-cta-modal .rap-cta-modal-err {
  font-size: 0.84rem;
  color: #fca5a5;
  margin: 8px 0;
  background: rgba(239, 68, 68, 0.10);
  border: 1px solid rgba(239, 68, 68, 0.30);
  padding: 8px 12px;
  border-radius: 8px;
  display: none;
}
.rap-cta-modal .rap-cta-modal-err.show { display: block; }
.rap-cta-modal-actions { display: flex; justify-content: flex-end; gap: 8px; margin-top: 8px; }
.rap-cta-modal-btn {
  padding: 9px 18px;
  border-radius: 10px;
  font-family: inherit;
  font-size: 0.9rem;
  font-weight: 600;
  cursor: pointer;
  border: 1px solid transparent;
  transition: background .15s, opacity .15s, transform .15s;
}
.rap-cta-modal-btn[disabled] { opacity: 0.5; cursor: wait; }
.rap-cta-modal-btn.cancel { background: transparent; border-color: rgba(255, 255, 255, 0.16); color: #cbd5e1; }
.rap-cta-modal-btn.cancel:hover { background: rgba(255, 255, 255, 0.06); }
.rap-cta-modal-btn.primary {
  background: linear-gradient(135deg, #D6A42D, #a8801f);
  color: #1a1a1a;
  font-weight: 700;
}
.rap-cta-modal-btn.primary:hover {
  transform: translateY(-1px);
  background: linear-gradient(135deg, #ECC25A, #D6A42D);
  box-shadow: 0 8px 24px rgba(214, 164, 45, 0.35);
}
