- Does not include Patternlab, can be ported over easily
We follow Harry Robert's CSS Guidelines
- Try to extract things you see repeating over and over into classes so you can reuse them for the sake of speed. We use an [Expressive CSS](http://johnpolacek.github.io/expressive-css/ BEM-hybrid) approach: class names should be very descriptive and never abbreviated (ex.
.button
not.btn
). Follow BEM syntax but map to the property/value if only one style is captured. ex..text-align--center
,.position--relative
. Please review the_library.tools.scss
partial to see whats written and available for reuse.
config.
prefix denotes other files have dependencies on themlibrary.
prefix means file is basic, global styling and toolingmodule.
is a small block of code that is indivisibleobject.
is a collection of modules or a module and other elements
- See
_config.mediaqueries.scss
- We're using http://include-media.com/ to handle our media queries. Example usage:
@include media('>large') {
}
@include media('>=large') {
}
@include media('<large') {
}
- See
_library.spacing.scss
- We're using the lobotomized owl technique for vertical spacing, meaning you should rarely if ever have to add margin-top/margin-bottom on elements for spacing. Instead, please add a class of
.spacing
,.spacing--half
,.spacing--double
etc to the elements parents in order to create space between elements. If you have to add a parent div strictly for spacing, that is completely acceptable. - We use the variable
$padding
to keep spacing around objects consistent
- Built off Neat grids
- Starter grid is a 12 column grid with fixed 10px gutters (see
_config.grid.scss
). - Columns must be created with a
.layout-NNN
class. WhereNNN
is one offull
,split-2
,split-3
, orsplit-4
. Column percentages are expressed as.layout-split-2--25-75
where on desktop we expect a 2 column layout where the first column is 25% width and the second is 75% width. - To avoid
.layout-full > .column
you can just use.column-full
- Gutters are defined at a fixed width per column.
- Please use the
rem()
function for all units (see_config.map-fun.scss
), it will print a px fallback ex.font-size: rem(15);
- See Expressive CSS for Type and
_library.type-styles.scss
- Text styles should be defined once, captured in classes to be applied directly to the elements in the HTML, classes like
.type-alpha--xxl
- Text style classes should never be extended with
@extend
in Sass, in general, please do not use@extend