/* ───── VAPOR announcement bar ─────
   Slim ticker above the header. Two modes: ink (black band) or accent
   (lime band). Mono uppercase typography, lime status dot at the start. */

.vp-announce {
  position: relative;
  z-index: 30;
  font-family: var(--font-mono);
  font-size: 11px;
  font-weight: 500;
  letter-spacing: var(--tracking-mono);
  text-transform: uppercase;
}

.vp-announce--ink {
  background: var(--color-bg);
  color: var(--color-text);
  border-bottom: 1px solid var(--color-border);
}
.vp-announce--accent {
  background: var(--color-accent);
  color: var(--color-accent-ink);
  border-bottom: 1px solid var(--color-accent-ink);
}

.vp-announce__inner {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: var(--space-3);
  padding-block: 10px;
  position: relative;
  min-height: 36px;
}

.vp-announce__dot {
  width: 6px; height: 6px;
  background: var(--color-accent);
  border-radius: 50%;
  flex-shrink: 0;
  animation: vp-announce-pulse 1.6s ease-in-out infinite;
}
.vp-announce--accent .vp-announce__dot {
  background: var(--color-accent-ink);
}

@keyframes vp-announce-pulse {
  0%, 100% { transform: scale(1);   opacity: 1;   }
  50%      { transform: scale(1.3); opacity: 0.6; }
}

.vp-announce__text { margin: 0; text-align: center; }
.vp-announce__text a {
  color: inherit;
  text-decoration: none;
  display: inline-flex;
  align-items: center;
  gap: 6px;
  position: relative;
}
.vp-announce__text a::after {
  content: '';
  position: absolute;
  left: 0;
  bottom: -2px;
  width: 100%;
  height: 1px;
  background: currentColor;
  transform: scaleX(0);
  transform-origin: left;
  transition: transform 240ms var(--ease);
}
.vp-announce__text a:hover::after { transform: scaleX(1); }
.vp-announce__arrow { transition: transform 200ms var(--ease); }
.vp-announce__text a:hover .vp-announce__arrow { transform: translateX(3px); }

.vp-announce__close {
  position: absolute;
  right: var(--container-px);
  top: 50%;
  transform: translateY(-50%);
  background: none;
  border: 0;
  padding: 6px;
  color: inherit;
  opacity: 0.6;
  line-height: 0;
  cursor: pointer;
  transition: opacity var(--transition);
}
.vp-announce__close:hover { opacity: 1; }
.vp-announce__close .icon { width: 12px; height: 12px; }

@media (max-width: 640px) {
  .vp-announce { font-size: 10px; }
  .vp-announce__close { right: 12px; }
}
