/* ========================================================================================
                                Archivo de diseño principal
   ========================================================================================
*/

/*========================================= 
                BANNERS
===========================================*/

.breadcrumb-content {
    background-color: rgba(0, 0, 0, 0.5); /* Filtro oscuro */
    background-blend-mode: darken; /* Mezcla el filtro con la imagen */
    background-size: cover; /* Asegura que la imagen cubra el área */
    background-position: center; /* Centra la imagen */
}

.breadcrumb-thumb img {
    filter: brightness(50%); /* Aplica un filtro de brillo reducido */
}



/*========================================= 
                SLIDER
===========================================*/

@media (min-width: 1400px) {
    .hero-side {
        padding-top: 344px;
        padding-bottom: 344px;
    }
}

@media (min-width: 1700px) {
    .hero-side {
        padding-top: 400px;
        padding-bottom: 370px;
    }
}

@media (min-width: 1850px) {
    .hero-side {
        padding-top: 444px;
        padding-bottom: 344px;
    }
}

@media (min-width: 2000px) {
    .hero-side {
        padding-top: 500px;
        padding-bottom: 400px;
    }
}




/*========================================= 
                CARDS
===========================================*/

/* Tarjetas genericas */
.tarjeta {
    background-color: var(--background-color-2);
    display: block;
    border-radius: 15px;
    padding: 50px 30px;
}

.tarjeta.sidebar {
    padding: 30px;
}


.tarjeta h4 {
    margin: 15px 30px 40px 0px;
    text-align: left;
    color: var(--theme-color-3);
}

.tarjeta h3 {
    margin: 15px;
    text-align: center;
    font-size: 52px;
    color: var(--theme-color-3);
}

.tarjeta .contenido {
    margin-top: 20px;
    color: var(--text-color); /* Mantener consistencia con la plantilla */
    font-size: 16px;
    line-height: 1.6;
}

.tarjeta .contenido p {
    margin-bottom: 15px;
}


.tarjeta ul {
    list-style: none;
    padding-left: 0;
}

.tarjeta ul li {
    margin-bottom: 10px;
    cursor: pointer;
    color: var(--text-color-2);
    transition: 0.3s;
}

.tarjeta ul li:hover {
    color: var(--sidemenu-config-item);
}


.config-item {
    margin: 40px 0 100px;
}

.config-item h4 {
    margin: 15px 0px;
    color: var(--theme-color-4);
}

.config-item p {
    text-align: left;
    color: var(--text-color-2);
}
/* Tarjetas genericas */





.tarjeta-portada {
    background-color: var(--elements-background-color);
    border-radius: 5px;
    padding: 5px;
    margin-bottom: 30px;
    display: block;
}

.tarjeta-portada img {
    border-radius: 5px;
}

.tarjeta-portada h2 {
    margin: 15px;
    text-align: center;
    color: var(--theme-color-3);
}




.tarjeta-lista-capitulos {
    background-color: var(--background-color-2);
    display: block;
    border-radius: 15px;
    padding: 30px 0px;
    margin: 20px 0px;
}

.tarjeta-lista-capitulos .lista{
    max-height: 860px;      /* Ajusta según tu diseño */
    overflow-y: auto;       /* Activar scroll vertical */
    padding: 0px 20px;
}

/* Scroll para navegadores Webkit (Chrome, Edge, Safari) */
.tarjeta-lista-capitulos .lista::-webkit-scrollbar {
    width: 8px;
}

.tarjeta-lista-capitulos .lista::-webkit-scrollbar-thumb {
    background-color: var(--theme-color-3);
    border-radius: 4px;
}

.tarjeta-lista-capitulos .lista::-webkit-scrollbar-track {
    background: var(--background-color-2);
}

.tarjeta-lista-capitulos .lista h3 {
    color: var(--theme-color-3);
    font-size: 48px;
    margin-bottom: 30px;
}

.tarjeta-lista-capitulos .lista a {
    color: var(--link-color);
}

.tarjeta-lista-capitulos .lista a:hover {
    color: var(--link-color-hover);
}

.tarjeta-lista-capitulos .lista .lista-capitulo {
    background-color: var(--background-color);
    display: block;
    border-radius: 15px;
    margin: 15px 0px;
}

.tarjeta-lista-capitulos .lista .lista-arco {
    background-color: var(--button-color);
    display: block;
    border-radius: 20px;
    padding: 30px;
    margin: 30px 0px 15px 0px;
}

.tarjeta-lista-capitulos .lista .lista-arco h4 {
    color: var(--button-color-2);
    margin: 0px;
}

.lista-capitulo.sin-arco {
  background: rgba(255,255,255,0.02);
  border-left: 4px dashed #c0c0c0; /* borde distinto para destacar */
  padding-left: 12px;
}

.lista-capitulo .tag-sin-arco {
  display: inline-block;
  margin-left: 8px;
  font-size: 0.75rem;
  color: #777;
  background: #f0f0f0;
  padding: 2px 6px;
  border-radius: 4px;
}

/* Hacer que lista-capitulo sin-arco use flexbox para alinear contenido y botón */
.tarjeta-lista-capitulos .lista .lista-capitulo.sin-arco {
    display: flex;
    align-items: center;
    justify-content: space-between;
}

/* Enlace principal ocupa todo el espacio disponible a la izquierda */
.tarjeta-lista-capitulos .lista .lista-capitulo.sin-arco .cap-link {
    flex: 1;
    text-decoration: none;
    padding: 20px;
}

/* Botón editar a la derecha */
.tarjeta-lista-capitulos .lista .lista-capitulo.sin-arco .btn-editar {
    flex: 0 0 auto; /* tamaño natural */
    margin-left: 12px;
    padding: 6px 10px;
    border-radius: 10px;
    background: var(--button-color-2);
    color: #fff;
    text-decoration: none;
    font-size: 0.85rem;
    line-height: 1;
}

/* Hover del botón */
.tarjeta-lista-capitulos .lista .lista-capitulo.sin-arco .btn-editar:hover, 
.tarjeta-lista-capitulos .lista .lista-capitulo.sin-arco .btn-editar:hover {
    opacity: 0.95;
}



/* --------- Añadidos mínimos para botón editar --------- */
/* Hacer que lista-capitulo use flexbox para alinear contenido y botón */
.tarjeta-lista-capitulos .lista .lista-capitulo {
    display: flex;
    align-items: center;
    justify-content: space-between;
}

/* Enlace principal ocupa todo el espacio disponible a la izquierda */
.tarjeta-lista-capitulos .lista .lista-capitulo .cap-link {
    flex: 1;
    text-decoration: none;
    padding: 20px;
}

