From 102ce68d17338c905f890e5bce7965552326eef0 Mon Sep 17 00:00:00 2001 From: Nigel O'Toole Date: Wed, 21 Feb 2018 14:30:15 +0000 Subject: [PATCH] Add passive event listener and refine demo site styles --- index.html | 2 +- index.js | 2 +- package.json | 2 +- scripts/bundle.js | 2 +- scripts/bundle.js.map | 2 +- scripts/direction-reveal.js | 12 ++++++------ styles/direction-reveal.css | 24 +++++++++++++++++------- styles/direction-reveal.scss | 12 +++++++++--- styles/site.css | 17 ++++++++++++++--- styles/site/_site.scss | 20 +++++++++++++++----- 10 files changed, 66 insertions(+), 29 deletions(-) diff --git a/index.html b/index.html index 62739c0..9e9b9a1 100644 --- a/index.html +++ b/index.html @@ -484,7 +484,7 @@

Touch support

Browser support

-

Supports all modern browsers(Firefox, Chrome and Edge) released as of January 2018. For older browsers you may need to include polyfills for Nodelist.forEach and Element.classList.

+

Supports all modern browsers(Firefox, Chrome and Edge) released as of January 2018. For older browsers you may need to include polyfills for Nodelist.forEach, Element.classList and Passive Event Listeners.

