/* Dark Mode Styles - Transiciones suaves y modernas */

/* Variables CSS para colores del dark mode */
:root {
  --bg-primary: #ffffff;
  --bg-secondary: #f8f9fa;
  --bg-card: #ffffff;
  --text-primary: #040404;
  --text-secondary: #4F4F4C;
  --text-muted: #77747B;
  --border-color: #7B7B7B;
  --accent-color: #040404;
  --accent-hover: #4F4F4C;
  --shadow: rgba(0, 0, 0, 0.1);
  --navbar-bg: #ffffff;
  --navbar-shadow: rgba(0, 0, 0, 0.1);
  --input-bg: #ffffff;
}

/* Dark mode variables */
[data-theme="dark"] {
  --bg-primary: #0d1117;
  --bg-secondary: #161b22;
  --bg-card: #21262d;
  --text-primary: #f0f6fc;
  --text-secondary: #e6edf3;
  --text-muted: #8b949e;
  --border-color: #30363d;
  --accent-color: #58a6ff;
  --accent-hover: #79c0ff;
  --shadow: rgba(0, 0, 0, 0.3);
  --navbar-bg: #161b22;
  --navbar-shadow: rgba(0, 0, 0, 0.4);
  --input-bg: #21262d;
}

/* Transiciones globales para elementos que cambiarán */
* {
  transition: background-color 0.3s cubic-bezier(0.4, 0, 0.2, 1),
              color 0.3s cubic-bezier(0.4, 0, 0.2, 1),
              border-color 0.3s cubic-bezier(0.4, 0, 0.2, 1),
              box-shadow 0.3s cubic-bezier(0.4, 0, 0.2, 1);
}

/* Body y elementos principales */
body {
  background-color: var(--bg-primary) !important;
  color: var(--text-primary) !important;
}

/* Headers y títulos */
h1, h2, h3, h4, h5, h6,
.titulo_hero,
.titulo_noticia_principal,
.titulo_noticia_secundaria {
  color: var(--text-primary) !important;
}

/* Texto secundario y párrafos */
p, .text-muted, .small,
.texto_noticia_principal,
.article_body {
  color: var(--text-secondary) !important;
}

/* Navbar */
header.bg-white,
header.shadow-sm {
  background-color: var(--navbar-bg) !important;
  box-shadow: 0 1px 3px var(--navbar-shadow) !important;
}

.navbar-light .navbar-nav .nav-link {
  color: var(--text-primary) !important;
}

.navbar-light .navbar-nav .nav-link:hover,
.navbar-light .navbar-nav .nav-link:focus {
  color: var(--accent-color) !important;
}

.navbar-brand img {
  filter: var(--logo-filter, none);
}

[data-theme="dark"] .navbar-brand img {
  --logo-filter: brightness(0) invert(1);
}

/* Cards y contenedores */
.bg-white,
.list-group-item,
.card {
  background-color: var(--bg-card) !important;
  border-color: var(--border-color) !important;
}

.list-group-item:hover,
.list-group-item-action:hover {
  background-color: var(--bg-secondary) !important;
}

/* Eliminar borders problemáticos */
.list-group-item,
.list-group-item-action {
  border: none !important;
  border-radius: 0 !important;
}

/* Botones */
.btn-dark {
  background-color: var(--accent-color) !important;
  border-color: var(--accent-color) !important;
  color: var(--bg-primary) !important;
}

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

/* Botón específico para "Leer noticia" y botones principales */
[data-theme="dark"] .btn-dark {
  background-color: #f0f6fc !important;
  border-color: #f0f6fc !important;
  color: #0d1117 !important;
  font-weight: 600;
}

[data-theme="dark"] .btn-dark:hover,
[data-theme="dark"] .btn-dark:focus {
  background-color: #e6edf3 !important;
  border-color: #e6edf3 !important;
  color: #0d1117 !important;
  transform: translateY(-1px);
  box-shadow: 0 4px 12px rgba(240, 246, 252, 0.3) !important;
}

[data-theme="dark"] .btn-dark:active {
  background-color: #d0d7de !important;
  border-color: #d0d7de !important;
  transform: translateY(0);
}

