/* ============================================
   Variables globales
   ============================================ */

:root {
	/* Colores */
	--color-primary:    #003894;
	--color-secondary:  #FF1C23;
	--color-dark:       #191919;
	--color-body:       #191919;
	--color-border:     #f0f0f0;
	--color-bg-light:   #f8f9fa;

	/* Tipografía */
	--font-base:        1rem;       /* 16px */
	--font-sm:          0.875rem;   /* 14px */
	--font-lg:          1.25rem;    /* 20px */
	--font-h1:          2rem;       /* 32px */
	--font-h2:          1.5rem;     /* 24px */
	--font-h3:          1.2rem;     /* 19px */
	--line-height:      1.8;

	/* Espaciado */
	--spacing-page:     60px;
	--spacing-content:  860px;      /* max-width del contenido */
}


/* ============================================
   Layout de la página
   ============================================ */

.blocks-page {
	padding: var(--spacing-page) 0;
}

.blocks-container {
	max-width: var(--spacing-content);
	margin: 0 auto;
	padding: 0 24px;
}

.blocks-header {
	margin-bottom: 40px;
	padding-bottom: 24px;
	border-bottom: 2px solid var(--color-border);
}

.blocks-title {
	font-size: var(--font-h1);
	font-weight: 700;
	color: var(--color-dark);
	margin: 0;
}


/* ============================================
   Contenido
   ============================================ */

.blocks-content {
	font-size: var(--font-base);
	line-height: var(--line-height);
	color: var(--color-body);
}

.blocks-content h2 {
	font-size: var(--font-h2);
	font-weight: 700;
	margin-top: 2.5rem;
	margin-bottom: 1rem;
	color: var(--color-dark);
}

.blocks-content h3 {
	font-size: var(--font-h3);
	font-weight: 600;
	margin-top: 2rem;
	margin-bottom: 0.75rem;
	color: var(--color-dark);
}

.blocks-content p {
	margin-bottom: 1.25rem;
}

.blocks-content a {
	color: var(--color-primary);
	text-decoration: underline;
}

.blocks-content a:hover {
	color: var(--color-secondary);
}

.blocks-content ul,
.blocks-content ol {
	padding-left: 1.5rem;
	margin-bottom: 1.25rem;
}

.blocks-content li {
	margin-bottom: 0.5rem;
}


/* ============================================
   Bloques de Gutenberg
   ============================================ */

/* wp:separator */
.blocks-content .wp-block-separator {
	border: none;
	border-top: 2px solid var(--color-border);
	margin: 2rem 0;
}

/* wp:quote */
.blocks-content blockquote,
.blocks-content .wp-block-quote {
	border-left: 4px solid var(--color-primary);
	padding: 1rem 1.5rem;
	margin: 1.5rem 0;
	background: var(--color-bg-light);
	font-style: italic;
}

/* wp:table */
.blocks-content .wp-block-table table {
	width: 100%;
	border-collapse: collapse;
	margin-bottom: 1.5rem;
}

.blocks-content .wp-block-table td,
.blocks-content .wp-block-table th {
	border: 1px solid #ddd;
	padding: 10px 14px;
	text-align: left;
}

.blocks-content .wp-block-table th {
	background: var(--color-border);
	font-weight: 600;
}

/* wp:image */
.blocks-content .wp-block-image img {
	max-width: 100%;
	height: auto;
	border-radius: 4px;
}

/* wp:buttons */
.blocks-content .wp-block-button__link {
	background-color: var(--color-primary);
	color: #fff;
	padding: 12px 28px;
	border-radius: 4px;
	text-decoration: none;
	font-weight: 600;
	display: inline-block;
}

.blocks-content .wp-block-button__link:hover {
	background-color: var(--color-secondary);
	color: #fff;
}


/* ============================================
   Responsive
   ============================================ */

@media (max-width: 767px) {
	.blocks-page {
		padding: 40px 0;
	}

	.blocks-title {
		font-size: 1.5rem;
	}

	.blocks-content h2 {
		font-size: 1.25rem;
	}
}
