🔹 Card-mod - Add css styles to any lovelace card

A bit later I will review our old badge styling (which we discussed 1-2 months ago) with the new "--ha-label-badge-label-color" method.
Regarding your flickering - I myself facing some problems on my setup like “loosing a style” - sometimes a style is not applied, it works after refreshing a page. Cannot explain it((.

Card-mod v3.0 is not working

The following is not working for me:

type: markdown
content: '## Hello'
card_mod:
  style: |
    ha-card {
      background: transparent;
      text-align: center;
    }

But the syntax from prior to card-mod v3.0 still works:

type: markdown
content: '## Hello'
style: |
  ha-card {
    background: transparent;
    text-align: center;
  }

I uninstalled and re-installed card-mod in HACS, and it still only responds to pre- v3.0 syntax. I’m at a loss.

Searching for days but can’t find a solution. Is it possible to change the icon on a state?

card:
  type: horizontal-stack
  cards:
    - type: entity
      entity: media_player.samsung_tv_remote
      icon: 'mdi:monitor'
      style: |
        ha-card {
          --state-icon-color: {% if is_state('media_player.samsung_tv_remote', 'on') %} #50A14F {% else %} #5591c2 {% endif %};
          }
      name: TV living```

Cannot check "background" but "text-align" works:

type: vertical-stack
title: >-
  card-mod 2 vs card-mod 3
cards:
  - type: markdown
    content: |-
      text text text text text text
      text text text text text text
    card_mod:
      style: |
        ha-card {
          text-align: center;
        }
  - type: markdown
    content: <h1>Example</h1><h2>Hello</h2><h3>World</h3>
    style: |
      ha-card {
        text-align: center;
      }

изображение

That’s 100% a caching issue.
Make sure your browser console says you’re using card-mod 3.
Otherwise, try this: https://github.com/thomasloven/hass-config/wiki/Lovelace-Plugins#clearing-cache

Styling stock Media player card

Colored player’s name & icon:
изображение

Code
type: media-control
entity: media_player.kodi_rpi_1
style:
  .player:
    .top-info: |
      .icon-name {
        color: red;
      }   

Colored player’s name:
изображение

Code
type: media-control
entity: media_player.kodi_rpi_1
style:
  .player:
    .top-info: |
      .icon-name div {
        color: red;
      }   

Colored player’s icon:
изображение

Code
type: media-control
entity: media_player.kodi_rpi_1
style:
  .player:
    .top-info: |
      .icon-name ha-state-icon {
        color: red;
      }   

Colored movie’s title:
изображение

Code
type: media-control
entity: media_player.kodi_rpi_1
style:
  .player: |
    .title-controls .media-info {
      color: red;
    }   

Colored music album’s title & artist (different colors):
Note: the upper style (red) will be used for movie’s title too.
изображение

Code
type: media-control
entity: media_player.kodi_rpi_1
style:
  .player: |
    .title-controls .media-info {
      color: red;
    }
    hui-marquee {
      color: green;
    }   

Colored “more-info” button:
изображение

Code
type: media-control
entity: media_player.kodi_rpi_1
style:
  .player:
    .top-info: |
      .more-info {
        color: red;
      }   

Colored bottom buttons:
изображение

Code
type: media-control
entity: media_player.kodi_rpi_1
style:
  .player: |
    .title-controls .controls {
      color: red;
    }   

Colored botom control buttons:
изображение

Code
type: media-control
entity: media_player.kodi_iiyama
card_mod:
  style:
    .player: |
      .title-controls .controls ha-icon-button:not(.browse-media) {
        color: red;
      }   

Colored “power” button:
изображение

Code
type: media-control
entity: media_player.kodi_iiyama
card_mod:
  style:
    .player: |
      .title-controls .controls ha-icon-button:nth-child(1) {
        color: red;
      }   

Colored botom control buttons (different colors):
изображение

Code
type: media-control
entity: media_player.kodi_iiyama
card_mod:
  style:
    .player: |
      .title-controls .controls ha-icon-button:nth-child(1) {
        color: cyan;
      }   
      .title-controls .controls ha-icon-button:nth-child(2) {
        color: green;
      }   
      .title-controls .controls ha-icon-button:nth-child(3) {
        color: red;
      }   
      .title-controls .controls ha-icon-button:nth-child(4) {
        color: magenta;
      }   

Colored “browse media” button:
изображение

Code
type: media-control
entity: media_player.kodi_rpi_1
style:
  .player: |
    .browse-media {
      color: red;
    }   

Colored progress-bar:
изображение

Code
type: media-control
entity: media_player.kodi_iiyama
card_mod:
  style: |
    .player mwc-linear-progress {
      --mdc-theme-primary: magenta !important;
      --mdc-linear-progress-buffer-color: cyan !important;
    }   

Colored background:
When a media with a defined cover art is played, then the "background-color" is automatically set dependingly on the cover:
image
Otherwise a standard color is displayed (also when the player is idle):
image
How to change the color:
image
image

Code
type: media-control
entity: media_player.kodi_iiyama
card_mod:
  style: |
    .background.no-image > * {
      background-color: cyan;
    }   

More examples are described here.

3 Likes

Thanks for the wiki resource. The ?v=n version trick worked in this case for me.

Styling History Graph card:

Warning: at least in 2023.7 styling the card is very UNSTABLE.


Colored title:
изображение

Code
type: history-graph
entities:
  - entity: sun.sun
    name: Sun
  - entity: binary_sensor.net_is_available_internet
    name: Internet
hours_to_show: 8
refresh_interval: 0
title: Colored title
card_mod:
  style: |
    ha-card {
      --ha-card-header-color: red;
    }

More formats for a title:
изображение

Code
type: history-graph
entities:
  - entity: sun.sun
    name: Sun
  - entity: binary_sensor.net_is_available_internet
    name: Internet
hours_to_show: 8
refresh_interval: 0
title: >-
  The quick brown fox jumps over the lazy dog The quick brown fox jumps over the
  lazy dog The quick brown fox jumps over the lazy dog The quick brown fox jumps
  over the lazy dog
card_mod:
  style: |
    .card-header {
      color: red;
      font-size: 10px;
      line-height: 1.2;
    }

Colored legend:

Code
type: history-graph
entities:
  - entity: sensor.xiaomi_cg_1_co2
  - entity: sensor.xiaomi_cg_2_co2
  - entity: sensor.xiaomi_cg_1_temperature
hours_to_show: 8
refresh_interval: 0
title: Colored legend
card_mod:
  style:
    .content state-history-charts $:
      div:
        state-history-chart-line $ ha-chart-base $: |
          .chart-legend li {
            color: red !important;
          }

Update 21.09.22: the code above may not work in MacOS & iOS 15.x, use this code (works in Win, iOS 15.x, MacOS):

Code
card_mod:
  style:
    state-history-charts $ .entry-container:nth-child(n):
      state-history-chart-line $ ha-chart-base $: |
        .chart-legend li {
          color: red !important;
        }

Colored legend (different colors):

Code
type: history-graph
entities:
  - entity: sensor.xiaomi_cg_1_co2
  - entity: sensor.xiaomi_cg_2_co2
  - entity: sensor.xiaomi_cg_1_temperature
hours_to_show: 8
refresh_interval: 0
title: Colored legend (different colors)
card_mod:
  style:
    .content state-history-charts $:
      div:nth-child(1):
        state-history-chart-line $ ha-chart-base $: |
          .chart-legend li {
            color: red !important;
          }
      div:nth-child(2):
        state-history-chart-line $ ha-chart-base $: |
          .chart-legend li {
            color: orange !important;
          }

Update 21.09.22: the code above may not work in MacOS & iOS 15.x, use this code (works in Win, iOS 15.x, MacOS):

Code
card_mod:
  style:
    state-history-charts $ .entry-container:nth-child(1):
      state-history-chart-line $ ha-chart-base $: |
        .chart-legend li {
          color: red !important;
        }
    state-history-charts $ .entry-container:nth-child(2):
      state-history-chart-line $ ha-chart-base $: |
        .chart-legend li {
          color: orange !important;
        }

Colored legend (different colors for different sensors):

Code
type: history-graph
entities:
  - entity: sensor.xiaomi_cg_1_co2
  - entity: sensor.xiaomi_cg_2_co2
  - entity: sensor.xiaomi_cg_1_temperature
hours_to_show: 8
refresh_interval: 0
title: Colored legend (different colors)
card_mod:
  style:
    .content state-history-charts $:
      div:nth-child(1):
        state-history-chart-line $ ha-chart-base $: |
          .chart-legend li:nth-child(1) {
            color: red !important;
          }
          .chart-legend li:nth-child(2) {
            color: cyan !important;
          }
      div:nth-child(2):
        state-history-chart-line $ ha-chart-base $: |
          .chart-legend li {
            color: magenta !important;
          }

Update 21.09.22: the code above may not work in MacOS & iOS 15.x, use this code (works in Win, iOS 15.x, MacOS):

Code
    card_mod:
      style:
        state-history-charts $ div:nth-child(1):
          state-history-chart-line $ ha-chart-base $: |
            .chart-legend li:nth-child(1) {
              color: red !important;
            }
            .chart-legend li:nth-child(2) {
              color: cyan !important;
            }
        state-history-charts $ div:nth-child(2):
          state-history-chart-line $ ha-chart-base $: |
            .chart-legend li {
              color: magenta !important;
            }

Colored header: unit & legend (different colors):
Note: does not work since HA 2021.7.

Obsolete code
type: history-graph
entities:
  - entity: sensor.cleargrass_1_co2
  - entity: sensor.cleargrass_2_co2
  - entity: sensor.cleargrass_1_temp
hours_to_show: 8
refresh_interval: 0
title: Colored header (different colors)
style:
  .content state-history-charts:
    $:
      'state-history-chart-line:nth-child(1)':
        $:
          ha-chart-base:
            $: |
              .chartHeader .chartTitle {
                color: red;
              }
              .chartHeader .chartLegend {
                color: cyan;
              }
      'state-history-chart-line:nth-child(2)':
        $:
          ha-chart-base:
            $: |
              .chartHeader {
                color: orange;
              }
              .chartHeader .chartLegend {
                color: magenta;
              }

Hiding legend:

Code
type: history-graph
entities:
  - entity: sensor.xiaomi_cg_1_co2
  - entity: sensor.xiaomi_cg_2_co2
  - entity: sensor.xiaomi_cg_1_temperature
hours_to_show: 8
refresh_interval: 0
title: Hidden legend
card_mod:
  style:
    .content state-history-charts $:
      div:
        state-history-chart-line $ ha-chart-base $: |
          .chart-legend {
            display: none;
          }

Update 21.09.22: the code above may not work in MacOS & iOS 15.x, use this code (works in Win, iOS 15.x, MacOS):

Code
    card_mod:
      style:
        state-history-charts $ div:nth-child(n):
          state-history-chart-line $ ha-chart-base $: |
            .chart-legend {
              display: none;
            }

Tooltip: colored text:
Note: does not work since HA 2021.7.
изображение

Obsolete code
type: history-graph
entities:
  - entity: sensor.cleargrass_1_co2
  - entity: sensor.cleargrass_2_co2
  - entity: sensor.cleargrass_1_temp
hours_to_show: 8
refresh_interval: 0
title: Tooltip (text)
style:
  .content state-history-charts:
    $:
      state-history-chart-line:
        $:
          ha-chart-base:
            $:
              '#chartTarget div': |
                .chartTooltip {
                  color: orange;
                  font-size: 10px;
                }
                .chartTooltip .title {
                  color: red;
                  font-size: 20px;
                }

изображение

Obsolete code
type: history-graph
entities:
  - entity: sun.sun
    name: Sun
  - entity: binary_sensor.net_is_available_internet
    name: Internet
hours_to_show: 8
refresh_interval: 0
title: Tooltip (text)
style:
  .content state-history-charts:
    $:
      state-history-chart-timeline:
        $:
          ha-chart-base:
            $:
              '#chartTarget div': |
                .chartTooltip {
                  color: orange;
                  font-size: 10px;
                }
                .chartTooltip .title {
                  color: red;
                  font-size: 20px;
                }
                .chartTooltip .beforeBody {
                  color: cyan;
                 font-size: 15px;
                }

Tooltip: changed background:
Note: does not work since HA 2021.7.
изображение

Obsolete code
type: history-graph
entities:
  - entity: sensor.cleargrass_1_co2
  - entity: sensor.cleargrass_2_co2
  - entity: sensor.cleargrass_1_temp
hours_to_show: 8
refresh_interval: 0
title: Tooltip (text)
style:
  .content state-history-charts:
    $:
      state-history-chart-line:
        $:
          ha-chart-base:
            $:
              '#chartTarget div': |
                .chartTooltip {
                  background-color: rgba(0,0,255,0.7);
                }

изображение

Obsolete code
type: history-graph
entities:
  - entity: sun.sun
    name: Sun
  - entity: binary_sensor.net_is_available_internet
    name: Internet
hours_to_show: 8
refresh_interval: 0
title: Tooltip (background)
style:
  .content state-history-charts:
    $:
      state-history-chart-timeline:
        $:
          ha-chart-base:
            $:
              '#chartTarget div': |
                .chartTooltip {
                  background-color: rgba(0,0,255,0.7);
                }

Colored scale:
(05.01.25: may be not persistent)

Code
type: vertical-stack
cards:
  - type: history-graph
    entities:
      - entity: sun.sun
        name: Sun
      - entity: binary_sensor.net_is_available_internet
        name: Internet
    hours_to_show: 8
    refresh_interval: 0
    title: Colored scale
    card_mod:
      style: |
        .content {
          --secondary-text-color: red !important;
          --divider-color: cyan !important;
        }
  - type: history-graph
    entities:
      - entity: sensor.xiaomi_cg_1_co2
        name: CO2
    hours_to_show: 8
    refresh_interval: 0
    title: Colored scale
    card_mod:
      style: |
        .content {
          --secondary-text-color: red !important;
          --divider-color: cyan !important;
          
        }

More examples are described here.

5 Likes

I am using card-mod 3 and I converted all of my style: keys to be underneath the new card_mod: key. Everything works fine EXCEPT when I’m using the Home Assistant iOS app and off-network via Home Assistant Cloud to view my dashboard. Under this condition, all of the new card_mod: styles are not taking affect at all. I can revert one or more of them back to the old method, Save, Reload, and those styles return.

Again, this is only happening on the iOS app via Home Assistant Cloud (nabu case). When I’m on-net it works fine. On my desktop browser, it works both on-net and via Cloud.

Anybody else having this issue?

It’s caching.

1 Like

I can revert one or more of them back to the old method, Save, Reload, and those styles return. Edit it back to new method, they break again. Does caching save between versions of the dashboard?

Caching is caused by your browser. Google “how to clear cache [however you view ha]”.

Okay, reset Front End cache worked. You probably mean its caching the old version of card-mod.

Reset the frontend cache in the iOS app. I don’t see any issues with the app and card mod 3 and I reworked all my cards for the new syntax yesterday. They all work fine.

Yep that did it. Didn’t consider caching because it worked when on-network, only broke when I turned off wifi to enable HA Cloud. Wierd. Thanks for the help @KTibow and @DavidFW1960.

Honestly the whole caching thing is a bitch on iOS. I can delete all website data in the Chrome app and it will still load the old card until I reset the frontend cache in the app which should not be related anyway.
I also find on my PC chrome I need to go to dev-tools and then right click refresh and select empty cache and hard reload and then do a CTRL+F5 TWICE before everything will work reliably and properly. I thought the point of using HACS and a non-caching endpoint for resources was supposed to prevent this kind of BS…

Although I believe, that this mod only styles cards, I’m still interested, is it possible to use it somehow to style the background of the dashboard… I would like to use this script, can it be done in any way?

That script uses JS, and creates additional elements, both of which card-mod cannot do on its own.

Thought so, thx for reply :slight_smile: .

I would like to be able to change the font size of everything in the Lovelace dashboard that uses font-size: var(--paper-font-body1_-_font-size); to a font size of 24px. If I have to use card-mod for every single entity I am fine with that but I am unable to get card-mod to override font-size: var(--paper-font-body1_-_font-size);

First I attempted formatting just one of the entities in an entities card. Then I tried formatting the whole entities card. Neither attempt was successful.

Here is one of my attempts

type: entities
entities:
  - entity: sensor.samjin_water_75430b01_temperature
    card_mod:
      style: |
        :host {
          font-size: 24px;
          }  
  - entity: sensor.inovelli_unknown_type_000d_id_0001_temperature
  - entity: switch.smartswitch_on_off

Here is another attempt

type: entities
card_mod:
  style: |
    ha-card {
    font-size: 24px;
    }
entities:
  - entity: sensor.samjin_water_75430b01_temperature
  - entity: sensor.inovelli_unknown_type_000d_id_0001_temperature
  - entity: switch.smartswitch_on_off

Am I formatting the card incorrectly in both attempts? Is there something different I should be doing if I want all of the fonts that use font-size: var(--paper-font-body1_-_font-size); to be set to 24px?

I have multiple Lovelace dashboards and only want one of them to have all fonts that use font-size: var(--paper-font-body1_-_font-size); to have 24px so I don’t want to adjust a theme unless I need to make a new theme and have just this dashboard use the adjusted theme.

edit: I had a test dashboard and the first example started to work at some point. I’m not sure when or why since I haven’t been visiting the page. I have now applied the setting to my Wallmount dashboard. It’s pretty nice.