/* Botón editar a la derecha */
.tarjeta-lista-capitulos .lista .lista-capitulo .btn-editar {
    flex: 0 0 auto; /* tamaño natural */
    margin-right: 20px;
    padding: 6px 10px;
    border-radius: 10px;
    background: var(--button-color-2);
    color: #fff;
    text-decoration: none;
    font-size: 0.85rem;
    line-height: 1;
}

/* Hover del botón */
.tarjeta-lista-capitulos .lista .lista-capitulo .btn-editar:hover {
    opacity: 0.95;
}




/* ---------- Ajustes mínimos para que .lista-arco tenga el mismo layout que .lista-capitulo ---------- */
.tarjeta-lista-capitulos .lista .lista-arco {
    display: flex;
    align-items: center;
    justify-content: space-between;
    /* reducimos el padding para que coincida con .lista-capitulo (sobrescribe el padding:30px actual) */
    padding: 30px 20px;
}

/* H4 ocupa el espacio disponible (como .cap-link) */
.tarjeta-lista-capitulos .lista .lista-arco h4 {
    margin: 0;
    flex: 1;
    /* si quieres que el texto respire igual que .cap-link */
    padding-right: 12px;
    font-weight: 600; /* opcional, mantiene buena jerarquía visual */
}

/* Botón editar con el mismo estilo que en los capítulos */
.tarjeta-lista-capitulos .lista .lista-arco .btn-editar {
    flex: 0 0 auto;
    margin-left: 12px;
    padding: 6px 10px;
    border-radius: 10px;
    background: var(--button-color-2);
    color: #fff;
    text-decoration: none;
    font-size: 0.85rem;
    line-height: 1;
}

/* Hover del botón */
.tarjeta-lista-capitulos .lista .lista-arco .btn-editar:hover {
    opacity: 0.95;
}




.tarjeta-capitulo {
    background-color: var(--background-color-2);
    display: block;
    border-radius: 15px;
    padding: 50px 30px;
}

.tarjeta-capitulo .titulo {
    margin-bottom: 30px;
    text-align: center;
}

.tarjeta-capitulo .titulo h3 {
    color: var(--theme-color-3);
    font-size: 60px;
    margin: 0;
}

.tarjeta-capitulo .titulo h2 {
    color: var(--theme-color-3);
    margin: 0;
}

.tarjeta-capitulo .titulo h4,
.tarjeta-capitulo .titulo h5 {
    color: var(--pre-title-color-2);
    margin: 0;
}

.tarjeta-capitulo .titulo h4{
    font-size: 18px;
}

.tarjeta-capitulo .titulo h5 {
    font-size: 14px;
}

.tarjeta-capitulo .contenido {
    margin-top: 60px;
}

.tarjeta-capitulo .contenido p {
    font-size: 1.5rem;
}



/*========================================= 
        CATEGORIAS DE HISTORIAS
===========================================*/

.categorias {
    margin: 10px;
}

.categorias p {
    cursor: pointer;
    display: inline-block;
    padding: 6px 14px;
    margin-bottom: 10px;
    background: var(--footer-background-color);
    border: 1.5px solid rgba(255, 255, 255, 0.3);
    box-shadow: inset 0 4px 11px rgba(255, 255, 255, 0.4), inset -1px -4px 23.1px rgba(0, 24, 25, 0.28);
    backdrop-filter: blur(23.9px);
    border-radius: 53px;
    color: var(--white-color);
    font-size: 0.8rem;
}

.categorias p:hover {
    background: var(--theme-color-3);
    color: var(--white-color);
}


/*========================================= 
    BOTON DE CAMBIO DE MODO (CLARO/OSCURO)
===========================================*/

/* Toggle mode floating button (con ring siempre visible) */
#toggleMode {
  --toggle-ring-color: rgba(255,168,136,0.18); /* ring por defecto (modo claro) */
  position: fixed;
  bottom: 24px;
  right: 24px;
  width: 56px;
  height: 56px;
  padding: 0;
  border: none;
  border-radius: 50%;
  display: inline-block;
  box-sizing: border-box;
  z-index: 999999;
  cursor: pointer;
  -webkit-tap-highlight-color: transparent;
  outline: none;

  /* icon as background (sun by default) */
  background-image: url("/img/icons/sol.png");
  background-position: center;
  background-repeat: no-repeat;
  background-size: 60%;

  /* fondo circular */
  background-color: #ffffff; /* blanco cuando muestra el sol */

  /* sombra grande + ring persistente */
  box-shadow:
    0 16px 48px rgba(0, 0, 0, 0.40),  /* sombra amplia */
    0 0 0 4px var(--toggle-ring-color); /* ring persistente */
  transition: transform .12s ease, box-shadow .12s ease, background-color .12s ease;
}

/* Dark mode: switch icon, background and ring color */
body.dark-mode #toggleMode {
  --toggle-ring-color: rgba(255,168,136,0.22); /* ring algo más visible en oscuro */
  background-image: url("/img/icons/media-luna.png");
  background-color: #000000; /* negro cuando muestra la luna */

  /* sombra un poco más intensa en modo oscuro */
  box-shadow:
    0 20px 60px rgba(0, 0, 0, 0.75),
    0 0 0 4px var(--toggle-ring-color);
}

/* Hover: eleva y suaviza la sombra (ring se mantiene) */
#toggleMode:hover {
  transform: translateY(-3px) scale(1.02);
  box-shadow:
    0 22px 68px rgba(0, 0, 0, 0.45),
    0 0 0 4px var(--toggle-ring-color);
}

/* Active (presionado) */
#toggleMode:active {
  transform: translateY(-1px) scale(0.995);
}

/* Focus accesible: agrandar ligeramente el ring */
#toggleMode:focus {
  box-shadow:
    0 22px 68px rgba(0, 0, 0, 0.45),
    0 0 0 6px rgba(255,168,136,0.26); /* ring más visible para teclado */
  outline: none;
}

/* Small screens: reducir tamaño un poco */
@media (max-width: 420px) {
  #toggleMode {
    width: 48px;
    height: 48px;
    bottom: 16px;
    right: 16px;
    background-size: 58%;
  }
}





/*========================================= 
                FOOTER
===========================================*/

/* Estilo de los enlaces dentro del footer 
.footer-copyright a {
    color: #004540; 
    text-decoration: none; 
}
*/
/* Cambia el color al pasar el cursor por encima del enlace 
.footer-copyright a:hover {
    color: #007860; 
}
*/



.footer-copyright .link {
    color: var(--link-color);
}

