Upgrade to Pro — share decks privately, control downloads, hide ads and more …

CSS3 for Responsive Web Design (full day worksh...

Andy Clarke
March 18, 2015

CSS3 for Responsive Web Design (full day workshop) 2015

This workshop’s not all talk as you’ll work with practical, everyday examples of responsive Web designs and see them working across a range of devices from mobile phones to desktops and everything in between. You’ll walk away with a full set of resources and example files too.

In just one day, Andy will teach you how to:

- Use table display properties to rearrange content
- Create cross-browser layouts using Flexible Box Layout (Flexbox)
- Improve typography with Multi-column Layout
- Make the most of tiny bitmaps with border images
- Use transformations and transitions

Andy Clarke

March 18, 2015
Tweet

More Decks by Andy Clarke

Other Decks in Design

Transcript

  1. Modern layout foundations
 Flexible Boxes (Flexbox) and table display properties

    
 Modules and content components
 Advanced Flexbox for content and functionality 
 Responsive typography
 Units, columns, shapes and masks 
 Responsive design details Border images, filters and blends Today’s schedule
  2. CSS Grid Layout Module
 Grid by Example simple usage examples

    by Rachel Andrew http://gridbyexample.com What we won’t cover
  3. Three ingredients for responsive web design A flexible grid Flexible

    images and media CSS3 media queries And a whole lot more
  4. Modern layout is about proportions, not pixels Hecton 1.73205 Golden

    1.61803 Hemiolon 1.5 Bipenton 1.458 Diagon 1.41421 Penton 1.27201 Biauron 1.23606 Quadriagon 1.2071 Trion 1.1547 Hermidiagon 1.11803 Source: Gridset
  5. Drawbacks of traditional CSS layout Complicated maths Vertical centering Float

    drops Float clearing Same height columns Shrink-to-fit containers Source order dependence
  6. .container { display : flex; // display : inline-flex; }

    Apply flex to a container Flexible Box Layout
  7. .container { display : flex; flex-direction : row; /* default

    */ } // row, row-reverse, column, column-reverse Set the flex direction Flexible Box Layout
  8. .container { display : flex; flex-direction : row; flex-wrap :

    nowrap; /* default */ } Rows and columns Flexible Box Layout
  9. .container { display : flex; flex-flow : row nowrap; }

    Rows and columns Flexible Box Layout
  10. <body class="layout-flex-2col"> <div class="container"> <header role="banner" class="flex-banner">…<header> <div class="main">…</div> <aside

    class="aside—1">…</aside> <footer role="contentinfo">…</footer> 
 </div> </body> Two-column Flexbox layout Flexible Box Layout
  11. .container { display : flex; 
 } [role="banner"], [role="contentinfo"], aside

    { /* All children have equal size inside a container */ flex-grow : 1;
 /* The default size before any remaining space is distributed */ flex-basis : 100%; 
 } Two-column Flexbox layout Flexible Box Layout
  12. @media (min-width: 48em) { .main {
 /* Take three times

    the available space as other siblings */ flex : 3;
 /* The default size before any remaining space is distributed */ flex-basis : 1px; } aside {
 /* Take one unit of available space */ flex : 1; 
 /* The default size before any remaining space is distributed */
 flex-basis : 1px; } } Two-column Flexbox layout Flexible Box Layout
  13. .box--one { flex : 1; 
 } .box--two { flex

    : 1; 
 } .box--three { flex : 1; 
 } Flex-grow Flexible Box Layout .box { /* All children have equal size */ flex : 1; 
 }
  14. Flex-grow Flexible Box Layout 1 1 1 The ability for

    a flex item to grow if necessary and dictates the amount 
 of available space an item should take.
  15. .box--one { flex : 1; 
 } .box--two { /*

    Take twice the available space as other siblings */ flex : 2; 
 } .box--three { flex : 1; 
 } Flex-grow Flexible Box Layout
  16. Flex-grow Flexible Box Layout 1 1 2 The ability for

    a flex item to grow if necessary and dictates the amount 
 of available space an item should take.
  17. .container { width : 700px; } .box--one { flex-grow :

    1; flex-basis : 200px; /* 33px added */ } .box--two { flex-grow : 1; flex-basis : 200px; /* 33px added */ } .box--three { flex-grow : 1; flex-basis : 200px; /* 33px added */ } Flex-basis Flexible Box Layout
  18. Flex-basis Flexible Box Layout .container { width : 700px; }

    .box--one { flex-grow : 1; flex-basis : 200px; /* 25px added */ } .box--two { flex-grow : 2; flex-basis : 200px; /* 50px added */ } .box--three { flex-grow : 1; flex-basis : 200px; /* 25px added */ }
  19. Flex Flexible Box Layout .container { width : 700px; }

    .box--one { flex : 1 200px; /* 25px added */ } .box--two { flex : 2 200px; /* 50px added */ } .box--three { flex : 1 200px; /* 25px added */ }
  20. <body class="layout-flex-3col"> <div class="container"> <header role="banner" class="flex-banner">…</header> <div class="main">…</div> <aside

    class="aside—1">…</aside>
 <aside class="aside—2">…</aside> <footer role="contentinfo">…</footer> 
 </div> </body> Three-column Flexbox layout Flexible Box Layout
  21. 1 2 3 Order Flexible Box Layout Controls the order

    in which items appear visually in a flex container.
  22. Flex-direction Flexible Box Layout 3 2 1 Right to left

    in ltr layouts, left to right in rtl layouts.
  23. Order Flexible Box Layout 2 1 3 Controls the order

    in which items appear visually in a flex container.
  24. <body class="layout-flex-3col-variant"> <div class="container"> <header role="banner" class="flex-banner">…</header> <div class="main">…</div> <aside

    class="aside—1">…</aside>
 <aside class="aside—2">…</aside> <footer role="contentinfo">…</footer> 
 </div> </body> Three-column Flexbox layout Flexible Box Layout
  25. [role="banner"] { order : 1; } .main { order :

    3; } .aside--1 { order : 2; } .aside--2 { order : 4; } [role="contentinfo"] { order : 5; } Three-column Flexbox layout Flexible Box Layout
  26. [role="banner"] { order : 1; } .main { order :

    4; } .aside--1 { order : 3; } .aside--2 { order : 2; } [role="contentinfo"] { order : 5; } Three-column Flexbox layout Flexible Box Layout
  27. When is Flexbox appropriate? 11 30 27 23 6.1 1

    4.4 7.1 1 37 Flexible Box Layout 1 Supported with -webkit- prefix
  28. Legacy browser implementations Flexible Box Layout 10 2012 syntax with

    -ms- prefix 5.1 Old syntax with -webkit- prefix 7 Old syntax with -webkit- prefix 4.4 Old syntax with -webkit- prefix
  29. Legacy Flexbox syntax Flexible Box Layout .container { display :

    -webkit-box; display : -moz-box; display : -ms-flexbox; display : -webkit-flex; display : flex; 
 } .container { display : -webkit-flex; display : flex; 
 }
  30. Legacy Flexbox Sass mixin Flexible Box Layout @mixin flexbox() {

    display : -webkit-box; display : -moz-box; display : -ms-flexbox; display : -webkit-flex; display : flex; } @mixin flex($values) { -webkit-box-flex : $values; -moz-box-flex : $values; -webkit-flex : $values; -ms-flex : $values; flex : $values; } .container { @include flexbox(); 
 } .box { @include flex(1 200px); 
 }
  31. Modernizr Flexbox Isolate Flexbox compatible and non-compatible files Modernizr adds

    flexbox, no-flexbox, and flexboxlegacy classes .no-flexbox .container { /* styles */ } Flexible Box Layout
  32. When is Flexbox appropriate? Flexible Box Layout CSS performance test:

    Flexbox v CSS Table
 http://benfrain.com/css-performance-test-flexbox-v-css-table-fight/
  33. Table properties Display table layout display : table
 Defines element

    as a block-level table 
 display : table-caption
 Treats element as a caption for the table 
 (caption-side : top | bottom | inherit) 
 display : table-row
 An element represents a row of cells 
 display : table-cell An element represents a table cell
  34. Table properties Display table layout display : table-header-group
 A row

    group always displayed before all other rows 
 and row groups and after any top captions 
 display : table-footer-group
 A row group always displayed after all other rows and row groups and after any bottom captions 
 display : table-row-group
 One or more rows of cells
  35. table-row An ‘anonymous’ box created by applying display:table-row to an

    element 
 display : table
 An ‘anonymous’ box created by applying display:table to an element
  36. <body class="table-1"> <header role="banner" class="flex-banner">…</header> <div class="content-group"> <div class="content">…</div> <nav

    role="navigation">…</nav>
 </div> <footer role="contentinfo">…</footer> </body> Content first Display table layout
  37. @media (min-width : 48em) { .content { display : table-footer-group;

    } [role="navigation"] { display : table-header-group; }
 } } Content first Display table layout
  38. Skip to navigation Display table layout <body class="table-1">
 <a href="#navigation">Menu</a>

    <header role="banner" class="flex-banner">…</header> <div class="content-group"> <div class="content">…</div> <nav role="navigation" id="navigation">…</nav>
 </div> <footer role="contentinfo">…</footer> </body>
  39. Skip to navigation Display table layout a[href="#navigation"] { 
 display

    : block; 
 } @media (min-width : 48em { a[href="#navigation"] { 
 display : none; } }
  40. Two-column display-table layout Display table layout <body class="table-2"> <header role="banner"

    class="flex-banner">…</header>
 <div class="content-group">
 <div class="content"> <div class="main">…</div> <aside class="aside-1">…</aside>
 </div>
 </div> <footer role="contentinfo">…</footer> </body>
  41. Two-column display-table layout Display table layout @media (min-width : 62em

    { .content, .aside-1 { display : table-cell; } .main { width : 65%; } .aside-1 { width : 35%; } }
  42. Creating columns Display table layout @media (min-width : 62em {

    .commerce-item { float : left; width : 33%; }
 }
  43. Creating columns Display table layout @media (min-width : 62em {

    .commerce-item { display : table-cell; width : 33%; }
 }
  44. Align-items Display table layout .content {
 align-items : flex-start; 


    } flex-start: Items placed on the cross axis start line
  45. Align-items Display table layout .content {
 align-items : flex-end; 


    } flex-end: Items placed on the cross axis end line
  46. Align-items Display table layout .content {
 align-items : stretch; /*

    default value */
 } stretch (default): items stretch to fill container height
  47. Align-items Flexible Box Layout Starts on baseline Starts on baseline

    Starts on baseline cross axis main axis baseline: items aligned so that their baselines match
  48. Align-items Display table layout .content {
 align-items : baseline; 


    } baseline: items aligned so that their baselines match
  49. Justify-content Display table layout .content {
 justify-content : flex-start; 


    } flex-start: Items placed on the main axis start line
  50. Justify-content Flexible Box Layout space-between: Items distributed in the line;

    first item on the start line, last on the end cross axis main axis
  51. Justify-content Display table layout .content {
 justify-content : space-between; 


    } space-between: Items distributed in the line; first item on the start line, last on the end
  52. Justify-content Flexible Box Layout main axis cross axis space-around: Items

    distributed in the line with equal space around them
  53. Justify-content Display table layout .content {
 justify-content : space-around; 


    } space-around: Items distributed in the line with equal space around them
  54. Align-content Display table layout .content {
 align-content : flex-start; 


    } flex-start: lines placed at the start of the container
  55. Align-content Display table layout .content {
 align-content : flex-end; 


    } flex-end: lines placed at the end of the container
  56. Align-content Flexible Box Layout cross axis cross axis center: lines

    placed at the center of the container main axis
  57. Align-content Display table layout .content {
 align-content : center; 


    } center: lines placed at the center of the container
  58. Align-content Flexible Box Layout cross axis cross axis stretch (default):

    lines stretch to fill container height main axis
  59. Align-content Display table layout .content {
 align-content : stretch; /*

    default value */
 } stretch (default): lines stretch to fill container height
  60. Align-content Flexible Box Layout cross axis cross axis space-between: Lines

    distributed in the container; first item on the start line, last on the end main axis
  61. Align-content Display table layout .content {
 align-content : space-between; 


    } space-between: Lines distributed in the container; first item on the start line, last on the end
  62. Align-content Flexible Box Layout cross axis cross axis main axis

    space-around: Lines distributed in the container with equal space around them
  63. Align-content Display table layout .content {
 align-content : space-around; 


    } space-around: Lines distributed in the container with equal space around them
  64. Align-self Flexible Box Layout cross axis cross axis main axis

    align-self: Overrides for individual flex items
  65. Align-items Display table layout .content { /* auto | flex-start

    | flex-end | center | baseline | stretch */
 align-self : flex-end; 
 } align-self: Overrides for individual flex items
  66. Media modules Modules and components <div class="flex-media"> 
 <div class="flex-media__figure">

    <img src="media__img.png -->" alt=""> </div> <div class="flex-media__content"> <p>…</p> </div>
 </div>
  67. Media modules Modules and components .flex-media { display : flex;

    } .flex-media__figure { margin-right : 22px; } .flex-media__content { flex : 1; }
  68. Media modules Modules and components .flex-media { display : flex;

    } .flex-media__figure { margin-right : 22px; } .flex-media__content { flex : 1; } Use the Web Inspector to add: .media--reverse, .media--center and .media--bottom to .flex-media
  69. Store items Modules and components .flex-commerce-media-items { display : flex;

    } .commerce-media-item { flex : 1; } Use the Web Inspector to add: .media--reverse, .media--center and .media--bottom to .flex-media
  70. Store items Modules and components Use the Web Inspector to

    add align-items : flex-end; to the flex-media__figure element
  71. Pinning buttons Modules and components <div class="flex-commerce-media-items"> 
 <div class="commerce-media-item">…</div>

    <div class="commerce-media-item">…</div> <div class="commerce-media-item">…</div> </div>
  72. Pinning buttons Modules and components <div class="commerce-media-item"> <div class="flex-media__figure">…</div> <div

    class="flex-media__content"> <h3 class="item__header">…</h3> <p>…</p> <a href="" class="item__button">Buy now</a> </div> </div>
  73. Pinning buttons Modules and components .flex-commerce-media-items { display : flex;

    
 flex-wrap : wrap; } .commerce-media-item { flex : 1; } .flex-media__content { display : flex; flex-direction : column; } .item__button { margin-top : auto; }
  74. Figures and captions Modules and components @media (min-width : 64em)

    { .flex-figure { display : flex; } .flex-figure img { flex : 2 0 320px; } .flex-figure figcaption { flex : 1; } } Use the Web Inspector to add: .figure--reverse, .figure--center, 
 .figure--bottom and figure--alt to .flex-figure
  75. Use the Web Inspector to add: .figure--reverse, .figure--center, 
 .figure--bottom

    and figure--alt to .flex-figure Figures and captions Modules and components
  76. Superhero Modules and components @media (min-width : 37.5em) { .flex-hero

    { display : flex; align-items : center; justify-content : center; height : auto; min-height : 24em; } } Use the Web Inspector to add: .hero--top and .hero--bottom to .flex-hero
  77. Centered banner Modules and components <header role="banner" class="flex-banner"> <div class="banner__logo">

    <img src="banner__logo.png" alt=""> </div> <nav role="navigation"> <ul class="banner__list">…</ul> </nav> </header>
  78. Centered banner Modules and components .banner__logo { text-align : center;

    } @media (min-width : 37.5em) { .banner__list { display : flex; justify-content : space-between; } }
  79. Centered banner Modules and components @media (min-width : 48em) {

    .banner__list { transform : translateY(-130px); } #link-one { margin-right : 22px; } #link-three { margin-left : auto; } #link-four { margin-left : 22px; }
 }
  80. Flexbox pagination Modules and components <ul class="flex-pagination"> <li><a href="">Previous</a></li> <li><a

    href="">1</a></li> <li><a href="">2</a></li> <li><a href="">3</a></li> <li><a href="">4</a></li> <li><a href="">5</a></li> <li><a href="">6</a></li> <li><a href="">Next</a></li> </ul>
  81. Flexbox pagination Modules and components .flex-pagination { display : flex;

    flex-wrap : wrap; justify-content : space-between; } .flex-pagination li { order : 2; display : inline-block; }
  82. Flexbox pagination Modules and components .flex-pagination li:first-child { order :

    0; width : 50%; text-align : left; } .flex-pagination li:last-child { order : 1; width : 50%; text-align : right; }
  83. Medium screens without Flexbox Medium screens display : flex; Large

    screens display : flex; Flexbox pagination Modules and components
  84. Flexbox pagination Modules and components @media (min-width : 48em) {

    .flex-pagination li { order : 0; } .flex-pagination li:first-child { order : 0; width : auto; text-align : center; } .flex-pagination li:last-child { order : 0; width : auto; text-align : center; } }
  85. Flexible forms Modules and components <div class="flex-form"> <span class="flex-form__item">Name</span> <input

    class="flex-form__input"> </div> <div class="flex-form"> <input class="flex-form__input"> <a class="flex-form__item">Go</a> </div>
  86. Flexible forms Modules and components <div class="flex-form"> <span class="flex-form__item">www</span> <input

    class="flex-form__input"> <select class="flex-form__item"> <option>.com</option> <option>.co.uk</option> <option>.uk</option> </select> </div>
  87. Flexible forms Modules and components .flex-form { display : flex;

    flex-wrap : wrap; justify-content : space-between; } .flex-form__input { flex : 1; 
 }
  88. Flexible forms Modules and components <div class="flex-form-stretch"> <label>A long label

    that keeps expanding</label> <input type="text"> <button>Search</button> </div>
  89. vw
 Equal to 1% of the width of the viewport

    
 vh
 Equal to 1% of the height of the viewport 
 vmin
 Equal to either vw or vh, whichever is smaller 
 vmax Opposite behaviour to vmin Viewport width units Responsive typography
  90. Viewport width units Responsive typography h1 {
 font-size : 32px;

    
 font-size : 3.2rem; 
 font-size : 5.4vw; 
 }
  91. Sticky footer .layout-full {
 display : flex; min-height : 100vh;

    flex-direction : column; 
 } .layout-full .container { flex : 1; }
  92. Multiple column layout support 10 31 2 32 1 24

    1 5.1 1 2.3 1 7.1 1 37 1 Multiple column layout 1 Supported with -webkit- prefix 2 Supported with -moz- prefix
  93. Column properties Column count Column width Column span Break after

    Column gap Column rule Break before Multiple column layout
  94. Column width @media (min-width : 48em) { .content-cols { -webkit-column-width

    : 24em; -moz-column-width : 24em; column-width : 24em; } } Multiple column layout
  95. Column count @media (min-width : 48em) { .content-cols { -webkit-column-count

    : 2; -moz-column-count : 2; column-count : 2; } } Multiple column layout
  96. Columns @media (min-width : 48em) { .content-cols { -webkit-columns :

    2 24em; -moz-columns : 2 24em; columns : 2 24em; } } Multiple column layout
  97. Column gap @media (min-width : 48em) { .content-cols { -webkit-column-gap

    : 44px; -moz-column-gap : 44px; column-gap : 44px; } } Multiple column layout
  98. Column rule @media (min-width : 48em) { .content-cols { column-rule-width

    : 3px; column-rule-style : double; 
 column-rule-color : #e3e2e0; } 
 } -moz- and -webkit- prefixes are also required Multiple column layout
  99. Columnised lists @media (min-width : 37.5em) { .sidebar ul {

    column-count : 2; column-gap : 48px; } } @media (min-width : 48em) { .sidebar ul { column-count : 1; } } Multiple column layout
  100. Columnised captions @media (min-width : 37.5em) { .cols-figure figcaption {

    column-count : 2; column-gap : 44px; } } Multiple column layout
  101. Spanning columns <div class="columns"> <p>...</p> <figure class="column__span" >...</figure> <p>...</p> <h2

    class="column__span">Ape-o-nauts?</h2> ... </div> Multiple column layout Column-span is not supported in Firefox
  102. Spanning breaks .columns h2 { break-before : column; break-after :

    avoid-column; 
 } Multiple column layout
  103. .shapes__circle { /* Content will wrap around a shape */

    shape-outside : circle ( ); } CSS shapes Responsive design details .shapes__circle { /* Content contained within a shape. May not be implemented */ shape-inside : circle ( ); }
  104. CSS shapes Responsive design details circle () ellipse () inset

    () polygon () Each shape is defined by a set of points.
  105. Conditions for use Responsive design details Floated left or right

    
 A shapes element must be floated to enable content 
 to wrap around it. 
 Intrinsic size
 Intrinsic size (height and width dimensions) needed to establish a coordinate system on the element; the system will be used to position the shape functions’ points on the element. The intrinsic size doesn’t have to be set using absolute values (e.g pixels), you can use percentages, which means that the shaped element can be fully responsive.
  106. .shapes__circle { float : left; height : 200px; width :

    200px; shape-outside : circle ( ); } CSS shapes Responsive design details
  107. . shapes__circle { float : left; height : 200px; width

    : 200px; shape-outside : circle ( );
 shape-margin : 22px; } CSS shapes Responsive design details The content-box and padding-box keywords are optional
  108. . shapes__ellipse { float : left; height : 250px; width

    : 200px; shape-outside : ellipse ( );
 } CSS shapes Responsive design details
  109. Responsive design details Inset shape . shapes__inset { float :

    left; height : 200px; width : 300px; shape-outside : inset ( );
 }
  110. Responsive design details Polygon shape . shapes__polygon { float :

    left; height : 200px; width : 250px;
 background : url(polygon.png) 100% 100%; clip-path: polygon(99.67px -3.00px, 117.08px 19.87px,…);
 shape-outside: polygon(99.67px -3.00px, 117.08px 19.87px…); } }
  111. Responsive design details Image shape Browser uses the alpha channel

    of an image to extract a shape. 
 Shape is computed to be the path that encloses the area where the opacity of the specified image is greater than the ‘shape-image-threshold’ value. When shape-image-threshold is not specified, the initial value to be considered is 0.5.
  112. Responsive design details Image shape An image should be CORS

    (Cross-Origin Resource Sharing.) Image has to be an image with an alpha channel, not a luminance channel. Luminance masks/images won’t be used and will have no effect
  113. Responsive design details Image shape . shapes__img { float :

    left; height : 200px; width : 250px;
 background : url(ship.png); shape-outside : url(ship-mask.png); shape-image-threshold : .5; } }
  114. Source set attribute <img src="ursus.png" srcset=" [email protected] 1.5x, /* 300px

    */ [email protected] 2x, /* 400px */ [email protected] 3x" /* 600px */ width="200px" alt="General Ursus"> Responsive images
  115. Sizes attribute <img src="ursus.png" srcset=" ursus-small.png 200w, ursus-medium.png 400w, ursus-large.png

    600w" sizes="(max-width : 30em) 100vw, (max-width : 48em) 50vw" alt="General Ursus"> Responsive images
  116. Resolution switching <img src="ursus.png" srcset=" ursus-small.png 200w, ursus-medium.png 400w, ursus-large.png

    600w, [email protected] 200w 2x" sizes="(max-width : 30em) 100vw, (max-width : 48em) 50vw" alt="General Ursus"> Responsive images
  117. 32 1 34 24 7.1 8 37 1 Not enabled

    by default but can be enabled in about:config Source set Responsive images
  118. CSS3 for responsive web design © Stuff & Nonsense 2014

    Responsive design details Part four
  119. Border images Responsive design details .hero__image { border-image-slice : 33

    43 33 43; border-image-source : url(hero__image.png); } .hero__image { border-image : url(hero__image.png) 33 43 33 43; } .hero__image { border-image : url(hero__image.png) 33 43; border-width : 33px 43px; }
  120. Border images Responsive design details .html { border-image-repeat : repeat

    /* top */ repeat /* right */ repeat /* bottom */ repeat /* left */ ;}
  121. Stretch
 Stretches slice areas to fill horizontally or vertically 


    Repeat
 Repeats slice areas to fill horizontally or vertically 
 Round
 Resizes a slice so that only whole pieces fit when repeating 
 Space Repeats whole slice pieces and adds space to fill a border evenly Border images Responsive design details
  122. color color-burn color-dodge darken difference exclusion hard-light hue lighten luminosity

    multiply overlay saturation soft-light screen Background blends Responsive design details
  123. Background blends Responsive design details Mix blend mode
 Specifies how

    an element will mix its colors with those 
 of others it overlaps in the ‘background.’ Mixing and the isolation property 
 Background blend mode
 Specifies how an element will mix the colour of its own background image and background color.
  124. .hero { position : relative;
 } .hero:before { content :

    ""; position : absolute; top : 0; right : 0; 
 bottom : 0; left : 0; background-color : #fbd996; mix-blend-mode: difference; 
 } Mix blend mode Responsive design details
  125. .hero__lead { mix-blend-mode : exclusion; 
 } .hero__action { mix-blend-mode

    : hard-light; 
 } Background blend mode Responsive design details
  126. Use the Web Inspector to change the mix-blend-mode property: color

    color-burn color-dodge darken saturation soft-light screen difference exclusion hard-light hue lighten luminosity multiply overlay
  127. .blend {
 background-color : #396d7f;
 background-image : 
 url(bg-waves-front.png), 


    url(bg-ship.png), 
 url(bg-waves-back.png), 
 url(bg-sky.png);
 background-blend-mode : difference;
 } Background blend mode Responsive design details
  128. Use the Web Inspector to change the background-blend-mode property: color

    color-burn color-dodge darken saturation soft-light screen difference exclusion hard-light hue lighten luminosity multiply overlay
  129. normal Use the Web Inspector to change the background-blend-mode property:

    color color-burn color-dodge darken saturation soft-light screen difference exclusion hard-light hue lighten luminosity multiply overlay
  130. Use the Web Inspector to change the background-blend-mode property: color

    color-burn color-dodge darken saturation soft-light screen difference exclusion hard-light hue lighten luminosity multiply overlay
  131. Use the Web Inspector to change the background-blend-mode property: color

    color-burn color-dodge darken saturation soft-light screen difference exclusion hard-light hue lighten luminosity multiply overlay
  132. color-burn Use the Web Inspector to change the background-blend-mode property:

    color color-burn color-dodge darken saturation soft-light screen difference exclusion hard-light hue lighten luminosity multiply overlay
  133. Use the Web Inspector to change the background-blend-mode property: color

    color-burn color-dodge darken saturation soft-light screen difference exclusion hard-light hue lighten luminosity multiply overlay
  134. Use the Web Inspector to change the background-blend-mode property: color

    color-burn color-dodge darken saturation soft-light screen difference exclusion hard-light hue lighten luminosity multiply overlay
  135. .blend {
 background-color : #396d7f;
 background-image : 
 url(bg-waves-front.png), 


    url(bg-ship.png), 
 url(bg-waves-back.png), 
 url(bg-sky.png);
 background-blend-mode : difference;
 } Background blend mode Responsive design details
  136. Use the Web Inspector to change the background-blend-mode property: color

    color-burn color-dodge darken saturation soft-light screen difference exclusion hard-light hue lighten luminosity multiply overlay
  137. .blend { background-position : 5% 200px, 100% 20px, 2% 140px,

    0px 0px, 100% -200px; } Background blend mode Responsive design details
  138. Use the Web Inspector to change the background-blend-mode property: color

    color-burn color-dodge darken saturation soft-light screen difference exclusion hard-light hue lighten luminosity multiply overlay
  139. Filter effects support 31 1 24 1 6.1 1 4.4

    1 7.1 1 371 Responsive design details 1 Supported with -webkit- prefix 2 Support from Firefox 35 (January 2015) 35 2
  140. Combining filters Responsive design details .donthatetimvandamme { -webkit-filter : 


    contrast(1.5) drop-shadow(20px 20px 20px black); filter : 
 contrast(1.5) drop-shadow(20px 20px 20px black); }
  141. Transform support 9 31 31 1 36 24 5.1 1

    2.3 1 7.1 1 37 Some more things 1 Supported with -webkit- prefix
  142. Scale
 Stretches slice areas to fill horizontally or vertically 


    Translate
 Moves an element horizontally and vertically 
 Rotate
 Rotates an element 
 Skew Distorts an element horizontally and vertically Transforms Some more things
  143. ‘Escape from the Planet of the Apes’, is a 1971

    science fiction film starring 
 Roddy McDowall, Kim Hunter and Ricardo Montalbán. It’s the third of five
 films in the original Planet of the Apes series. The film was well
 received, getting the best reviews of the four Planet of the Apes 
 sequels. Despite ‘Beneath the Planet of the Apes’ ending in 
 it prevented the series from moving on, 20th Century 
 Fox wanted a sequel, so producer Arthur P. Jacobs 
 sent screenwriter Paul Dehn a telegram that 
 read “Apes exist, Sequel required.” 
 Production was rushed due to its low 
 budget and was filmed in only 
 six weeks. ‘Escape from the 
 Planet of the Apes’ begins by 
 establishing that three apes; 
 Cornelius, Zira and Dr. Milo, escaped 
 Earth’s destruction by salvaging and 
 repairing the astronaut Taylor’s spaceship.
  144. ‘Escape from the Planet of the Apes’, is a 1971

    science fiction film starringRoddy McDowall, Kim Hunter and Ricardo Montalbán. It’s the third of five films in the original Planet of the Apes series. The film was well received, getting the best reviews of the four Planet of the Apes sequels. Despite ‘Beneath the Planet of the Apes’ ending in it prevented the series from moving on, 20th Century Fox wanted a sequel, so producer Arthur P. Jacobs sent screenwriter Paul Dehn a telegram that read “Apes exist, Sequel required.” Production was rushed due to its low budget and was filmed in only six weeks. ‘Escape from the Planet of the Apes’ begins by establishing that three apes; Cornelius, Zira and Dr. Milo, escaped Earth’s destruction by salvaging and repairing the astronaut Taylor’s spaceship.
  145. Transition support 10 31 32 24 5.1 1 6.1 2.3

    1 4.4 7.1 37 Some more things 1 Supported with -webkit- prefix
  146. Transition property Some more things .donthatetimvandamme { transition-property : opacity,

    color; } .donthatetimvandamme { transition-property : all; }