
/* a11y-contrast.css – refuerzo AA 4.5:1 */
:root {
  --btn-primary-bg: #0B5ED7; /* Bootstrappy AA-friendly */
  --btn-primary-color: #FFFFFF;
  --link-color: #0a58ca;
  --link-hover: #084298;
}

a { text-decoration: underline; color: var(--link-color); }
a:hover, a:focus { color: var(--link-hover); text-decoration-thickness: 2px; }

.btn, .btn:focus {
  text-shadow: none !important;
}

.btn-primary, .btn-primary:focus {
  background-color: var(--btn-primary-bg) !important;
  border-color: var(--btn-primary-bg) !important;
  color: var(--btn-primary-color) !important;
}

.btn-outline-primary {
  color: var(--btn-primary-bg) !important;
  border-color: var(--btn-primary-bg) !important;
}

.btn-outline-primary:hover, .btn-outline-primary:focus {
  background-color: var(--btn-primary-bg) !important;
  color: #fff !important;
}

.navbar a, .nav-link { color: var(--link-color); }
.navbar a:hover, .nav-link:hover { color: var(--link-hover); }

/* Focus visible */
:focus-visible {
  outline: 3px solid #ffbf47;
  outline-offset: 2px;
}


/* === Paleta estilo rural AA === */

/* a11y-contrast.css · Paleta 'estilo rural' con AA */
:root{
  --brand-primary:#2E5E3A;   /* Verde oliva profundo */
  --brand-primary-800:#21442A;
  --brand-accent:#8C3B2A;    /* Terracota */
  --brand-accent-800:#6E2F23;
  --neutral-50:#F6F2EA;      /* Marfil cálido */
  --neutral-900:#1E1E1E;

  --btn-primary-bg:var(--brand-primary);
  --btn-primary-color:#FFFFFF;
  --link-color:var(--brand-primary);
  --link-hover:var(--brand-primary-800);
}

html{color-scheme: light; -webkit-font-smoothing: antialiased; -moz-osx-font-smoothing: grayscale;}
body{background-color:var(--neutral-50);}

a{color:var(--link-color); text-decoration: underline; text-underline-offset: 2px;}
a:hover,a:focus{color:var(--link-hover); text-decoration-thickness: 2px;}

.btn,.btn:focus{text-shadow:none !important;}
.btn-primary,.btn-primary:focus{
  background-color:var(--btn-primary-bg) !important;
  border-color:var(--btn-primary-bg) !important;
  color:var(--btn-primary-color) !important;
}
.btn-primary:hover{background-color:var(--brand-primary-800) !important; border-color:var(--brand-primary-800) !important;}
.btn-outline-primary{color:var(--brand-primary) !important; border-color:var(--brand-primary) !important;}
.btn-outline-primary:hover,.btn-outline-primary:focus{background-color:var(--brand-primary) !important; color:#fff !important;}

.badge, .nav-link, .navbar a{color:var(--brand-primary);}
.nav-link:hover, .navbar a:hover{color:var(--brand-primary-800);}

:focus-visible{outline:3px solid #ffbf47; outline-offset:2px;}

/* Tap targets en móvil */
@media (max-width: 480px){
  .btn, .nav-link, a.btn{min-height:44px; padding-top:.65rem; padding-bottom:.65rem;}
}

/* Imágenes: evita CLS básico sin conocer dimensiones */
img{height:auto; -ms-interpolation-mode: bicubic;}

/* Usuarios con motion reducido */
@media (prefers-reduced-motion: reduce){
  *{animation-duration:0.01ms !important; animation-iteration-count:1 !important; transition-duration:0.01ms !important; scroll-behavior:auto !important;}
}
