.fmr-scroll-popup {
  position: fixed;
  right: 24px;
  bottom: 24px;
  z-index: 9999;
  width: min(392px, calc(100vw - 32px));
  color: #111;
  background: rgba(255,255,255,.94);
  border: 1px solid rgba(17,17,17,.12);
  border-radius: 28px;
  box-shadow: 0 28px 80px rgba(0,0,0,.24);
  overflow: hidden;
  opacity: 0;
  pointer-events: none;
  transform: translate3d(0, 22px, 0) scale(.98);
  transition: opacity .28s ease, transform .28s ease;
  font-family: Helvetica, Arial, sans-serif;
}
.fmr-scroll-popup.is-visible { opacity: 1; pointer-events: auto; transform: translate3d(0,0,0) scale(1); }
.fmr-scroll-popup__close { position:absolute; top:12px; right:12px; z-index:2; width:34px; height:34px; border:1px solid rgba(255,255,255,.42); border-radius:999px; background:rgba(17,17,17,.44); color:#fff; font-size:22px; line-height:1; cursor:pointer; }
.fmr-scroll-popup__media { height: 138px; background:#111; overflow:hidden; }
.fmr-scroll-popup__media img { width:100%; height:100%; object-fit:cover; object-position:center 28%; display:block; }
.fmr-scroll-popup__body { padding: 22px 22px 20px; }
.fmr-scroll-popup__eyebrow { margin:0 0 8px; color:rgba(17,17,17,.58); font-size:11px; line-height:1.4; font-weight:700; letter-spacing:.16em; text-transform:uppercase; }
.fmr-scroll-popup__title { margin:0; color:#111; font-family:'League Spartan', Helvetica, Arial, sans-serif; font-size:28px; line-height:.98; font-weight:600; letter-spacing:-.03em; text-transform:uppercase; }
.fmr-scroll-popup__copy { margin:12px 0 0; color:rgba(17,17,17,.72); font-size:15px; line-height:1.55; }
.fmr-scroll-popup__footer { display:flex; align-items:center; justify-content:space-between; gap:14px; margin-top:18px; }
.fmr-scroll-popup__name { display:grid; gap:2px; color:rgba(17,17,17,.62); font-size:12px; line-height:1.35; }
.fmr-scroll-popup__name strong { color:#111; font-size:13px; }
.fmr-scroll-popup__cta { flex:0 0 auto; min-height:42px; display:inline-flex; align-items:center; justify-content:center; padding:0 16px; border-radius:999px; background:#111; color:#fff !important; text-decoration:none; font-size:12px; line-height:1; font-weight:700; letter-spacing:.1em; text-transform:uppercase; }
.fmr-scroll-popup__cta:hover { background:#000; }
@media (max-width: 640px) {
  .fmr-scroll-popup { left:16px; right:16px; bottom:16px; width:auto; border-radius:24px; }
  .fmr-scroll-popup__media { height:112px; }
  .fmr-scroll-popup__body { padding:18px; }
  .fmr-scroll-popup__title { font-size:24px; }
  .fmr-scroll-popup__footer { align-items:flex-start; flex-direction:column; }
  .fmr-scroll-popup__cta { width:100%; }
}
