/* ===========================================================
   Global accessibility layer for BlueMoso
   - Visible focus rings on all interactive elements
   - Reduced-motion: kill animations + scroll-reveal transitions
   - Skip link
   =========================================================== */

/* Skip-to-content link */
.skip-link {
  position: absolute;
  left: -9999px;
  top: 8px;
  z-index: 1000;
  padding: 10px 16px;
  background: var(--ink, #0E2542);
  color: #fff;
  border-radius: 8px;
  font-size: 14px;
  font-weight: 500;
  text-decoration: none;
}
.skip-link:focus { left: 8px; outline: 2px solid #fff; outline-offset: 2px; }

/* Visible focus ring (keyboard only) */
:focus { outline: none; }
a:focus-visible,
button:focus-visible,
[role="button"]:focus-visible,
[role="tab"]:focus-visible,
[role="switch"]:focus-visible,
[role="radio"]:focus-visible,
input:focus-visible,
textarea:focus-visible,
select:focus-visible,
summary:focus-visible {
  outline: 2px solid var(--blue, #0878D8);
  outline-offset: 2px;
  border-radius: 4px;
}

/* Reduced motion: disable animations, transitions, smooth scroll */
@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after {
    animation-duration: 0.001ms !important;
    animation-iteration-count: 1 !important;
    transition-duration: 0.001ms !important;
    scroll-behavior: auto !important;
  }
  /* Scroll-reveal: show immediately, no fade */
  .reveal { opacity: 1 !important; transform: none !important; }
}

/* ===========================================================
   High-contrast preference
   When the user has requested "more contrast" at OS-level, bolt
   muted text up to full strength and harden every hairline border.
   This is on top of the AAA-tuned default palette — a belt-and-
   braces layer for users who need it.
   =========================================================== */
@media (prefers-contrast: more) {
  :root {
    --ink-muted: #2C325C !important;   /* === --ink-soft, fully legible on white */
    --line: #B3C4D5 !important;
    --line-soft: #C9D5E2 !important;
  }
  /* Force all low-opacity white text on dark backgrounds to full opacity. */
  .pain .section-eyebrow,
  .bm-pain-cloud .bm-pill,
  .foot,
  .foot h4,
  .foot-base,
  .mid-cta-h,
  .mid-cta-p,
  .mid-cta-meta,
  .cta-stat-l,
  .cta-bullets li {
    color: #fff !important;
  }
}

/* Windows High Contrast / forced-colors mode — make sure focus rings,
   buttons and links stay visible against the system-overridden palette. */
@media (forced-colors: active) {
  a:focus-visible,
  button:focus-visible,
  [role="button"]:focus-visible,
  [role="tab"]:focus-visible,
  input:focus-visible,
  textarea:focus-visible,
  select:focus-visible,
  summary:focus-visible {
    outline: 2px solid CanvasText;
    outline-offset: 2px;
  }
}


/* ===========================================================
   De-italicize emphasized text (Outfit doesn't ship a true italic)
   Replace italic gesture with semibold weight + color accents
   inherited from inline styles.
   =========================================================== */
em, i, .kicker, em.kicker {
  font-style: normal !important;
  font-weight: 600;
}