.btn-outline-dark {
  color: var(--accent-color) !important;
  border-color: var(--accent-color) !important;
  background-color: transparent !important;
}

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

/* Botón outline específico para dark mode */
[data-theme="dark"] .btn-outline-dark {
  color: #f0f6fc !important;
  border-color: #f0f6fc !important;
  background-color: transparent !important;
}

[data-theme="dark"] .btn-outline-dark:hover,
[data-theme="dark"] .btn-outline-dark:focus {
  background-color: #f0f6fc !important;
  border-color: #f0f6fc !important;
  color: #0d1117 !important;
}

/* Enlaces */
a {
  color: var(--accent-color) !important;
}

a:hover,
a:focus {
  color: var(--accent-hover) !important;
}

a.text-dark {
  color: var(--text-primary) !important;
}

a.text-dark:hover,
a.text-dark:focus {
  color: var(--accent-color) !important;
}

a.text-decoration-none:hover {
  text-decoration: none !important;
}

/* Formularios */
.form-control {
  background-color: var(--input-bg) !important;
  border-color: var(--border-color) !important;
  color: var(--text-primary) !important;
}

.form-control:focus {
  background-color: var(--input-bg) !important;
  border-color: var(--accent-color) !important;
  color: var(--text-primary) !important;
  box-shadow: 0 0 0 0.2rem rgba(88, 166, 255, 0.25) !important;
}

.form-control::placeholder {
  color: var(--text-muted) !important;
}

.input-group-text {
  background-color: var(--bg-secondary) !important;
  border-color: var(--border-color) !important;
  color: var(--text-primary) !important;
}

/* Alerts */
.alert-info {
  background-color: var(--bg-secondary) !important;
  border-color: var(--border-color) !important;
  color: var(--text-primary) !important;
}

/* HR y separadores */
hr {
  border-color: var(--border-color) !important;
  opacity: 0.5;
}

.section-divider {
  background: linear-gradient(to right, transparent, var(--border-color), transparent) !important;
}

/* Iconos de Bootstrap - Corrección completa para dark mode */
.bi {
    color: var(--text-primary) !important;
    background: none !important;
    background-color: transparent !important;
    background-image: none !important;
}

.bi::before {
    background: none !important;
    background-color: transparent !important;
    background-image: none !important;
}

/* Iconos en elementos específicos */
[data-theme="dark"] .bi {
    color: var(--text-primary) !important;
    background: none !important;
    background-color: transparent !important;
    background-image: none !important;
    filter: none !important;
}

[data-theme="dark"] .bi::before {
    color: inherit !important;
    background: none !important;
    background-color: transparent !important;
    background-image: none !important;
}

/* Iconos en botones y enlaces */
[data-theme="dark"] .btn .bi,
[data-theme="dark"] a .bi,
[data-theme="dark"] button .bi {
    color: inherit !important;
    background: none !important;
    background-color: transparent !important;
}

/* Iconos específicos por contexto */
[data-theme="dark"] .card-header .bi {
    color: white !important;
    background: none !important;
}

[data-theme="dark"] .alert .bi {
    color: inherit !important;
    background: none !important;
}

[data-theme="dark"] .badge .bi {
    color: inherit !important;
    background: none !important;
}

/* Iconos en formularios */
[data-theme="dark"] .form-check-label .bi,
[data-theme="dark"] .input-group-text .bi {
    color: var(--text-primary) !important;
    background: none !important;
}

/* Iconos en navegación */
[data-theme="dark"] .nav-link .bi,
[data-theme="dark"] .navbar .bi {
    color: inherit !important;
    background: none !important;
}

/* Iconos de meta información (fechas, usuarios, etc.) */
[data-theme="dark"] .news-meta .bi,
[data-theme="dark"] span .bi,
[data-theme="dark"] small .bi {
    color: var(--accent-color) !important;
    background: none !important;
}

/* Botón toggle para dark mode */
.dark-mode-toggle {
  position: fixed;
  bottom: 20px;
  right: 20px;
  z-index: 1050;
  background: var(--bg-card);
  border: 2px solid rgba(0, 0, 0, 0.1);
  border-radius: 50%;
  width: 56px;
  height: 56px;
  display: flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1);
  box-shadow: 0 4px 12px rgba(0, 0, 0, 0.1);
}