.footer-copyright .link:hover {
    color: var(--link-color-hover);
}






/*=========================================
                COMENTARIOS
===========================================*/

/* Variables  */
:root{
  --c-bg: #ffffff;
  --c-muted: #6b7280;
  --c-border: #e6e6e9;
  --c-accent: #2563eb;
  --c-like: #ef4444;
  --radius: 15px;
  --gap: 12px;
}

/* contenedor principal de comentarios */
.comentarios-container {
  display: flex;
  flex-direction: column;
  gap: 14px;
  width: 100%;
  padding: 12px;
  box-sizing: border-box;
}

/* cada comentario */
.comentario {
  display: flex;
  gap: 12px;
  background: var(--background-color-2);
  border: 1px solid var(--linea-2);
  border-radius: var(--radius);
  padding: 12px;
  align-items: flex-start;
  box-shadow: 0 1px 2px rgba(16,24,40,0.03);
}

/* avatar izquierda */
.comentario .avatar {
  flex: 0 0 48px;
  height: 48px;
  border-radius: 50%;
  overflow: hidden;
  background: #ddd;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-weight: 700;
  color: #fff;
  font-size: 18px;
}

/* cuerpo del comentario */
.comentario .contenido {
  flex: 1 1 auto;
  min-width: 0;
}

.comentario .meta {
  display: flex;
  align-items: center;
  gap: 8px;
  margin-bottom: 6px;
}

.comentario .autor {
  font-weight: 600;
  color: var(--text-color);
  font-size: 14px;
  line-height: 1;
}

.comentario .fecha {
  font-size: 13px;
}

/* texto del comentario */
.comentario .texto {
    color: var(--text-color-2);
    font-size: 14px;
    line-height: 1.5;
    margin-bottom: 8px;
}

/* acciones (responder, like) */
.comentario .acciones {
  display: flex;
  gap: 8px;
  align-items: center;
}

.comentario .acciones button {
  background: transparent;
  border: none;
  color: var(--c-muted);
  cursor: pointer;
  font-size: 13px;
  padding: 6px 8px;
  border-radius: 6px;
}

.comentario .acciones button:hover {
  background: #f3f4f6;
  color: #111827;
}

/* contador visual para likes */
.comentario .like-count {
  display:inline-block;
  font-size: 13px;
  color: var(--c-muted);
  margin-left: 4px;
}

/* estilo para respuesta anidada */
.respuesta {
    margin-left: 60px; /* espacio para avatar */
    margin-top: 8px;
    padding-left: 12px;
    border: 0;

}

/* si quieres que las respuestas se parezcan a comentarios pero más pequeñas */
.respuesta .avatar { width:36px; height:36px; flex:0 0 36px; font-size:14px; }


/* media queries: mobil */
@media (max-width: 600px) {
  .comentario {
    gap: 10px;
    padding: 10px;
  }
  .comentario .avatar { width:40px; height:40px; flex:0 0 40px; }
  .respuesta { margin-left: 48px; padding-left:10px; }
}








/*========================================= 
                BUSCADOR DINAMICO
===========================================*/
/* POPUPS: prefijo bh-popup- para evitar colisiones */

/* Barra */
.bh-popup-bar {
  display:flex;
  gap:10px;
  align-items:center;
  flex-wrap:wrap;
  padding:8px;
}

/* contenedor por botón+panel */
.bh-popup-item {
  position: relative; /* ancla el popup absoluto */
}

/* botón que abre popup */
.bh-popup-toggle {
  background: var(--background-color-2);
  border:1px solid var(--linea-2);
  padding:8px 12px;
  border-radius:8px;
  cursor:pointer;
  font-weight:600;
  display:inline-flex;
  align-items:center;
  gap:8px;
  color: var(--text-color);
  box-shadow:0 2px 6px rgba(15,23,42,0.04);
}

/* badge contador (pequeño) */
.bh-popup-badge {
  background: var(--theme-color-2);
  border-radius:999px;
  padding:2px 8px;
  font-size:12px;
  color:#fff; 
}
.bh-popup-badge--count { 
    background:var(--theme-color-2); 
    color:#fff; 
    font-size:12px; 
    padding:2px 6px; 
}

/* panel popup (oculto por defecto) */
.bh-popup-panel {
  position:absolute;
  top:calc(100% + 10px);
  left:0;
  min-width:260px;
  background: var(--background-color-2);
  border:1px solid var(--linea-2);
  box-shadow:0 8px 24px rgba(2,6,23,0.08);
  border-radius:10px;
  z-index:1000;
  display:none;
  transform-origin: top left;
}

/* Flecha pequeña */
.bh-popup-panel::before{
  content:"";
  position:absolute;
  top:-7px;
  left:20px;
  width:12px;
  height:12px;
  background: var(--background-color-2);
  transform: rotate(45deg);
  border-left:1px solid #e6e6e9;
  border-top:1px solid #e6e6e9;
  z-index:-1;
}

/* interior del panel */
.bh-popup-panel-inner{
    padding:12px;
    max-height:320px;
    width:320px;
    box-sizing:border-box;

    overflow-y: auto;       /* Activar scroll vertical */
    padding: 0px 20px;
}

/* Personalización del scroll solo para el popup */
.bh-popup-panel-inner::-webkit-scrollbar {
  width: 8px; /* ancho de la barra vertical */
  height: 8px; /* alto de la barra horizontal (si aparece) */
}

/* Fondo de la barra (track) */
.bh-popup-panel-inner::-webkit-scrollbar-track {
  background: #f1f1f1; 
  border-radius: 8px;
}

/* La parte que se mueve (thumb) */
.bh-popup-panel-inner::-webkit-scrollbar-thumb {
  background: var(--theme-color-3); /* usa tu color de tema */
  border-radius: 8px;
  transition: background 0.3s ease;
}

/* Hover sobre el thumb */
.bh-popup-panel-inner::-webkit-scrollbar-thumb:hover {
  background: var(--theme-color-2); /* color un poco más oscuro */
}







.bh-popup-panel-inner.xl{
  width: 640px;
  max-height: 540px;
}

/* disposición de opciones */
.bh-popup-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr); /* ← ahora 4 columnas */
  gap: 8px;
  margin-bottom: 10px;
}

.bh-grid-col-1 { grid-template-columns:1fr; }

/* cada opción */
.bh-option {
  display:flex;
  align-items:center;
  gap:8px;
  padding:8px;
  border-radius:8px;
  cursor:pointer;
  user-select:none;
  font-size:14px;
}

.bh-popup-grid label {
    color: var(--text-color);
}

.bh-option input { width:16px; height:16px; }

