body { font-family: Arial, sans-serif; background: #f4f4f4; overflow-x: hidden; }
body.modal-aviso-activo { overflow: hidden; }
.demandas-main { margin: 0 auto; padding: 24px; width: 98%; box-sizing: border-box; }
.barra-demandas-ciudadanas { margin-top: 10px; width: 90%; margin-left: auto; margin-right: auto; display: flex; align-items: center; justify-content: space-between; padding: 12px 24px 12px 24px; border: 1px solid #ddd; border-radius: 8px; background: #fff; box-shadow: 0 2px 8px #eee; box-sizing: border-box; }
.btn-volver-demanda { display: flex; align-items: center; gap: 8px; border: 1px solid transparent; background: transparent; cursor: pointer; font-size: 1.1em; padding: 8px 18px; transition: box-shadow 0.2s, background 0.2s, border-color 0.2s; outline: none; color: #222; position: relative; z-index: 1; box-sizing: border-box; }
.btn-volver-demanda:hover, .btn-volver-demanda:focus { background: #f0a4a4; border-color: #a19e9e; box-shadow: 0 2px 8px #c5c5c5; }
.voto-favor, .voto-contra, .demanda-responder-btn { border: none !important; background: none !important; outline: none; }
.demandas-grid { display: flex; flex-wrap: wrap; gap: 24px; justify-content: center; align-items: stretch; width: 100%; }
.demanda-card { background: #fff; border: 1px solid #ddd; border-radius: 8px; box-shadow: 0 2px 8px #eee; padding: 16px; width: 340px; cursor: pointer; transition: box-shadow .2s; display: flex; flex-direction: column; height: 100%; min-height: 340px; box-sizing: border-box; }
.demanda-card:hover { box-shadow: 0 4px 16px #ccc; }
.demanda-fotos { display: flex; flex-wrap: wrap; align-content: flex-start; gap: 4px; }
.modulo-fotos-bloque { min-height: var(--modulo-fotos-bloque-height, 0px); }
.modulo-fotos-respuesta strong { display: block; width: 100%; margin-bottom: 5px; }
.demanda-fotos img { max-width: 120px; max-height: 120px; margin: 0; border-radius: 4px; }
.demanda-contenido { margin-top: 8px; flex: 1 1 auto; display: flex; flex-direction: column; min-height: 0; }
.demanda-usuario, .demanda-fecha { display: block; color: #888; font-size: 0.95em; margin-bottom: 4px; }
.modulo-meta-etiqueta { display: block; width: 100%; box-sizing: border-box; min-height: 0; min-height: var(--modulo-meta-etiqueta-height, 0px); text-align: left; }
.modulo-meta-bloque { display: flex; flex-direction: column; gap: 4px; min-height: 0; min-height: var(--modulo-meta-bloque-height, 0px); width: 100%; align-items: stretch; justify-content: flex-start; }
.modulo-meta-bloque .modulo-meta-etiqueta { margin-bottom: 0; }
.modulo-respuesta-bloque { min-height: 0; min-height: var(--modulo-respuesta-bloque-height, 0px); margin-top: 8px; flex-shrink: 0; display: flex; flex-direction: column; justify-content: flex-start; width: 100%; }
.demanda-texto { font-size: 1.1em; margin-bottom: 8px; }
.demanda-respuesta-admin { margin-top: 10px; padding: 8px 10px; border-left: 4px solid #2f7d32; background: #eef8ee; border-radius: 4px; color: #244b26; font-size: 0.96em; }
.demanda-fecha-respuesta { margin-top: 6px; }
.demanda-votos { margin-top: auto; margin-bottom: 10px; display: flex; gap: 16px; row-gap: 10px; flex-wrap: wrap; align-items: center; justify-content: flex-start; flex-shrink: 0; }
.demanda-responder-btn { margin-left: 16px; color: #555; cursor: pointer; font-size: 1em; }
.demanda-respuestas-total-num { font-weight: bold; color: #555; margin-left: 6px; }
.demanda-estado-indicador { display: inline-flex; align-items: center; justify-content: center; width: 15px; height: 15px; margin-left: 8px; border-radius: 3px; font-size: 10px; font-weight: 700; color: #fff; line-height: 1; }
.demanda-estado-indicador.estado-pendiente { background: #7b4a12; }
.demanda-estado-indicador.estado-respondido { background: #1f8f3a; }
.demanda-estado-indicador.estado-rechazado { background: #c62828; }
.modal-foto, .modal-comentario { position: fixed; top:0; left:0; width:100vw; height:100vh; z-index:99999; background:rgba(0,0,0,0.7); display:none; }
.modal-foto { overflow-y:auto; }
.modal-comentario { overflow-y:auto; padding:24px 16px; }
.modal-foto-contenido, .modal-comentario-contenido { background:#fff; margin:60px auto; padding:24px; border-radius:8px; max-width:600px; box-shadow:0 0 24px #0003; position:relative; }
.modal-foto-contenido { width:min(600px, calc(100vw - 32px)); max-height:calc(100vh - 48px); overflow-y:auto; }
.modal-comentario-contenido { width:min(600px, 100%); max-height:calc(100vh - 48px); overflow-y:auto; }
.cerrar-modal-foto, .cerrar-modal-comentario { position:absolute; top:16px; right:24px; font-size:2em; color:#888; cursor:pointer; background:transparent; border:none; }
.btn-guardar-respuesta { background:#dd1515; color:#fff; border:none; border-radius:4px; padding:8px 16px; margin-top:8px; cursor:pointer; font-size:1em; }
.btn-guardar-respuesta:hover { background:#a01111; }
.btn-guardar-respuesta.is-disabled-soft, .btn-guardar-respuesta[aria-disabled="true"] { background:#f0c7c7; color:#7a2727; cursor:not-allowed; box-shadow:inset 0 0 0 1px rgba(122,39,39,.18); }
.btn-guardar-respuesta.is-disabled-soft:hover, .btn-guardar-respuesta[aria-disabled="true"]:hover { background:#f0c7c7; color:#7a2727; }
.modal-aviso-formulario { position:fixed; inset:0; z-index:100000; display:flex; align-items:center; justify-content:center; padding:24px; background:rgba(15,23,42,.68); }
.modal-aviso-formulario.oculto { display:none; }
.modal-aviso-formulario-contenido { width:min(760px,100%); background:#fff; border-radius:18px; box-shadow:0 24px 60px rgba(0,0,0,.3); padding:28px; border-top:6px solid #dd1515; }
.modal-aviso-formulario-texto p { margin:0 0 14px 0; line-height:1.65; color:#374151; }
.modal-aviso-formulario-acciones { display:flex; justify-content:flex-end; margin-top:20px; }
.aviso-formulario-banner { margin-bottom:18px; padding:14px 16px; border-radius:10px; background:#f3f4f6; border:1px solid #d1d5db; color:#111827; }
.aviso-formulario-banner strong { display:block; margin-bottom:6px; }
.textarea-resaltada-wrap { position:relative; width:100%; }
.textarea-resaltada-backdrop { position:absolute; inset:0; z-index:1; border:1px solid #ced4da; border-radius:.375rem; padding:.375rem .75rem; background:#fff; color:#111; white-space:pre-wrap; overflow:hidden; word-break:break-word; pointer-events:none; line-height:1.5; font-size:1rem; font-family:inherit; }
.textarea-resaltada-backdrop mark { background:#fde68a; color:#111; border-radius:4px; padding:0 2px; }
.campo-texto-moderado textarea { position:relative; z-index:2; background:transparent; color:transparent; caret-color:#111; text-shadow:0 0 0 #111; }
.campo-texto-moderado textarea.campo-bloqueado-amarillo { border-color:#eab308; box-shadow:0 0 0 4px rgba(250,204,21,.22); }
.palabras-prohibidas-detectadas { display:none; gap:8px; flex-wrap:wrap; align-items:center; margin-top:10px; color:#92400e; }
.palabras-prohibidas-detectadas.visible { display:flex; }
.palabra-prohibida-chip { display:inline-flex; align-items:center; justify-content:center; padding:4px 10px; border-radius:999px; background:#fde68a; color:#78350f; font-weight:700; font-size:.9rem; }
.btn-guardar-respuesta.is-disabled-soft, .btn-guardar-respuesta[aria-disabled="true"] { background:#f0c7c7; color:#7a2727; cursor:not-allowed; box-shadow:inset 0 0 0 1px rgba(122,39,39,.18); }
.btn-guardar-respuesta.is-disabled-soft:hover, .btn-guardar-respuesta[aria-disabled="true"]:hover { background:#f0c7c7; color:#7a2727; }
.campo-texto-moderado-modal .textarea-resaltada-backdrop { color:transparent; border-color:transparent; }
.campo-texto-moderado-modal .textarea-resaltada-backdrop mark { color:transparent; background:#fde68a; }
.campo-texto-moderado-modal textarea.textarea-moderada-modal { color:#111; caret-color:#111; text-shadow:none; background:transparent; }
.demanda-hilo-comentario { border-bottom:1px solid #eee; padding:10px 0; }
.demanda-hilo-comentario:last-child { border-bottom:none; }
.demanda-hilo-cabecera { display:flex; align-items:center; gap:8px; flex-wrap:wrap; margin-bottom:6px; }
.demanda-hilo-fecha { color:#888; font-size:.9em; }
.demanda-hilo-ciudad { color:#555; font-size:.9em; }
.demanda-hilo-texto { color:#222; line-height:1.45; }
.demanda-hilo-responder { margin-left:auto; border:none; background:#f3f3f3; color:#444; border-radius:4px; padding:4px 10px; cursor:pointer; font-size:.9em; }
.demanda-hilo-responder:hover { background:#dd1515; color:#fff; }
.demanda-hilo-respuestas { margin-top:10px; margin-left:18px; padding-left:12px; border-left:3px solid #f0c7c7; display:flex; flex-direction:column; gap:8px; }
.demanda-hilo-respuesta { background:#fafafa; border:1px solid #eee; border-radius:6px; padding:8px 10px; }
.acciones-formulario-secundarias { display:flex; gap:30px; justify-content:flex-end; flex-wrap:wrap; margin-top:8px; }
.acciones-formulario-secundarias .btn-secundario,
.acciones-formulario-secundarias .enlace-boton.btn-secundario { background:#d9d9d9; color:#333; text-decoration:none; border:1px solid #bfbfbf; padding:8px 16px; font-size:1em; border-radius:4px; display:inline-flex; align-items:center; justify-content:center; }
.acciones-formulario-secundarias .btn-secundario:hover,
.acciones-formulario-secundarias .btn-secundario:focus,
.acciones-formulario-secundarias .enlace-boton.btn-secundario:hover,
.acciones-formulario-secundarias .enlace-boton.btn-secundario:focus { background:#c9c9c9; text-decoration:none; }
.noticias-pagination { margin-top: 24px; padding: 16px; display: flex; justify-content: center; gap: 12px; flex-wrap: wrap; align-items: center; background: #fff; border-radius: 16px; box-shadow: 0 2px 8px #eee; }
.noticias-pagination .noticias-page-btn,
.noticias-pagination .noticias-page-btn:hover,
.noticias-pagination .noticias-page-btn:focus,
.noticias-pagination .noticias-page-btn:focus-visible,
.noticias-pagination .noticias-page-btn:active,
.noticias-pagination .noticias-page-btn.is-active,
.noticias-pagination .noticias-page-btn[disabled] { border: 0 !important; background: transparent !important; box-shadow: none !important; outline: none !important; padding: 0 3px !important; border-radius: 0 !important; color: inherit !important; min-width: auto !important; height: auto !important; font-weight: 700; -webkit-appearance: none; appearance: none; }
.noticias-pagination .noticias-page-btn[disabled] { opacity: 0.55; }
@media (min-width: 1200px) {
    .demandas-grid {
        width: 92vw;
        margin-left: auto;
        margin-right: auto;
        justify-content: center;
    }

    .demanda-card {
        width: calc((92vw - 48px) / 3);
        max-width: calc((92vw - 48px) / 3);
    }
}
@media (max-width: 670px) { .modal-aviso-formulario-contenido { padding:20px; } .modal-aviso-formulario-acciones { justify-content:stretch; } .modal-aviso-formulario-acciones .btn-guardar-respuesta { width:100%; } .barra-demandas-ciudadanas { flex-direction: column; align-items: center; padding: 12px 8px 12px 8px; gap: 10px; text-align: center; } .barra-demandas-ciudadanas h2 { margin: 0; text-align: center; font-size: 1.2em; order: 2; width: 100%; display: flex; justify-content: center; } .btn-volver-demanda { justify-content: center; width: 100%; order: 1; margin-bottom: 8px; } .barra-demandas-ciudadanas .espaciador-barra { display: none; } .acciones-formulario-secundarias { flex-direction:column; gap:12px; } .acciones-formulario-secundarias .btn-guardar-respuesta, .acciones-formulario-secundarias .btn-secundario { width:100%; } .noticias-pagination { padding-left: 14px; padding-right: 14px; } }