.dark-mode-toggle:hover {
  transform: scale(1.1);
  border-color: rgba(0, 0, 0, 0.2);
  box-shadow: 0 6px 20px rgba(0, 0, 0, 0.15);
}

.dark-mode-toggle i {
  font-size: 1.3rem;
  color: var(--text-primary);
  background: none !important;
}

/* Animación de rotación para el icono */
.dark-mode-toggle.rotating i {
  animation: rotate 0.3s ease-in-out;
}

@keyframes rotate {
  from {
    transform: rotate(0deg);
  }
  to {
    transform: rotate(180deg);
  }
}

/* Estilos específicos para dark mode toggle en tema oscuro */
[data-theme="dark"] .dark-mode-toggle {
  background: rgba(255, 255, 255, 0.08);
  border: 2px solid rgba(255, 255, 255, 0.2);
  box-shadow: 0 4px 16px rgba(0, 0, 0, 0.4);
}

[data-theme="dark"] .dark-mode-toggle:hover {
  background: rgba(255, 255, 255, 0.15);
  border-color: rgba(255, 255, 255, 0.3);
  box-shadow: 0 6px 24px rgba(0, 0, 0, 0.5);
  transform: scale(1.1);
}

[data-theme="dark"] .dark-mode-toggle i {
  color: #ffd700;
  text-shadow: 0 0 8px rgba(255, 215, 0, 0.6);
  background: none !important;
  font-weight: 600;
}

[data-theme="dark"] .dark-mode-toggle:hover i {
  color: #ffed4e;
  text-shadow: 0 0 12px rgba(255, 215, 0, 0.8);
}

[data-theme="dark"] .dark-mode-toggle::before {
  background: linear-gradient(45deg, rgba(255, 255, 255, 0.1), rgba(255, 255, 255, 0.05));
}

[data-theme="dark"] .dark-mode-toggle:hover::before {
  opacity: 0.3;
}

/* Mejoras específicas para evitar recuadros feos */
.list-group-item-action {
  border: none !important;
  background: none !important;
}

.list-group-item-action:hover {
  border: none !important;
  background-color: var(--bg-secondary) !important;
}

/* Asegurarse de que las imágenes no tengan fondos extraños */
img {
  background: transparent !important;
}

/* Container principal */
.container {
  background-color: transparent !important;
}

/* Sticky top elements */
.sticky-top {
  background-color: var(--navbar-bg) !important;
}

/* Dropdowns y modals si existen */
.dropdown-menu {
  background-color: var(--bg-card) !important;
  border-color: var(--border-color) !important;
}

.dropdown-item {
  color: var(--text-primary) !important;
}

.dropdown-item:hover,
.dropdown-item:focus {
  background-color: var(--bg-secondary) !important;
  color: var(--text-primary) !important;
}

.modal-content {
  background-color: var(--bg-card) !important;
  border-color: var(--border-color) !important;
}

.modal-header,
.modal-footer {
  border-color: var(--border-color) !important;
}

/* Tables */
.table {
  color: var(--text-primary) !important;
}

.table th,
.table td {
  border-color: var(--border-color) !important;
}

.table-striped > tbody > tr:nth-of-type(odd) > td,
.table-striped > tbody > tr:nth-of-type(odd) > th {
  background-color: var(--bg-secondary) !important;
}

/* Badges y pills */
.badge {
  background-color: var(--accent-color) !important;
  color: var(--bg-primary) !important;
}

/* Botones del Hero section en dark mode */
[data-theme="dark"] .btn[style*="background-color: #040404"] {
  background-color: #f0f6fc !important;
  color: #0d1117 !important;
  border-color: #f0f6fc !important;
}

[data-theme="dark"] .btn[style*="background-color: #040404"]:hover {
  background-color: #e6edf3 !important;
  color: #0d1117 !important;
  border-color: #e6edf3 !important;
}