/* hover opción */
.bh-option:hover {
  background:var(--bg-banner);
}

/* acciones del popup */
.bh-popup-actions{
  display:flex;
  gap:8px;
  justify-content:flex-end;
  margin-top:6px;
}

/* botones estilo */
.bh-btn { 
    padding: 8px 12px; 
    border-radius: 8px; 
    border: 1px solid transparent; 
    cursor: pointer; 

    background: var(--theme-color-3); 
    color: var(--text-color); 

    font-weight: 600;
}

.bh-btn:hover { 
    background: var(--link-color-hover); 
}



/* abrir el popup (clase JS añade inline style display:block) */
.bh-popup-panel[data-open="true"]{ display:block; animation: bhPopupIn .12s ease both; padding: 5px; }

/* anim */
@keyframes bhPopupIn {
  from { transform: translateY(-6px) scale(.98); opacity:0; }
  to   { transform: translateY(0) scale(1); opacity:1; }
}

/* responsive: en pantallas pequeñas el popup ocupa ancho completo y se posiciona abajo */




/* opcional: en pantallas medianas usar 2 columnas para mejor legibilidad */
@media (max-width: 900px) {
  .bh-popup-grid {
    grid-template-columns: repeat(2, 1fr);
  }
  
  .bh-popup-panel-inner.xl {
    width: 440px;
    max-height: 440px;
  }
}

/* ya tienes esto para móviles (1 columna) */
@media (max-width:600px){
  .bh-popup-panel { 
    left: 50%; 
    transform: translateX(-50%); 
    min-width: 90vw; 
  }

  /* centrar la flecha correctamente respecto al panel centrado */
  .bh-popup-panel::before{
    transform: translateX(-50%) rotate(45deg);
    top: -7px;
    /* conservar dimensiones y estilos previos */
    width: 12px;
    height: 12px;
    background: #fff;
    border-left:1px solid #e6e6e9;
    border-top:1px solid #e6e6e9;
  }

  .bh-popup-panel-inner { 
    width: 90vw; 
    max-height: 55vh; 
  }

  .bh-popup-grid { 
    grid-template-columns: 1fr; 
  }
}








/*========================================= 
                PAGINACION
===========================================*/

/* Simple styles para paginación (puedes mover al CSS global) */
.bh-pagination { 
    text-align:center; 
    margin-top:18px; 
}

.bh-pagination ul { 
    list-style:none; 
    padding:0; margin:0; 
    display:inline-flex; 
    gap:6px; 
}

.bh-pagination li {

}

.bh-pagination a { 
    display:inline-block; 
    padding:6px 10px; 
    border:1px solid #e0e0e3; 
    border-radius:6px; 
    text-decoration:none; 
    color:#222; 
    background:#fff; 
}

.bh-pagination a:hover { 
    background:#f3f4f6; 
}
.bh-pagination .active a { 
    background: var(--theme-color-3); 
    color:#fff; 
    border-color:#111827; 
}

.bh-pagination .disabled a { 
    opacity:0.5; 
    pointer-events:none; 
}


/* transición sutil al actualizar #historias */
#historias.bh-loading-transition {
  /* nada que oculte inmediatamente - solo preparativo */
}
#historias > * {
  transition: opacity 220ms ease;
}
#historias.bh-loading-transition > * {
  opacity: 0.98; /* apenas perceptible mientras carga */
}







/*========================================= 
                Banners
===========================================*/
/* Banner que ocupa todo el ancho */
.banner-section {
    width: 100%;
    background: var(--footer-background-color);
    background-size: cover; /* Para que la imagen se ajuste al ancho */
    padding: 60px 0; /* Espaciado arriba y abajo */
    color: #fff; /* Texto blanco para contraste */
    position: relative;
}

/* Opcional: capa semitransparente encima del fondo */
.banner-section::before {
    content: "";
    position: absolute;
    top: 0; left: 0;
    width: 100%; height: 100%;
    background: rgba(0, 0, 0, 0.1); /* oscurece un poco la imagen */
    z-index: 1;
}

/* Contenido centrado dentro del banner */
.banner {
    position: relative;
    z-index: 2; /* por encima del ::before */
    text-align: left;
    max-width: 1200px;
    margin: 0 auto;
}

/* Estilos de texto */
.banner h3 {
    color: var(--theme-color-3);
    font-size: 62px;
    font-weight: 700;
    margin-bottom: 1rem;
}

.banner p {
    font-size: 1.2rem;
    font-weight: 400;
    line-height: 1.6;
}








/* ========================================= 
                    Quill 
========================================= */
.ql-toolbar.ql-snow {
    background: var(--background-color-2);
}

.ql-snow .ql-picker{
    color: var(--theme-color-3);
}
.ql-snow .ql-stroke {
    stroke: var(--theme-color-3);
}

.ql-snow .ql-fill, .ql-snow .ql-stroke.ql-fill {
    fill: var(--theme-color-3);
}


.ql-snow.ql-toolbar button:hover, .ql-snow .ql-toolbar button:hover, .ql-snow.ql-toolbar button:focus, .ql-snow .ql-toolbar button:focus, .ql-snow.ql-toolbar button.ql-active, .ql-snow .ql-toolbar button.ql-active, .ql-snow.ql-toolbar .ql-picker-label:hover, .ql-snow .ql-toolbar .ql-picker-label:hover, .ql-snow.ql-toolbar .ql-picker-label.ql-active, .ql-snow .ql-toolbar .ql-picker-label.ql-active, .ql-snow.ql-toolbar .ql-picker-item:hover, .ql-snow .ql-toolbar .ql-picker-item:hover, .ql-snow.ql-toolbar .ql-picker-item.ql-selected, .ql-snow .ql-toolbar .ql-picker-item.ql-selected {
    color: var(--link-color-hover);
}

