Ratio Tokens » CSS Variables
$ratio-var-prefix (string)
$ratio-var-prefix: 'ratio-' !default;Set a prefix for all ratio-tokens,
and we’ll apply it when setting or calling CSS variables
based on your ratio maps.
Set to null or '' (empty string) for no prefix.
Since 2.0.0:
        - NEW: Initial release
Example
tools.$ratios: ('my-ratio': 0.875);
tools.$ratio-var-prefix: 'prefix_';
html { @include tools.ratios--; }html {
  --prefix_my-ratio: 0.875;
}@mixin ratios--()
Convert any ratio-map into CSS variables,
using the global $ratio-var-prefix.
- Ratio names that start with _or-are considered “private” and will not be output as variables
- Ratios that contain a simple alias with no adjustments
will be output with a var()value, keeping the alias relationship intact
Since 2.0.0:
        - NEW: Initial release
Parameters & Output
$source: $ratios (map)
Optionally use a custom map of ratios to set as CSS variables
{CSS output} (code block)
Custom properties for all public ratios in the map
Example
tools.$ratios: (
  'my-golden': 1.61803399,
  'line-height': '#_major-third',
);
html {
  @include tools.ratios--;
}html {
  --ratio-my-golden: 1.61803399;
  --ratio-line-height: 1.25;
}@mixin ratio--()
Set a single custom property based on a ratio token, with optional alias and fallback
Since 2.0.0:
        - NEW: Initial release
Parameters
$ratio: (*)
Ratio name available in the $source map,
or alias to use in naming the CSS variable
$value: null (string | null)
Optional value for the variable,
if different from the given $ratio
$fallback: true (*)
The optional fallback value for a var() function:
- truewill generate a fallback based on the token value
- A token name will fallback to the value of that CSS variable and then to the token’s calculated value
- Any other fallback will be passed through unchanged
$source: $ratios (map)
Optional map of ratios to use as a palette source
Example
tools.$ratios: (
  'my-golden': 1.61803399,
  'line-height': '#_major-third',
);
.example {
  @include tools.ratio--('my-golden');
  @include tools.ratio--('gutter', 'line-height', 1.4em);
}.example {
  --ratio-my-golden: 1.61803399;
  --ratio-gutter: var(--ratio-line-height, 1.4em);
}@function var-ratio()
Access the CSS variable associated with a given token, along with a fallback value based on the token itself
Since 2.0.0:
        - NEW: Initial release
Parameters & Return
$ratio: (*)
Ratio name available in the $source map
$fallback: true (*)
The optional fallback value for a var() function:
- truewill generate a fallback based on the token value
- A token name will fallback to the value of that CSS variable and then to the token’s calculated value
- Any other fallback will be passed through unchanged
$source: (map)
Optional Accoutrement map of ratios to use as source
@return (string)
CSS variable call, in the format:
var(--<token>, <fallback>)
Example
tools.$ratios: (
  'my-golden': 1.61803399,
  'line-height': '#_major-third',
);
.example {
  line-height: tools.var-ratio('line-height');
  padding-bottom: calc(1 / #{tools.var-ratio('my-golden', 1.6)} * 100%);
}.example {
  line-height: var(--ratio-line-height, 1.25);
  padding-bottom: calc(1 / var(--ratio-my-golden, 1.6) * 100%);
}