/* Asegurar legibilidad en todos los botones dark */
[data-theme="dark"] .btn-dark,
[data-theme="dark"] button[style*="background-color"],
[data-theme="dark"] a[style*="background-color"] {
  background-color: #f0f6fc !important;
  color: #0d1117 !important;
  border-color: #f0f6fc !important;
  transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1) !important;
}

[data-theme="dark"] .btn-dark:hover,
[data-theme="dark"] button[style*="background-color"]:hover,
[data-theme="dark"] a[style*="background-color"]:hover {
  background-color: #e6edf3 !important;
  color: #0d1117 !important;
  border-color: #e6edf3 !important;
}

/* Botones con colores específicos inline */
[data-theme="dark"] *[onmouseover] {
  transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1) !important;
}

/* Pagination */
.page-link {
  background-color: var(--bg-card) !important;
  border-color: var(--border-color) !important;
  color: var(--accent-color) !important;
}

.page-link:hover {
  background-color: var(--bg-secondary) !important;
  color: var(--accent-hover) !important;
}

.page-item.active .page-link {
  background-color: var(--accent-color) !important;
  border-color: var(--accent-color) !important;
}

/* Breadcrumbs - Estilos base y dark mode */
.breadcrumb {
  background-color: transparent !important;
  border: none !important;
  padding: 0.5rem 0 !important;
  margin-bottom: 1rem !important;
  border-radius: 0 !important;
}

.breadcrumb-item {
  font-size: 0.9rem;
}