.ql-snow.ql-toolbar button:hover .ql-stroke, .ql-snow .ql-toolbar button:hover .ql-stroke, .ql-snow.ql-toolbar button:focus .ql-stroke, .ql-snow .ql-toolbar button:focus .ql-stroke, .ql-snow.ql-toolbar button.ql-active .ql-stroke, .ql-snow .ql-toolbar button.ql-active .ql-stroke, .ql-snow.ql-toolbar .ql-picker-label:hover .ql-stroke, .ql-snow .ql-toolbar .ql-picker-label:hover .ql-stroke, .ql-snow.ql-toolbar .ql-picker-label.ql-active .ql-stroke, .ql-snow .ql-toolbar .ql-picker-label.ql-active .ql-stroke, .ql-snow.ql-toolbar .ql-picker-item:hover .ql-stroke, .ql-snow .ql-toolbar .ql-picker-item:hover .ql-stroke, .ql-snow.ql-toolbar .ql-picker-item.ql-selected .ql-stroke, .ql-snow .ql-toolbar .ql-picker-item.ql-selected .ql-stroke, .ql-snow.ql-toolbar button:hover .ql-stroke-miter, .ql-snow .ql-toolbar button:hover .ql-stroke-miter, .ql-snow.ql-toolbar button:focus .ql-stroke-miter, .ql-snow .ql-toolbar button:focus .ql-stroke-miter, .ql-snow.ql-toolbar button.ql-active .ql-stroke-miter, .ql-snow .ql-toolbar button.ql-active .ql-stroke-miter, .ql-snow.ql-toolbar .ql-picker-label:hover .ql-stroke-miter, .ql-snow .ql-toolbar .ql-picker-label:hover .ql-stroke-miter, .ql-snow.ql-toolbar .ql-picker-label.ql-active .ql-stroke-miter, .ql-snow .ql-toolbar .ql-picker-label.ql-active .ql-stroke-miter, .ql-snow.ql-toolbar .ql-picker-item:hover .ql-stroke-miter, .ql-snow .ql-toolbar .ql-picker-item:hover .ql-stroke-miter, .ql-snow.ql-toolbar .ql-picker-item.ql-selected .ql-stroke-miter, .ql-snow .ql-toolbar .ql-picker-item.ql-selected .ql-stroke-miter {
    stroke: var(--link-color-hover);
}

.ql-snow.ql-toolbar button:hover .ql-fill, .ql-snow .ql-toolbar button:hover .ql-fill, .ql-snow.ql-toolbar button:focus .ql-fill, .ql-snow .ql-toolbar button:focus .ql-fill, .ql-snow.ql-toolbar button.ql-active .ql-fill, .ql-snow .ql-toolbar button.ql-active .ql-fill, .ql-snow.ql-toolbar .ql-picker-label:hover .ql-fill, .ql-snow .ql-toolbar .ql-picker-label:hover .ql-fill, .ql-snow.ql-toolbar .ql-picker-label.ql-active .ql-fill, .ql-snow .ql-toolbar .ql-picker-label.ql-active .ql-fill, .ql-snow.ql-toolbar .ql-picker-item:hover .ql-fill, .ql-snow .ql-toolbar .ql-picker-item:hover .ql-fill, .ql-snow.ql-toolbar .ql-picker-item.ql-selected .ql-fill, .ql-snow .ql-toolbar .ql-picker-item.ql-selected .ql-fill, .ql-snow.ql-toolbar button:hover .ql-stroke.ql-fill, .ql-snow .ql-toolbar button:hover .ql-stroke.ql-fill, .ql-snow.ql-toolbar button:focus .ql-stroke.ql-fill, .ql-snow .ql-toolbar button:focus .ql-stroke.ql-fill, .ql-snow.ql-toolbar button.ql-active .ql-stroke.ql-fill, .ql-snow .ql-toolbar button.ql-active .ql-stroke.ql-fill, .ql-snow.ql-toolbar .ql-picker-label:hover .ql-stroke.ql-fill, .ql-snow .ql-toolbar .ql-picker-label:hover .ql-stroke.ql-fill, .ql-snow.ql-toolbar .ql-picker-label.ql-active .ql-stroke.ql-fill, .ql-snow .ql-toolbar .ql-picker-label.ql-active .ql-stroke.ql-fill, .ql-snow.ql-toolbar .ql-picker-item:hover .ql-stroke.ql-fill, .ql-snow .ql-toolbar .ql-picker-item:hover .ql-stroke.ql-fill, .ql-snow.ql-toolbar .ql-picker-item.ql-selected .ql-stroke.ql-fill, .ql-snow .ql-toolbar .ql-picker-item.ql-selected .ql-stroke.ql-fill {
    fill: var(--link-color-hover);
}

.quill_editor {
    min-height: 300px;
    background: var(--background-color);
}

.ql-container.ql-snow {
    border: 2px solid transparent;
    border-radius: 0 0 12px 12px; 
}

.ql-toolbar.ql-snow {
    border: 1px solid var(--linea-2);
    border-radius: 12px 12px 0 0; 
}

.ql-editor p {
    margin: 0px 0px 16px; 
}



/* ========================================= 
                    Formulario 
========================================= */


.label-color {
    color: var(--text-color);
}


/* ========================================= 
                    Botones 
========================================= */

/* ==================================== Botones ==================================== */
/* Botones generales */
.boton {
    display: block;
    border-radius: 30px;
    padding: 10px 0; /* un poco más de padding vertical */
    margin: 20px 0; /* un poco más de padding vertical */
    text-align: center;
    width: 100%;      /* Asegura que ocupe todo el ancho */
    box-sizing: border-box; /* Para incluir padding en el ancho */
}

/* Botón editar */
.boton.crear {
    color: #1d1d1d;
    background-color: #fff;
    border: 1px solid #8b8b8b;
    text-decoration: none; /* Quita subrayado si es <a> */
}

/* Botón editar */
.boton.editar {
    color: #fff;
    background-color: var(--link-color);
    border: 1px solid #8b8b8b;
    text-decoration: none; /* Quita subrayado si es <a> */
}

/* Botón eliminar */
.boton.eliminar {
    color: #fff;
    background-color: var(--pre-title-color);
    border: 1px solid #8b8b8b;
    cursor: pointer;
}

/* Formulario que contiene el botón */
form.eliminar{
    width: 100%; /* Para que el botón tome todo el ancho del contenedor */
}



.e-primary-btn.has-icon.left {
    padding: 5px 25px 5px 5px;
    gap: 15px;
}









/* Contenedor principal */
.tarjeta-portada.btn-capitulos-container {
    width: 100%;
    max-width: 100%; /* opcional: define un máximo para que no se estire demasiado */
    background: var(--elements-background-color); /* para visualizar límites */
    padding: 10px;
    border-radius: 10px;
}

/* Contenedor de botones */
.btn-capitulos {
    display: flex;
    flex-direction: column; /* uno arriba del otro */
    gap: 8px; /* espacio entre botones */
    width: 100%;
}

/* Estilos base para cada botón */
.btn-capitulos a {
    display: flex;
    align-items: center;
    justify-content: center;

    width: 100%;
    padding: 12px;
    font-size: 16px;
    font-weight: 500;
    text-decoration: none;
    color: #fff;

    background-color: var(--footer-background-color);
    border-radius: 6px;
    transition: background-color 0.3s, transform 0.2s;
}

