:root{
  --flyout-z: 9999;
  --flyout-bg: #ffffff;
  --flyout-shadow: 0 16px 50px rgba(0,0,0,.28);
  --flyout-radius: 14px;
  --flyout-gap: 16px;
  --flyout-maxw: 540px;
}

/* Container anchored bottom-right */
.flyout{
    position: fixed;

  /* right: var(--flyout-gap); */
  /* bottom: var(--flyout-gap); */
  /* z-index: var(--flyout-z); */
  pointer-events: none; /* enable clicks only on children */
}

/* Full panel */
.flyout__panel{
  width: min(var(--flyout-maxw), calc(100vw - (var(--flyout-gap) * 2)));
  background: var(--flyout-bg);
  color: var(--dkgray);
  border-radius: var(--flyout-radius);
  box-shadow: var(--flyout-shadow);
  overflow: hidden;
  pointer-events: auto;

  /* animation base */
  transform: translate3d(120%, 120%, 0);
  opacity: 0;
  transition:
    transform 260ms cubic-bezier(.2,.9,.2,1),
    opacity 200ms ease;
}

/* Close (minimize) button */
.flyout__close{
  position: absolute;
  top: 8px;
  right: 8px;
  width: 34px;
  height: 34px;
  border: 0;
  border-radius: 10px;
  background: rgba(255,255,255,.10);
  color: var(--dkgray);
  cursor: pointer;
  pointer-events: auto;
}

.flyout__close:hover{
  background: rgba(255,255,255,.16);
}

.flyout__content{
  padding: 18px 18px 16px 18px;
  padding-right: 56px; /* room for close button */
}

/* .flyout__title{ */
/*   font-weight: 700; */
/*   font-size: 1rem; */
/*   line-height: 1.2; */
/*   margin-bottom: 6px; */
/* } */

.flyout__body{
  font-size: .92rem;
  line-height: 1.35;
  margin-bottom: 12px;
}

.flyout__cta{
  display: inline-block;
  font-size: .92rem;
  color: var(--dkgray);
  text-decoration: none;
  padding: 8px 10px;
  border-radius: 10px;
  background: rgba(255,255,255,.12);
}
.flyout__cta:hover{
  background: rgba(255,255,255,.18);
}

/* Minified pill */
.flyout__pill{
  pointer-events: auto;
  border: 0;
  cursor: pointer;

  display: inline-flex;
  align-items: center;
  gap: 10px;

  padding: 10px 12px;
  border-radius: 999px;
  box-shadow: var(--flyout-shadow);
  background: var(--flyout-bg);
  color: var(--dkgray);

  /* animation base */
  transform: translate3d(120%, 120%, 0);
  opacity: 0;
  transition:
    transform 260ms cubic-bezier(.2,.9,.2,1),
    opacity 200ms ease;

    position: absolute;
    right: 0;
    top: 85%;
}

.flyout__dot{
  width: 10px;
  height: 10px;
  border-radius: 999px;
  background: #36d399; /* small accent dot */
}

.flyout__pillText{
  font-weight: 600;
  font-size: .92rem;
}

/* OPEN state: show panel, hide pill */
.flyout.is-open {
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
}
.flyout.is-open .flyout__panel{
  transform: translate3d(0,0,0);
  opacity: 1;
}
.flyout.is-open .flyout__pill{
  transform: translate3d(0,0,0);
  opacity: 0;
  pointer-events: none;
}

/* MINIFIED state: hide panel, show pill */
.flyout.is-minified .flyout__panel{
  transform: translate3d(20%, 20%, 0) scale(.96);
  opacity: 0;
  pointer-events: none;
}
.flyout.is-minified .flyout__pill{
  transform: translate3d(0,0,0);
  opacity: 1;
  position: fixed;
  right: 40px;
  bottom: 40px;
  top: unset;
}

/* Reduced motion */
@media (prefers-reduced-motion: reduce){
  .flyout__panel,
  .flyout__pill{
    transition: none;
  }
}

