/* Floating CTA specific rules */
.floating-cta{
  position: fixed;
  left: 16px;
  top: 50%;
  transform: translateY(-50%);
  background: #d2401e; /* logo orange */
  color: #fff;
  z-index: 99999;
  padding: 18px 18px;
  border-radius: 8px;
  box-shadow: 0 6px 18px rgba(0,0,0,0.25);
  max-width: 320px;
  display: flex;
  flex-direction: column;
  gap: 10px;
  align-items: flex-start;
  font-family: inherit;
}

.floating-cta .cta-text {
    font-weight: 700;
    font-size: 16px;
    line-height: 1.2;
    width: calc(100% - 40px);
}

.floating-cta .cta-button{
  background:#ffffff;
  color:#d2401e;
  padding:10px 14px;
  border-radius:6px;
  text-decoration:none;
  font-weight:600;
  display:inline-block;
  box-shadow: 0 2px 8px rgba(0,0,0,0.12);
}

.floating-cta .cta-button:focus,
.floating-cta .cta-button:hover{
  text-decoration:none;
  opacity:0.95;
}

/* Close button */
.floating-cta .cta-close{
  position:absolute;
  top:8px;
  right:8px;
  background: #ffffff; /* white background */
  color: #d2401e; /* orange X */
  border: 1px solid rgba(0,0,0,0.06);
  font-size:18px;
  line-height:1;
  min-width:34px;
  min-height:34px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  cursor:pointer;
  border-radius:6px;
  padding:6px;
  box-shadow: 0 2px 6px rgba(0,0,0,0.08);
}
.floating-cta .cta-close:focus,
.floating-cta .cta-close:hover{
  background: #fff;
  transform: translateY(-1px);
  outline: 3px solid rgba(210,64,30,0.12);
}

/* Slightly smaller on narrow screens */
@media (max-width: 991px){
  .floating-cta .cta-close{ top:6px; right:6px; font-size:16px; padding:5px; min-width:30px; min-height:30px; }
}

/* Animation + entrance/exit behavior */
.floating-cta{
  transition: transform .32s cubic-bezier(.2,.9,.2,1), opacity .32s cubic-bezier(.2,.9,.2,1);
  will-change: transform, opacity;
}

/* Pre-animation hidden state (applied briefly by script to trigger entrance) */
.floating-cta.cta-anim-pre{
  opacity: 0;
  transform: translateY(8px);
}

/* Visible state */
.floating-cta.animated-in{
  opacity: 1;
  transform: translateY(0);
}

/* Exit state */
.floating-cta.animated-out{
  opacity: 0;
  transform: translateY(8px);
  pointer-events: none;
}

/* Provide a fallback class left from earlier; keep for compatibility */
.floating-cta.hidden{
  opacity:0;
  transform: translateY(10px);
  visibility:hidden;
  pointer-events:none;
}

/* Medium & mobile: bottom-left position - keep transform behavior for entrance (slide from bottom looks OK) */
@media (max-width: 991px){
  .floating-cta{
    left: 16px;
    right: auto;
    top: auto;
    bottom: 16px;
    transform: none;
    max-width: 360px;
    padding:12px;
  }
  .floating-cta .cta-text{ font-size:14px; }
  .floating-cta .cta-button{ padding:8px 12px; font-size:14px; }
  .floating-cta .cta-close{ top:6px; right:6px; }
}

/* Responsive - smaller and less intrusive on mobile */
@media (max-width: 767px){
  .floating-cta{
    left: 8px;
    padding: 10px;
    max-width: 200px;
    border-radius:6px;
  }
  .floating-cta .cta-text{
    font-size:13px;
  }
  .floating-cta .cta-button{
    padding:8px 10px;
    font-size:14px;
  }
}

@media (max-width: 420px){
  .floating-cta{
    left: 8px;
    padding:8px;
    max-width:160px;
  }
  .floating-cta .cta-text{
    font-size:12px;
  }
  .floating-cta .cta-button{
    padding:6px 8px;
    font-size:13px;
  }
}

/* Reduced motion: disable transitions */
@media (prefers-reduced-motion: reduce){
  .floating-cta,
  .floating-cta.cta-anim-pre,
  .floating-cta.animated-in,
  .floating-cta.animated-out{
    transition: none !important;
  }
}