/* Efecto hover */
.btn-capitulos a:hover {
    background-color: var(--link-color);
    transform: translateY(-2px);
}

/* Colores específicos */
.btn-siguiente, 
.btn-lista, 
.btn-anterior {
    background-color: var(--elements-background-color); /* verde */
}


/* Íconos */
.btn-capitulos i {
    margin: 0px 8px;
    font-size: 18px;
}



/* ==================================== Botones 2 ==================================== */
/* Contenedor principal */
.btn-capitulos-container-custom {
    display: flex;
    justify-content: center;
    align-items: center;
    gap: 15px; /* Espacio entre botones */
    flex-wrap: wrap; /* Permite que se acomoden en móviles */
    margin-top: 15px;
}

/* Botón base */
.btn-capitulo-custom {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    padding: 10px 18px;
    font-size: 16px;
    font-weight: 500;
    border-radius: 8px;
    text-decoration: none;
    transition: all 0.3s ease;
    min-width: 110px;
    background-color: var(--footer-background-color); /* Azul base */
    color: #fff;
}

/* Hover y enfoque */
.btn-capitulo-custom:hover {
    background-color: var(--link-color);
    text-decoration: none;
    color: #fff;
}

/* Botón especial para lista */
.btn-capitulo-lista {
    background-color: var(--footer-background-color); /* Gris */
}

.btn-capitulo-lista:hover {
    background-color: var(--link-color);
}

/* Ícono dentro del botón */
.btn-capitulo-custom i {
    margin-left: 8px; /* Espacio entre texto e ícono */
    font-size: 16px;
}

/* Ícono en botón anterior (icono a la izquierda del texto) */
.btn-capitulo-prev i {
    margin-left: 0;
    margin-right: 8px;
}

/* Adaptación móvil */
@media (max-width: 576px) {
    .btn-capitulos-container-custom {
        gap: 10px;
    }

    .btn-capitulo-custom {
        width: 100%;
        max-width: 250px;
    }
}

@media (max-width: 1199px) {
    .btn-capitulos-container-custom {
        display: none !important;
    }
} 









/* ========================================= 
                    Select2 
========================================= */

/* Contenedor de todas las tags */
.select2-container--default .select2-selection--multiple .select2-selection__rendered {
    justify-content: flex-start;   /* ya lo tenías */
    align-items: flex-start;       /* esto fuerza las tags a la parte superior */
    flex-wrap: wrap;               /* mantener el wrap de tags */
}


/* Texto dentro de la tag */
.select2-selection__choice__display {
    padding-left: 4px;
    text-align: left;
}

/* resaltar la caja Select2 cuando tenga clase .is-invalid */
.select2-container--default .select2-selection.is-invalid {
  border-color: #dc3545;
  box-shadow: 0 0 0 .15rem rgba(220,53,69,.15);
}



.select-container {
    background-color: var(--background-color) !important;
    padding: 18px 20px;
    border: none;
    border-radius: 12px;
    color: var(--theme-color-3) !important;
    font-size: 18px;
}

.select-container:focus {
    background-color: var(--background-color);
}


option {
    background-color: var(--background-color);
    border: 1px solid var(--theme-color-3);
}

.form-control:disabled {
    cursor: not-allowed;
    opacity: 0.6;
    background-color: #f5f5f5;
}



.select2-container--default .select2-selection--multiple {
    background-color: var(--background-color);
    padding: 15px 10px;
    border: none;
    border-radius: 12px;
}

.select2-container .select2-search--inline .select2-search__field {
    margin: 0;
}

.select2-container--default .select2-selection--multiple .select2-selection__choice {
    text-align: left;
    margin-top: 2px; 
    background-color: var(--theme-color-3);
    border: 1px solid #000000;
}

.select2-container--default .select2-selection--multiple .select2-selection__choice__display {
    color: #000000;
}

.select2-search__field {
    color: var(--theme-color-3) !important;
}

.select2-container--default .select2-selection--multiple .select2-selection__choice__remove {
    border-right: 1px solid #000000;
}

.select2-container--default .select2-selection--multiple .select2-selection__choice__remove:hover, .select2-container--default .select2-selection--multiple .select2-selection__choice__remove {
    color: #000000;
}

.select2-container--default .select2-selection--multiple .select2-selection__choice__remove:hover, .select2-container--default .select2-selection--multiple .select2-selection__choice__remove:focus {
    background-color: var(--button-color);
    color: #ffffff;
}















/* ========================================= 
                Switch Roles 
========================================= */

.toggle-row { display:flex; align-items:center; gap:16px; margin-top:18px; }
.toggle-label { 
    font-weight:600; 
    color: var(--text-color-2);
}

/* Switch */
.switch {
    position: relative;
    display: inline-block;
    width: 56px;
    height: 32px;
}

.switch input { display:none; }
.slider {
    position: absolute;
    cursor: pointer;
    inset: 0;
    background-color: #ddd;
    border-radius: 999px;
    transition: background-color .2s ease;
    box-shadow: inset 0 1px 2px rgba(0,0,0,.1);
}

.slider:before {
    content: "";
    position: absolute;
    left: 4px;
    top: 4px;
    width: 24px;
    height: 24px;
    background: #fff;
    border-radius: 50%;
    transition: transform .22s cubic-bezier(.2,.9,.2,1);
    box-shadow: 0 2px 4px rgba(0,0,0,.12);
}

.switch input:checked + .slider {
    background-color: var(--theme-color-3); /* color activo */
}

.switch input:checked + .slider:before {
    transform: translateX(24px);
}

/* Estado texto */
    .estado-escritor {
    font-size: 0.95rem;
    color: #444;
}

