/* Accessibility – focus indicator (WCAG 2.4.7) */
:focus-visible {
  outline: 3px solid #1a73e8;
  outline-offset: 2px;
}

/* Accessibility – screen-reader-only helper */
.sr-only {
  position: absolute;
  width: 1px;
  height: 1px;
  padding: 0;
  margin: -1px;
  overflow: hidden;
  clip: rect(0, 0, 0, 0);
  white-space: nowrap;
  border: 0;
}

/* Accessibility – skip-to-content link */
.skip-link {
  position: absolute;
  width: 1px;
  height: 1px;
  padding: 0;
  margin: -1px;
  overflow: hidden;
  clip: rect(0, 0, 0, 0);
  white-space: nowrap;
  z-index: 10000;
}

.skip-link:focus {
  width: auto;
  height: auto;
  padding: 0.75em 1.5em;
  margin: 0;
  overflow: visible;
  clip: auto;
  top: 0;
  left: 0;
  background: #000;
  color: #fff;
  font-size: 1rem;
  text-decoration: none;
}

/* =============================================
   Accessibility – prefers-contrast: more
   ============================================= */
@media (prefers-contrast: more) {
  /* Text a pozadí na maximální kontrast */
  body {
    color: #000 !important;
    background-color: #fff !important;
  }

  /* Sekundární texty — žádná šedá, vše černé */
  .datum,
  .lay_patickacopy,
  .aktualita_perex,
  .lay_patickanavigace {
    color: #000 !important;
  }

  /* Formulářové prvky — viditelné ohraničení */
  input,
  textarea,
  select,
  button {
    border: 2px solid #000 !important;
  }

  /* Focus indikátor — silný a viditelný */
  :focus {
    outline: 3px solid #000 !important;
    outline-offset: 2px !important;
  }

  /* Navigační bloky — jasné hranice */
  .lay_menu,
  .lay_lsloupec,
  .blok_s_hlavickou,
  .blok_bez_hlavicky {
    border: 2px solid #000 !important;
  }

  /* Šedé hlavičky bloků — pozadí textura nemusí být vidět */
  .nadpis_v_sede_liste {
    background: #000 !important;
    color: #fff !important;
  }
  .nadpis_v_sede_liste .matrjoska {
    color: #fff !important;
  }

  /* Ouška — aktivní stav zvýraznit */
  .ousko_vybrane .ousko_bg_r {
    outline: 3px solid #000 !important;
  }

  /* Červená ouška nahoře — border pro odlišení */
  .lay_la li {
    border: 1px solid #000 !important;
  }
}

/* =============================================
   Accessibility – forced-colors (Win High Contrast)
   ============================================= */
@media (forced-colors: active) {
  /* Aktivní ouško — pozadí zmizí, border zůstane */
  .ousko_vybrane .ousko_bg_r {
    border: 3px solid ButtonText !important;
  }

  /* Červená ouška nahoře — ztratí gradient, potřebují border */
  .lay_la li {
    border: 1px solid ButtonText !important;
  }

  /* Šedé hlavičky bloků — textura zmizí */
  .nadpis_v_sede_liste {
    border: 2px solid ButtonText !important;
  }

  /* Patička navigace — bg zmizí */
  .lay_patickanavigace {
    border: 2px solid ButtonText !important;
  }

  /* Slideshow dekorace — dekorativní, ale potřebuje alespoň rámeček */
  .lay_lc_deco {
    border: 1px solid ButtonText !important;
  }

  /* Hover/focus — viditelný outline */
  a:hover,
  a:focus {
    outline: 2px solid LinkText !important;
  }

  /* SVG ikony — zachovat viditelnost */
  svg {
    forced-color-adjust: auto;
  }
}

/* Accessibility – prefers-reduced-motion */
@media (prefers-reduced-motion: reduce) {
  *,
  *::before,
  *::after {
    animation-duration: 0.01ms !important;
    animation-iteration-count: 1 !important;
    transition-duration: 0.01ms !important;
    scroll-behavior: auto !important;
  }
}
