uuid: - value: b86c14c0-4dfe-485e-bc8a-d18215ac85a7 langcode: - value: en type: - target_id: daily_email target_type: node_type target_uuid: 8bde1f2f-eef9-4f2d-ae9c-96921f8193d7 revision_timestamp: - value: '2025-05-11T09:00:00+00:00' revision_uid: - target_type: user target_uuid: b8966985-d4b2-42a7-a319-2e94ccfbb849 revision_log: { } status: - value: true uid: - target_type: user target_uuid: b8966985-d4b2-42a7-a319-2e94ccfbb849 title: - value: 'CSS variables everywhere' created: - value: '2025-03-08T00:00:00+00:00' changed: - value: '2025-05-11T09:00:00+00:00' promote: - value: false sticky: - value: false default_langcode: - value: true revision_translation_affected: - value: true path: - alias: /daily/2025/03/08/variables langcode: en body: - value: |

Now CSS supports variables (aka custom properties) and Tailwind CSS v4 is configured using CSS instead of JavaScript, I've been making heavy use of CSS variables in my front-end code.

I still use Tailwind to do the heavy lifting, but I can use CSS variables to extract themeable classes with variables like --color-primary that can change value based on a data attribute or by something else.

These variables can still use Tailwind's core variables by doing --color-primary: var(--color-red-500), rather than having to recreate all its colors, spacing or whatever variables I need to use.

Tailwind has a arbitrary syntax to easily use CSS variables - e.g. bg-(--color-primary) - and you can define one-off variables with [--box-spacing:30px] or [--box-spacing:--spacing(3)] and using the standard arbitrary class syntax.

CSS variables aren't specific to Tailwind CSS, so if I wasn't using Tailwind in a codebase, I'd use the new native CSS features instead of a preprocessor like Sass.

format: full_html processed: |

Now CSS supports variables (aka custom properties) and Tailwind CSS v4 is configured using CSS instead of JavaScript, I've been making heavy use of CSS variables in my front-end code.

I still use Tailwind to do the heavy lifting, but I can use CSS variables to extract themeable classes with variables like --color-primary that can change value based on a data attribute or by something else.

These variables can still use Tailwind's core variables by doing --color-primary: var(--color-red-500), rather than having to recreate all its colors, spacing or whatever variables I need to use.

Tailwind has a arbitrary syntax to easily use CSS variables - e.g. bg-(--color-primary) - and you can define one-off variables with [--box-spacing:30px] or [--box-spacing:--spacing(3)] and using the standard arbitrary class syntax.

CSS variables aren't specific to Tailwind CSS, so if I wasn't using Tailwind in a codebase, I'd use the new native CSS features instead of a preprocessor like Sass.

summary: null field_daily_email_cta: { }