.estado-escritor.active { color: var(--theme-color-3); font-weight:700; }
.estado-escritor.inactive { color: #888; font-weight:600; }

/* Alineación del botón actualizar */
.ser-escritor-actions { margin-top: 18px; }



/* ========================================= 
                Alertas 
========================================= */
.alerta {
    padding: 10px;
    margin: 30px 30px 0px 30px;
    border-radius: 5px;
    border: 1px solid #8b8b8b;
}

.alerta.sugerencia-rechazada {
    background-color: #8a1919ff;
}
.alerta.sugerencia-aprobada {
    background-color: #004540;
}
.alerta.sugerencia-pendiente {
    background-color: #c4962c;
}

.alerta p {
    color: #fff;
}







/* ========================================= 
                Likes 
========================================= */

.tarjeta-likes {
    background-color: var(--background-color-2);
    display: block;
    border-radius: 15px;
    padding: 50px 30px;
}



.tarjeta-likes .titulo {
    margin-bottom: 30px;
    text-align: center;
}

.tarjeta-likes .titulo h3 {
    color: var(--theme-color-3);
    font-size: 60px;
    margin: 0;
}

.tarjeta-likes .titulo h2 {
    color: var(--theme-color-3);
    margin: 0;
}


/* ======== Contenedor principal ======== */
.like-container {
    display: flex;
    justify-content: center;
    align-items: center;
    padding: 15px;
}

/* ======== Botón de Like ======== */
.like {
    position: relative;
    width: 60px;
    height: 60px;
    display: flex;
    justify-content: center;
    align-items: center;
    cursor: pointer;
    border-radius: 50%;
    background: var(--background-color-2);
    box-shadow: 0 4px 8px rgba(0, 0, 0, 0.1);
    transition: background 0.3s ease, transform 0.2s ease;
}

.like:hover {
    background: #ffeaea;
    transform: scale(1.05);
}

/* ======== Ícono del corazón ======== */
.like i {
    font-size: 28px;
    color: #999;
    transition: color 0.3s ease, transform 0.3s ease;
}

/* ======== Estado activo (like marcado) ======== */
.like.active i {
    color: #e63946; /* Rojo para el corazón */
    transform: scale(1.2);
}

/* ======== Pequeña animación cuando se activa ======== */
@keyframes pop {
    0% {
        transform: scale(1);
    }
    50% {
        transform: scale(1.4);
    }
    100% {
        transform: scale(1);
    }
}

.like.active i {
    animation: pop 0.3s ease;
}


.no-background {
    background-color: transparent;
}






/* ========================================= 
            Historia Favorita
=========================================*/
/* =========== Variables (fácil de ajustar) =========== */

/* Contenedor */
.fav-container {
  margin-top: 15px;
  display: flex;
  align-items: center;
  gap: 8px; /* separación controlada entre icono y texto */
}

/* Botón */
.fav {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  background-color: #f8f9fa;
  border: 2px solid var(--fav-color);
  border-radius: 50%;
  width: var(--btn-size);
  height: var(--btn-size);
  cursor: pointer;
  transition: background-color var(--transition-med), border-color var(--transition-med), transform var(--transition-fast);
  user-select: none;
  -webkit-tap-highlight-color: transparent;
}

/* Icono base */
.fav i {
  font-size: 18px;
  color: var(--fav-color); /* color por defecto (no favorito) */
  transition: transform var(--transition-med), color var(--transition-med);
  line-height: 1;
  pointer-events: none; /* evita que el click llegue al icono en vez del botón */
}

/* Especificar colores por clase (definimos antes el hover para que no los sobreescriba) */
.fav i.fa-regular { color: var(--fav-color); } /* estado por defecto */
.fav i.fa-solid  { color: var(--fav-on);   } /* si por alguna razón el icono ya viene solid */

/* HOVER / FOCUS (SE APLICA A CUALQUIER ICONO) 
   — Fuerza color blanco para el icono independientemente de clases posteriores */
.fav:hover,
.fav:focus {
  background-color: var(--fav-color);
  border-color: var(--fav-color);
  transform: translateY(-2px);
  outline: none;
}

.fav:hover i,
.fav:focus i {
  color: var(--fav-on) !important; /* importante sólo aquí para garantizar visibilidad en plantillas externas */
  transform: scale(1.18);
}

/* Estado activo (favorito) — permanece rojo y con corazón blanco */
.fav.active {
  background-color: var(--fav-color);
  border-color: var(--fav-color);
}

.fav.active i {
  color: var(--fav-on);
  transform: scale(1.05);
}

/* Texto al lado */
.fav-container p {
  margin: 0;
  font-weight: 600;
  color: var(--text-color-2);
  font-size: 16px;
  user-select: none;
}

/* Accesibilidad: foco visible */
.fav:focus-visible {
  box-shadow: 0 0 0 4px rgba(230,57,70,0.12);
  border-color: var(--fav-color);
}

/* Opcional: reducir la opacidad cuando está deshabilitado */
.fav[aria-disabled="true"] {
  opacity: 0.6;
  cursor: not-allowed;
  transform: none;
}







/* ========================================= 
            Seguir Historia
=========================================*/


/* Ajuste del contenedor (compatibilidad con tu .seguir-container) */
.seguir-container { 
    gap: var(--follow-gap); 
    margin-top: 15px;
}

/* Clase específica para el botón seguir (no afecta al corazón) */
.seguir-follow {
  border-radius: 10px;           /* botón rectangular con bordes suaves */
  width: auto;
  height: var(--follow-size);
  min-width: calc(var(--follow-size) * 1.1);
  padding: 0 12px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  background-color: var(--follow-off-bg); /* fondo sutil si NO está siguiendo */
  border: 2px solid rgba(37,99,235,0.15);
  transition: background-color var(--follow-transition) ease, border-color var(--follow-transition) ease, transform var(--follow-transition) ease, box-shadow var(--follow-transition) ease;
  cursor: pointer;
  gap: 8px;
}

/* Icono (check) */
.seguir-follow .follow-icon {
  font-size: 18px;
  color: var(--follow-blue); /* check azul cuando inactivo */
  transition: transform var(--follow-transition) ease, color var(--follow-transition) ease, opacity var(--follow-transition) ease;
  line-height: 1;
  display: inline-block;
  width: 20px;
  text-align: center;
}

/* Texto al costado */
.seguir-container p {
    margin: 0;
    font-weight: 600;
    color: var(--text-color-2);
    font-size: 16px;
    user-select: none;
}

/* HOVER: siempre mostrar el botón con fondo azul y check blanco */
.seguir-follow:hover,
.seguir-follow:focus {
  background-color: var(--follow-blue);
  border-color: var(--follow-blue-dark);
  transform: translateY(-2px);
  outline: none;
  box-shadow: 0 6px 18px rgba(37,99,235,0.12);
}

.seguir-follow:hover .follow-icon,
.seguir-follow:focus .follow-icon {
  color: var(--follow-on); /* check blanco en hover */
  transform: scale(1.12);
}

/* ESTADO activo: cuando ya sigue (persistente) */
.seguir-follow.active {
  background-color: var(--follow-blue);
  border-color: var(--follow-blue-dark);
  box-shadow: 0 6px 18px rgba(37,99,235,0.12);
}

.seguir-follow.active .follow-icon {
  color: var(--follow-on); /* check blanco cuando activo */
  transform: scale(1.05);
}

/* Label cambia color al estar activo */
.seguir-follow.active + .follow-label,
.seguir-follow.active ~ .follow-label,
.seguir-follow.active .follow-label {
  color: var(--follow-blue-dark);
}

/* Accesibilidad: foco visible */
.seguir-follow:focus-visible {
  box-shadow: 0 0 0 4px rgba(37,99,235,0.12);
}

/* Si tu icono se muestra con SVG en FA, también cubrir fill */
.seguir-follow svg {
  fill: currentColor;
}

/* Si el botón es pequeño en mobile, ajustar */
@media (max-width: 480px) {
  :root { --follow-size: 40px; }
  .seguir-follow { padding: 0 10px; }
  .seguir-follow .follow-icon { font-size: 16px; width: 18px; }
  .seguir-container .follow-label { font-size: 14px; }
}



/* ========================================= 
 Valoraciones de Historias (ajustes layout) 
========================================= */

.rating-wrap {
  display: flex;
  align-items: center;
  gap: 0.6rem;
  font-family: system-ui, -apple-system, "Segoe UI", Roboto, "Helvetica Neue", Arial;
}

/* Hacemos que el enlace que contiene número + estrellas sea inline-flex para que no salte línea */
.rating-link {
  display: inline-flex;
  align-items: center;
  gap: 0.5rem;
  white-space: nowrap; /* evita que el número y las estrellas se quiebren en distintas líneas */
  text-decoration: none;
  color: inherit;
}

/* El número no debe forzar salto: ajustar min-width si es necesario */
.rating-value {
  font-weight: 700;
  font-size: 0.95rem;
  min-width: 2.2rem; /* si te sigue provocando salto, reduce o elimina esta regla */
  text-align: left;
  flex: none; /* evita que crezca/encoga inesperadamente */
}

/* Stars */
.stars {
  display: inline-flex;
  gap: 4px;
  align-items: center;
  line-height: 1;
}

/* Cada estrella y área clickeable */
.star-btn { padding: 2px 4px; display: inline-flex; align-items: center; }
.star {
  font-size: 18px;
  line-height: 1;
  display: inline-block;
  --fill: 0%;
  background: linear-gradient(90deg, gold var(--fill), #cfcfcf var(--fill));
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
  user-select: none;
  cursor: pointer;
  vertical-align: middle;
}

/* Si quieres que las estrellas solo lectura no muestren cursor pointer */
.star.read-only { cursor: default; }









/*========================================= 
        MENUS PARA REPORTAR HISTORIAS 
===========================================*/

/* Botón menú — encima de la imagen, top-right */
.thumb-menu {
  position: absolute;      /* asume que .thumb ya es relative (si no, funciona sobre otro ancestro posicionado) */
  top: 8px;
  right: 8px;
  z-index: 30;
  display: inline-block;
}

/* botón visible, tamaño y estilo propio, no toca clases existentes */
.thumb-menu-button {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 36px;
  height: 36px;
  border-radius: 8px;
  border: none;
  background: rgba(0,0,0,0.55);
  color: #fff;
  cursor: pointer;
  font-size: 18px;
  line-height: 1;
  padding: 0;
  box-shadow: 0 2px 6px rgba(0,0,0,0.35);
}

/* pequeños ajustes visuales (dot icon) */
.thumb-menu-button .hamburger-dots {
  transform: translateY(-1px);
}

/* Popup menú — oculto por defecto */
.thumb-menu-popup {
  position: absolute;
  right: 0;
  top: calc(100% + 8px);
  min-width: 160px;
  background: var(--background-color-2);
  color: var(--text-color-2);
  border-radius: 8px;
  box-shadow: 0 6px 18px rgba(0,0,0,0.25);
  padding: 6px;
  display: none; /* mostrado vía JS toggle */
  z-index: 40;
}

/* ítems del menú */
.thumb-menu-item {
  display: block;
  width: 100%;
  text-align: left;
  padding: 8px 10px;
  border: none;
  background: transparent;
  cursor: pointer;
  font-size: 14px;
  color: inherit;
  border-radius: 6px;
}
.thumb-menu-item:hover,
.thumb-menu-item:focus {
  background: rgba(0,0,0,0.06);
  outline: none;
}

/* Responsivo: botón más grande en pantallas pequeñas */
@media (max-width: 480px) {
  .thumb-menu-button {
    width: 42px;
    height: 42px;
    font-size: 20px;
  }
  .thumb-menu-popup {
    min-width: 140px;
    right: 4px;
    top: calc(100% + 6px);
  }
}

/* ---- Modal global ---- */
.modal-overlay {
  position: fixed;
  inset: 0;
  display: none; /* toggled via JS */
  align-items: center;
  justify-content: center;
  background: rgba(0,0,0,0.55);
  z-index: 1000;
  padding: 24px;
}

.modal-overlay.active { display: flex; }

.modal-content {
  background: var(--background-color-2);
  border-radius: 10px;
  width: 100%;
  max-width: 740px;
  box-shadow: 0 10px 30px rgba(0,0,0,0.3);
  padding: 18px;
  position: relative;
}

.modal-header { font-weight: 700; margin-bottom: 8px; color: var(--theme-color-3); }
.modal-body { margin-bottom: 12px; }
.modal-body label {
    color: var(--text-color-2);
}
.modal-actions { text-align: right; }

.modal-close {
  position: absolute;
  top: 10px;
  right: 10px;
  border: none;
  background: transparent;
  font-size: 18px;
  cursor: pointer;
  color: var(--text-color);
}

/* botones */
.btn {
  display: inline-block;
  padding: 8px 12px;
  border-radius: 6px;
  border: none;
  cursor: pointer;
}
.btn-primary { background: #2563eb; color: #fff; }
.btn-secondary { background: #f3f4f6; color: #111; margin-right:8px; }







/*========================================= 
                OTROS ELEMENTOS
===========================================*/

/* linea de espaceado */
.linea-espaceado {
  border-top: 1px solid var(--linea);
  margin: 24px 0px;
}




/* Color label */
.label {
    color: var(--text-color-2);
}




/*  Iconos  */
.icon-mrg {
    margin-left: 5px;
}



/*  Links de redireccion  */
.link {
    color: var(--link-color);
}

.link:hover {
    color: var(--link-color-hover);
}


.common-title.titulo-patreon h2 {
    color: var(--theme-color-4);
}

.contenido-patreon p {
    color: var(--text-color);
    font-size: 30px;
}


/*  Responsividad Detalle Historias  */
@media (max-width: 1199px) {
    .blog-card-4 .content {
        padding: 24px 30px 26px 30px;
    }
}

@media (max-width: 480px) {
    .blog-card-4 .content .blog-info {
        display: inline-grid;
    }
}
