HELLO
MANDY
​MICHAEL
@mandy_kerr
@mandymichael
@mandy_kerr
div {
...
overflow: hidden;
}
OVERFLOW: HIDDEN
@mandy_kerr
h1 {
...
overflow: hidden;
text-overflow: ellipsis;
}
TEXT-OVERFLOW: ELLIPSIS
@mandy_kerr
TEXT-OVERFLOW: ELLIPSIS
@mandy_kerr
TEXT-OVERFLOW: ELLIPSIS
@mandy_kerr
VERTICAL ALIGNMENT: FLEXBOX - CENTRED
@mandy_kerr
div {
...
display: flex;
align-items: center;
}
VERTICAL ALIGNMENT: FLEXBOX - ROW
@mandy_kerr
div {
...
display: flex;
align-items: center;
flex-direction: row;
}
Cross Axis
Main Axis
VERTICAL ALIGNMENT: FLEXBOX - COLUMN
@mandy_kerr
div {
display: flex;
justify-items: center;
flex-direction: column;
}
Main Axis
Cross Axis
@mandy_kerr
div {
display: flex;
flex-direction: column;
justify-content: space-between;
}
VERTICAL ALIGNMENT: FLEXBOX - SPACE BETWEEN
@mandy_kerr
div {
display: flex;
align-items: flex-end;
}
VERTICAL ALIGNMENT: FLEXBOX - END
@mandy_kerr
div {
display: grid;
grid-gap: 20px;
grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
grid-auto-rows: minmax(150px, auto);
}
CSS GRID
@mandy_kerr
CSS GRID
@mandy_kerr
CSS SHAPES
.shape {
width: 100%;
height: 100%;
float: left;
shape-outside: polygon(0 0, 0% 100%, 50% 50%);
}
@mandy_kerr
CSS SHAPES
.shape {
width: 100%;
height: 100%;
float: left;
shape-outside: circle(50% at 0 50%);
}
REMOVE CONSTRAINTS
@mandy_kerr
@mandy_kerr
REMOVE CONSTRAINTS
VIEWPORT UNITS
@mandy_kerr
h1 {
...
font-size: 5vw;
}
VIEWPORT UNITS
@mandy_kerr
VARIABLE FONTS
@mandy_kerr
h1 {
font-family: "Dunbar";
font-variation-settings: "wght" 178, "xhgt" 353;
}
span {
font-variation-settings: "wght" 50, "xhgt" 574;
}
span + span {
font-variation-settings: "wght" 89.1875, "xhgt" 527.311;
}
VARIABLE FONTS
@mandy_kerr
FIRST LETTER
@mandy_kerr
h1::first-letter {
font-size: 150px;
font-family: 'Fata background';
font-weight: normal;
color: yellow;
}
TEXT DECORATION: SKIP
@mandy_kerr
h1 {
text-decoration: underline;
text-decoration-skip: ink;
text-decoration-color: rebeccapurple;
}
TEXT DECORATION: UNDER & OVER LINES
@mandy_kerr
h1 {
text-decoration: underline;
text-decoration-color: rebeccapurple;
text-decoration-line: overline underline;
}
TEXT DECORATION: WAVY & LINE-THROUGH
@mandy_kerr
h1 {
color: royalblue;
text-decoration-color: rebeccapurple;
text-decoration-style: wavy;
text-decoration-line: line-through;
}
@mandy_kerr
SHADOWS
@mandy_kerr
SHADOWS
div {
border-color: #f98ca4;
box-shadow:
0px 0px 0px 1px #2f3e9c,
8px 8px 0px 0px #4ad9db;
}
h1 {
color: #4ad9db;
text-shadow:
-1px -1px 0 #2f3e9c,
1px -1px 0 #2f3e9c,
-1px 1px 0 #2f3e9c,
1px 1px 0px #2f3e9c,
1px 0px 0px #f98ca4,
0px 1px 0px #f98ca4,
2px 1px 0px #f98ca4,
1px 2px 0px #f98ca4,
3px 2px 0px #f98ca4,
2px 3px 0px #f98ca4,
4px 3px 0px #f98ca4,
3px 4px 0px #f98ca4,
5px 4px 0px #f98ca4,
3px 5px 0px #2f3e9c,
6px 5px 0px #2f3e9c;
}
@mandy_kerr
SHADOWS
@mandy_kerr
div {
box-shadow:
-1px -1px 0 rgba(255, 255, 255, .7),
1px -1px 0 rgba(255, 255, 255, .7),
-1px 1px 0 rgba(255, 255, 255, .7),
1px 1px 0 rgba(255, 255, 255, .7),
-1px 2px 1px #a0a0a0,
-2px 4px 2px #a0a0a0,
-3px 6px 3px rgba(#a0a0a0, 0.6),
-4px 8px 4px rgba(#a0a0a0, 0.5),
-5px 10px 5px rgba(#a0a0a0, 0.4),
-6px 12px 6px rgba(#a0a0a0, 0.3),
-7px 13px 7px rgba(#a0a0a0, 0.2),
-8px 15px 8px rgba(#a0a0a0, 0.2),
-9px 17px 9px rgba(#a0a0a0, 0.2),
-10px 19px 10px rgba(#a0a0a0, 0.2),
-11px 20px 11px rgba(#a0a0a0, 0.1),
-12px 22px 12px rgba(#a0a0a0, 0.1),
-13px 24px 13px rgba(#a0a0a0, 0.1),
-14px 26px 14px rgba(#a0a0a0, 0.1),
-15px 28px 15px rgba(#a0a0a0, 0.1),
-16px 30px 16px rgba(#a0a0a0, 0.1),
-17px 32px 17px rgba(#a0a0a0, 0.1),
-18px 34px 18px rgba(#a0a0a0, 0.1),
-19px 36px 19px rgba(#a0a0a0, 0.1),
-20px 38px 20px rgba(#a0a0a0, 0.1),
-21px 39px 21px rgba(#a0a0a0, 0.1);
}
SHADOWS
ANIMATION WARNING
!
@mandy_kerr
ANIMATIONS
@mandy_kerr
ANIMATIONS
@keyframes disco {
0% { background: #ece914; }
20% { background: #f92727; }
40% { background: #3434ff; }
60% { background: #7bf927; }
80% { background: #11d8df; }
100% { background: #e41ed8; }
}
div {
animation-name: disco;
animation-timing: 1000ms;
animation-iteration-count: infinite;
animation-direction: alternate;
}
@mandy_kerr
BLEND MODES
body {
background-color: #ffff24;
background-image: url('image.png');
background-blend-mode: darken;
}
h1 {
color: #bcff00;
mix-blend-mode: color-dodge;
}
@mandy_kerr
BLEND MODES
@mandy_kerr
BLEND MODES
ANIMATION WARNING
!
@mandy_kerr
BLEND MODES
@mandy_kerr
@mandy_kerr
sibling selectors
:first-letter
matrix()
pseudo-elements
filters
currentColor
counters
columns
attr()
:nth-child
calc
custom properties
linear-gradient
border-radius
transitions
whitespace
:nth-of-type
background-size
background-position
scale
rotate
translate
skew
@supports
opacity
object-fit
will-change
quotes
rem
pointer-events
fr
hyphens
auto
:first-child
masking
floats
background-image
box-sizing
media queries
stroke
display: contents
:empty
@mandy_kerr
By Stacey Reiman @mspanish
THANK YOU
@mandy_kerr
@mandymichael
CSS is Awesome
By Mandy Michael
CSS is Awesome
- 2,225