/* ===== Directorio de Iniciativas Ciudadanas ===== */

/* Grid de tarjetas */
.dic-grid {
	display: grid;
	gap: 24px;
	margin: 24px 0;
}
.dic-grid-cols-1 { grid-template-columns: 1fr; }
.dic-grid-cols-2 { grid-template-columns: repeat(2, 1fr); }
.dic-grid-cols-3 { grid-template-columns: repeat(3, 1fr); }
.dic-grid-cols-4 { grid-template-columns: repeat(4, 1fr); }

@media (max-width: 900px) {
	.dic-grid-cols-3,
	.dic-grid-cols-4 { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 600px) {
	.dic-grid-cols-2,
	.dic-grid-cols-3,
	.dic-grid-cols-4 { grid-template-columns: 1fr; }
}

/* Tarjeta individual */
.dic-card {
	display: flex;
	flex-direction: column;
	border: 1px solid #e2e2e2;
	border-radius: 10px;
	overflow: hidden;
	background: #fff;
	box-shadow: 0 1px 4px rgba(0,0,0,.06);
	transition: transform .15s ease, box-shadow .15s ease;
}
.dic-card:hover {
	transform: translateY(-3px);
	box-shadow: 0 6px 18px rgba(0,0,0,.10);
}
.dic-card-imagen {
	display: block;
}
.dic-card-imagen img {
	width: 100%;
	height: 180px;
	object-fit: cover;
	display: block;
}
.dic-card-imagen-placeholder {
	width: 100%;
	height: 180px;
	background: linear-gradient(135deg, #f0f0f0, #e0e0e0);
}
.dic-card-contenido {
	padding: 16px;
	display: flex;
	flex-direction: column;
	flex: 1;
}
.dic-card-titulo {
	margin: 0 0 8px;
	font-size: 1.35rem;
	line-height: 1.25;
}
.dic-card-titulo a {
	text-decoration: none;
	color: inherit;
}
.dic-card-descripcion {
	flex: 1;
	margin-bottom: 14px;
	font-size: .92rem;
	color: #444;
	line-height: 1.5;
}
.dic-card-boton {
	align-self: center;
	padding: 8px 16px;
	border-radius: 6px;
	background: #1a73e8;
	color: #fff !important;
	text-decoration: none;
	text-align: center;
	font-size: .9rem;
}
.dic-card-boton:hover { background: #1558b8; }

/* Paginación */
.dic-paginacion {
	margin: 20px 0;
	display: flex;
	gap: 6px;
	flex-wrap: wrap;
}
.dic-paginacion .page-numbers {
	padding: 6px 12px;
	border: 1px solid #ddd;
	border-radius: 4px;
	text-decoration: none;
}
.dic-paginacion .page-numbers.current {
	background: #1a73e8;
	color: #fff;
	border-color: #1a73e8;
}

.dic-sin-resultados {
	padding: 16px;
	background: #f7f7f7;
	border-radius: 6px;
}

/* Formulario de envío */
.dic-formulario-wrapper { max-width: 560px; }
.dic-formulario .dic-campo {
	margin-bottom: 16px;
	display: flex;
	flex-direction: column;
}
.dic-formulario label {
	font-weight: 600;
	margin-bottom: 6px;
}
.dic-formulario input[type="text"],
.dic-formulario input[type="url"],
.dic-formulario textarea,
.dic-formulario input[type="file"] {
	padding: 10px;
	border: 1px solid #ccc;
	border-radius: 6px;
	font-size: .95rem;
}
.dic-honeypot { display: none !important; }

.dic-boton-enviar {
	padding: 10px 22px;
	background: #1a73e8;
	color: #fff;
	border: none;
	border-radius: 6px;
	cursor: pointer;
	font-size: .95rem;
}
.dic-boton-enviar:hover { background: #1558b8; }

/* Mensajes de estado */
.dic-mensaje {
	padding: 12px 16px;
	border-radius: 6px;
	margin-bottom: 16px;
	font-size: .92rem;
}
.dic-mensaje-exito { background: #e6f4ea; color: #1e7e34; border: 1px solid #b7e1c2; }
.dic-mensaje-error { background: #fdecea; color: #b71c1c; border: 1px solid #f5c2c0; }
.dic-mensaje-aviso { background: #fff8e1; color: #8a6d00; border: 1px solid #ffe08a; }