.breadcrumb-item a {
  color: var(--accent-color, #0d6efd) !important;
  text-decoration: none !important;
  transition: color 0.3s ease !important;
}

.breadcrumb-item a:hover {
  color: var(--accent-hover, #0b5ed7) !important;
  text-decoration: underline !important;
}

.breadcrumb-item + .breadcrumb-item::before {
  content: "›" !important;
  font-size: 1.1em !important;
  color: var(--text-muted, #6c757d) !important;
  margin: 0 0.5rem !important;
}

.breadcrumb-item.active {
  color: var(--text-primary, #212529) !important;
}

/* Dark mode específico */
[data-theme="dark"] .breadcrumb {
  background-color: transparent !important;
  border: none !important;
}

[data-theme="dark"] .breadcrumb-item {
  color: var(--text-muted) !important;
}

[data-theme="dark"] .breadcrumb-item a {
  color: var(--accent-color) !important;
  text-decoration: none !important;
}

[data-theme="dark"] .breadcrumb-item a:hover {
  color: var(--accent-hover) !important;
  text-decoration: underline !important;
}

[data-theme="dark"] .breadcrumb-item + .breadcrumb-item::before {
  color: var(--text-muted) !important;
  content: "›" !important;
  font-size: 1.1em !important;
}

[data-theme="dark"] .breadcrumb-item.active {
  color: var(--text-primary) !important;
  font-weight: 500 !important;
}

.breadcrumb-item a {
  color: var(--accent-color) !important;
}

/* Responsive adjustments */
@media (max-width: 768px) {
  .dark-mode-toggle {
    bottom: 80px;
    right: 15px;
    width: 50px;
    height: 50px;
    z-index: 1060;
  }
  
  .dark-mode-toggle i {
    font-size: 1.1rem;
  }
}

@media (max-width: 480px) {
  .dark-mode-toggle {
    bottom: 70px;
    right: 10px;
    width: 48px;
    height: 48px;
  }
  
  .dark-mode-toggle i {
    font-size: 1rem;
  }
}

/* Ajuste adicional cuando hay elementos fijos en la parte inferior */
@media (max-width: 768px) {
  body.has-bottom-nav .dark-mode-toggle {
    bottom: 120px;
  }
}

/* Evitar superposición con elementos del navbar en móviles */
@media (max-width: 991px) {
  .dark-mode-toggle {
    z-index: 1060; /* Mayor que el navbar de Bootstrap */
  }
}

/* Ocultar temporalmente durante transiciones del navbar */
.navbar-collapse.collapsing ~ * .dark-mode-toggle,
.navbar-collapse.show ~ * .dark-mode-toggle {
  opacity: 0.7;
  pointer-events: auto;
}

@media (min-width: 992px) {
  .navbar-collapse.collapsing ~ * .dark-mode-toggle,
  .navbar-collapse.show ~ * .dark-mode-toggle {
    opacity: 1;
  }
}

/* Smooth scroll behavior */
html {
  scroll-behavior: smooth;
}

/* Focus styles para accesibilidad */
.dark-mode-toggle:focus {
  outline: 2px solid var(--accent-color);
  outline-offset: 2px;
}

/* Mejor interacción táctil en móviles */
@media (hover: none) and (pointer: coarse) {
  .dark-mode-toggle {
    width: 52px;
    height: 52px;
  }
  
  .dark-mode-toggle:active {
    transform: scale(0.95);
    transition: transform 0.1s ease;
  }
}

/* Indicador visual de que es interactivo */
.dark-mode-toggle::before {
  content: '';
  position: absolute;
  top: -2px;
  left: -2px;
  right: -2px;
  bottom: -2px;
  border-radius: 50%;
  background: linear-gradient(45deg, var(--accent-color), var(--accent-hover));
  opacity: 0;
  z-index: -1;
  transition: opacity 0.3s ease;
}

.dark-mode-toggle:hover::before {
  opacity: 0.1;
}

/* Evitar interferencia con elementos de navegación */
@media (max-width: 991px) {
  .dark-mode-toggle {
    pointer-events: auto;
  }
  
  .navbar-collapse.show {
    z-index: 1055;
  }
  
  .navbar-collapse.show ~ .dark-mode-toggle {
    z-index: 1056;
  }
}

/* Estilos para el weather widget */
#_MI_242ac75e153077672d4a52380bc27b02 {
  background-color: var(--bg-card) !important;
  border-radius: 8px;
  padding: 15px;
  border: 1px solid var(--border-color);
}

/* Navbar toggler en dark mode */
.navbar-toggler {
  border-color: var(--border-color) !important;
}

.navbar-toggler:focus {
  box-shadow: 0 0 0 0.2rem rgba(88, 166, 255, 0.25);
}

.navbar-toggler-icon {
  background-image: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 30 30'%3e%3cpath stroke='rgba%2833, 37, 41, 0.75%29' stroke-linecap='round' stroke-miterlimit='10' stroke-width='2' d='M4 7h22M4 15h22M4 23h22'/%3e%3c/svg%3e") !important;
}

[data-theme="dark"] .navbar-toggler-icon {
  background-image: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 30 30'%3e%3cpath stroke='rgba%28255, 255, 255, 0.75%29' stroke-linecap='round' stroke-miterlimit='10' stroke-width='2' d='M4 7h22M4 15h22M4 23h22'/%3e%3c/svg%3e") !important;
}

/* Eliminar cualquier outline o border no deseado */
button:focus,
a:focus,
input:focus,
select:focus,
textarea:focus {
  outline: none;
  box-shadow: 0 0 0 2px var(--accent-color);
}

/* Asegurar que no hay backgrounds extraños en contenedores */
.d-flex,
.row,
.col,
.col-md-6,
.col-md-12,
.col-lg-3,
.col-lg-9 {
  background: none !important;
}

/* Mejorar la apariencia de elementos inline */
code,
pre {
  background-color: var(--bg-secondary) !important;
  color: var(--text-primary) !important;
  border: 1px solid var(--border-color) !important;
}

/* Blockquotes */
blockquote {
  border-left: 4px solid var(--accent-color) !important;
  background-color: var(--bg-secondary) !important;
  color: var(--text-primary) !important;
}

/* Font Size Controls - Control de tamaño de letra */
.font-size-controls {
  background: var(--bg-card) !important;
  border: 1px solid var(--border-color) !important;
  box-shadow: 0 2px 8px var(--shadow) !important;
}

.font-size-controls button {
  background: var(--bg-card) !important;
  border: 1px solid var(--border-color) !important;
  color: var(--text-primary) !important;
  transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1) !important;
}

.font-size-controls button:hover {
  background: var(--bg-secondary) !important;
  border-color: var(--accent-color) !important;
  color: var(--accent-color) !important;
  transform: scale(1.05);
}

.font-size-controls button:focus {
  outline: none !important;
  box-shadow: 0 0 0 2px var(--accent-color) !important;
}

.font-size-display {
  color: var(--text-primary) !important;
  font-weight: 600;
  background: var(--bg-secondary) !important;
  padding: 4px 8px;
  border-radius: 4px;
  border: 1px solid var(--border-color) !important;
}

/* Iconos dentro de los botones de font-size */
.font-size-controls button i {
  color: var(--text-primary) !important;
  transition: color 0.3s cubic-bezier(0.4, 0, 0.2, 1) !important;
}

.font-size-controls button:hover i {
  color: var(--accent-color) !important;
}

/* Article content y elementos relacionados */
.article-content,
.article_body {
  color: var(--text-secondary) !important;
  transition: font-size 0.3s ease, color 0.3s cubic-bezier(0.4, 0, 0.2, 1) !important;
}

.article_head {
  color: var(--text-primary) !important;
  transition: font-size 0.3s ease, color 0.3s cubic-bezier(0.4, 0, 0.2, 1) !important;
}

/* ===============================
   SECTIONS DARK MODE COMPATIBILITY
   =============================== */

/* Asegurar que las secciones usen los colores correctos */
[data-theme="dark"] .news-grid {
  background: transparent !important;
}

[data-theme="dark"] .news-card {
  background-color: var(--bg-card) !important;
  border-color: var(--border-color) !important;
  box-shadow: 0 2px 8px rgba(0, 0, 0, 0.3) !important;
}

[data-theme="dark"] .news-card:hover {
  box-shadow: 0 4px 16px rgba(0, 0, 0, 0.4) !important;
}

[data-theme="dark"] .news-content {
  background-color: var(--bg-card) !important;
}

[data-theme="dark"] .news-title {
  color: var(--text-primary) !important;
}

[data-theme="dark"] .news-title a {
  color: var(--text-primary) !important;
}

[data-theme="dark"] .news-title a:hover {
  color: var(--accent-color) !important;
}

[data-theme="dark"] .news-excerpt {
  color: var(--text-secondary) !important;
}

[data-theme="dark"] .news-meta {
  color: var(--text-muted) !important;
}

[data-theme="dark"] .news-meta i {
  color: var(--accent-color) !important;
}

[data-theme="dark"] .section-header h1 {
  color: var(--text-primary) !important;
  border-bottom-color: var(--text-primary) !important;
}

/* Loading spinner en dark mode */
[data-theme="dark"] #loading .spinner-border {
  color: var(--accent-color) !important;
}

[data-theme="dark"] #loading .visually-hidden {
  color: var(--text-primary) !important;
}

