#tuff-refresh-indicator {
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  display: flex;
  justify-content: center;
  padding-top: 10px;
  pointer-events: none;
  transform: translateY(calc(-72px + var(--pull-offset, 0px)));
  transition: transform 0.22s ease, opacity 0.18s ease;
  opacity: 0;
  z-index: 3000;
}

#tuff-refresh-indicator.active {
  opacity: 1;
}

#tuff-refresh-indicator.pulling {
  transition: none;
}

#tuff-refresh-indicator.refreshing {
  transform: translateY(0);
}

#tuff-refresh-indicator .tuff-refresh-card {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 0.75rem;
  min-height: 56px;
  padding: 0.85rem 1.6rem;
  border-radius: 20px;
  border: 1px solid rgba(255, 255, 255, 0.18);
  background:
    linear-gradient(135deg, rgba(255, 255, 255, 0.22), rgba(48, 72, 108, 0.12)),
    rgba(18, 28, 46, 0.72);
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.22),
    inset 0 -1px 0 rgba(0, 0, 0, 0.35),
    0 14px 32px rgba(8, 12, 24, 0.55);
  -webkit-backdrop-filter: blur(18px);
  backdrop-filter: blur(18px);
  color: rgba(237, 244, 255, 0.92);
  font-size: 0.95rem;
  font-weight: 600;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  pointer-events: none;
}

#tuff-refresh-indicator.ready .tuff-refresh-text {
  font-weight: 700;
}

#tuff-refresh-indicator .tuff-refresh-icon {
  display: inline-flex;
  font-size: 1.65rem;
  line-height: 1;
  transition: transform 0.2s ease;
}

#tuff-refresh-indicator .tuff-refresh-icon.spin {
  animation: tuff-refresh-spin 0.9s linear infinite;
}

#tuff-refresh-indicator .tuff-refresh-text {
  display: inline-flex;
  align-items: center;
}

@keyframes tuff-refresh-spin {
  0% {
    transform: rotate(0deg);
  }
  100% {
    transform: rotate(-360deg);
  }
}
