/* components/flags_filter.css */

/* Hide the checkbox visually but keep it accessible */
.btn-check {
  position: absolute;
  clip: rect(0, 0, 0, 0);
  clip-path: inset(50%);
  width: 1px;
  height: 1px;
  overflow: hidden;
  white-space: nowrap;
  border: 0;
  padding: 0;
  margin: -1px;
}

/* Label wrapper for the flag */
.flag-toggle {
  display: inline-block;
  cursor: pointer;
  border-radius: 6px;
  transition: transform 0.2s ease, box-shadow 0.2s ease;
}

/* Flag image base style */
.flag-img {
  width: 48px;
  height: 32px;
  object-fit: cover;
  filter: grayscale(80%) brightness(0.8);
  border-radius: 6px;
  transition: filter 0.3s ease, transform 0.2s ease;
}

/* Hover effect */
.flag-toggle:hover .flag-img {
  filter: grayscale(20%) brightness(1);
  transform: scale(1.05);
}

/* Checked state */
.btn-check:checked + .flag-toggle .flag-img {
  filter: none;
  box-shadow: 0 0 0 2px var(--primary, #0d6efd);
  transform: scale(1.05);
}

/* Dark mode adjustments (optional if not inheriting properly) */
body.dark-mode .flag-toggle .flag-img {
  filter: grayscale(80%) brightness(0.7);
}

body.dark-mode .btn-check:checked + .flag-toggle .flag-img {
  filter: none;
  box-shadow: 0 0 0 2px var(--primary, #0d6efd);
}