/* Mejorar blockquotes para dark mode */
[data-theme="dark"] blockquote {
  background-color: var(--bg-secondary) !important;
  border-left-color: var(--accent-color) !important;
  color: var(--text-primary) !important;
  box-shadow: 0 2px 8px var(--shadow) !important;
}

[data-theme="dark"] blockquote::before,
[data-theme="dark"] blockquote::after {
  color: var(--text-muted) !important;
  opacity: 0.2;
}

[data-theme="dark"] blockquote cite {
  color: var(--text-muted) !important;
}

/* Cards de noticias relacionadas */
.card {
  background-color: var(--bg-card) !important;
  border-color: var(--border-color) !important;
  transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1) !important;
}

.card:hover {
  box-shadow: 0 4px 20px var(--shadow) !important;
  transform: translateY(-2px);
}

.card-body {
  background-color: var(--bg-card) !important;
}

.card-footer {
  background-color: var(--bg-secondary) !important;
  border-color: var(--border-color) !important;
}

.card-title {
  color: var(--text-primary) !important;
}

.card-text {
  color: var(--text-secondary) !important;
}

/* Poll Container */
[data-theme="dark"] .poll-container .card {
    background-color: #161b22 !important;
    border: 1px solid #30363d !important;
    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.3) !important;
}

/* Poll Header */
[data-theme="dark"] .poll-container .card-header {
    background-color: #21262d !important;
    border-bottom: 1px solid #30363d !important;
}