diff --git a/index.js b/index.js index 6ec8490..aef53be 100644 --- a/index.js +++ b/index.js @@ -117,7 +117,7 @@ item.addEventListener('touchstart', function (e) { touchStart = +new Date(); - }); + }, { passive: true }); item.addEventListener('touchend', function (e) { var touchTime = +new Date() - touchStart; diff --git a/package.json b/package.json index 9b8c526..7bc7f46 100644 --- a/package.json +++ b/package.json @@ -1,7 +1,7 @@ { "name": "direction-reveal", "description": "Direction aware content reveals.", - "version": "1.3.0", + "version": "1.3.1", "main": "index.js", "module": "scripts/direction-reveal.js", "jsnext:main": "scripts/direction-reveal.js", diff --git a/scripts/bundle.js b/scripts/bundle.js index 89cb342..b4d5aa3 100644 --- a/scripts/bundle.js +++ b/scripts/bundle.js @@ -105,7 +105,7 @@ var DirectionReveal = function DirectionReveal() { item.addEventListener('touchstart', function (e) { touchStart = +new Date(); - }); + }, { passive: true }); item.addEventListener('touchend', function (e) { var touchTime = +new Date() - touchStart; diff --git a/scripts/bundle.js.map b/scripts/bundle.js.map index a3cfdd1..18da8fd 100644 --- a/scripts/bundle.js.map +++ b/scripts/bundle.js.map @@ -1 +1 @@ -{"version":3,"sources":["node_modules/browser-pack/_prelude.js","scripts/direction-reveal.js","scripts/main.js"],"names":[],"mappings":"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","file":"bundle.js","sourcesContent":["(function e(t,n,r){function s(o,u){if(!n[o]){if(!t[o]){var a=typeof require==\"function\"&&require;if(!u&&a)return a(o,!0);if(i)return i(o,!0);var f=new Error(\"Cannot find module '\"+o+\"'\");throw f.code=\"MODULE_NOT_FOUND\",f}var l=n[o]={exports:{}};t[o][0].call(l.exports,function(e){var n=t[o][1][e];return s(n?n:e)},l,l.exports,e,t,n,r)}return n[o].exports}var i=typeof require==\"function\"&&require;for(var o=0;o h ? (h / w) : 1));\n let y = (e.pageY - position.y - (h / 2) * (h > w ? (w / h) : 1));\n\n // Calculate the angle the pointer entered/exited and convert to clockwise format (top/right/bottom/left = 0/1/2/3). See https://stackoverflow.com/a/3647634 for a full explanation.\n let d = Math.round(Math.atan2(y, x) / 1.57079633 + 5) % 4;\n\n // console.table([x, y, w, h, e.pageX, e.pageY, item.offsetLeft, item.offsetTop, position.x, position.y]);\n\n return d;\n };\n\n\n // https://www.kirupa.com/html5/get_element_position_using_javascript.htm\n const getPosition = function (el) {\n let xPos = 0;\n let yPos = 0;\n\n while (el) {\n xPos += (el.offsetLeft + el.clientLeft);\n yPos += (el.offsetTop + el.clientTop);\n\n el = el.offsetParent;\n }\n return {\n x: xPos,\n y: yPos\n };\n }\n\n\n const translateDirection = switchcase({\n 0: 'top',\n 1: 'right',\n 2: 'bottom',\n 3: 'left'\n })('top');\n\n\n const addClass = function (e, state) {\n let currentItem = e.currentTarget;\n let direction = getDirection(e, currentItem);\n let directionString = translateDirection(direction);\n\n // Remove current animation classes and add new ones e.g. swap --in for --out.\n let currentCssClasses = currentItem.className.split(' ');\n let filteredCssClasses = currentCssClasses.filter((cssClass) => (!cssClass.startsWith(animationName))).join(' ');\n currentItem.className = filteredCssClasses;\n currentItem.classList.add(`${animationName}--${state}-${directionString}`);\n };\n\n\n const bindEvents = function (containerItem) {\n const items = containerItem.querySelectorAll(itemSelector);\n\n items.forEach((item) => {\n\n addEventListenerMulti(item, ['mouseenter', 'focus'], function(e) {\n addClass(e, 'in');\n });\n\n addEventListenerMulti(item, ['mouseleave', 'blur'], function(e) {\n addClass(e, 'out');\n });\n\n\n if (enableTouch) {\n\n item.addEventListener('touchstart', function(e) {\n touchStart = +new Date;\n });\n\n item.addEventListener('touchend', function(e) {\n let touchTime = +new Date - touchStart;\n\n if (touchTime < touchThreshold && !item.className.includes(`${animationName}--in`)) {\n e.preventDefault();\n\n resetVisible(e, items, addClass(e, 'in'));\n }\n });\n\n }\n\n });\n };\n\n const addEventListenerMulti = function (element, events, fn) {\n events.forEach((e) => element.addEventListener(e, fn));\n }\n\n\n const resetVisible = function (e, items, callback) {\n\n items.forEach((item) => {\n let currentCssClasses = item.className;\n\n if(currentCssClasses.includes(`${animationName}--in`) && item !== e.currentTarget) {\n item.className = currentCssClasses.replace(`${animationName}--in`, `${animationName}--out`);\n }\n });\n\n callback;\n };\n\n\n const init = function () {\n\n if (containers.length) {\n containers.forEach((containerItem) => {\n bindEvents(containerItem);\n });\n }\n else {\n return;\n }\n\n };\n\n // Init is called by default\n init();\n\n\n // Reveal API\n return {\n init\n };\n};\n\nexport default DirectionReveal;\n\n\n// Better switch cases - https://hackernoon.com/rethinking-javascript-eliminate-the-switch-statement-for-better-code-5c81c044716d\nexport const switchcase = cases => defaultCase => key =>\nkey in cases ? cases[key] : defaultCase;\n","import DirectionReveal from './direction-reveal.js';\n\n// Swing animation(Default)\nconst directionRevealSwing = DirectionReveal({\n selector: '.direction-reveal--demo-swing'\n});\n\n// Slide animation with all options specified\nconst directionRevealSlide = DirectionReveal({\n selector: '.direction-reveal--demo-slide',\n itemSelector: '.direction-reveal__card',\n animationName: 'slide',\n enableTouch: true,\n touchThreshold: 250\n});\n\n// Slide & push\nconst directionRevealSlidePush = DirectionReveal({\n selector: '.direction-reveal--demo-slide-push',\n animationName: 'slide'\n});\n\n// Rotate animation\nconst directionRevealRotate = DirectionReveal({\n selector: '.direction-reveal--demo-rotate',\n animationName: 'rotate'\n});\n\n// Flip animation\nconst directionRevealFlip = DirectionReveal({\n selector: '.direction-reveal--demo-flip',\n animationName: 'flip'\n});\n\n// Bootstrap demo\nconst directionRevealBoostrap = DirectionReveal({\n selector: '.direction-reveal--demo-bootstrap'\n});\n"],"preExistingComment":"//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["node_modules/browser-pack/_prelude.js","scripts/direction-reveal.js","scripts/main.js"],"names":[],"mappings":"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","file":"generated.js","sourceRoot":"","sourcesContent":["(function e(t,n,r){function s(o,u){if(!n[o]){if(!t[o]){var a=typeof require==\"function\"&&require;if(!u&&a)return a(o,!0);if(i)return i(o,!0);var f=new Error(\"Cannot find module '\"+o+\"'\");throw f.code=\"MODULE_NOT_FOUND\",f}var l=n[o]={exports:{}};t[o][0].call(l.exports,function(e){var n=t[o][1][e];return s(n?n:e)},l,l.exports,e,t,n,r)}return n[o].exports}var i=typeof require==\"function\"&&require;for(var o=0;o<r.length;o++)s(r[o]);return s})","\n/**\n  Direction aware content reveals.\n\n  @param {Object} object - Container for all options.\n  @param {string} selector - Container element selector.\n  @param {string} itemSelector - Item element selector.\n  @param {string} animationName - Animation CSS class.\n  @param {bollean} enableTouch  - Adds touch event to show content on first click then follow link on the second click.\n  @param {integer} touchThreshold - Touch length must be less than this to trigger reveal which prevents the event triggering if user is scrolling.\n*/\n\n\nconst DirectionReveal = function({\n  selector: selector = '.direction-reveal',\n  itemSelector: itemSelector = '.direction-reveal__card',\n  animationName: animationName = 'swing',\n  enableTouch: enableTouch = true,\n  touchThreshold: touchThreshold = 250\n  } = {}) {\n\n  const containers = document.querySelectorAll(selector);\n  let touchStart;\n\n\n  const getDirection = function (e, item) {\n    // Width and height of current item\n    let w = item.offsetWidth;\n    let h = item.offsetHeight;\n    let position = getPosition(item);\n\n    // Calculate the x/y value of the pointer entering/exiting, relative to the center of the item.\n    let x = (e.pageX - position.x - (w / 2) * (w > h ? (h / w) : 1));\n    let y = (e.pageY - position.y - (h / 2) * (h > w ? (w / h) : 1));\n\n    // Calculate the angle the pointer entered/exited and convert to clockwise format (top/right/bottom/left = 0/1/2/3).  See https://stackoverflow.com/a/3647634 for a full explanation.\n    let d = Math.round(Math.atan2(y, x) / 1.57079633 + 5) % 4;\n\n    // console.table([x, y, w, h, e.pageX, e.pageY, item.offsetLeft, item.offsetTop, position.x, position.y]);\n\n    return d;\n  };\n\n\n  // https://www.kirupa.com/html5/get_element_position_using_javascript.htm\n  const getPosition = function (el) {\n    let xPos = 0;\n    let yPos = 0;\n\n    while (el) {\n      xPos += (el.offsetLeft + el.clientLeft);\n      yPos += (el.offsetTop + el.clientTop);\n\n      el = el.offsetParent;\n    }\n    return {\n      x: xPos,\n      y: yPos\n    };\n  }\n\n\n  const translateDirection = switchcase({\n    0: 'top',\n    1: 'right',\n    2: 'bottom',\n    3: 'left'\n  })('top');\n\n\n  const addClass = function (e, state) {\n    let currentItem = e.currentTarget;\n    let direction = getDirection(e, currentItem);\n    let directionString = translateDirection(direction);\n\n    // Remove current animation classes and add new ones e.g. swap --in for --out.\n    let currentCssClasses = currentItem.className.split(' ');\n    let filteredCssClasses = currentCssClasses.filter((cssClass) => (!cssClass.startsWith(animationName))).join(' ');\n    currentItem.className = filteredCssClasses;\n    currentItem.classList.add(`${animationName}--${state}-${directionString}`);\n  };\n\n\n  const bindEvents = function (containerItem) {\n    const items = containerItem.querySelectorAll(itemSelector);\n\n    items.forEach((item) => {\n\n      addEventListenerMulti(item, ['mouseenter', 'focus'], function(e) {\n        addClass(e, 'in');\n      });\n\n      addEventListenerMulti(item, ['mouseleave', 'blur'], function(e) {\n        addClass(e, 'out');\n      });\n\n\n      if (enableTouch) {\n\n        item.addEventListener('touchstart', function(e) {\n          touchStart = +new Date;\n        });\n\n        item.addEventListener('touchend', function(e) {\n          let touchTime = +new Date - touchStart;\n\n          if (touchTime < touchThreshold && !item.className.includes(`${animationName}--in`)) {\n            e.preventDefault();\n\n            resetVisible(e, items, addClass(e, 'in'));\n          }\n        });\n\n      }\n\n    });\n  };\n\n  const addEventListenerMulti = function (element, events, fn) {\n    events.forEach((e) => element.addEventListener(e, fn));\n  }\n\n\n  const resetVisible = function (e, items, callback) {\n\n    items.forEach((item) => {\n      let currentCssClasses = item.className;\n\n      if(currentCssClasses.includes(`${animationName}--in`) && item !== e.currentTarget) {\n        item.className = currentCssClasses.replace(`${animationName}--in`, `${animationName}--out`);\n      }\n    });\n\n    callback;\n  };\n\n\n  const init = function () {\n\n    if (containers.length) {\n      containers.forEach((containerItem) => {\n        bindEvents(containerItem);\n      });\n    }\n    else {\n      return;\n    }\n\n  };\n\n  // Init is called by default\n  init();\n\n\n  // Reveal API\n  return {\n    init\n  };\n};\n\nexport default DirectionReveal;\n\n\n// Better switch cases - https://hackernoon.com/rethinking-javascript-eliminate-the-switch-statement-for-better-code-5c81c044716d\nexport const switchcase = cases => defaultCase => key =>\nkey in cases ? cases[key] : defaultCase;\n","import DirectionReveal from './direction-reveal.js';\n\n// Swing animation(Default)\nconst directionRevealSwing = DirectionReveal({\n  selector: '.direction-reveal--demo-swing'\n});\n\n// Slide animation with all options specified\nconst directionRevealSlide = DirectionReveal({\n  selector: '.direction-reveal--demo-slide',\n  itemSelector: '.direction-reveal__card',\n  animationName: 'slide',\n  enableTouch: true,\n  touchThreshold: 250\n});\n\n// Slide & push\nconst directionRevealSlidePush = DirectionReveal({\n  selector: '.direction-reveal--demo-slide-push',\n  animationName: 'slide'\n});\n\n// Rotate animation\nconst directionRevealRotate = DirectionReveal({\n  selector: '.direction-reveal--demo-rotate',\n  animationName: 'rotate'\n});\n\n// Flip animation\nconst directionRevealFlip = DirectionReveal({\n  selector: '.direction-reveal--demo-flip',\n  animationName: 'flip'\n});\n\n// Bootstrap demo\nconst directionRevealBoostrap = DirectionReveal({\n  selector: '.direction-reveal--demo-bootstrap'\n});\n"]}"} \ No newline at end of file +{"version":3,"sources":["node_modules/browser-pack/_prelude.js","scripts/direction-reveal.js","scripts/main.js"],"names":[],"mappings":"AAAA;;;;;;;ACCA;;;;;;;;;;;AAYA,IAAM,kBAAkB,SAAlB,eAAkB,GAMd;AAAA,iFAAJ,EAAI;AAAA,2BALR,QAKQ;AAAA,MALE,QAKF,iCALa,mBAKb;AAAA,+BAJR,YAIQ;AAAA,MAJM,YAIN,qCAJqB,yBAIrB;AAAA,gCAHR,aAGQ;AAAA,MAHO,aAGP,sCAHuB,OAGvB;AAAA,8BAFR,WAEQ;AAAA,MAFK,WAEL,oCAFmB,IAEnB;AAAA,iCADR,cACQ;AAAA,MADQ,cACR,uCADyB,GACzB;;AAER,MAAM,aAAa,SAAS,gBAAT,CAA0B,QAA1B,CAAnB;AACA,MAAI,mBAAJ;;AAGA,MAAM,eAAe,SAAf,YAAe,CAAU,CAAV,EAAa,IAAb,EAAmB;AACtC;AACA,QAAI,IAAI,KAAK,WAAb;AACA,QAAI,IAAI,KAAK,YAAb;AACA,QAAI,WAAW,YAAY,IAAZ,CAAf;;AAEA;AACA,QAAI,IAAK,EAAE,KAAF,GAAU,SAAS,CAAnB,GAAwB,IAAI,CAAL,IAAW,IAAI,CAAJ,GAAS,IAAI,CAAb,GAAkB,CAA7B,CAAhC;AACA,QAAI,IAAK,EAAE,KAAF,GAAU,SAAS,CAAnB,GAAwB,IAAI,CAAL,IAAW,IAAI,CAAJ,GAAS,IAAI,CAAb,GAAkB,CAA7B,CAAhC;;AAEA;AACA,QAAI,IAAI,KAAK,KAAL,CAAW,KAAK,KAAL,CAAW,CAAX,EAAc,CAAd,IAAmB,UAAnB,GAAgC,CAA3C,IAAgD,CAAxD;;AAEA;;AAEA,WAAO,CAAP;AACD,GAhBD;;AAmBA;AACA,MAAM,cAAc,SAAd,WAAc,CAAU,EAAV,EAAc;AAChC,QAAI,OAAO,CAAX;AACA,QAAI,OAAO,CAAX;;AAEA,WAAO,EAAP,EAAW;AACT,cAAS,GAAG,UAAH,GAAgB,GAAG,UAA5B;AACA,cAAS,GAAG,SAAH,GAAe,GAAG,SAA3B;;AAEA,WAAK,GAAG,YAAR;AACD;AACD,WAAO;AACL,SAAG,IADE;AAEL,SAAG;AAFE,KAAP;AAID,GAdD;;AAiBA,MAAM,qBAAqB,WAAW;AACpC,OAAG,KADiC;AAEpC,OAAG,OAFiC;AAGpC,OAAG,QAHiC;AAIpC,OAAG;AAJiC,GAAX,EAKxB,KALwB,CAA3B;;AAQA,MAAM,WAAW,SAAX,QAAW,CAAU,CAAV,EAAa,KAAb,EAAoB;AACnC,QAAI,cAAc,EAAE,aAApB;AACA,QAAI,YAAY,aAAa,CAAb,EAAgB,WAAhB,CAAhB;AACA,QAAI,kBAAkB,mBAAmB,SAAnB,CAAtB;;AAEA;AACA,QAAI,oBAAoB,YAAY,SAAZ,CAAsB,KAAtB,CAA4B,GAA5B,CAAxB;AACA,QAAI,qBAAqB,kBAAkB,MAAlB,CAAyB,UAAC,QAAD;AAAA,aAAe,CAAC,SAAS,UAAT,CAAoB,aAApB,CAAhB;AAAA,KAAzB,EAA8E,IAA9E,CAAmF,GAAnF,CAAzB;AACA,gBAAY,SAAZ,GAAwB,kBAAxB;AACA,gBAAY,SAAZ,CAAsB,GAAtB,CAA6B,aAA7B,UAA+C,KAA/C,SAAwD,eAAxD;AACD,GAVD;;AAaA,MAAM,aAAa,SAAb,UAAa,CAAU,aAAV,EAAyB;AAC1C,QAAM,QAAQ,cAAc,gBAAd,CAA+B,YAA/B,CAAd;;AAEA,UAAM,OAAN,CAAc,UAAC,IAAD,EAAU;;AAEtB,4BAAsB,IAAtB,EAA4B,CAAC,YAAD,EAAe,OAAf,CAA5B,EAAqD,UAAC,CAAD,EAAO;AAC1D,iBAAS,CAAT,EAAY,IAAZ;AACD,OAFD;;AAIA,4BAAsB,IAAtB,EAA4B,CAAC,YAAD,EAAe,MAAf,CAA5B,EAAoD,UAAC,CAAD,EAAO;AACzD,iBAAS,CAAT,EAAY,KAAZ;AACD,OAFD;;AAKA,UAAI,WAAJ,EAAiB;;AAEf,aAAK,gBAAL,CAAsB,YAAtB,EAAoC,UAAC,CAAD,EAAO;AACzC,uBAAa,CAAC,IAAI,IAAJ,EAAd;AACD,SAFD,EAEG,EAAE,SAAS,IAAX,EAFH;;AAIA,aAAK,gBAAL,CAAsB,UAAtB,EAAkC,UAAC,CAAD,EAAO;AACvC,cAAI,YAAY,CAAC,IAAI,IAAJ,EAAD,GAAY,UAA5B;;AAEA,cAAI,YAAY,cAAZ,IAA8B,CAAC,KAAK,SAAL,CAAe,QAAf,CAA2B,aAA3B,UAAnC,EAAoF;AAClF,cAAE,cAAF;;AAEA,yBAAa,CAAb,EAAgB,KAAhB,EAAuB,SAAS,CAAT,EAAY,IAAZ,CAAvB;AACD;AACF,SARD;AAUD;AAEF,KA7BD;AA8BD,GAjCD;;AAmCA,MAAM,wBAAwB,SAAxB,qBAAwB,CAAU,OAAV,EAAmB,MAAnB,EAA2B,EAA3B,EAA+B;AAC3D,WAAO,OAAP,CAAe,UAAC,CAAD;AAAA,aAAO,QAAQ,gBAAR,CAAyB,CAAzB,EAA4B,EAA5B,CAAP;AAAA,KAAf;AACD,GAFD;;AAKA,MAAM,eAAe,SAAf,YAAe,CAAU,CAAV,EAAa,KAAb,EAAoB,QAApB,EAA8B;;AAEjD,UAAM,OAAN,CAAc,UAAC,IAAD,EAAU;AACtB,UAAI,oBAAoB,KAAK,SAA7B;;AAEA,UAAG,kBAAkB,QAAlB,CAA8B,aAA9B,cAAsD,SAAS,EAAE,aAApE,EAAmF;AACjF,aAAK,SAAL,GAAiB,kBAAkB,OAAlB,CAA6B,aAA7B,WAAqD,aAArD,WAAjB;AACD;AACF,KAND;;AAQA;AACD,GAXD;;AAcA,MAAM,OAAO,SAAP,IAAO,GAAY;;AAEvB,QAAI,WAAW,MAAf,EAAuB;AACrB,iBAAW,OAAX,CAAmB,UAAC,aAAD,EAAmB;AACpC,mBAAW,aAAX;AACD,OAFD;AAGD,KAJD,MAKK;AACH;AACD;AAEF,GAXD;;AAaA;AACA;;AAGA;AACA,SAAO;AACL;AADK,GAAP;AAGD,CAjJD;;kBAmJe,e;;AAGf;;AACO,IAAM,kCAAa,SAAb,UAAa;AAAA,SAAS;AAAA,WAAe;AAAA,aAClD,OAAO,KAAP,GAAe,MAAM,GAAN,CAAf,GAA4B,WADsB;AAAA,KAAf;AAAA,GAAT;AAAA,CAAnB;;;;;ACpKP;;;;;;AAEA;AACA,IAAM,uBAAuB,+BAAgB;AAC3C,YAAU;AADiC,CAAhB,CAA7B;;AAIA;AACA,IAAM,uBAAuB,+BAAgB;AAC3C,YAAU,+BADiC;AAE3C,gBAAc,yBAF6B;AAG3C,iBAAe,OAH4B;AAI3C,eAAa,IAJ8B;AAK3C,kBAAgB;AAL2B,CAAhB,CAA7B;;AAQA;AACA,IAAM,2BAA2B,+BAAgB;AAC/C,YAAU,oCADqC;AAE/C,iBAAe;AAFgC,CAAhB,CAAjC;;AAKA;AACA,IAAM,wBAAwB,+BAAgB;AAC5C,YAAU,gCADkC;AAE5C,iBAAe;AAF6B,CAAhB,CAA9B;;AAKA;AACA,IAAM,sBAAsB,+BAAgB;AAC1C,YAAU,8BADgC;AAE1C,iBAAe;AAF2B,CAAhB,CAA5B;;AAKA;AACA,IAAM,0BAA0B,+BAAgB;AAC9C,YAAU;AADoC,CAAhB,CAAhC","file":"bundle.js","sourcesContent":["(function e(t,n,r){function s(o,u){if(!n[o]){if(!t[o]){var a=typeof require==\"function\"&&require;if(!u&&a)return a(o,!0);if(i)return i(o,!0);var f=new Error(\"Cannot find module '\"+o+\"'\");throw f.code=\"MODULE_NOT_FOUND\",f}var l=n[o]={exports:{}};t[o][0].call(l.exports,function(e){var n=t[o][1][e];return s(n?n:e)},l,l.exports,e,t,n,r)}return n[o].exports}var i=typeof require==\"function\"&&require;for(var o=0;o h ? (h / w) : 1));\n let y = (e.pageY - position.y - (h / 2) * (h > w ? (w / h) : 1));\n\n // Calculate the angle the pointer entered/exited and convert to clockwise format (top/right/bottom/left = 0/1/2/3). See https://stackoverflow.com/a/3647634 for a full explanation.\n let d = Math.round(Math.atan2(y, x) / 1.57079633 + 5) % 4;\n\n // console.table([x, y, w, h, e.pageX, e.pageY, item.offsetLeft, item.offsetTop, position.x, position.y]);\n\n return d;\n };\n\n\n // https://www.kirupa.com/html5/get_element_position_using_javascript.htm\n const getPosition = function (el) {\n let xPos = 0;\n let yPos = 0;\n\n while (el) {\n xPos += (el.offsetLeft + el.clientLeft);\n yPos += (el.offsetTop + el.clientTop);\n\n el = el.offsetParent;\n }\n return {\n x: xPos,\n y: yPos\n };\n }\n\n\n const translateDirection = switchcase({\n 0: 'top',\n 1: 'right',\n 2: 'bottom',\n 3: 'left'\n })('top');\n\n\n const addClass = function (e, state) {\n let currentItem = e.currentTarget;\n let direction = getDirection(e, currentItem);\n let directionString = translateDirection(direction);\n\n // Remove current animation classes and add new ones e.g. swap --in for --out.\n let currentCssClasses = currentItem.className.split(' ');\n let filteredCssClasses = currentCssClasses.filter((cssClass) => (!cssClass.startsWith(animationName))).join(' ');\n currentItem.className = filteredCssClasses;\n currentItem.classList.add(`${animationName}--${state}-${directionString}`);\n };\n\n\n const bindEvents = function (containerItem) {\n const items = containerItem.querySelectorAll(itemSelector);\n\n items.forEach((item) => {\n\n addEventListenerMulti(item, ['mouseenter', 'focus'], (e) => {\n addClass(e, 'in');\n });\n\n addEventListenerMulti(item, ['mouseleave', 'blur'], (e) => {\n addClass(e, 'out');\n });\n\n\n if (enableTouch) {\n\n item.addEventListener('touchstart', (e) => {\n touchStart = +new Date;\n }, { passive: true });\n\n item.addEventListener('touchend', (e) => {\n let touchTime = +new Date - touchStart;\n\n if (touchTime < touchThreshold && !item.className.includes(`${animationName}--in`)) {\n e.preventDefault();\n\n resetVisible(e, items, addClass(e, 'in'));\n }\n });\n\n }\n\n });\n };\n\n const addEventListenerMulti = function (element, events, fn) {\n events.forEach((e) => element.addEventListener(e, fn));\n }\n\n\n const resetVisible = function (e, items, callback) {\n\n items.forEach((item) => {\n let currentCssClasses = item.className;\n\n if(currentCssClasses.includes(`${animationName}--in`) && item !== e.currentTarget) {\n item.className = currentCssClasses.replace(`${animationName}--in`, `${animationName}--out`);\n }\n });\n\n callback;\n };\n\n\n const init = function () {\n\n if (containers.length) {\n containers.forEach((containerItem) => {\n bindEvents(containerItem);\n });\n }\n else {\n return;\n }\n\n };\n\n // Init is called by default\n init();\n\n\n // Reveal API\n return {\n init\n };\n};\n\nexport default DirectionReveal;\n\n\n// Better switch cases - https://hackernoon.com/rethinking-javascript-eliminate-the-switch-statement-for-better-code-5c81c044716d\nexport const switchcase = cases => defaultCase => key =>\nkey in cases ? cases[key] : defaultCase;\n","import DirectionReveal from './direction-reveal.js';\n\n// Swing animation(Default)\nconst directionRevealSwing = DirectionReveal({\n selector: '.direction-reveal--demo-swing'\n});\n\n// Slide animation with all options specified\nconst directionRevealSlide = DirectionReveal({\n selector: '.direction-reveal--demo-slide',\n itemSelector: '.direction-reveal__card',\n animationName: 'slide',\n enableTouch: true,\n touchThreshold: 250\n});\n\n// Slide & push\nconst directionRevealSlidePush = DirectionReveal({\n selector: '.direction-reveal--demo-slide-push',\n animationName: 'slide'\n});\n\n// Rotate animation\nconst directionRevealRotate = DirectionReveal({\n selector: '.direction-reveal--demo-rotate',\n animationName: 'rotate'\n});\n\n// Flip animation\nconst directionRevealFlip = DirectionReveal({\n selector: '.direction-reveal--demo-flip',\n animationName: 'flip'\n});\n\n// Bootstrap demo\nconst directionRevealBoostrap = DirectionReveal({\n selector: '.direction-reveal--demo-bootstrap'\n});\n"],"preExistingComment":"//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["node_modules/browser-pack/_prelude.js","scripts/direction-reveal.js","scripts/main.js"],"names":[],"mappings":"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","file":"generated.js","sourceRoot":"","sourcesContent":["(function e(t,n,r){function s(o,u){if(!n[o]){if(!t[o]){var a=typeof require==\"function\"&&require;if(!u&&a)return a(o,!0);if(i)return i(o,!0);var f=new Error(\"Cannot find module '\"+o+\"'\");throw f.code=\"MODULE_NOT_FOUND\",f}var l=n[o]={exports:{}};t[o][0].call(l.exports,function(e){var n=t[o][1][e];return s(n?n:e)},l,l.exports,e,t,n,r)}return n[o].exports}var i=typeof require==\"function\"&&require;for(var o=0;o<r.length;o++)s(r[o]);return s})","\n/**\n  Direction aware content reveals.\n\n  @param {Object} object - Container for all options.\n  @param {string} selector - Container element selector.\n  @param {string} itemSelector - Item element selector.\n  @param {string} animationName - Animation CSS class.\n  @param {bollean} enableTouch  - Adds touch event to show content on first click then follow link on the second click.\n  @param {integer} touchThreshold - Touch length must be less than this to trigger reveal which prevents the event triggering if user is scrolling.\n*/\n\n\nconst DirectionReveal = function ({\n  selector: selector = '.direction-reveal',\n  itemSelector: itemSelector = '.direction-reveal__card',\n  animationName: animationName = 'swing',\n  enableTouch: enableTouch = true,\n  touchThreshold: touchThreshold = 250\n  } = {}) {\n\n  const containers = document.querySelectorAll(selector);\n  let touchStart;\n\n\n  const getDirection = function (e, item) {\n    // Width and height of current item\n    let w = item.offsetWidth;\n    let h = item.offsetHeight;\n    let position = getPosition(item);\n\n    // Calculate the x/y value of the pointer entering/exiting, relative to the center of the item.\n    let x = (e.pageX - position.x - (w / 2) * (w > h ? (h / w) : 1));\n    let y = (e.pageY - position.y - (h / 2) * (h > w ? (w / h) : 1));\n\n    // Calculate the angle the pointer entered/exited and convert to clockwise format (top/right/bottom/left = 0/1/2/3).  See https://stackoverflow.com/a/3647634 for a full explanation.\n    let d = Math.round(Math.atan2(y, x) / 1.57079633 + 5) % 4;\n\n    // console.table([x, y, w, h, e.pageX, e.pageY, item.offsetLeft, item.offsetTop, position.x, position.y]);\n\n    return d;\n  };\n\n\n  // https://www.kirupa.com/html5/get_element_position_using_javascript.htm\n  const getPosition = function (el) {\n    let xPos = 0;\n    let yPos = 0;\n\n    while (el) {\n      xPos += (el.offsetLeft + el.clientLeft);\n      yPos += (el.offsetTop + el.clientTop);\n\n      el = el.offsetParent;\n    }\n    return {\n      x: xPos,\n      y: yPos\n    };\n  }\n\n\n  const translateDirection = switchcase({\n    0: 'top',\n    1: 'right',\n    2: 'bottom',\n    3: 'left'\n  })('top');\n\n\n  const addClass = function (e, state) {\n    let currentItem = e.currentTarget;\n    let direction = getDirection(e, currentItem);\n    let directionString = translateDirection(direction);\n\n    // Remove current animation classes and add new ones e.g. swap --in for --out.\n    let currentCssClasses = currentItem.className.split(' ');\n    let filteredCssClasses = currentCssClasses.filter((cssClass) => (!cssClass.startsWith(animationName))).join(' ');\n    currentItem.className = filteredCssClasses;\n    currentItem.classList.add(`${animationName}--${state}-${directionString}`);\n  };\n\n\n  const bindEvents = function (containerItem) {\n    const items = containerItem.querySelectorAll(itemSelector);\n\n    items.forEach((item) => {\n\n      addEventListenerMulti(item, ['mouseenter', 'focus'], (e) => {\n        addClass(e, 'in');\n      });\n\n      addEventListenerMulti(item, ['mouseleave', 'blur'], (e) => {\n        addClass(e, 'out');\n      });\n\n\n      if (enableTouch) {\n\n        item.addEventListener('touchstart', (e) => {\n          touchStart = +new Date;\n        }, { passive: true });\n\n        item.addEventListener('touchend', (e) => {\n          let touchTime = +new Date - touchStart;\n\n          if (touchTime < touchThreshold && !item.className.includes(`${animationName}--in`)) {\n            e.preventDefault();\n\n            resetVisible(e, items, addClass(e, 'in'));\n          }\n        });\n\n      }\n\n    });\n  };\n\n  const addEventListenerMulti = function (element, events, fn) {\n    events.forEach((e) => element.addEventListener(e, fn));\n  }\n\n\n  const resetVisible = function (e, items, callback) {\n\n    items.forEach((item) => {\n      let currentCssClasses = item.className;\n\n      if(currentCssClasses.includes(`${animationName}--in`) && item !== e.currentTarget) {\n        item.className = currentCssClasses.replace(`${animationName}--in`, `${animationName}--out`);\n      }\n    });\n\n    callback;\n  };\n\n\n  const init = function () {\n\n    if (containers.length) {\n      containers.forEach((containerItem) => {\n        bindEvents(containerItem);\n      });\n    }\n    else {\n      return;\n    }\n\n  };\n\n  // Init is called by default\n  init();\n\n\n  // Reveal API\n  return {\n    init\n  };\n};\n\nexport default DirectionReveal;\n\n\n// Better switch cases - https://hackernoon.com/rethinking-javascript-eliminate-the-switch-statement-for-better-code-5c81c044716d\nexport const switchcase = cases => defaultCase => key =>\nkey in cases ? cases[key] : defaultCase;\n","import DirectionReveal from './direction-reveal.js';\n\n// Swing animation(Default)\nconst directionRevealSwing = DirectionReveal({\n  selector: '.direction-reveal--demo-swing'\n});\n\n// Slide animation with all options specified\nconst directionRevealSlide = DirectionReveal({\n  selector: '.direction-reveal--demo-slide',\n  itemSelector: '.direction-reveal__card',\n  animationName: 'slide',\n  enableTouch: true,\n  touchThreshold: 250\n});\n\n// Slide & push\nconst directionRevealSlidePush = DirectionReveal({\n  selector: '.direction-reveal--demo-slide-push',\n  animationName: 'slide'\n});\n\n// Rotate animation\nconst directionRevealRotate = DirectionReveal({\n  selector: '.direction-reveal--demo-rotate',\n  animationName: 'rotate'\n});\n\n// Flip animation\nconst directionRevealFlip = DirectionReveal({\n  selector: '.direction-reveal--demo-flip',\n  animationName: 'flip'\n});\n\n// Bootstrap demo\nconst directionRevealBoostrap = DirectionReveal({\n  selector: '.direction-reveal--demo-bootstrap'\n});\n"]}"} \ No newline at end of file diff --git a/scripts/direction-reveal.js b/scripts/direction-reveal.js index 6686a34..90aa68d 100644 --- a/scripts/direction-reveal.js +++ b/scripts/direction-reveal.js @@ -11,7 +11,7 @@ */ -const DirectionReveal = function({ +const DirectionReveal = function ({ selector: selector = '.direction-reveal', itemSelector: itemSelector = '.direction-reveal__card', animationName: animationName = 'swing', @@ -86,22 +86,22 @@ const DirectionReveal = function({ items.forEach((item) => { - addEventListenerMulti(item, ['mouseenter', 'focus'], function(e) { + addEventListenerMulti(item, ['mouseenter', 'focus'], (e) => { addClass(e, 'in'); }); - addEventListenerMulti(item, ['mouseleave', 'blur'], function(e) { + addEventListenerMulti(item, ['mouseleave', 'blur'], (e) => { addClass(e, 'out'); }); if (enableTouch) { - item.addEventListener('touchstart', function(e) { + item.addEventListener('touchstart', (e) => { touchStart = +new Date; - }); + }, { passive: true }); - item.addEventListener('touchend', function(e) { + item.addEventListener('touchend', (e) => { let touchTime = +new Date - touchStart; if (touchTime < touchThreshold && !item.className.includes(`${animationName}--in`)) { diff --git a/styles/direction-reveal.css b/styles/direction-reveal.css index 377e479..e4ea3a5 100644 --- a/styles/direction-reveal.css +++ b/styles/direction-reveal.css @@ -921,22 +921,32 @@ } .direction-reveal--3-grid-flexbox .direction-reveal__card { - -webkit-box-flex: 0; - -ms-flex: 0 0 33.333333%; - flex: 0 0 33.333333%; - max-width: 33.333333%; border: 10px solid transparent; } +@media (min-width: 576px) { + .direction-reveal--3-grid-flexbox .direction-reveal__card { + -webkit-box-flex: 0; + -ms-flex: 0 0 33.333333%; + flex: 0 0 33.333333%; + max-width: 33.333333%; + } +} + .direction-reveal--3-grid-cssgrid { display: -ms-grid; display: grid; - -ms-grid-columns: (1fr)[3]; - grid-template-columns: repeat(3, 1fr); margin-right: -10px; margin-left: -10px; } +@media (min-width: 576px) { + .direction-reveal--3-grid-cssgrid { + -ms-grid-columns: (1fr)[3]; + grid-template-columns: repeat(3, 1fr); + } +} + .direction-reveal--3-grid-cssgrid .direction-reveal__card { border: 10px solid transparent; } @@ -946,4 +956,4 @@ margin-bottom: 15px; } -/*# sourceMappingURL=data:application/json;charset=utf8;base64,{"version":3,"sources":["_animations.scss","_variables.scss","direction-reveal.css","direction-reveal.scss"],"names":[],"mappings":"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","file":"direction-reveal.css","sourcesContent":["// Generates classes to assign animations\n@mixin animation-classes($animation-name) {\n\n  $directions-list: in out;\n  $positions-list:  top bottom left right;\n\n  $directions-opposite-list: out in;\n  $positions-opposite-list:  bottom top right left;\n\n  @each $direction in $directions-list {\n    @each $position in $positions-list {\n\n      $class-name: #{$animation-name}--#{$direction}-#{$position};\n\n      .#{$class-name} {\n        .direction-reveal__anim--in {\n          animation-name: #{$class-name};\n        }\n      }\n\n      $direction-opposite: nth($directions-opposite-list, index($directions-list, $direction));\n      $position-opposite: nth($positions-opposite-list, index($positions-list, $position));\n      $class-name-opposite: #{$animation-name}--#{$direction-opposite}-#{$position-opposite};\n\n      .#{$class-name} {\n        .direction-reveal__anim--out {\n          animation-name: #{$class-name-opposite};\n        }\n      }\n\n    }\n  }\n\n}\n\n\n\n// Swing animation\n\n@include animation-classes('swing');\n\n// Default visible state after animation - used as start or end points for the keyframe animations\n.direction-reveal [class*='swing--'] {\n  perspective: 400px;\n\n  .direction-reveal__anim--in, .direction-reveal__anim--out {\n    transform: rotate3d(0, 0, 0, 0);\n    animation-timing-function: $anim-easing-easeOutCubic;\n  }\n}\n\n.swing--in-top, .swing--out-top {\n  perspective-origin: center top;\n\n  .direction-reveal__anim--in, .direction-reveal__anim--out {\n    transform-origin: center top;\n  }\n}\n\n.swing--in-bottom, .swing--out-bottom {\n  perspective-origin: center bottom;\n\n  .direction-reveal__anim--in, .direction-reveal__anim--out {\n    transform-origin: center bottom;\n  }\n}\n\n.swing--in-left, .swing--out-left {\n  perspective-origin: left center;\n\n  .direction-reveal__anim--in, .direction-reveal__anim--out {\n    transform-origin: left center;\n  }\n}\n\n.swing--in-right, .swing--out-right {\n  perspective-origin: right center;\n\n  .direction-reveal__anim--in, .direction-reveal__anim--out {\n    transform-origin: right center;\n  }\n}\n\n\n@keyframes swing--in-top {\n  0% {\n    transform: rotate3d(-1, 0, 0, 90deg);\n  }\n}\n\n@keyframes swing--out-top {\n  100% {\n    transform: rotate3d(-1, 0, 0, 90deg);\n  }\n}\n\n@keyframes swing--in-bottom {\n  0% {\n    transform: rotate3d(1, 0, 0, 90deg);\n  }\n}\n\n@keyframes swing--out-bottom {\n  100% {\n    transform: rotate3d(1, 0, 0, 90deg);\n  }\n}\n\n@keyframes swing--in-left {\n  0% {\n    transform: rotate3d(0, 1, 0, 90deg);\n  }\n}\n\n@keyframes swing--out-left {\n  100% {\n    transform: rotate3d(0, 1, 0, 90deg);\n  }\n}\n\n@keyframes swing--in-right {\n  0% {\n    transform: rotate3d(0, -1, 0, 90deg);\n  }\n}\n\n@keyframes swing--out-right {\n  100% {\n    transform: rotate3d(0, -1, 0, 90deg);\n  }\n}\n\n\n\n// Slide animation\n\n@include animation-classes('slide');\n\n.direction-reveal [class*='slide--'] {\n  .direction-reveal__anim--in, .direction-reveal__anim--out {\n    transform: translate3d(0, 0, 0);\n    animation-timing-function: $anim-easing-easeOutQuad;\n  }\n}\n\n@keyframes slide--in-top {\n  0% {\n    transform: translate3d(0, -100%, 0);\n  }\n}\n\n@keyframes slide--out-top {\n  100% {\n    transform: translate3d(0, -100%, 0);\n  }\n}\n\n@keyframes slide--in-bottom {\n  0% {\n    transform: translate3d(0, 100%, 0);\n  }\n}\n\n@keyframes slide--out-bottom {\n  100% {\n    transform: translate3d(0, 100%, 0);\n  }\n}\n\n@keyframes slide--in-left {\n  0% {\n    transform: translate3d(-100%, 0, 0);\n  }\n}\n\n@keyframes slide--out-left {\n  100% {\n    transform: translate3d(-100%, 0, 0);\n  }\n}\n\n\n@keyframes slide--in-right {\n  0% {\n    transform: translate3d(100%, 0, 0);\n  }\n}\n\n@keyframes slide--out-right {\n  100% {\n    transform: translate3d(100%, 0, 0);\n  }\n}\n\n\n\n// Rotate animation\n\n@include animation-classes('rotate');\n\n.direction-reveal [class*='rotate--'] {\n  .direction-reveal__anim--in, .direction-reveal__anim--out {\n    transform: rotate(0);\n    animation-timing-function: $anim-easing-easeOutQuad;\n  }\n}\n\n.rotate--in-top, .rotate--out-top {\n  .direction-reveal__anim--in, .direction-reveal__anim--out {\n    transform-origin: left top;\n  }\n}\n\n.rotate--in-bottom, .rotate--out-bottom {\n  .direction-reveal__anim--in, .direction-reveal__anim--out {\n    transform-origin: left bottom;\n  }\n}\n\n.rotate--in-left, .rotate--out-left {\n  .direction-reveal__anim--in, .direction-reveal__anim--out {\n    transform-origin: left top;\n  }\n}\n\n.rotate--in-right, .rotate--out-right {\n  .direction-reveal__anim--in, .direction-reveal__anim--out {\n    transform-origin: right top;\n  }\n}\n\n@keyframes rotate--in-top {\n  0% {\n    transform: rotate(-90deg);\n  }\n}\n\n@keyframes rotate--out-top {\n  100% {\n    transform: rotate(-90deg);\n  }\n}\n\n@keyframes rotate--in-bottom {\n  0% {\n    transform: rotate(90deg);\n  }\n}\n\n@keyframes rotate--out-bottom {\n  100% {\n    transform: rotate(90deg);\n  }\n}\n\n@keyframes rotate--in-left {\n  0% {\n    transform: rotate(90deg);\n  }\n}\n\n@keyframes rotate--out-left {\n  100% {\n    transform: rotate(90deg);\n  }\n}\n\n@keyframes rotate--in-right {\n  0% {\n    transform: rotate(-90deg);\n  }\n}\n\n@keyframes rotate--out-right {\n  100% {\n    transform: rotate(-90deg);\n  }\n}\n\n\n\n// Flip animation\n\n@include animation-classes('flip');\n\n.direction-reveal [class*='flip--'] {\n  perspective: 800px;\n  overflow: visible;\n\n  .direction-reveal__anim--in, .direction-reveal__anim--out {\n    transform: rotateX(0) rotateY(0); // Order must be the same as the animations\n    animation-timing-function: $anim-easing-easeInOutQuad;\n    animation-duration: $anim-duration*2;\n    backface-visibility: hidden;\n    z-index: 1;\n  }\n}\n\n@keyframes flip--in-top {\n  0% {\n    transform: rotateX(180deg) rotateY(0);\n  }\n}\n\n@keyframes flip--out-top {\n  100% {\n    transform: rotateX(180deg) rotateY(0);\n  }\n}\n\n@keyframes flip--in-bottom {\n  0% {\n    transform: rotateX(-180deg) rotateY(0);\n  }\n}\n\n@keyframes flip--out-bottom {\n  100% {\n    transform: rotateX(-180deg) rotateY(0);\n  }\n}\n\n@keyframes flip--in-left {\n  0% {\n    transform: rotateX(0) rotateY(-180deg);\n  }\n}\n\n@keyframes flip--out-left {\n  100% {\n    transform: rotateX(0) rotateY(-180deg);\n  }\n}\n\n@keyframes flip--in-right {\n  0% {\n    transform: rotateX(0) rotateY(180deg);\n  }\n}\n\n@keyframes flip--out-right {\n  100% {\n    transform: rotateX(0) rotateY(180deg);\n  }\n}\n","$anim-easing-easeOutQuad:   cubic-bezier(0.250, 0.460, 0.450, 0.940);\n$anim-easing-easeOutCubic:  cubic-bezier(0.215, 0.610, 0.355, 1.000);\n$anim-easing-easeInOutQuad: cubic-bezier(0.455, 0.030, 0.515, 0.955);\n$anim-duration:             .3s;\n\n$grid-spacing:              10px;\n",".swing--in-top .direction-reveal__anim--in {\n  animation-name: swing--in-top;\n}\n\n.swing--in-top .direction-reveal__anim--out {\n  animation-name: swing--out-bottom;\n}\n\n.swing--in-bottom .direction-reveal__anim--in {\n  animation-name: swing--in-bottom;\n}\n\n.swing--in-bottom .direction-reveal__anim--out {\n  animation-name: swing--out-top;\n}\n\n.swing--in-left .direction-reveal__anim--in {\n  animation-name: swing--in-left;\n}\n\n.swing--in-left .direction-reveal__anim--out {\n  animation-name: swing--out-right;\n}\n\n.swing--in-right .direction-reveal__anim--in {\n  animation-name: swing--in-right;\n}\n\n.swing--in-right .direction-reveal__anim--out {\n  animation-name: swing--out-left;\n}\n\n.swing--out-top .direction-reveal__anim--in {\n  animation-name: swing--out-top;\n}\n\n.swing--out-top .direction-reveal__anim--out {\n  animation-name: swing--in-bottom;\n}\n\n.swing--out-bottom .direction-reveal__anim--in {\n  animation-name: swing--out-bottom;\n}\n\n.swing--out-bottom .direction-reveal__anim--out {\n  animation-name: swing--in-top;\n}\n\n.swing--out-left .direction-reveal__anim--in {\n  animation-name: swing--out-left;\n}\n\n.swing--out-left .direction-reveal__anim--out {\n  animation-name: swing--in-right;\n}\n\n.swing--out-right .direction-reveal__anim--in {\n  animation-name: swing--out-right;\n}\n\n.swing--out-right .direction-reveal__anim--out {\n  animation-name: swing--in-left;\n}\n\n.direction-reveal [class*='swing--'] {\n  perspective: 400px;\n}\n\n.direction-reveal [class*='swing--'] .direction-reveal__anim--in, .direction-reveal [class*='swing--'] .direction-reveal__anim--out {\n  transform: rotate3d(0, 0, 0, 0);\n  animation-timing-function: cubic-bezier(0.215, 0.61, 0.355, 1);\n}\n\n.swing--in-top, .swing--out-top {\n  perspective-origin: center top;\n}\n\n.swing--in-top .direction-reveal__anim--in, .swing--in-top .direction-reveal__anim--out, .swing--out-top .direction-reveal__anim--in, .swing--out-top .direction-reveal__anim--out {\n  transform-origin: center top;\n}\n\n.swing--in-bottom, .swing--out-bottom {\n  perspective-origin: center bottom;\n}\n\n.swing--in-bottom .direction-reveal__anim--in, .swing--in-bottom .direction-reveal__anim--out, .swing--out-bottom .direction-reveal__anim--in, .swing--out-bottom .direction-reveal__anim--out {\n  transform-origin: center bottom;\n}\n\n.swing--in-left, .swing--out-left {\n  perspective-origin: left center;\n}\n\n.swing--in-left .direction-reveal__anim--in, .swing--in-left .direction-reveal__anim--out, .swing--out-left .direction-reveal__anim--in, .swing--out-left .direction-reveal__anim--out {\n  transform-origin: left center;\n}\n\n.swing--in-right, .swing--out-right {\n  perspective-origin: right center;\n}\n\n.swing--in-right .direction-reveal__anim--in, .swing--in-right .direction-reveal__anim--out, .swing--out-right .direction-reveal__anim--in, .swing--out-right .direction-reveal__anim--out {\n  transform-origin: right center;\n}\n\n@keyframes swing--in-top {\n  0% {\n    transform: rotate3d(-1, 0, 0, 90deg);\n  }\n}\n\n@keyframes swing--out-top {\n  100% {\n    transform: rotate3d(-1, 0, 0, 90deg);\n  }\n}\n\n@keyframes swing--in-bottom {\n  0% {\n    transform: rotate3d(1, 0, 0, 90deg);\n  }\n}\n\n@keyframes swing--out-bottom {\n  100% {\n    transform: rotate3d(1, 0, 0, 90deg);\n  }\n}\n\n@keyframes swing--in-left {\n  0% {\n    transform: rotate3d(0, 1, 0, 90deg);\n  }\n}\n\n@keyframes swing--out-left {\n  100% {\n    transform: rotate3d(0, 1, 0, 90deg);\n  }\n}\n\n@keyframes swing--in-right {\n  0% {\n    transform: rotate3d(0, -1, 0, 90deg);\n  }\n}\n\n@keyframes swing--out-right {\n  100% {\n    transform: rotate3d(0, -1, 0, 90deg);\n  }\n}\n\n.slide--in-top .direction-reveal__anim--in {\n  animation-name: slide--in-top;\n}\n\n.slide--in-top .direction-reveal__anim--out {\n  animation-name: slide--out-bottom;\n}\n\n.slide--in-bottom .direction-reveal__anim--in {\n  animation-name: slide--in-bottom;\n}\n\n.slide--in-bottom .direction-reveal__anim--out {\n  animation-name: slide--out-top;\n}\n\n.slide--in-left .direction-reveal__anim--in {\n  animation-name: slide--in-left;\n}\n\n.slide--in-left .direction-reveal__anim--out {\n  animation-name: slide--out-right;\n}\n\n.slide--in-right .direction-reveal__anim--in {\n  animation-name: slide--in-right;\n}\n\n.slide--in-right .direction-reveal__anim--out {\n  animation-name: slide--out-left;\n}\n\n.slide--out-top .direction-reveal__anim--in {\n  animation-name: slide--out-top;\n}\n\n.slide--out-top .direction-reveal__anim--out {\n  animation-name: slide--in-bottom;\n}\n\n.slide--out-bottom .direction-reveal__anim--in {\n  animation-name: slide--out-bottom;\n}\n\n.slide--out-bottom .direction-reveal__anim--out {\n  animation-name: slide--in-top;\n}\n\n.slide--out-left .direction-reveal__anim--in {\n  animation-name: slide--out-left;\n}\n\n.slide--out-left .direction-reveal__anim--out {\n  animation-name: slide--in-right;\n}\n\n.slide--out-right .direction-reveal__anim--in {\n  animation-name: slide--out-right;\n}\n\n.slide--out-right .direction-reveal__anim--out {\n  animation-name: slide--in-left;\n}\n\n.direction-reveal [class*='slide--'] .direction-reveal__anim--in, .direction-reveal [class*='slide--'] .direction-reveal__anim--out {\n  transform: translate3d(0, 0, 0);\n  animation-timing-function: cubic-bezier(0.25, 0.46, 0.45, 0.94);\n}\n\n@keyframes slide--in-top {\n  0% {\n    transform: translate3d(0, -100%, 0);\n  }\n}\n\n@keyframes slide--out-top {\n  100% {\n    transform: translate3d(0, -100%, 0);\n  }\n}\n\n@keyframes slide--in-bottom {\n  0% {\n    transform: translate3d(0, 100%, 0);\n  }\n}\n\n@keyframes slide--out-bottom {\n  100% {\n    transform: translate3d(0, 100%, 0);\n  }\n}\n\n@keyframes slide--in-left {\n  0% {\n    transform: translate3d(-100%, 0, 0);\n  }\n}\n\n@keyframes slide--out-left {\n  100% {\n    transform: translate3d(-100%, 0, 0);\n  }\n}\n\n@keyframes slide--in-right {\n  0% {\n    transform: translate3d(100%, 0, 0);\n  }\n}\n\n@keyframes slide--out-right {\n  100% {\n    transform: translate3d(100%, 0, 0);\n  }\n}\n\n.rotate--in-top .direction-reveal__anim--in {\n  animation-name: rotate--in-top;\n}\n\n.rotate--in-top .direction-reveal__anim--out {\n  animation-name: rotate--out-bottom;\n}\n\n.rotate--in-bottom .direction-reveal__anim--in {\n  animation-name: rotate--in-bottom;\n}\n\n.rotate--in-bottom .direction-reveal__anim--out {\n  animation-name: rotate--out-top;\n}\n\n.rotate--in-left .direction-reveal__anim--in {\n  animation-name: rotate--in-left;\n}\n\n.rotate--in-left .direction-reveal__anim--out {\n  animation-name: rotate--out-right;\n}\n\n.rotate--in-right .direction-reveal__anim--in {\n  animation-name: rotate--in-right;\n}\n\n.rotate--in-right .direction-reveal__anim--out {\n  animation-name: rotate--out-left;\n}\n\n.rotate--out-top .direction-reveal__anim--in {\n  animation-name: rotate--out-top;\n}\n\n.rotate--out-top .direction-reveal__anim--out {\n  animation-name: rotate--in-bottom;\n}\n\n.rotate--out-bottom .direction-reveal__anim--in {\n  animation-name: rotate--out-bottom;\n}\n\n.rotate--out-bottom .direction-reveal__anim--out {\n  animation-name: rotate--in-top;\n}\n\n.rotate--out-left .direction-reveal__anim--in {\n  animation-name: rotate--out-left;\n}\n\n.rotate--out-left .direction-reveal__anim--out {\n  animation-name: rotate--in-right;\n}\n\n.rotate--out-right .direction-reveal__anim--in {\n  animation-name: rotate--out-right;\n}\n\n.rotate--out-right .direction-reveal__anim--out {\n  animation-name: rotate--in-left;\n}\n\n.direction-reveal [class*='rotate--'] .direction-reveal__anim--in, .direction-reveal [class*='rotate--'] .direction-reveal__anim--out {\n  transform: rotate(0);\n  animation-timing-function: cubic-bezier(0.25, 0.46, 0.45, 0.94);\n}\n\n.rotate--in-top .direction-reveal__anim--in, .rotate--in-top .direction-reveal__anim--out, .rotate--out-top .direction-reveal__anim--in, .rotate--out-top .direction-reveal__anim--out {\n  transform-origin: left top;\n}\n\n.rotate--in-bottom .direction-reveal__anim--in, .rotate--in-bottom .direction-reveal__anim--out, .rotate--out-bottom .direction-reveal__anim--in, .rotate--out-bottom .direction-reveal__anim--out {\n  transform-origin: left bottom;\n}\n\n.rotate--in-left .direction-reveal__anim--in, .rotate--in-left .direction-reveal__anim--out, .rotate--out-left .direction-reveal__anim--in, .rotate--out-left .direction-reveal__anim--out {\n  transform-origin: left top;\n}\n\n.rotate--in-right .direction-reveal__anim--in, .rotate--in-right .direction-reveal__anim--out, .rotate--out-right .direction-reveal__anim--in, .rotate--out-right .direction-reveal__anim--out {\n  transform-origin: right top;\n}\n\n@keyframes rotate--in-top {\n  0% {\n    transform: rotate(-90deg);\n  }\n}\n\n@keyframes rotate--out-top {\n  100% {\n    transform: rotate(-90deg);\n  }\n}\n\n@keyframes rotate--in-bottom {\n  0% {\n    transform: rotate(90deg);\n  }\n}\n\n@keyframes rotate--out-bottom {\n  100% {\n    transform: rotate(90deg);\n  }\n}\n\n@keyframes rotate--in-left {\n  0% {\n    transform: rotate(90deg);\n  }\n}\n\n@keyframes rotate--out-left {\n  100% {\n    transform: rotate(90deg);\n  }\n}\n\n@keyframes rotate--in-right {\n  0% {\n    transform: rotate(-90deg);\n  }\n}\n\n@keyframes rotate--out-right {\n  100% {\n    transform: rotate(-90deg);\n  }\n}\n\n.flip--in-top .direction-reveal__anim--in {\n  animation-name: flip--in-top;\n}\n\n.flip--in-top .direction-reveal__anim--out {\n  animation-name: flip--out-bottom;\n}\n\n.flip--in-bottom .direction-reveal__anim--in {\n  animation-name: flip--in-bottom;\n}\n\n.flip--in-bottom .direction-reveal__anim--out {\n  animation-name: flip--out-top;\n}\n\n.flip--in-left .direction-reveal__anim--in {\n  animation-name: flip--in-left;\n}\n\n.flip--in-left .direction-reveal__anim--out {\n  animation-name: flip--out-right;\n}\n\n.flip--in-right .direction-reveal__anim--in {\n  animation-name: flip--in-right;\n}\n\n.flip--in-right .direction-reveal__anim--out {\n  animation-name: flip--out-left;\n}\n\n.flip--out-top .direction-reveal__anim--in {\n  animation-name: flip--out-top;\n}\n\n.flip--out-top .direction-reveal__anim--out {\n  animation-name: flip--in-bottom;\n}\n\n.flip--out-bottom .direction-reveal__anim--in {\n  animation-name: flip--out-bottom;\n}\n\n.flip--out-bottom .direction-reveal__anim--out {\n  animation-name: flip--in-top;\n}\n\n.flip--out-left .direction-reveal__anim--in {\n  animation-name: flip--out-left;\n}\n\n.flip--out-left .direction-reveal__anim--out {\n  animation-name: flip--in-right;\n}\n\n.flip--out-right .direction-reveal__anim--in {\n  animation-name: flip--out-right;\n}\n\n.flip--out-right .direction-reveal__anim--out {\n  animation-name: flip--in-left;\n}\n\n.direction-reveal [class*='flip--'] {\n  perspective: 800px;\n  overflow: visible;\n}\n\n.direction-reveal [class*='flip--'] .direction-reveal__anim--in, .direction-reveal [class*='flip--'] .direction-reveal__anim--out {\n  transform: rotateX(0) rotateY(0);\n  animation-timing-function: cubic-bezier(0.455, 0.03, 0.515, 0.955);\n  animation-duration: 0.6s;\n  backface-visibility: hidden;\n  z-index: 1;\n}\n\n@keyframes flip--in-top {\n  0% {\n    transform: rotateX(180deg) rotateY(0);\n  }\n}\n\n@keyframes flip--out-top {\n  100% {\n    transform: rotateX(180deg) rotateY(0);\n  }\n}\n\n@keyframes flip--in-bottom {\n  0% {\n    transform: rotateX(-180deg) rotateY(0);\n  }\n}\n\n@keyframes flip--out-bottom {\n  100% {\n    transform: rotateX(-180deg) rotateY(0);\n  }\n}\n\n@keyframes flip--in-left {\n  0% {\n    transform: rotateX(0) rotateY(-180deg);\n  }\n}\n\n@keyframes flip--out-left {\n  100% {\n    transform: rotateX(0) rotateY(-180deg);\n  }\n}\n\n@keyframes flip--in-right {\n  0% {\n    transform: rotateX(0) rotateY(180deg);\n  }\n}\n\n@keyframes flip--out-right {\n  100% {\n    transform: rotateX(0) rotateY(180deg);\n  }\n}\n\n.direction-reveal__card {\n  display: inline-block;\n  position: relative;\n  overflow: hidden;\n}\n\n.direction-reveal__overlay {\n  position: absolute;\n  top: 0;\n  left: 0;\n  width: 100%;\n  height: 100%;\n  padding: 15px;\n  color: #fff;\n  overflow: hidden;\n  background-color: rgba(0, 0, 0, 0.6);\n}\n\n.direction-reveal__anim--in, .direction-reveal__anim--out {\n  animation-duration: 0.3s;\n  animation-timing-function: cubic-bezier(0.25, 0.46, 0.45, 0.94);\n  animation-fill-mode: forwards;\n}\n\n.direction-reveal__anim--in {\n  transform: translate3d(0, -100%, 0);\n}\n\n.direction-reveal__title {\n  margin-top: 0;\n}\n\n.direction-reveal__text {\n  margin-bottom: 0;\n}\n\n.direction-reveal--3-grid-flexbox {\n  display: flex;\n  flex-wrap: wrap;\n  margin-right: -10px;\n  margin-left: -10px;\n}\n\n.direction-reveal--3-grid-flexbox .direction-reveal__card {\n  flex: 0 0 33.333333%;\n  max-width: 33.333333%;\n  border: 10px solid transparent;\n}\n\n.direction-reveal--3-grid-cssgrid {\n  display: grid;\n  grid-template-columns: repeat(3, 1fr);\n  margin-right: -10px;\n  margin-left: -10px;\n}\n\n.direction-reveal--3-grid-cssgrid .direction-reveal__card {\n  border: 10px solid transparent;\n}\n\n.direction-reveal--grid-bootstrap .direction-reveal__card {\n  margin-top: 15px;\n  margin-bottom: 15px;\n}\n","@import 'variables';\n@import 'animations';\n\n\n// ----- Component -----\n.direction-reveal {}\n\n  .direction-reveal__card {\n    display: inline-block;\n    position: relative;\n    overflow: hidden;\n  }\n\n    .direction-reveal__overlay {\n      position: absolute;\n      top: 0;\n      left: 0;\n      width: 100%;\n      height: 100%;\n      padding: 15px;\n      color: #fff;\n      overflow: hidden;\n      background-color: rgba(0, 0, 0, .6);\n    }\n\n    // .direction-reveal__anim--in is used to animate in hidden content, the default animation used on the overlay\n    // .direction-reveal__anim--out is used to animate out visible content\n    .direction-reveal__anim--in, .direction-reveal__anim--out {\n      animation-duration: $anim-duration;\n      animation-timing-function: $anim-easing-easeOutQuad;\n      animation-fill-mode: forwards;\n    }\n\n    .direction-reveal__anim--in {\n      transform: translate3d(0, -100%, 0); // Initial position before any animation i.e. hidden by default\n    }\n\n      .direction-reveal__title {\n        margin-top: 0;\n      }\n\n      .direction-reveal__text {\n        margin-bottom: 0;\n      }\n\n\n\n// ----- Layouts -----\n\n// 3x3 grid layout - flexbox\n.direction-reveal--3-grid-flexbox {\n  display: flex;\n  flex-wrap: wrap;\n  margin-right: -$grid-spacing;\n  margin-left: -$grid-spacing;\n\n  .direction-reveal__card {\n    flex: 0 0 33.333333%;\n    max-width: 33.333333%;\n    border: $grid-spacing solid transparent; // Transparent border used for spacing as this make direction detection more accurate as there is more area to detect.\n  }\n}\n\n// 3x3 grid layout - CSS grid\n.direction-reveal--3-grid-cssgrid {\n  display: grid;\n  grid-template-columns: repeat(3, 1fr);\n  margin-right: -$grid-spacing;\n  margin-left: -$grid-spacing;\n\n  .direction-reveal__card {\n    border: $grid-spacing solid transparent;\n  }\n}\n\n// Bootstrap grid\n.direction-reveal--grid-bootstrap {\n  .direction-reveal__card {\n    margin-top: 15px;\n    margin-bottom: 15px;\n  }\n}\n"]} */ +/*# sourceMappingURL=data:application/json;charset=utf8;base64,{"version":3,"sources":["_animations.scss","_variables.scss","direction-reveal.css","direction-reveal.scss"],"names":[],"mappings":"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","file":"direction-reveal.css","sourcesContent":["// Generates classes to assign animations\n@mixin animation-classes($animation-name) {\n\n  $directions-list: in out;\n  $positions-list:  top bottom left right;\n\n  $directions-opposite-list: out in;\n  $positions-opposite-list:  bottom top right left;\n\n  @each $direction in $directions-list {\n    @each $position in $positions-list {\n\n      $class-name: #{$animation-name}--#{$direction}-#{$position};\n\n      .#{$class-name} {\n        .direction-reveal__anim--in {\n          animation-name: #{$class-name};\n        }\n      }\n\n      $direction-opposite: nth($directions-opposite-list, index($directions-list, $direction));\n      $position-opposite: nth($positions-opposite-list, index($positions-list, $position));\n      $class-name-opposite: #{$animation-name}--#{$direction-opposite}-#{$position-opposite};\n\n      .#{$class-name} {\n        .direction-reveal__anim--out {\n          animation-name: #{$class-name-opposite};\n        }\n      }\n\n    }\n  }\n\n}\n\n\n\n// Swing animation\n\n@include animation-classes('swing');\n\n// Default visible state after animation - used as start or end points for the keyframe animations\n.direction-reveal [class*='swing--'] {\n  perspective: 400px;\n\n  .direction-reveal__anim--in, .direction-reveal__anim--out {\n    transform: rotate3d(0, 0, 0, 0);\n    animation-timing-function: $anim-easing-easeOutCubic;\n  }\n}\n\n.swing--in-top, .swing--out-top {\n  perspective-origin: center top;\n\n  .direction-reveal__anim--in, .direction-reveal__anim--out {\n    transform-origin: center top;\n  }\n}\n\n.swing--in-bottom, .swing--out-bottom {\n  perspective-origin: center bottom;\n\n  .direction-reveal__anim--in, .direction-reveal__anim--out {\n    transform-origin: center bottom;\n  }\n}\n\n.swing--in-left, .swing--out-left {\n  perspective-origin: left center;\n\n  .direction-reveal__anim--in, .direction-reveal__anim--out {\n    transform-origin: left center;\n  }\n}\n\n.swing--in-right, .swing--out-right {\n  perspective-origin: right center;\n\n  .direction-reveal__anim--in, .direction-reveal__anim--out {\n    transform-origin: right center;\n  }\n}\n\n\n@keyframes swing--in-top {\n  0% {\n    transform: rotate3d(-1, 0, 0, 90deg);\n  }\n}\n\n@keyframes swing--out-top {\n  100% {\n    transform: rotate3d(-1, 0, 0, 90deg);\n  }\n}\n\n@keyframes swing--in-bottom {\n  0% {\n    transform: rotate3d(1, 0, 0, 90deg);\n  }\n}\n\n@keyframes swing--out-bottom {\n  100% {\n    transform: rotate3d(1, 0, 0, 90deg);\n  }\n}\n\n@keyframes swing--in-left {\n  0% {\n    transform: rotate3d(0, 1, 0, 90deg);\n  }\n}\n\n@keyframes swing--out-left {\n  100% {\n    transform: rotate3d(0, 1, 0, 90deg);\n  }\n}\n\n@keyframes swing--in-right {\n  0% {\n    transform: rotate3d(0, -1, 0, 90deg);\n  }\n}\n\n@keyframes swing--out-right {\n  100% {\n    transform: rotate3d(0, -1, 0, 90deg);\n  }\n}\n\n\n\n// Slide animation\n\n@include animation-classes('slide');\n\n.direction-reveal [class*='slide--'] {\n  .direction-reveal__anim--in, .direction-reveal__anim--out {\n    transform: translate3d(0, 0, 0);\n    animation-timing-function: $anim-easing-easeOutQuad;\n  }\n}\n\n@keyframes slide--in-top {\n  0% {\n    transform: translate3d(0, -100%, 0);\n  }\n}\n\n@keyframes slide--out-top {\n  100% {\n    transform: translate3d(0, -100%, 0);\n  }\n}\n\n@keyframes slide--in-bottom {\n  0% {\n    transform: translate3d(0, 100%, 0);\n  }\n}\n\n@keyframes slide--out-bottom {\n  100% {\n    transform: translate3d(0, 100%, 0);\n  }\n}\n\n@keyframes slide--in-left {\n  0% {\n    transform: translate3d(-100%, 0, 0);\n  }\n}\n\n@keyframes slide--out-left {\n  100% {\n    transform: translate3d(-100%, 0, 0);\n  }\n}\n\n\n@keyframes slide--in-right {\n  0% {\n    transform: translate3d(100%, 0, 0);\n  }\n}\n\n@keyframes slide--out-right {\n  100% {\n    transform: translate3d(100%, 0, 0);\n  }\n}\n\n\n\n// Rotate animation\n\n@include animation-classes('rotate');\n\n.direction-reveal [class*='rotate--'] {\n  .direction-reveal__anim--in, .direction-reveal__anim--out {\n    transform: rotate(0);\n    animation-timing-function: $anim-easing-easeOutQuad;\n  }\n}\n\n.rotate--in-top, .rotate--out-top {\n  .direction-reveal__anim--in, .direction-reveal__anim--out {\n    transform-origin: left top;\n  }\n}\n\n.rotate--in-bottom, .rotate--out-bottom {\n  .direction-reveal__anim--in, .direction-reveal__anim--out {\n    transform-origin: left bottom;\n  }\n}\n\n.rotate--in-left, .rotate--out-left {\n  .direction-reveal__anim--in, .direction-reveal__anim--out {\n    transform-origin: left top;\n  }\n}\n\n.rotate--in-right, .rotate--out-right {\n  .direction-reveal__anim--in, .direction-reveal__anim--out {\n    transform-origin: right top;\n  }\n}\n\n@keyframes rotate--in-top {\n  0% {\n    transform: rotate(-90deg);\n  }\n}\n\n@keyframes rotate--out-top {\n  100% {\n    transform: rotate(-90deg);\n  }\n}\n\n@keyframes rotate--in-bottom {\n  0% {\n    transform: rotate(90deg);\n  }\n}\n\n@keyframes rotate--out-bottom {\n  100% {\n    transform: rotate(90deg);\n  }\n}\n\n@keyframes rotate--in-left {\n  0% {\n    transform: rotate(90deg);\n  }\n}\n\n@keyframes rotate--out-left {\n  100% {\n    transform: rotate(90deg);\n  }\n}\n\n@keyframes rotate--in-right {\n  0% {\n    transform: rotate(-90deg);\n  }\n}\n\n@keyframes rotate--out-right {\n  100% {\n    transform: rotate(-90deg);\n  }\n}\n\n\n\n// Flip animation\n\n@include animation-classes('flip');\n\n.direction-reveal [class*='flip--'] {\n  perspective: 800px;\n  overflow: visible;\n\n  .direction-reveal__anim--in, .direction-reveal__anim--out {\n    transform: rotateX(0) rotateY(0); // Order must be the same as the animations\n    animation-timing-function: $anim-easing-easeInOutQuad;\n    animation-duration: $anim-duration*2;\n    backface-visibility: hidden;\n    z-index: 1;\n  }\n}\n\n@keyframes flip--in-top {\n  0% {\n    transform: rotateX(180deg) rotateY(0);\n  }\n}\n\n@keyframes flip--out-top {\n  100% {\n    transform: rotateX(180deg) rotateY(0);\n  }\n}\n\n@keyframes flip--in-bottom {\n  0% {\n    transform: rotateX(-180deg) rotateY(0);\n  }\n}\n\n@keyframes flip--out-bottom {\n  100% {\n    transform: rotateX(-180deg) rotateY(0);\n  }\n}\n\n@keyframes flip--in-left {\n  0% {\n    transform: rotateX(0) rotateY(-180deg);\n  }\n}\n\n@keyframes flip--out-left {\n  100% {\n    transform: rotateX(0) rotateY(-180deg);\n  }\n}\n\n@keyframes flip--in-right {\n  0% {\n    transform: rotateX(0) rotateY(180deg);\n  }\n}\n\n@keyframes flip--out-right {\n  100% {\n    transform: rotateX(0) rotateY(180deg);\n  }\n}\n","$anim-easing-easeOutQuad:   cubic-bezier(0.250, 0.460, 0.450, 0.940);\n$anim-easing-easeOutCubic:  cubic-bezier(0.215, 0.610, 0.355, 1.000);\n$anim-easing-easeInOutQuad: cubic-bezier(0.455, 0.030, 0.515, 0.955);\n$anim-duration:             .3s;\n\n$grid-spacing:              10px;\n",".swing--in-top .direction-reveal__anim--in {\n  animation-name: swing--in-top;\n}\n\n.swing--in-top .direction-reveal__anim--out {\n  animation-name: swing--out-bottom;\n}\n\n.swing--in-bottom .direction-reveal__anim--in {\n  animation-name: swing--in-bottom;\n}\n\n.swing--in-bottom .direction-reveal__anim--out {\n  animation-name: swing--out-top;\n}\n\n.swing--in-left .direction-reveal__anim--in {\n  animation-name: swing--in-left;\n}\n\n.swing--in-left .direction-reveal__anim--out {\n  animation-name: swing--out-right;\n}\n\n.swing--in-right .direction-reveal__anim--in {\n  animation-name: swing--in-right;\n}\n\n.swing--in-right .direction-reveal__anim--out {\n  animation-name: swing--out-left;\n}\n\n.swing--out-top .direction-reveal__anim--in {\n  animation-name: swing--out-top;\n}\n\n.swing--out-top .direction-reveal__anim--out {\n  animation-name: swing--in-bottom;\n}\n\n.swing--out-bottom .direction-reveal__anim--in {\n  animation-name: swing--out-bottom;\n}\n\n.swing--out-bottom .direction-reveal__anim--out {\n  animation-name: swing--in-top;\n}\n\n.swing--out-left .direction-reveal__anim--in {\n  animation-name: swing--out-left;\n}\n\n.swing--out-left .direction-reveal__anim--out {\n  animation-name: swing--in-right;\n}\n\n.swing--out-right .direction-reveal__anim--in {\n  animation-name: swing--out-right;\n}\n\n.swing--out-right .direction-reveal__anim--out {\n  animation-name: swing--in-left;\n}\n\n.direction-reveal [class*='swing--'] {\n  perspective: 400px;\n}\n\n.direction-reveal [class*='swing--'] .direction-reveal__anim--in, .direction-reveal [class*='swing--'] .direction-reveal__anim--out {\n  transform: rotate3d(0, 0, 0, 0);\n  animation-timing-function: cubic-bezier(0.215, 0.61, 0.355, 1);\n}\n\n.swing--in-top, .swing--out-top {\n  perspective-origin: center top;\n}\n\n.swing--in-top .direction-reveal__anim--in, .swing--in-top .direction-reveal__anim--out, .swing--out-top .direction-reveal__anim--in, .swing--out-top .direction-reveal__anim--out {\n  transform-origin: center top;\n}\n\n.swing--in-bottom, .swing--out-bottom {\n  perspective-origin: center bottom;\n}\n\n.swing--in-bottom .direction-reveal__anim--in, .swing--in-bottom .direction-reveal__anim--out, .swing--out-bottom .direction-reveal__anim--in, .swing--out-bottom .direction-reveal__anim--out {\n  transform-origin: center bottom;\n}\n\n.swing--in-left, .swing--out-left {\n  perspective-origin: left center;\n}\n\n.swing--in-left .direction-reveal__anim--in, .swing--in-left .direction-reveal__anim--out, .swing--out-left .direction-reveal__anim--in, .swing--out-left .direction-reveal__anim--out {\n  transform-origin: left center;\n}\n\n.swing--in-right, .swing--out-right {\n  perspective-origin: right center;\n}\n\n.swing--in-right .direction-reveal__anim--in, .swing--in-right .direction-reveal__anim--out, .swing--out-right .direction-reveal__anim--in, .swing--out-right .direction-reveal__anim--out {\n  transform-origin: right center;\n}\n\n@keyframes swing--in-top {\n  0% {\n    transform: rotate3d(-1, 0, 0, 90deg);\n  }\n}\n\n@keyframes swing--out-top {\n  100% {\n    transform: rotate3d(-1, 0, 0, 90deg);\n  }\n}\n\n@keyframes swing--in-bottom {\n  0% {\n    transform: rotate3d(1, 0, 0, 90deg);\n  }\n}\n\n@keyframes swing--out-bottom {\n  100% {\n    transform: rotate3d(1, 0, 0, 90deg);\n  }\n}\n\n@keyframes swing--in-left {\n  0% {\n    transform: rotate3d(0, 1, 0, 90deg);\n  }\n}\n\n@keyframes swing--out-left {\n  100% {\n    transform: rotate3d(0, 1, 0, 90deg);\n  }\n}\n\n@keyframes swing--in-right {\n  0% {\n    transform: rotate3d(0, -1, 0, 90deg);\n  }\n}\n\n@keyframes swing--out-right {\n  100% {\n    transform: rotate3d(0, -1, 0, 90deg);\n  }\n}\n\n.slide--in-top .direction-reveal__anim--in {\n  animation-name: slide--in-top;\n}\n\n.slide--in-top .direction-reveal__anim--out {\n  animation-name: slide--out-bottom;\n}\n\n.slide--in-bottom .direction-reveal__anim--in {\n  animation-name: slide--in-bottom;\n}\n\n.slide--in-bottom .direction-reveal__anim--out {\n  animation-name: slide--out-top;\n}\n\n.slide--in-left .direction-reveal__anim--in {\n  animation-name: slide--in-left;\n}\n\n.slide--in-left .direction-reveal__anim--out {\n  animation-name: slide--out-right;\n}\n\n.slide--in-right .direction-reveal__anim--in {\n  animation-name: slide--in-right;\n}\n\n.slide--in-right .direction-reveal__anim--out {\n  animation-name: slide--out-left;\n}\n\n.slide--out-top .direction-reveal__anim--in {\n  animation-name: slide--out-top;\n}\n\n.slide--out-top .direction-reveal__anim--out {\n  animation-name: slide--in-bottom;\n}\n\n.slide--out-bottom .direction-reveal__anim--in {\n  animation-name: slide--out-bottom;\n}\n\n.slide--out-bottom .direction-reveal__anim--out {\n  animation-name: slide--in-top;\n}\n\n.slide--out-left .direction-reveal__anim--in {\n  animation-name: slide--out-left;\n}\n\n.slide--out-left .direction-reveal__anim--out {\n  animation-name: slide--in-right;\n}\n\n.slide--out-right .direction-reveal__anim--in {\n  animation-name: slide--out-right;\n}\n\n.slide--out-right .direction-reveal__anim--out {\n  animation-name: slide--in-left;\n}\n\n.direction-reveal [class*='slide--'] .direction-reveal__anim--in, .direction-reveal [class*='slide--'] .direction-reveal__anim--out {\n  transform: translate3d(0, 0, 0);\n  animation-timing-function: cubic-bezier(0.25, 0.46, 0.45, 0.94);\n}\n\n@keyframes slide--in-top {\n  0% {\n    transform: translate3d(0, -100%, 0);\n  }\n}\n\n@keyframes slide--out-top {\n  100% {\n    transform: translate3d(0, -100%, 0);\n  }\n}\n\n@keyframes slide--in-bottom {\n  0% {\n    transform: translate3d(0, 100%, 0);\n  }\n}\n\n@keyframes slide--out-bottom {\n  100% {\n    transform: translate3d(0, 100%, 0);\n  }\n}\n\n@keyframes slide--in-left {\n  0% {\n    transform: translate3d(-100%, 0, 0);\n  }\n}\n\n@keyframes slide--out-left {\n  100% {\n    transform: translate3d(-100%, 0, 0);\n  }\n}\n\n@keyframes slide--in-right {\n  0% {\n    transform: translate3d(100%, 0, 0);\n  }\n}\n\n@keyframes slide--out-right {\n  100% {\n    transform: translate3d(100%, 0, 0);\n  }\n}\n\n.rotate--in-top .direction-reveal__anim--in {\n  animation-name: rotate--in-top;\n}\n\n.rotate--in-top .direction-reveal__anim--out {\n  animation-name: rotate--out-bottom;\n}\n\n.rotate--in-bottom .direction-reveal__anim--in {\n  animation-name: rotate--in-bottom;\n}\n\n.rotate--in-bottom .direction-reveal__anim--out {\n  animation-name: rotate--out-top;\n}\n\n.rotate--in-left .direction-reveal__anim--in {\n  animation-name: rotate--in-left;\n}\n\n.rotate--in-left .direction-reveal__anim--out {\n  animation-name: rotate--out-right;\n}\n\n.rotate--in-right .direction-reveal__anim--in {\n  animation-name: rotate--in-right;\n}\n\n.rotate--in-right .direction-reveal__anim--out {\n  animation-name: rotate--out-left;\n}\n\n.rotate--out-top .direction-reveal__anim--in {\n  animation-name: rotate--out-top;\n}\n\n.rotate--out-top .direction-reveal__anim--out {\n  animation-name: rotate--in-bottom;\n}\n\n.rotate--out-bottom .direction-reveal__anim--in {\n  animation-name: rotate--out-bottom;\n}\n\n.rotate--out-bottom .direction-reveal__anim--out {\n  animation-name: rotate--in-top;\n}\n\n.rotate--out-left .direction-reveal__anim--in {\n  animation-name: rotate--out-left;\n}\n\n.rotate--out-left .direction-reveal__anim--out {\n  animation-name: rotate--in-right;\n}\n\n.rotate--out-right .direction-reveal__anim--in {\n  animation-name: rotate--out-right;\n}\n\n.rotate--out-right .direction-reveal__anim--out {\n  animation-name: rotate--in-left;\n}\n\n.direction-reveal [class*='rotate--'] .direction-reveal__anim--in, .direction-reveal [class*='rotate--'] .direction-reveal__anim--out {\n  transform: rotate(0);\n  animation-timing-function: cubic-bezier(0.25, 0.46, 0.45, 0.94);\n}\n\n.rotate--in-top .direction-reveal__anim--in, .rotate--in-top .direction-reveal__anim--out, .rotate--out-top .direction-reveal__anim--in, .rotate--out-top .direction-reveal__anim--out {\n  transform-origin: left top;\n}\n\n.rotate--in-bottom .direction-reveal__anim--in, .rotate--in-bottom .direction-reveal__anim--out, .rotate--out-bottom .direction-reveal__anim--in, .rotate--out-bottom .direction-reveal__anim--out {\n  transform-origin: left bottom;\n}\n\n.rotate--in-left .direction-reveal__anim--in, .rotate--in-left .direction-reveal__anim--out, .rotate--out-left .direction-reveal__anim--in, .rotate--out-left .direction-reveal__anim--out {\n  transform-origin: left top;\n}\n\n.rotate--in-right .direction-reveal__anim--in, .rotate--in-right .direction-reveal__anim--out, .rotate--out-right .direction-reveal__anim--in, .rotate--out-right .direction-reveal__anim--out {\n  transform-origin: right top;\n}\n\n@keyframes rotate--in-top {\n  0% {\n    transform: rotate(-90deg);\n  }\n}\n\n@keyframes rotate--out-top {\n  100% {\n    transform: rotate(-90deg);\n  }\n}\n\n@keyframes rotate--in-bottom {\n  0% {\n    transform: rotate(90deg);\n  }\n}\n\n@keyframes rotate--out-bottom {\n  100% {\n    transform: rotate(90deg);\n  }\n}\n\n@keyframes rotate--in-left {\n  0% {\n    transform: rotate(90deg);\n  }\n}\n\n@keyframes rotate--out-left {\n  100% {\n    transform: rotate(90deg);\n  }\n}\n\n@keyframes rotate--in-right {\n  0% {\n    transform: rotate(-90deg);\n  }\n}\n\n@keyframes rotate--out-right {\n  100% {\n    transform: rotate(-90deg);\n  }\n}\n\n.flip--in-top .direction-reveal__anim--in {\n  animation-name: flip--in-top;\n}\n\n.flip--in-top .direction-reveal__anim--out {\n  animation-name: flip--out-bottom;\n}\n\n.flip--in-bottom .direction-reveal__anim--in {\n  animation-name: flip--in-bottom;\n}\n\n.flip--in-bottom .direction-reveal__anim--out {\n  animation-name: flip--out-top;\n}\n\n.flip--in-left .direction-reveal__anim--in {\n  animation-name: flip--in-left;\n}\n\n.flip--in-left .direction-reveal__anim--out {\n  animation-name: flip--out-right;\n}\n\n.flip--in-right .direction-reveal__anim--in {\n  animation-name: flip--in-right;\n}\n\n.flip--in-right .direction-reveal__anim--out {\n  animation-name: flip--out-left;\n}\n\n.flip--out-top .direction-reveal__anim--in {\n  animation-name: flip--out-top;\n}\n\n.flip--out-top .direction-reveal__anim--out {\n  animation-name: flip--in-bottom;\n}\n\n.flip--out-bottom .direction-reveal__anim--in {\n  animation-name: flip--out-bottom;\n}\n\n.flip--out-bottom .direction-reveal__anim--out {\n  animation-name: flip--in-top;\n}\n\n.flip--out-left .direction-reveal__anim--in {\n  animation-name: flip--out-left;\n}\n\n.flip--out-left .direction-reveal__anim--out {\n  animation-name: flip--in-right;\n}\n\n.flip--out-right .direction-reveal__anim--in {\n  animation-name: flip--out-right;\n}\n\n.flip--out-right .direction-reveal__anim--out {\n  animation-name: flip--in-left;\n}\n\n.direction-reveal [class*='flip--'] {\n  perspective: 800px;\n  overflow: visible;\n}\n\n.direction-reveal [class*='flip--'] .direction-reveal__anim--in, .direction-reveal [class*='flip--'] .direction-reveal__anim--out {\n  transform: rotateX(0) rotateY(0);\n  animation-timing-function: cubic-bezier(0.455, 0.03, 0.515, 0.955);\n  animation-duration: 0.6s;\n  backface-visibility: hidden;\n  z-index: 1;\n}\n\n@keyframes flip--in-top {\n  0% {\n    transform: rotateX(180deg) rotateY(0);\n  }\n}\n\n@keyframes flip--out-top {\n  100% {\n    transform: rotateX(180deg) rotateY(0);\n  }\n}\n\n@keyframes flip--in-bottom {\n  0% {\n    transform: rotateX(-180deg) rotateY(0);\n  }\n}\n\n@keyframes flip--out-bottom {\n  100% {\n    transform: rotateX(-180deg) rotateY(0);\n  }\n}\n\n@keyframes flip--in-left {\n  0% {\n    transform: rotateX(0) rotateY(-180deg);\n  }\n}\n\n@keyframes flip--out-left {\n  100% {\n    transform: rotateX(0) rotateY(-180deg);\n  }\n}\n\n@keyframes flip--in-right {\n  0% {\n    transform: rotateX(0) rotateY(180deg);\n  }\n}\n\n@keyframes flip--out-right {\n  100% {\n    transform: rotateX(0) rotateY(180deg);\n  }\n}\n\n.direction-reveal__card {\n  display: inline-block;\n  position: relative;\n  overflow: hidden;\n}\n\n.direction-reveal__overlay {\n  position: absolute;\n  top: 0;\n  left: 0;\n  width: 100%;\n  height: 100%;\n  padding: 15px;\n  color: #fff;\n  overflow: hidden;\n  background-color: rgba(0, 0, 0, 0.6);\n}\n\n.direction-reveal__anim--in, .direction-reveal__anim--out {\n  animation-duration: 0.3s;\n  animation-timing-function: cubic-bezier(0.25, 0.46, 0.45, 0.94);\n  animation-fill-mode: forwards;\n}\n\n.direction-reveal__anim--in {\n  transform: translate3d(0, -100%, 0);\n}\n\n.direction-reveal__title {\n  margin-top: 0;\n}\n\n.direction-reveal__text {\n  margin-bottom: 0;\n}\n\n.direction-reveal--3-grid-flexbox {\n  display: flex;\n  flex-wrap: wrap;\n  margin-right: -10px;\n  margin-left: -10px;\n}\n\n.direction-reveal--3-grid-flexbox .direction-reveal__card {\n  border: 10px solid transparent;\n}\n\n@media (min-width: 576px) {\n  .direction-reveal--3-grid-flexbox .direction-reveal__card {\n    flex: 0 0 33.333333%;\n    max-width: 33.333333%;\n  }\n}\n\n.direction-reveal--3-grid-cssgrid {\n  display: grid;\n  margin-right: -10px;\n  margin-left: -10px;\n}\n\n@media (min-width: 576px) {\n  .direction-reveal--3-grid-cssgrid {\n    grid-template-columns: repeat(3, 1fr);\n  }\n}\n\n.direction-reveal--3-grid-cssgrid .direction-reveal__card {\n  border: 10px solid transparent;\n}\n\n.direction-reveal--grid-bootstrap .direction-reveal__card {\n  margin-top: 15px;\n  margin-bottom: 15px;\n}\n","@import 'variables';\n@import 'animations';\n\n\n// ----- Component -----\n.direction-reveal {}\n\n  .direction-reveal__card {\n    display: inline-block;\n    position: relative;\n    overflow: hidden;\n  }\n\n    .direction-reveal__overlay {\n      position: absolute;\n      top: 0;\n      left: 0;\n      width: 100%;\n      height: 100%;\n      padding: 15px;\n      color: #fff;\n      overflow: hidden;\n      background-color: rgba(0, 0, 0, .6);\n    }\n\n    // .direction-reveal__anim--in is used to animate in hidden content, the default animation used on the overlay\n    // .direction-reveal__anim--out is used to animate out visible content\n    .direction-reveal__anim--in, .direction-reveal__anim--out {\n      animation-duration: $anim-duration;\n      animation-timing-function: $anim-easing-easeOutQuad;\n      animation-fill-mode: forwards;\n    }\n\n    .direction-reveal__anim--in {\n      transform: translate3d(0, -100%, 0); // Initial position before any animation i.e. hidden by default\n    }\n\n      .direction-reveal__title {\n        margin-top: 0;\n      }\n\n      .direction-reveal__text {\n        margin-bottom: 0;\n      }\n\n\n\n// ----- Layouts -----\n\n// 3x3 grid layout - flexbox\n.direction-reveal--3-grid-flexbox {\n  display: flex;\n  flex-wrap: wrap;\n  margin-right: -$grid-spacing;\n  margin-left: -$grid-spacing;\n\n  .direction-reveal__card {\n    border: $grid-spacing solid transparent; // Transparent border used for spacing as this make direction detection more accurate as there is more area to detect.\n    @media (min-width: 576px) {\n      flex: 0 0 33.333333%;\n      max-width: 33.333333%;\n    }\n  }\n\n}\n\n// 3x3 grid layout - CSS grid\n.direction-reveal--3-grid-cssgrid {\n  display: grid;\n  margin-right: -$grid-spacing;\n  margin-left: -$grid-spacing;\n\n  @media (min-width: 576px) {\n    grid-template-columns: repeat(3, 1fr);\n  }\n\n  .direction-reveal__card {\n    border: $grid-spacing solid transparent;\n  }\n}\n\n// Bootstrap grid\n.direction-reveal--grid-bootstrap {\n  .direction-reveal__card {\n    margin-top: 15px;\n    margin-bottom: 15px;\n  }\n}\n"]} */ diff --git a/styles/direction-reveal.scss b/styles/direction-reveal.scss index c645fc6..ae378e4 100644 --- a/styles/direction-reveal.scss +++ b/styles/direction-reveal.scss @@ -55,19 +55,25 @@ margin-left: -$grid-spacing; .direction-reveal__card { - flex: 0 0 33.333333%; - max-width: 33.333333%; border: $grid-spacing solid transparent; // Transparent border used for spacing as this make direction detection more accurate as there is more area to detect. + @media (min-width: 576px) { + flex: 0 0 33.333333%; + max-width: 33.333333%; + } } + } // 3x3 grid layout - CSS grid .direction-reveal--3-grid-cssgrid { display: grid; - grid-template-columns: repeat(3, 1fr); margin-right: -$grid-spacing; margin-left: -$grid-spacing; + @media (min-width: 576px) { + grid-template-columns: repeat(3, 1fr); + } + .direction-reveal__card { border: $grid-spacing solid transparent; } diff --git a/styles/site.css b/styles/site.css index 82d43f6..07aca13 100644 --- a/styles/site.css +++ b/styles/site.css @@ -443,7 +443,7 @@ html { } body { - padding-top: 90px; + padding-top: 110px; font-family: "Lato", "Helvetica Neue", Helvetica, Arial, sans-serif; font-size: 18px; font-weight: 300; @@ -452,6 +452,12 @@ body { background-color: #fff; } +@media (min-width: 768px) { + body { + padding-top: 90px; + } +} + a { color: #1976D2; text-decoration: none; @@ -612,14 +618,19 @@ strong { } .demo { - margin-top: 20px; + margin-top: 40px; margin-bottom: 40px; } .demo--intro { + margin-top: 20px; border-bottom: 1px solid #ddd; } +.demo--intro p:last-child { + padding-bottom: 20px; +} + .btn { display: inline-block; text-align: center; @@ -662,4 +673,4 @@ pre { border-radius: 4px; } -/*# sourceMappingURL=data:application/json;charset=utf8;base64,{"version":3,"sources":["site/_normalize.scss","site.css","site/_site.scss"],"names":[],"mappings":"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","file":"site.css","sourcesContent":["/*! normalize.css v7.0.0 | MIT License | github.com/necolas/normalize.css */\n\n/* Document\n   ========================================================================== */\n\n/**\n * 1. Correct the line height in all browsers.\n * 2. Prevent adjustments of font size after orientation changes in\n *    IE on Windows Phone and in iOS.\n */\n\n html {\n  line-height: 1.15; /* 1 */\n  -ms-text-size-adjust: 100%; /* 2 */\n  -webkit-text-size-adjust: 100%; /* 2 */\n}\n\n/* Sections\n   ========================================================================== */\n\n/**\n * Remove the margin in all browsers (opinionated).\n */\n\nbody {\n  margin: 0;\n}\n\n/**\n * Add the correct display in IE 9-.\n */\n\narticle,\naside,\nfooter,\nheader,\nnav,\nsection {\n  display: block;\n}\n\n/**\n * Correct the font size and margin on `h1` elements within `section` and\n * `article` contexts in Chrome, Firefox, and Safari.\n */\n\nh1 {\n  font-size: 2em;\n  margin: 0.67em 0;\n}\n\n/* Grouping content\n   ========================================================================== */\n\n/**\n * Add the correct display in IE 9-.\n * 1. Add the correct display in IE.\n */\n\nfigcaption,\nfigure,\nmain { /* 1 */\n  display: block;\n}\n\n/**\n * Add the correct margin in IE 8.\n */\n\nfigure {\n  margin: 1em 40px;\n}\n\n/**\n * 1. Add the correct box sizing in Firefox.\n * 2. Show the overflow in Edge and IE.\n */\n\nhr {\n  box-sizing: content-box; /* 1 */\n  height: 0; /* 1 */\n  overflow: visible; /* 2 */\n}\n\n/**\n * 1. Correct the inheritance and scaling of font size in all browsers.\n * 2. Correct the odd `em` font sizing in all browsers.\n */\n\npre {\n  font-family: monospace, monospace; /* 1 */\n  font-size: 1em; /* 2 */\n}\n\n/* Text-level semantics\n   ========================================================================== */\n\n/**\n * 1. Remove the gray background on active links in IE 10.\n * 2. Remove gaps in links underline in iOS 8+ and Safari 8+.\n */\n\na {\n  background-color: transparent; /* 1 */\n  -webkit-text-decoration-skip: objects; /* 2 */\n}\n\n/**\n * 1. Remove the bottom border in Chrome 57- and Firefox 39-.\n * 2. Add the correct text decoration in Chrome, Edge, IE, Opera, and Safari.\n */\n\nabbr[title] {\n  border-bottom: none; /* 1 */\n  text-decoration: underline; /* 2 */\n  text-decoration: underline dotted; /* 2 */\n}\n\n/**\n * Prevent the duplicate application of `bolder` by the next rule in Safari 6.\n */\n\nb,\nstrong {\n  font-weight: inherit;\n}\n\n/**\n * Add the correct font weight in Chrome, Edge, and Safari.\n */\n\nb,\nstrong {\n  font-weight: bolder;\n}\n\n/**\n * 1. Correct the inheritance and scaling of font size in all browsers.\n * 2. Correct the odd `em` font sizing in all browsers.\n */\n\ncode,\nkbd,\nsamp {\n  font-family: monospace, monospace; /* 1 */\n  font-size: 1em; /* 2 */\n}\n\n/**\n * Add the correct font style in Android 4.3-.\n */\n\ndfn {\n  font-style: italic;\n}\n\n/**\n * Add the correct background and color in IE 9-.\n */\n\nmark {\n  background-color: #ff0;\n  color: #000;\n}\n\n/**\n * Add the correct font size in all browsers.\n */\n\nsmall {\n  font-size: 80%;\n}\n\n/**\n * Prevent `sub` and `sup` elements from affecting the line height in\n * all browsers.\n */\n\nsub,\nsup {\n  font-size: 75%;\n  line-height: 0;\n  position: relative;\n  vertical-align: baseline;\n}\n\nsub {\n  bottom: -0.25em;\n}\n\nsup {\n  top: -0.5em;\n}\n\n/* Embedded content\n   ========================================================================== */\n\n/**\n * Add the correct display in IE 9-.\n */\n\naudio,\nvideo {\n  display: inline-block;\n}\n\n/**\n * Add the correct display in iOS 4-7.\n */\n\naudio:not([controls]) {\n  display: none;\n  height: 0;\n}\n\n/**\n * Remove the border on images inside links in IE 10-.\n */\n\nimg {\n  border-style: none;\n}\n\n/**\n * Hide the overflow in IE.\n */\n\nsvg:not(:root) {\n  overflow: hidden;\n}\n\n/* Forms\n   ========================================================================== */\n\n/**\n * 1. Change the font styles in all browsers (opinionated).\n * 2. Remove the margin in Firefox and Safari.\n */\n\nbutton,\ninput,\noptgroup,\nselect,\ntextarea {\n  font-family: sans-serif; /* 1 */\n  font-size: 100%; /* 1 */\n  line-height: 1.15; /* 1 */\n  margin: 0; /* 2 */\n}\n\n/**\n * Show the overflow in IE.\n * 1. Show the overflow in Edge.\n */\n\nbutton,\ninput { /* 1 */\n  overflow: visible;\n}\n\n/**\n * Remove the inheritance of text transform in Edge, Firefox, and IE.\n * 1. Remove the inheritance of text transform in Firefox.\n */\n\nbutton,\nselect { /* 1 */\n  text-transform: none;\n}\n\n/**\n * 1. Prevent a WebKit bug where (2) destroys native `audio` and `video`\n *    controls in Android 4.\n * 2. Correct the inability to style clickable types in iOS and Safari.\n */\n\nbutton,\nhtml [type=\"button\"], /* 1 */\n[type=\"reset\"],\n[type=\"submit\"] {\n  -webkit-appearance: button; /* 2 */\n}\n\n/**\n * Remove the inner border and padding in Firefox.\n */\n\nbutton::-moz-focus-inner,\n[type=\"button\"]::-moz-focus-inner,\n[type=\"reset\"]::-moz-focus-inner,\n[type=\"submit\"]::-moz-focus-inner {\n  border-style: none;\n  padding: 0;\n}\n\n/**\n * Restore the focus styles unset by the previous rule.\n */\n\nbutton:-moz-focusring,\n[type=\"button\"]:-moz-focusring,\n[type=\"reset\"]:-moz-focusring,\n[type=\"submit\"]:-moz-focusring {\n  outline: 1px dotted ButtonText;\n}\n\n/**\n * Correct the padding in Firefox.\n */\n\nfieldset {\n  padding: 0.35em 0.75em 0.625em;\n}\n\n/**\n * 1. Correct the text wrapping in Edge and IE.\n * 2. Correct the color inheritance from `fieldset` elements in IE.\n * 3. Remove the padding so developers are not caught out when they zero out\n *    `fieldset` elements in all browsers.\n */\n\nlegend {\n  box-sizing: border-box; /* 1 */\n  color: inherit; /* 2 */\n  display: table; /* 1 */\n  max-width: 100%; /* 1 */\n  padding: 0; /* 3 */\n  white-space: normal; /* 1 */\n}\n\n/**\n * 1. Add the correct display in IE 9-.\n * 2. Add the correct vertical alignment in Chrome, Firefox, and Opera.\n */\n\nprogress {\n  display: inline-block; /* 1 */\n  vertical-align: baseline; /* 2 */\n}\n\n/**\n * Remove the default vertical scrollbar in IE.\n */\n\ntextarea {\n  overflow: auto;\n}\n\n/**\n * 1. Add the correct box sizing in IE 10-.\n * 2. Remove the padding in IE 10-.\n */\n\n[type=\"checkbox\"],\n[type=\"radio\"] {\n  box-sizing: border-box; /* 1 */\n  padding: 0; /* 2 */\n}\n\n/**\n * Correct the cursor style of increment and decrement buttons in Chrome.\n */\n\n[type=\"number\"]::-webkit-inner-spin-button,\n[type=\"number\"]::-webkit-outer-spin-button {\n  height: auto;\n}\n\n/**\n * 1. Correct the odd appearance in Chrome and Safari.\n * 2. Correct the outline style in Safari.\n */\n\n[type=\"search\"] {\n  -webkit-appearance: textfield; /* 1 */\n  outline-offset: -2px; /* 2 */\n}\n\n/**\n * Remove the inner padding and cancel buttons in Chrome and Safari on macOS.\n */\n\n[type=\"search\"]::-webkit-search-cancel-button,\n[type=\"search\"]::-webkit-search-decoration {\n  -webkit-appearance: none;\n}\n\n/**\n * 1. Correct the inability to style clickable types in iOS and Safari.\n * 2. Change font properties to `inherit` in Safari.\n */\n\n::-webkit-file-upload-button {\n  -webkit-appearance: button; /* 1 */\n  font: inherit; /* 2 */\n}\n\n/* Interactive\n   ========================================================================== */\n\n/*\n * Add the correct display in IE 9-.\n * 1. Add the correct display in Edge, IE, and Firefox.\n */\n\ndetails, /* 1 */\nmenu {\n  display: block;\n}\n\n/*\n * Add the correct display in all browsers.\n */\n\nsummary {\n  display: list-item;\n}\n\n/* Scripting\n   ========================================================================== */\n\n/**\n * Add the correct display in IE 9-.\n */\n\ncanvas {\n  display: inline-block;\n}\n\n/**\n * Add the correct display in IE.\n */\n\ntemplate {\n  display: none;\n}\n\n/* Hidden\n   ========================================================================== */\n\n/**\n * Add the correct display in IE 10-.\n */\n\n[hidden] {\n  display: none;\n}\n","/*! normalize.css v7.0.0 | MIT License | github.com/necolas/normalize.css */\n/* Document\n   ========================================================================== */\n/**\n * 1. Correct the line height in all browsers.\n * 2. Prevent adjustments of font size after orientation changes in\n *    IE on Windows Phone and in iOS.\n */\nhtml {\n  line-height: 1.15;\n  /* 1 */\n  -ms-text-size-adjust: 100%;\n  /* 2 */\n  -webkit-text-size-adjust: 100%;\n  /* 2 */\n}\n\n/* Sections\n   ========================================================================== */\n/**\n * Remove the margin in all browsers (opinionated).\n */\nbody {\n  margin: 0;\n}\n\n/**\n * Add the correct display in IE 9-.\n */\narticle,\naside,\nfooter,\nheader,\nnav,\nsection {\n  display: block;\n}\n\n/**\n * Correct the font size and margin on `h1` elements within `section` and\n * `article` contexts in Chrome, Firefox, and Safari.\n */\nh1 {\n  font-size: 2em;\n  margin: 0.67em 0;\n}\n\n/* Grouping content\n   ========================================================================== */\n/**\n * Add the correct display in IE 9-.\n * 1. Add the correct display in IE.\n */\nfigcaption,\nfigure,\nmain {\n  /* 1 */\n  display: block;\n}\n\n/**\n * Add the correct margin in IE 8.\n */\nfigure {\n  margin: 1em 40px;\n}\n\n/**\n * 1. Add the correct box sizing in Firefox.\n * 2. Show the overflow in Edge and IE.\n */\nhr {\n  box-sizing: content-box;\n  /* 1 */\n  height: 0;\n  /* 1 */\n  overflow: visible;\n  /* 2 */\n}\n\n/**\n * 1. Correct the inheritance and scaling of font size in all browsers.\n * 2. Correct the odd `em` font sizing in all browsers.\n */\npre {\n  font-family: monospace, monospace;\n  /* 1 */\n  font-size: 1em;\n  /* 2 */\n}\n\n/* Text-level semantics\n   ========================================================================== */\n/**\n * 1. Remove the gray background on active links in IE 10.\n * 2. Remove gaps in links underline in iOS 8+ and Safari 8+.\n */\na {\n  background-color: transparent;\n  /* 1 */\n  -webkit-text-decoration-skip: objects;\n  /* 2 */\n}\n\n/**\n * 1. Remove the bottom border in Chrome 57- and Firefox 39-.\n * 2. Add the correct text decoration in Chrome, Edge, IE, Opera, and Safari.\n */\nabbr[title] {\n  border-bottom: none;\n  /* 1 */\n  text-decoration: underline;\n  /* 2 */\n  text-decoration: underline dotted;\n  /* 2 */\n}\n\n/**\n * Prevent the duplicate application of `bolder` by the next rule in Safari 6.\n */\nb,\nstrong {\n  font-weight: inherit;\n}\n\n/**\n * Add the correct font weight in Chrome, Edge, and Safari.\n */\nb,\nstrong {\n  font-weight: bolder;\n}\n\n/**\n * 1. Correct the inheritance and scaling of font size in all browsers.\n * 2. Correct the odd `em` font sizing in all browsers.\n */\ncode,\nkbd,\nsamp {\n  font-family: monospace, monospace;\n  /* 1 */\n  font-size: 1em;\n  /* 2 */\n}\n\n/**\n * Add the correct font style in Android 4.3-.\n */\ndfn {\n  font-style: italic;\n}\n\n/**\n * Add the correct background and color in IE 9-.\n */\nmark {\n  background-color: #ff0;\n  color: #000;\n}\n\n/**\n * Add the correct font size in all browsers.\n */\nsmall {\n  font-size: 80%;\n}\n\n/**\n * Prevent `sub` and `sup` elements from affecting the line height in\n * all browsers.\n */\nsub,\nsup {\n  font-size: 75%;\n  line-height: 0;\n  position: relative;\n  vertical-align: baseline;\n}\n\nsub {\n  bottom: -0.25em;\n}\n\nsup {\n  top: -0.5em;\n}\n\n/* Embedded content\n   ========================================================================== */\n/**\n * Add the correct display in IE 9-.\n */\naudio,\nvideo {\n  display: inline-block;\n}\n\n/**\n * Add the correct display in iOS 4-7.\n */\naudio:not([controls]) {\n  display: none;\n  height: 0;\n}\n\n/**\n * Remove the border on images inside links in IE 10-.\n */\nimg {\n  border-style: none;\n}\n\n/**\n * Hide the overflow in IE.\n */\nsvg:not(:root) {\n  overflow: hidden;\n}\n\n/* Forms\n   ========================================================================== */\n/**\n * 1. Change the font styles in all browsers (opinionated).\n * 2. Remove the margin in Firefox and Safari.\n */\nbutton,\ninput,\noptgroup,\nselect,\ntextarea {\n  font-family: sans-serif;\n  /* 1 */\n  font-size: 100%;\n  /* 1 */\n  line-height: 1.15;\n  /* 1 */\n  margin: 0;\n  /* 2 */\n}\n\n/**\n * Show the overflow in IE.\n * 1. Show the overflow in Edge.\n */\nbutton,\ninput {\n  /* 1 */\n  overflow: visible;\n}\n\n/**\n * Remove the inheritance of text transform in Edge, Firefox, and IE.\n * 1. Remove the inheritance of text transform in Firefox.\n */\nbutton,\nselect {\n  /* 1 */\n  text-transform: none;\n}\n\n/**\n * 1. Prevent a WebKit bug where (2) destroys native `audio` and `video`\n *    controls in Android 4.\n * 2. Correct the inability to style clickable types in iOS and Safari.\n */\nbutton,\nhtml [type=\"button\"],\n[type=\"reset\"],\n[type=\"submit\"] {\n  -webkit-appearance: button;\n  /* 2 */\n}\n\n/**\n * Remove the inner border and padding in Firefox.\n */\nbutton::-moz-focus-inner,\n[type=\"button\"]::-moz-focus-inner,\n[type=\"reset\"]::-moz-focus-inner,\n[type=\"submit\"]::-moz-focus-inner {\n  border-style: none;\n  padding: 0;\n}\n\n/**\n * Restore the focus styles unset by the previous rule.\n */\nbutton:-moz-focusring,\n[type=\"button\"]:-moz-focusring,\n[type=\"reset\"]:-moz-focusring,\n[type=\"submit\"]:-moz-focusring {\n  outline: 1px dotted ButtonText;\n}\n\n/**\n * Correct the padding in Firefox.\n */\nfieldset {\n  padding: 0.35em 0.75em 0.625em;\n}\n\n/**\n * 1. Correct the text wrapping in Edge and IE.\n * 2. Correct the color inheritance from `fieldset` elements in IE.\n * 3. Remove the padding so developers are not caught out when they zero out\n *    `fieldset` elements in all browsers.\n */\nlegend {\n  box-sizing: border-box;\n  /* 1 */\n  color: inherit;\n  /* 2 */\n  display: table;\n  /* 1 */\n  max-width: 100%;\n  /* 1 */\n  padding: 0;\n  /* 3 */\n  white-space: normal;\n  /* 1 */\n}\n\n/**\n * 1. Add the correct display in IE 9-.\n * 2. Add the correct vertical alignment in Chrome, Firefox, and Opera.\n */\nprogress {\n  display: inline-block;\n  /* 1 */\n  vertical-align: baseline;\n  /* 2 */\n}\n\n/**\n * Remove the default vertical scrollbar in IE.\n */\ntextarea {\n  overflow: auto;\n}\n\n/**\n * 1. Add the correct box sizing in IE 10-.\n * 2. Remove the padding in IE 10-.\n */\n[type=\"checkbox\"],\n[type=\"radio\"] {\n  box-sizing: border-box;\n  /* 1 */\n  padding: 0;\n  /* 2 */\n}\n\n/**\n * Correct the cursor style of increment and decrement buttons in Chrome.\n */\n[type=\"number\"]::-webkit-inner-spin-button,\n[type=\"number\"]::-webkit-outer-spin-button {\n  height: auto;\n}\n\n/**\n * 1. Correct the odd appearance in Chrome and Safari.\n * 2. Correct the outline style in Safari.\n */\n[type=\"search\"] {\n  -webkit-appearance: textfield;\n  /* 1 */\n  outline-offset: -2px;\n  /* 2 */\n}\n\n/**\n * Remove the inner padding and cancel buttons in Chrome and Safari on macOS.\n */\n[type=\"search\"]::-webkit-search-cancel-button,\n[type=\"search\"]::-webkit-search-decoration {\n  -webkit-appearance: none;\n}\n\n/**\n * 1. Correct the inability to style clickable types in iOS and Safari.\n * 2. Change font properties to `inherit` in Safari.\n */\n::-webkit-file-upload-button {\n  -webkit-appearance: button;\n  /* 1 */\n  font: inherit;\n  /* 2 */\n}\n\n/* Interactive\n   ========================================================================== */\n/*\n * Add the correct display in IE 9-.\n * 1. Add the correct display in Edge, IE, and Firefox.\n */\ndetails,\nmenu {\n  display: block;\n}\n\n/*\n * Add the correct display in all browsers.\n */\nsummary {\n  display: list-item;\n}\n\n/* Scripting\n   ========================================================================== */\n/**\n * Add the correct display in IE 9-.\n */\ncanvas {\n  display: inline-block;\n}\n\n/**\n * Add the correct display in IE.\n */\ntemplate {\n  display: none;\n}\n\n/* Hidden\n   ========================================================================== */\n/**\n * Add the correct display in IE 10-.\n */\n[hidden] {\n  display: none;\n}\n\n*,\n*:before,\n*:after {\n  box-sizing: border-box;\n}\n\nhtml {\n  font-size: 10px;\n}\n\nbody {\n  padding-top: 90px;\n  font-family: \"Lato\", \"Helvetica Neue\", Helvetica, Arial, sans-serif;\n  font-size: 18px;\n  font-weight: 300;\n  line-height: 1.4;\n  color: #333;\n  background-color: #fff;\n}\n\na {\n  color: #1976D2;\n  text-decoration: none;\n  transition: color 0.3s;\n}\n\na:hover, a:focus {\n  color: #2196F3;\n}\n\nh1, h2, h3, h4, h5, h6 {\n  font-weight: 300;\n}\n\nh1 small, h2 small, h3 small, h4 small, h5 small, h6 small {\n  font-size: 60%;\n}\n\nh1, h2 {\n  margin: 0 0 20px 0;\n}\n\nh3, h4, h5, h6 {\n  margin: 0 0 15px 0;\n}\n\nh1 {\n  font-size: 38px;\n}\n\nh2 {\n  font-size: 34px;\n}\n\nh3 {\n  font-size: 26px;\n}\n\nh4 {\n  font-size: 20px;\n}\n\nh5 {\n  font-size: 16px;\n}\n\nh6 {\n  font-size: 14px;\n}\n\np {\n  margin: 0 0 15px 0;\n}\n\nstrong {\n  font-weight: 400;\n}\n\n.container {\n  width: 100%;\n  max-width: 1140px;\n  margin-right: auto;\n  margin-left: auto;\n  padding-left: 15px;\n  padding-right: 15px;\n}\n\n.container:before, .container:after {\n  content: \" \";\n  display: table;\n}\n\n.container:after {\n  clear: both;\n}\n\n.row {\n  display: flex;\n  flex-wrap: wrap;\n  margin-right: -15px;\n  margin-left: -15px;\n}\n\n.col-sm-4 {\n  position: relative;\n  width: 100%;\n  padding-left: 15px;\n  padding-right: 15px;\n  min-height: 1px;\n}\n\n@media (min-width: 576px) {\n  .col-sm-4 {\n    flex: 0 0 33.333333%;\n    max-width: 33.333333%;\n  }\n}\n\n.img-fluid {\n  max-width: 100%;\n  height: auto;\n  vertical-align: middle;\n  border-style: none;\n}\n\n.header {\n  position: fixed;\n  top: 0;\n  z-index: 100;\n  width: 100%;\n  padding: 15px 0;\n  color: #fff;\n  background-color: #1976D2;\n  box-shadow: 0 0 6px 6px rgba(0, 0, 0, 0.1);\n}\n\n.logo-text {\n  margin: 0;\n}\n\n@media (max-width: 767px) {\n  .logo-text {\n    font-size: 25px;\n  }\n}\n\n@media (min-width: 768px) {\n  .logo-text {\n    display: inline-block;\n  }\n}\n\n.header--links .btn {\n  margin: 0;\n  margin-top: 7px;\n}\n\n.header--links .btn:last-child {\n  margin-left: 7px;\n}\n\n@media (min-width: 768px) {\n  .header--links {\n    float: right;\n  }\n}\n\n.footer {\n  padding-top: 15px;\n  padding-bottom: 15px;\n  font-size: 12px;\n  text-align: center;\n}\n\n.demo {\n  margin-top: 20px;\n  margin-bottom: 40px;\n}\n\n.demo--intro {\n  border-bottom: 1px solid #ddd;\n}\n\n.btn {\n  display: inline-block;\n  text-align: center;\n  vertical-align: middle;\n  cursor: pointer;\n  border: 1px solid #bbb;\n  padding: 4px 12px 6px 12px;\n  font-size: 18px;\n  background-color: #fff;\n  border-radius: 4px;\n  transition: background-color .3s, color .3s;\n}\n\n.btn:hover, .btn:active {\n  background-color: #f3f3f3;\n}\n\n.btn-white {\n  color: #fff;\n  border-color: #fff;\n  background-color: transparent;\n}\n\n.install .btn {\n  margin-right: 15px;\n  margin-bottom: 15px;\n}\n\npre {\n  display: block;\n  padding: 10px 15px;\n  margin: 0 0 20px 0;\n  overflow: auto;\n  font-family: 'Cutive Mono', monospace;\n  font-size: 14px;\n  word-break: break-all;\n  word-wrap: break-word;\n  background-color: #f3f3f3;\n  border: 1px solid #bbb;\n  border-radius: 4px;\n}\n","// ----- Mixins -----\n@mixin clearfix() {\n  &:before,\n  &:after {\n    content: \" \";\n    display: table;\n  }\n  &:after {\n    clear: both;\n  }\n}\n\n\n// ----- Base styles -----\n\n*,\n*:before,\n*:after {\n  box-sizing: border-box;\n}\n\nhtml {\n  font-size: 10px;\n}\n\nbody {\n  padding-top: 90px;\n  font-family: \"Lato\", \"Helvetica Neue\", Helvetica, Arial, sans-serif;\n  font-size: 18px;\n  font-weight: 300;\n  line-height: 1.4;\n  color: #333;\n  background-color: #fff;\n}\n\na {\n  color: #1976D2;\n  text-decoration: none;\n  transition: color 0.3s;\n\n  &:hover, &:focus {\n    color: #2196F3;\n  }\n}\n\n// Type\nh1, h2, h3, h4, h5, h6 {\n  font-weight: 300;\n\n  small {\n    font-size: 60%;\n  }\n}\nh1, h2 {\n  margin: 0 0 20px 0;\n}\nh3, h4, h5, h6 {\n  margin: 0 0 15px 0;\n}\n\nh1 { font-size: 38px; }\nh2 { font-size: 34px; }\nh3 { font-size: 26px; }\nh4 { font-size: 20px; }\nh5 { font-size: 16px; }\nh6 { font-size: 14px; }\n\np {\n  margin: 0 0 15px 0;\n}\n\nstrong {\n  font-weight: 400;\n}\n\n\n\n// ----- Layout -----\n.container {\n  width: 100%;\n  max-width: 1140px;\n  margin-right: auto;\n  margin-left: auto;\n  padding-left: 15px;\n  padding-right: 15px;\n  @include clearfix();  \n}\n\n// Bootstrap grid example\n  .row {\n    display: flex;\n    flex-wrap: wrap;\n    margin-right: -15px;\n    margin-left: -15px;  \n  }\n\n    .col-sm-4 {\n      position: relative;\n      width: 100%;\n      padding-left: 15px;\n      padding-right: 15px;\n      min-height: 1px;\n    }\n\n    @media (min-width: 576px) {\n      .col-sm-4 {\n        flex: 0 0 33.333333%;\n        max-width: 33.333333%;\n      }\n    }\n\n\n.img-fluid {\n  max-width: 100%;\n  height: auto;\n  vertical-align: middle;\n  border-style: none;\n}\n\n\n// ----- Header and footer -----\n.header {\n  position: fixed;\n  top: 0;\n  z-index: 100;\n  width: 100%;\n  padding: 15px 0;\n  color: #fff;\n  background-color: #1976D2;\n  box-shadow: 0 0 6px 6px rgba(0,0,0,0.1);\n}\n\n  .logo-text {\n    margin: 0;\n\n    @media (max-width: 767px) {\n      font-size: 25px;\n    }\n    @media (min-width: 768px) {\n      display: inline-block;\n    }\n  }\n\n  .header--links {\n\n    .btn {\n      margin: 0;\n      margin-top: 7px;\n\n      &:last-child {\n        margin-left: 7px;\n      }\n    }\n    \n    @media (min-width: 768px) {\n      float: right;\n    }\n  }\n\n.footer {\n  padding-top: 15px;\n  padding-bottom: 15px;\n  font-size: 12px;\n  text-align: center;\n}\n\n\n// ----- Demo -----\n.demo {\n  margin-top: 20px;\n  margin-bottom: 40px;\n}\n\n.demo--intro {\n  border-bottom: 1px solid #ddd;\n}\n\n.btn {\n  display: inline-block;\n  text-align: center;\n  vertical-align: middle;\n  cursor: pointer;\n  border: 1px solid #bbb;\n  padding: 4px 12px 6px 12px;\n  font-size: 18px;\n  background-color: #fff;\n  border-radius: 4px;\n  transition: background-color .3s, color .3s;\n\n  &:hover, &:active {\n    background-color: #f3f3f3;\n  }\n}\n\n.btn-white {\n  color: #fff;\n  border-color: #fff;\n  background-color: transparent;\n}\n\n.install .btn {\n  margin-right: 15px;\n  margin-bottom: 15px;\n}\n\npre {\n  display: block;\n  padding: 10px 15px;\n  margin: 0 0 20px 0;\n  overflow: auto;\n  font-family: 'Cutive Mono', monospace;\n  font-size: 14px;\n  word-break: break-all;\n  word-wrap: break-word;\n  background-color: #f3f3f3;\n  border: 1px solid #bbb;\n  border-radius: 4px;\n}\n"]} */ +/*# sourceMappingURL=data:application/json;charset=utf8;base64,{"version":3,"sources":["site/_normalize.scss","site.css","site/_site.scss"],"names":[],"mappings":"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","file":"site.css","sourcesContent":["/*! normalize.css v7.0.0 | MIT License | github.com/necolas/normalize.css */\n\n/* Document\n   ========================================================================== */\n\n/**\n * 1. Correct the line height in all browsers.\n * 2. Prevent adjustments of font size after orientation changes in\n *    IE on Windows Phone and in iOS.\n */\n\n html {\n  line-height: 1.15; /* 1 */\n  -ms-text-size-adjust: 100%; /* 2 */\n  -webkit-text-size-adjust: 100%; /* 2 */\n}\n\n/* Sections\n   ========================================================================== */\n\n/**\n * Remove the margin in all browsers (opinionated).\n */\n\nbody {\n  margin: 0;\n}\n\n/**\n * Add the correct display in IE 9-.\n */\n\narticle,\naside,\nfooter,\nheader,\nnav,\nsection {\n  display: block;\n}\n\n/**\n * Correct the font size and margin on `h1` elements within `section` and\n * `article` contexts in Chrome, Firefox, and Safari.\n */\n\nh1 {\n  font-size: 2em;\n  margin: 0.67em 0;\n}\n\n/* Grouping content\n   ========================================================================== */\n\n/**\n * Add the correct display in IE 9-.\n * 1. Add the correct display in IE.\n */\n\nfigcaption,\nfigure,\nmain { /* 1 */\n  display: block;\n}\n\n/**\n * Add the correct margin in IE 8.\n */\n\nfigure {\n  margin: 1em 40px;\n}\n\n/**\n * 1. Add the correct box sizing in Firefox.\n * 2. Show the overflow in Edge and IE.\n */\n\nhr {\n  box-sizing: content-box; /* 1 */\n  height: 0; /* 1 */\n  overflow: visible; /* 2 */\n}\n\n/**\n * 1. Correct the inheritance and scaling of font size in all browsers.\n * 2. Correct the odd `em` font sizing in all browsers.\n */\n\npre {\n  font-family: monospace, monospace; /* 1 */\n  font-size: 1em; /* 2 */\n}\n\n/* Text-level semantics\n   ========================================================================== */\n\n/**\n * 1. Remove the gray background on active links in IE 10.\n * 2. Remove gaps in links underline in iOS 8+ and Safari 8+.\n */\n\na {\n  background-color: transparent; /* 1 */\n  -webkit-text-decoration-skip: objects; /* 2 */\n}\n\n/**\n * 1. Remove the bottom border in Chrome 57- and Firefox 39-.\n * 2. Add the correct text decoration in Chrome, Edge, IE, Opera, and Safari.\n */\n\nabbr[title] {\n  border-bottom: none; /* 1 */\n  text-decoration: underline; /* 2 */\n  text-decoration: underline dotted; /* 2 */\n}\n\n/**\n * Prevent the duplicate application of `bolder` by the next rule in Safari 6.\n */\n\nb,\nstrong {\n  font-weight: inherit;\n}\n\n/**\n * Add the correct font weight in Chrome, Edge, and Safari.\n */\n\nb,\nstrong {\n  font-weight: bolder;\n}\n\n/**\n * 1. Correct the inheritance and scaling of font size in all browsers.\n * 2. Correct the odd `em` font sizing in all browsers.\n */\n\ncode,\nkbd,\nsamp {\n  font-family: monospace, monospace; /* 1 */\n  font-size: 1em; /* 2 */\n}\n\n/**\n * Add the correct font style in Android 4.3-.\n */\n\ndfn {\n  font-style: italic;\n}\n\n/**\n * Add the correct background and color in IE 9-.\n */\n\nmark {\n  background-color: #ff0;\n  color: #000;\n}\n\n/**\n * Add the correct font size in all browsers.\n */\n\nsmall {\n  font-size: 80%;\n}\n\n/**\n * Prevent `sub` and `sup` elements from affecting the line height in\n * all browsers.\n */\n\nsub,\nsup {\n  font-size: 75%;\n  line-height: 0;\n  position: relative;\n  vertical-align: baseline;\n}\n\nsub {\n  bottom: -0.25em;\n}\n\nsup {\n  top: -0.5em;\n}\n\n/* Embedded content\n   ========================================================================== */\n\n/**\n * Add the correct display in IE 9-.\n */\n\naudio,\nvideo {\n  display: inline-block;\n}\n\n/**\n * Add the correct display in iOS 4-7.\n */\n\naudio:not([controls]) {\n  display: none;\n  height: 0;\n}\n\n/**\n * Remove the border on images inside links in IE 10-.\n */\n\nimg {\n  border-style: none;\n}\n\n/**\n * Hide the overflow in IE.\n */\n\nsvg:not(:root) {\n  overflow: hidden;\n}\n\n/* Forms\n   ========================================================================== */\n\n/**\n * 1. Change the font styles in all browsers (opinionated).\n * 2. Remove the margin in Firefox and Safari.\n */\n\nbutton,\ninput,\noptgroup,\nselect,\ntextarea {\n  font-family: sans-serif; /* 1 */\n  font-size: 100%; /* 1 */\n  line-height: 1.15; /* 1 */\n  margin: 0; /* 2 */\n}\n\n/**\n * Show the overflow in IE.\n * 1. Show the overflow in Edge.\n */\n\nbutton,\ninput { /* 1 */\n  overflow: visible;\n}\n\n/**\n * Remove the inheritance of text transform in Edge, Firefox, and IE.\n * 1. Remove the inheritance of text transform in Firefox.\n */\n\nbutton,\nselect { /* 1 */\n  text-transform: none;\n}\n\n/**\n * 1. Prevent a WebKit bug where (2) destroys native `audio` and `video`\n *    controls in Android 4.\n * 2. Correct the inability to style clickable types in iOS and Safari.\n */\n\nbutton,\nhtml [type=\"button\"], /* 1 */\n[type=\"reset\"],\n[type=\"submit\"] {\n  -webkit-appearance: button; /* 2 */\n}\n\n/**\n * Remove the inner border and padding in Firefox.\n */\n\nbutton::-moz-focus-inner,\n[type=\"button\"]::-moz-focus-inner,\n[type=\"reset\"]::-moz-focus-inner,\n[type=\"submit\"]::-moz-focus-inner {\n  border-style: none;\n  padding: 0;\n}\n\n/**\n * Restore the focus styles unset by the previous rule.\n */\n\nbutton:-moz-focusring,\n[type=\"button\"]:-moz-focusring,\n[type=\"reset\"]:-moz-focusring,\n[type=\"submit\"]:-moz-focusring {\n  outline: 1px dotted ButtonText;\n}\n\n/**\n * Correct the padding in Firefox.\n */\n\nfieldset {\n  padding: 0.35em 0.75em 0.625em;\n}\n\n/**\n * 1. Correct the text wrapping in Edge and IE.\n * 2. Correct the color inheritance from `fieldset` elements in IE.\n * 3. Remove the padding so developers are not caught out when they zero out\n *    `fieldset` elements in all browsers.\n */\n\nlegend {\n  box-sizing: border-box; /* 1 */\n  color: inherit; /* 2 */\n  display: table; /* 1 */\n  max-width: 100%; /* 1 */\n  padding: 0; /* 3 */\n  white-space: normal; /* 1 */\n}\n\n/**\n * 1. Add the correct display in IE 9-.\n * 2. Add the correct vertical alignment in Chrome, Firefox, and Opera.\n */\n\nprogress {\n  display: inline-block; /* 1 */\n  vertical-align: baseline; /* 2 */\n}\n\n/**\n * Remove the default vertical scrollbar in IE.\n */\n\ntextarea {\n  overflow: auto;\n}\n\n/**\n * 1. Add the correct box sizing in IE 10-.\n * 2. Remove the padding in IE 10-.\n */\n\n[type=\"checkbox\"],\n[type=\"radio\"] {\n  box-sizing: border-box; /* 1 */\n  padding: 0; /* 2 */\n}\n\n/**\n * Correct the cursor style of increment and decrement buttons in Chrome.\n */\n\n[type=\"number\"]::-webkit-inner-spin-button,\n[type=\"number\"]::-webkit-outer-spin-button {\n  height: auto;\n}\n\n/**\n * 1. Correct the odd appearance in Chrome and Safari.\n * 2. Correct the outline style in Safari.\n */\n\n[type=\"search\"] {\n  -webkit-appearance: textfield; /* 1 */\n  outline-offset: -2px; /* 2 */\n}\n\n/**\n * Remove the inner padding and cancel buttons in Chrome and Safari on macOS.\n */\n\n[type=\"search\"]::-webkit-search-cancel-button,\n[type=\"search\"]::-webkit-search-decoration {\n  -webkit-appearance: none;\n}\n\n/**\n * 1. Correct the inability to style clickable types in iOS and Safari.\n * 2. Change font properties to `inherit` in Safari.\n */\n\n::-webkit-file-upload-button {\n  -webkit-appearance: button; /* 1 */\n  font: inherit; /* 2 */\n}\n\n/* Interactive\n   ========================================================================== */\n\n/*\n * Add the correct display in IE 9-.\n * 1. Add the correct display in Edge, IE, and Firefox.\n */\n\ndetails, /* 1 */\nmenu {\n  display: block;\n}\n\n/*\n * Add the correct display in all browsers.\n */\n\nsummary {\n  display: list-item;\n}\n\n/* Scripting\n   ========================================================================== */\n\n/**\n * Add the correct display in IE 9-.\n */\n\ncanvas {\n  display: inline-block;\n}\n\n/**\n * Add the correct display in IE.\n */\n\ntemplate {\n  display: none;\n}\n\n/* Hidden\n   ========================================================================== */\n\n/**\n * Add the correct display in IE 10-.\n */\n\n[hidden] {\n  display: none;\n}\n","/*! normalize.css v7.0.0 | MIT License | github.com/necolas/normalize.css */\n/* Document\n   ========================================================================== */\n/**\n * 1. Correct the line height in all browsers.\n * 2. Prevent adjustments of font size after orientation changes in\n *    IE on Windows Phone and in iOS.\n */\nhtml {\n  line-height: 1.15;\n  /* 1 */\n  -ms-text-size-adjust: 100%;\n  /* 2 */\n  -webkit-text-size-adjust: 100%;\n  /* 2 */\n}\n\n/* Sections\n   ========================================================================== */\n/**\n * Remove the margin in all browsers (opinionated).\n */\nbody {\n  margin: 0;\n}\n\n/**\n * Add the correct display in IE 9-.\n */\narticle,\naside,\nfooter,\nheader,\nnav,\nsection {\n  display: block;\n}\n\n/**\n * Correct the font size and margin on `h1` elements within `section` and\n * `article` contexts in Chrome, Firefox, and Safari.\n */\nh1 {\n  font-size: 2em;\n  margin: 0.67em 0;\n}\n\n/* Grouping content\n   ========================================================================== */\n/**\n * Add the correct display in IE 9-.\n * 1. Add the correct display in IE.\n */\nfigcaption,\nfigure,\nmain {\n  /* 1 */\n  display: block;\n}\n\n/**\n * Add the correct margin in IE 8.\n */\nfigure {\n  margin: 1em 40px;\n}\n\n/**\n * 1. Add the correct box sizing in Firefox.\n * 2. Show the overflow in Edge and IE.\n */\nhr {\n  box-sizing: content-box;\n  /* 1 */\n  height: 0;\n  /* 1 */\n  overflow: visible;\n  /* 2 */\n}\n\n/**\n * 1. Correct the inheritance and scaling of font size in all browsers.\n * 2. Correct the odd `em` font sizing in all browsers.\n */\npre {\n  font-family: monospace, monospace;\n  /* 1 */\n  font-size: 1em;\n  /* 2 */\n}\n\n/* Text-level semantics\n   ========================================================================== */\n/**\n * 1. Remove the gray background on active links in IE 10.\n * 2. Remove gaps in links underline in iOS 8+ and Safari 8+.\n */\na {\n  background-color: transparent;\n  /* 1 */\n  -webkit-text-decoration-skip: objects;\n  /* 2 */\n}\n\n/**\n * 1. Remove the bottom border in Chrome 57- and Firefox 39-.\n * 2. Add the correct text decoration in Chrome, Edge, IE, Opera, and Safari.\n */\nabbr[title] {\n  border-bottom: none;\n  /* 1 */\n  text-decoration: underline;\n  /* 2 */\n  text-decoration: underline dotted;\n  /* 2 */\n}\n\n/**\n * Prevent the duplicate application of `bolder` by the next rule in Safari 6.\n */\nb,\nstrong {\n  font-weight: inherit;\n}\n\n/**\n * Add the correct font weight in Chrome, Edge, and Safari.\n */\nb,\nstrong {\n  font-weight: bolder;\n}\n\n/**\n * 1. Correct the inheritance and scaling of font size in all browsers.\n * 2. Correct the odd `em` font sizing in all browsers.\n */\ncode,\nkbd,\nsamp {\n  font-family: monospace, monospace;\n  /* 1 */\n  font-size: 1em;\n  /* 2 */\n}\n\n/**\n * Add the correct font style in Android 4.3-.\n */\ndfn {\n  font-style: italic;\n}\n\n/**\n * Add the correct background and color in IE 9-.\n */\nmark {\n  background-color: #ff0;\n  color: #000;\n}\n\n/**\n * Add the correct font size in all browsers.\n */\nsmall {\n  font-size: 80%;\n}\n\n/**\n * Prevent `sub` and `sup` elements from affecting the line height in\n * all browsers.\n */\nsub,\nsup {\n  font-size: 75%;\n  line-height: 0;\n  position: relative;\n  vertical-align: baseline;\n}\n\nsub {\n  bottom: -0.25em;\n}\n\nsup {\n  top: -0.5em;\n}\n\n/* Embedded content\n   ========================================================================== */\n/**\n * Add the correct display in IE 9-.\n */\naudio,\nvideo {\n  display: inline-block;\n}\n\n/**\n * Add the correct display in iOS 4-7.\n */\naudio:not([controls]) {\n  display: none;\n  height: 0;\n}\n\n/**\n * Remove the border on images inside links in IE 10-.\n */\nimg {\n  border-style: none;\n}\n\n/**\n * Hide the overflow in IE.\n */\nsvg:not(:root) {\n  overflow: hidden;\n}\n\n/* Forms\n   ========================================================================== */\n/**\n * 1. Change the font styles in all browsers (opinionated).\n * 2. Remove the margin in Firefox and Safari.\n */\nbutton,\ninput,\noptgroup,\nselect,\ntextarea {\n  font-family: sans-serif;\n  /* 1 */\n  font-size: 100%;\n  /* 1 */\n  line-height: 1.15;\n  /* 1 */\n  margin: 0;\n  /* 2 */\n}\n\n/**\n * Show the overflow in IE.\n * 1. Show the overflow in Edge.\n */\nbutton,\ninput {\n  /* 1 */\n  overflow: visible;\n}\n\n/**\n * Remove the inheritance of text transform in Edge, Firefox, and IE.\n * 1. Remove the inheritance of text transform in Firefox.\n */\nbutton,\nselect {\n  /* 1 */\n  text-transform: none;\n}\n\n/**\n * 1. Prevent a WebKit bug where (2) destroys native `audio` and `video`\n *    controls in Android 4.\n * 2. Correct the inability to style clickable types in iOS and Safari.\n */\nbutton,\nhtml [type=\"button\"],\n[type=\"reset\"],\n[type=\"submit\"] {\n  -webkit-appearance: button;\n  /* 2 */\n}\n\n/**\n * Remove the inner border and padding in Firefox.\n */\nbutton::-moz-focus-inner,\n[type=\"button\"]::-moz-focus-inner,\n[type=\"reset\"]::-moz-focus-inner,\n[type=\"submit\"]::-moz-focus-inner {\n  border-style: none;\n  padding: 0;\n}\n\n/**\n * Restore the focus styles unset by the previous rule.\n */\nbutton:-moz-focusring,\n[type=\"button\"]:-moz-focusring,\n[type=\"reset\"]:-moz-focusring,\n[type=\"submit\"]:-moz-focusring {\n  outline: 1px dotted ButtonText;\n}\n\n/**\n * Correct the padding in Firefox.\n */\nfieldset {\n  padding: 0.35em 0.75em 0.625em;\n}\n\n/**\n * 1. Correct the text wrapping in Edge and IE.\n * 2. Correct the color inheritance from `fieldset` elements in IE.\n * 3. Remove the padding so developers are not caught out when they zero out\n *    `fieldset` elements in all browsers.\n */\nlegend {\n  box-sizing: border-box;\n  /* 1 */\n  color: inherit;\n  /* 2 */\n  display: table;\n  /* 1 */\n  max-width: 100%;\n  /* 1 */\n  padding: 0;\n  /* 3 */\n  white-space: normal;\n  /* 1 */\n}\n\n/**\n * 1. Add the correct display in IE 9-.\n * 2. Add the correct vertical alignment in Chrome, Firefox, and Opera.\n */\nprogress {\n  display: inline-block;\n  /* 1 */\n  vertical-align: baseline;\n  /* 2 */\n}\n\n/**\n * Remove the default vertical scrollbar in IE.\n */\ntextarea {\n  overflow: auto;\n}\n\n/**\n * 1. Add the correct box sizing in IE 10-.\n * 2. Remove the padding in IE 10-.\n */\n[type=\"checkbox\"],\n[type=\"radio\"] {\n  box-sizing: border-box;\n  /* 1 */\n  padding: 0;\n  /* 2 */\n}\n\n/**\n * Correct the cursor style of increment and decrement buttons in Chrome.\n */\n[type=\"number\"]::-webkit-inner-spin-button,\n[type=\"number\"]::-webkit-outer-spin-button {\n  height: auto;\n}\n\n/**\n * 1. Correct the odd appearance in Chrome and Safari.\n * 2. Correct the outline style in Safari.\n */\n[type=\"search\"] {\n  -webkit-appearance: textfield;\n  /* 1 */\n  outline-offset: -2px;\n  /* 2 */\n}\n\n/**\n * Remove the inner padding and cancel buttons in Chrome and Safari on macOS.\n */\n[type=\"search\"]::-webkit-search-cancel-button,\n[type=\"search\"]::-webkit-search-decoration {\n  -webkit-appearance: none;\n}\n\n/**\n * 1. Correct the inability to style clickable types in iOS and Safari.\n * 2. Change font properties to `inherit` in Safari.\n */\n::-webkit-file-upload-button {\n  -webkit-appearance: button;\n  /* 1 */\n  font: inherit;\n  /* 2 */\n}\n\n/* Interactive\n   ========================================================================== */\n/*\n * Add the correct display in IE 9-.\n * 1. Add the correct display in Edge, IE, and Firefox.\n */\ndetails,\nmenu {\n  display: block;\n}\n\n/*\n * Add the correct display in all browsers.\n */\nsummary {\n  display: list-item;\n}\n\n/* Scripting\n   ========================================================================== */\n/**\n * Add the correct display in IE 9-.\n */\ncanvas {\n  display: inline-block;\n}\n\n/**\n * Add the correct display in IE.\n */\ntemplate {\n  display: none;\n}\n\n/* Hidden\n   ========================================================================== */\n/**\n * Add the correct display in IE 10-.\n */\n[hidden] {\n  display: none;\n}\n\n*,\n*:before,\n*:after {\n  box-sizing: border-box;\n}\n\nhtml {\n  font-size: 10px;\n}\n\nbody {\n  padding-top: 110px;\n  font-family: \"Lato\", \"Helvetica Neue\", Helvetica, Arial, sans-serif;\n  font-size: 18px;\n  font-weight: 300;\n  line-height: 1.4;\n  color: #333;\n  background-color: #fff;\n}\n\n@media (min-width: 768px) {\n  body {\n    padding-top: 90px;\n  }\n}\n\na {\n  color: #1976D2;\n  text-decoration: none;\n  transition: color 0.3s;\n}\n\na:hover, a:focus {\n  color: #2196F3;\n}\n\nh1, h2, h3, h4, h5, h6 {\n  font-weight: 300;\n}\n\nh1 small, h2 small, h3 small, h4 small, h5 small, h6 small {\n  font-size: 60%;\n}\n\nh1, h2 {\n  margin: 0 0 20px 0;\n}\n\nh3, h4, h5, h6 {\n  margin: 0 0 15px 0;\n}\n\nh1 {\n  font-size: 38px;\n}\n\nh2 {\n  font-size: 34px;\n}\n\nh3 {\n  font-size: 26px;\n}\n\nh4 {\n  font-size: 20px;\n}\n\nh5 {\n  font-size: 16px;\n}\n\nh6 {\n  font-size: 14px;\n}\n\np {\n  margin: 0 0 15px 0;\n}\n\nstrong {\n  font-weight: 400;\n}\n\n.container {\n  width: 100%;\n  max-width: 1140px;\n  margin-right: auto;\n  margin-left: auto;\n  padding-left: 15px;\n  padding-right: 15px;\n}\n\n.container:before, .container:after {\n  content: \" \";\n  display: table;\n}\n\n.container:after {\n  clear: both;\n}\n\n.row {\n  display: flex;\n  flex-wrap: wrap;\n  margin-right: -15px;\n  margin-left: -15px;\n}\n\n.col-sm-4 {\n  position: relative;\n  width: 100%;\n  padding-left: 15px;\n  padding-right: 15px;\n  min-height: 1px;\n}\n\n@media (min-width: 576px) {\n  .col-sm-4 {\n    flex: 0 0 33.333333%;\n    max-width: 33.333333%;\n  }\n}\n\n.img-fluid {\n  max-width: 100%;\n  height: auto;\n  vertical-align: middle;\n  border-style: none;\n}\n\n.header {\n  position: fixed;\n  top: 0;\n  z-index: 100;\n  width: 100%;\n  padding: 15px 0;\n  color: #fff;\n  background-color: #1976D2;\n  box-shadow: 0 0 6px 6px rgba(0, 0, 0, 0.1);\n}\n\n.logo-text {\n  margin: 0;\n}\n\n@media (max-width: 767px) {\n  .logo-text {\n    font-size: 25px;\n  }\n}\n\n@media (min-width: 768px) {\n  .logo-text {\n    display: inline-block;\n  }\n}\n\n.header--links .btn {\n  margin: 0;\n  margin-top: 7px;\n}\n\n.header--links .btn:last-child {\n  margin-left: 7px;\n}\n\n@media (min-width: 768px) {\n  .header--links {\n    float: right;\n  }\n}\n\n.footer {\n  padding-top: 15px;\n  padding-bottom: 15px;\n  font-size: 12px;\n  text-align: center;\n}\n\n.demo {\n  margin-top: 40px;\n  margin-bottom: 40px;\n}\n\n.demo--intro {\n  margin-top: 20px;\n  border-bottom: 1px solid #ddd;\n}\n\n.demo--intro p:last-child {\n  padding-bottom: 20px;\n}\n\n.btn {\n  display: inline-block;\n  text-align: center;\n  vertical-align: middle;\n  cursor: pointer;\n  border: 1px solid #bbb;\n  padding: 4px 12px 6px 12px;\n  font-size: 18px;\n  background-color: #fff;\n  border-radius: 4px;\n  transition: background-color .3s, color .3s;\n}\n\n.btn:hover, .btn:active {\n  background-color: #f3f3f3;\n}\n\n.btn-white {\n  color: #fff;\n  border-color: #fff;\n  background-color: transparent;\n}\n\n.install .btn {\n  margin-right: 15px;\n  margin-bottom: 15px;\n}\n\npre {\n  display: block;\n  padding: 10px 15px;\n  margin: 0 0 20px 0;\n  overflow: auto;\n  font-family: 'Cutive Mono', monospace;\n  font-size: 14px;\n  word-break: break-all;\n  word-wrap: break-word;\n  background-color: #f3f3f3;\n  border: 1px solid #bbb;\n  border-radius: 4px;\n}\n","// ----- Mixins -----\n@mixin clearfix() {\n  &:before,\n  &:after {\n    content: \" \";\n    display: table;\n  }\n  &:after {\n    clear: both;\n  }\n}\n\n\n// ----- Base styles -----\n\n*,\n*:before,\n*:after {\n  box-sizing: border-box;\n}\n\nhtml {\n  font-size: 10px;\n}\n\nbody {\n  padding-top: 110px;\n  font-family: \"Lato\", \"Helvetica Neue\", Helvetica, Arial, sans-serif;\n  font-size: 18px;\n  font-weight: 300;\n  line-height: 1.4;\n  color: #333;\n  background-color: #fff;\n\n  @media (min-width: 768px) {\n    padding-top: 90px;\n  }\n\n}\n\na {\n  color: #1976D2;\n  text-decoration: none;\n  transition: color 0.3s;\n\n  &:hover, &:focus {\n    color: #2196F3;\n  }\n}\n\n// Type\nh1, h2, h3, h4, h5, h6 {\n  font-weight: 300;\n\n  small {\n    font-size: 60%;\n  }\n}\nh1, h2 {\n  margin: 0 0 20px 0;\n}\nh3, h4, h5, h6 {\n  margin: 0 0 15px 0;\n}\n\nh1 { font-size: 38px; }\nh2 { font-size: 34px; }\nh3 { font-size: 26px; }\nh4 { font-size: 20px; }\nh5 { font-size: 16px; }\nh6 { font-size: 14px; }\n\np {\n  margin: 0 0 15px 0;\n}\n\nstrong {\n  font-weight: 400;\n}\n\n\n\n// ----- Layout -----\n.container {\n  width: 100%;\n  max-width: 1140px;\n  margin-right: auto;\n  margin-left: auto;\n  padding-left: 15px;\n  padding-right: 15px;\n  @include clearfix();\n}\n\n// Bootstrap grid example\n  .row {\n    display: flex;\n    flex-wrap: wrap;\n    margin-right: -15px;\n    margin-left: -15px;\n  }\n\n    .col-sm-4 {\n      position: relative;\n      width: 100%;\n      padding-left: 15px;\n      padding-right: 15px;\n      min-height: 1px;\n    }\n\n    @media (min-width: 576px) {\n      .col-sm-4 {\n        flex: 0 0 33.333333%;\n        max-width: 33.333333%;\n      }\n    }\n\n\n.img-fluid {\n  max-width: 100%;\n  height: auto;\n  vertical-align: middle;\n  border-style: none;\n}\n\n\n// ----- Header and footer -----\n.header {\n  position: fixed;\n  top: 0;\n  z-index: 100;\n  width: 100%;\n  padding: 15px 0;\n  color: #fff;\n  background-color: #1976D2;\n  box-shadow: 0 0 6px 6px rgba(0,0,0,0.1);\n}\n\n  .logo-text {\n    margin: 0;\n\n    @media (max-width: 767px) {\n      font-size: 25px;\n    }\n    @media (min-width: 768px) {\n      display: inline-block;\n    }\n  }\n\n  .header--links {\n\n    .btn {\n      margin: 0;\n      margin-top: 7px;\n\n      &:last-child {\n        margin-left: 7px;\n      }\n    }\n\n    @media (min-width: 768px) {\n      float: right;\n    }\n  }\n\n.footer {\n  padding-top: 15px;\n  padding-bottom: 15px;\n  font-size: 12px;\n  text-align: center;\n}\n\n\n// ----- Demo -----\n.demo {\n  margin-top: 40px;\n  margin-bottom: 40px;\n}\n\n.demo--intro {\n  margin-top: 20px;\n  border-bottom: 1px solid #ddd;\n\n  p:last-child {\n    padding-bottom: 20px;\n  }\n}\n\n.btn {\n  display: inline-block;\n  text-align: center;\n  vertical-align: middle;\n  cursor: pointer;\n  border: 1px solid #bbb;\n  padding: 4px 12px 6px 12px;\n  font-size: 18px;\n  background-color: #fff;\n  border-radius: 4px;\n  transition: background-color .3s, color .3s;\n\n  &:hover, &:active {\n    background-color: #f3f3f3;\n  }\n}\n\n.btn-white {\n  color: #fff;\n  border-color: #fff;\n  background-color: transparent;\n}\n\n.install .btn {\n  margin-right: 15px;\n  margin-bottom: 15px;\n}\n\npre {\n  display: block;\n  padding: 10px 15px;\n  margin: 0 0 20px 0;\n  overflow: auto;\n  font-family: 'Cutive Mono', monospace;\n  font-size: 14px;\n  word-break: break-all;\n  word-wrap: break-word;\n  background-color: #f3f3f3;\n  border: 1px solid #bbb;\n  border-radius: 4px;\n}\n"]} */ diff --git a/styles/site/_site.scss b/styles/site/_site.scss index 1d17d14..57ba05f 100644 --- a/styles/site/_site.scss +++ b/styles/site/_site.scss @@ -24,13 +24,18 @@ html { } body { - padding-top: 90px; + padding-top: 110px; font-family: "Lato", "Helvetica Neue", Helvetica, Arial, sans-serif; font-size: 18px; font-weight: 300; line-height: 1.4; color: #333; background-color: #fff; + + @media (min-width: 768px) { + padding-top: 90px; + } + } a { @@ -83,7 +88,7 @@ strong { margin-left: auto; padding-left: 15px; padding-right: 15px; - @include clearfix(); + @include clearfix(); } // Bootstrap grid example @@ -91,7 +96,7 @@ strong { display: flex; flex-wrap: wrap; margin-right: -15px; - margin-left: -15px; + margin-left: -15px; } .col-sm-4 { @@ -151,7 +156,7 @@ strong { margin-left: 7px; } } - + @media (min-width: 768px) { float: right; } @@ -167,12 +172,17 @@ strong { // ----- Demo ----- .demo { - margin-top: 20px; + margin-top: 40px; margin-bottom: 40px; } .demo--intro { + margin-top: 20px; border-bottom: 1px solid #ddd; + + p:last-child { + padding-bottom: 20px; + } } .btn {