Is this a Safari bug or am I doing something wrong?
Check out this CodePen in Safari vs Chrome and Firefox: https://codepen.io/mattaningram/pen/zWVxzR
Or run code snippet below:
.item {
--itemColor: 200, 0, 0;
--itemColorHex: #C80000;
width: 50vw;
height: 50vh;
background-color: rgba( var(--itemColor), 1 );
-webkit-box-shadow: 0 0 15px 10px rgba( var(--itemColor), .5 );
box-shadow: 0 0 15px 10px rgba( var(--itemColor), .5 );
/* box-shadow: 0 0 15px 10px var(--itemColorHex); THIS WORKS */
/* color: rgba( var(--itemColor), .5 ); BOX-SHADOW INHERITS THIS PROPERLY IF UNCOMMENTED */
}
.wrapper {
height: 100vh;
width: 100vw;
display: flex;
align-items: center;
justify-content: center;
}
<div class="wrapper">
<div class="item"></div>
</div>
In Safari the box-shadow renders as black (it should be red) with no alpha. This does work if you don't use rgba
(see commented out box-shadow
line).
Oddly Safari inspect element recognizes the CSS call and is able to identify the CSS custom property value:
Even stranger is that if you set the color
(text color) property of the item to the custom property the box-shadow inherits it and it works (sadly in my actual implementation I need multiple box-shadows so this doesn't fix my issue).
It's a Safari bug: https://bugs.webkit.org/show_bug.cgi?id=185940
The only way to make custom properties work in box-shadow, is to put the whole color into variable
.item {
--color: rgba(200, 0, 0, 0.5);
box-shadow: 0 0 10px var(--color);
}
Edit: looks like it is fixed since Safari 13.0.3
I have got a solution to your problem, if you simply add variable color in box shadow then it won't work in Safari browser. However by doing some manipulation in code, you can do it easily.
Here are few steps to do..
Select any root color in RGB value.
:root { --color: 130, 16, 253; }
Add same color but with some opacity to root for box shadow. Here is a trick you are using one variable in another --shadowColor variable.
:root { --color: 130, 16, 253; --shadowColor: 0px 10px 50px 0px rgba(var(--color), 0.08); }
Apply color and box shadow to any object.
.feature_box { color: rgba(var(--color), 1); -webkit-box-shadow: var(--shadowColor); box-shadow: var(--shadowColor); }
Enjoy:)
If you love us? You can donate to us via Paypal or buy me a coffee so we can maintain and grow! Thank you!
Donate Us With