[data-theme="dark"] .poll-container .card-header h5 {
    color: #f0f6fc !important;
}

/* Poll Header Icons */
[data-theme="dark"] .poll-container .card-header .bi {
    color: #f0f6fc !important;
    background: none !important;
    background-color: transparent !important;
}

/* Poll Body */
[data-theme="dark"] .poll-container .card-body {
    background-color: #0d1117 !important;
    border: none !important;
}

/* Poll Question */
[data-theme="dark"] .poll-container .card-title {
    color: #f0f6fc !important;
}

/* Poll Options */
[data-theme="dark"] .poll-container .form-check-label {
    color: #e6edf3 !important;
}

[data-theme="dark"] .poll-container .form-check-input {
    background-color: #21262d !important;
    border-color: #30363d !important;
}

[data-theme="dark"] .poll-container .form-check-input:checked {
    background-color: #58a6ff !important;
    border-color: #58a6ff !important;
}

[data-theme="dark"] .poll-container .form-check-input:focus {
    border-color: #58a6ff !important;
    box-shadow: 0 0 0 0.25rem rgba(88, 166, 255, 0.25) !important;
}

/* Poll Vote Button */
[data-theme="dark"] .poll-container .btn:not(.btn-outline-secondary) {
    background-color: #238636 !important;
    border-color: #238636 !important;
    color: #f0f6fc !important;
}

[data-theme="dark"] .poll-container .btn:not(.btn-outline-secondary):hover {
    background-color: #2ea043 !important;
    border-color: #2ea043 !important;
    color: #f0f6fc !important;
}

/* Poll Button Icons */
[data-theme="dark"] .poll-container .btn .bi {
    color: inherit !important;
    background: none !important;
    background-color: transparent !important;
}

/* Poll Secondary Buttons */
[data-theme="dark"] .poll-container .btn-outline-secondary {
    background-color: transparent !important;
    border-color: #6e7681 !important;
    color: #e6edf3 !important;
}

[data-theme="dark"] .poll-container .btn-outline-secondary:hover {
    background-color: #30363d !important;
    border-color: #58a6ff !important;
    color: #f0f6fc !important;
}

/* Poll Results */
[data-theme="dark"] .poll-container .poll-results span.fw-medium {
    color: #f0f6fc !important;
}

[data-theme="dark"] .poll-container .badge {
    background-color: #58a6ff !important;
    color: #f0f6fc !important;
}

/* Progress Bars */
[data-theme="dark"] .poll-container .progress {
    background-color: #21262d !important;
}

[data-theme="dark"] .poll-container .progress-bar {
    background-color: #58a6ff !important;
}

/* Poll Alerts */
[data-theme="dark"] .poll-container .alert {
    background-color: #1f2937 !important;
    border: 1px solid #374151 !important;
    color: #e6edf3 !important;
}

[data-theme="dark"] .poll-container .alert-warning {
    background-color: #1e1a16 !important;
    border-color: #9a6700 !important;
    color: #f8e3a1 !important;
}

/* Poll Alert Icons */
[data-theme="dark"] .poll-container .alert .bi {
    color: inherit !important;
    background: none !important;
    background-color: transparent !important;
}

/* Poll Text Elements */
[data-theme="dark"] .poll-container small {
    color: #8b949e !important;
}

[data-theme="dark"] .poll-container .mt-3 {
    color: #8b949e !important;
}

/* Poll Meta Icons (votos, usuarios, etc.) */
[data-theme="dark"] .poll-container small .bi,
[data-theme="dark"] .poll-container .mt-3 .bi {
    color: #58a6ff !important;
    background: none !important;
    background-color: transparent !important;
}

/* Poll Interactive Elements */
[data-theme="dark"] .poll-container .form-check-input:hover {
    border-color: #58a6ff !important;
}

[data-theme="dark"] .poll-container .progress-bar {
    transition: width 0.6s ease, background-color 0.3s ease !important;
}

/* Poll Card Hover Effect */
[data-theme="dark"] .poll-container .card:hover {
    box-shadow: 0 4px 12px rgba(0, 0, 0, 0.4) !important;
    transition: box-shadow 0.3s ease !important;
}