@charset "UTF-8";
/*!
Pure v0.6.2
Copyright 2013 Yahoo!
Licensed under the BSD License.
https://github.com/yahoo/pure/blob/master/LICENSE.md
*/
/*!
normalize.css v^3.0 | MIT License | git.io/normalize
Copyright (c) Nicolas Gallagher and Jonathan Neal
*/
/*! normalize.css v3.0.3 | MIT License | github.com/necolas/normalize.css */
/**
 * 1. Set default font family to sans-serif.
 * 2. Prevent iOS and IE text size adjust after device orientation change,
 *    without disabling user zoom.
 */
@import url("https://fonts.googleapis.com/css?family=Libre+Franklin:200,400,700");
@import url("https://fonts.googleapis.com/css?family=Source+Code+Pro:400,700");
html {
  font-family: sans-serif;
  /* 1 */
  -ms-text-size-adjust: 100%;
  /* 2 */
  -webkit-text-size-adjust: 100%;
  /* 2 */
}

/**
 * Remove default margin.
 */
body {
  margin: 0;
}

/* HTML5 display definitions
   ========================================================================== */
/**
 * Correct `block` display not defined for any HTML5 element in IE 8/9.
 * Correct `block` display not defined for `details` or `summary` in IE 10/11
 * and Firefox.
 * Correct `block` display not defined for `main` in IE 11.
 */
article, aside, details, figcaption, figure, footer, header, hgroup, main, menu, nav, section, summary {
  display: block;
}

/**
 * 1. Correct `inline-block` display not defined in IE 8/9.
 * 2. Normalize vertical alignment of `progress` in Chrome, Firefox, and Opera.
 */
audio, canvas, progress, video {
  display: inline-block;
  /* 1 */
  vertical-align: baseline;
  /* 2 */
}

/**
 * Prevent modern browsers from displaying `audio` without controls.
 * Remove excess height in iOS 5 devices.
 */
audio:not([controls]) {
  display: none;
  height: 0;
}

/**
 * Address `[hidden]` styling not present in IE 8/9/10.
 * Hide the `template` element in IE 8/9/10/11, Safari, and Firefox < 22.
 */
[hidden], template {
  display: none;
}

/* Links
   ========================================================================== */
/**
 * Remove the gray background color from active links in IE 10.
 */
a {
  background-color: transparent;
}
a:active, a:hover {
  outline: 0;
}

/**
 * Improve readability of focused elements when they are also in an
 * active/hover state.
 */
/* Text-level semantics
   ========================================================================== */
/**
 * Address styling not present in IE 8/9/10/11, Safari, and Chrome.
 */
abbr[title] {
  border-bottom: 1px dotted;
}

/**
 * Address style set to `bolder` in Firefox 4+, Safari, and Chrome.
 */
b, strong {
  font-weight: bold;
}

/**
 * Address styling not present in Safari and Chrome.
 */
dfn {
  font-style: italic;
}

/**
 * Address variable `h1` font-size and margin within `section` and `article`
 * contexts in Firefox 4+, Safari, and Chrome.
 */
h1 {
  font-size: 2em;
  margin: 0.67em 0;
}

/**
 * Address styling not present in IE 8/9.
 */
mark {
  background: #ff0;
  color: #000;
}

/**
 * Address inconsistent and variable font size in all browsers.
 */
small {
  font-size: 80%;
}

/**
 * Prevent `sub` and `sup` affecting `line-height` in all browsers.
 */
sub {
  font-size: 75%;
  line-height: 0;
  position: relative;
  vertical-align: baseline;
}

sup {
  font-size: 75%;
  line-height: 0;
  position: relative;
  vertical-align: baseline;
  top: -0.5em;
}

sub {
  bottom: -0.25em;
}

/* Embedded content
   ========================================================================== */
/**
 * Remove border when inside `a` element in IE 8/9/10.
 */
img {
  border: 0;
}

/**
 * Correct overflow not hidden in IE 9/10/11.
 */
svg:not(:root) {
  overflow: hidden;
}

/* Grouping content
   ========================================================================== */
/**
 * Address margin not present in IE 8/9 and Safari.
 */
figure {
  margin: 1em 40px;
}

/**
 * Address differences between Firefox and other browsers.
 */
hr {
  box-sizing: content-box;
  height: 0;
}

/**
 * Contain overflow in all browsers.
 */
pre {
  overflow: auto;
}

/**
 * Address odd `em`-unit font size rendering in all browsers.
 */
code, kbd, pre, samp {
  font-family: monospace, monospace;
  font-size: 1em;
}

/* Forms
   ========================================================================== */
/**
 * Known limitation: by default, Chrome and Safari on OS X allow very limited
 * styling of `select`, unless a `border` property is set.
 */
/**
 * 1. Correct color not being inherited.
 *    Known issue: affects color of disabled elements.
 * 2. Correct font properties not being inherited.
 * 3. Address margins set differently in Firefox 4+, Safari, and Chrome.
 */
button, input, optgroup, select, textarea {
  color: inherit;
  /* 1 */
  font: inherit;
  /* 2 */
  margin: 0;
  /* 3 */
}

/**
 * Address `overflow` set to `hidden` in IE 8/9/10/11.
 */
button {
  overflow: visible;
  text-transform: none;
}

/**
 * Address inconsistent `text-transform` inheritance for `button` and `select`.
 * All other form control elements do not inherit `text-transform` values.
 * Correct `button` style inheritance in Firefox, IE 8/9/10/11, and Opera.
 * Correct `select` style inheritance in Firefox.
 */
select {
  text-transform: none;
}

/**
 * 1. Avoid the WebKit bug in Android 4.0.* where (2) destroys native `audio`
 *    and `video` controls.
 * 2. Correct inability to style clickable `input` types in iOS.
 * 3. Improve usability and consistency of cursor style between image-type
 *    `input` and others.
 */
button, html input[type=button] {
  -webkit-appearance: button;
  /* 2 */
  cursor: pointer;
  /* 3 */
}

input[type=reset], input[type=submit] {
  -webkit-appearance: button;
  /* 2 */
  cursor: pointer;
  /* 3 */
}

/**
 * Re-set default cursor for disabled elements.
 */
button[disabled], html input[disabled] {
  cursor: default;
}

/**
 * Remove inner padding and border in Firefox 4+.
 */
button::-moz-focus-inner {
  border: 0;
  padding: 0;
}

input {
  line-height: normal;
}
input::-moz-focus-inner {
  border: 0;
  padding: 0;
}
input[type=checkbox], input[type=radio] {
  box-sizing: border-box;
  /* 1 */
  padding: 0;
  /* 2 */
}
input[type=number]::-webkit-inner-spin-button, input[type=number]::-webkit-outer-spin-button {
  height: auto;
}
input[type=search] {
  -webkit-appearance: textfield;
  /* 1 */
  box-sizing: content-box;
  /* 2 */
}
input[type=search]::-webkit-search-cancel-button, input[type=search]::-webkit-search-decoration {
  -webkit-appearance: none;
}

/**
 * Address Firefox 4+ setting `line-height` on `input` using `!important` in
 * the UA stylesheet.
 */
/**
 * It's recommended that you don't attempt to style these elements.
 * Firefox's implementation doesn't respect box-sizing, padding, or width.
 *
 * 1. Address box sizing set to `content-box` in IE 8/9/10.
 * 2. Remove excess padding in IE 8/9/10.
 */
/**
 * Fix the cursor style for Chrome's increment/decrement buttons. For certain
 * `font-size` values of the `input`, it causes the cursor style of the
 * decrement button to change from `default` to `text`.
 */
/**
 * 1. Address `appearance` set to `searchfield` in Safari and Chrome.
 * 2. Address `box-sizing` set to `border-box` in Safari and Chrome.
 */
/**
 * Remove inner padding and search cancel button in Safari and Chrome on OS X.
 * Safari (but not Chrome) clips the cancel button when the search input has
 * padding (and `textfield` appearance).
 */
/**
 * Define consistent border, margin, and padding.
 */
fieldset {
  border: 1px solid #c0c0c0;
  margin: 0 2px;
  padding: 0.35em 0.625em 0.75em;
}

/**
 * 1. Correct `color` not being inherited in IE 8/9/10/11.
 * 2. Remove padding so people aren't caught out if they zero out fieldsets.
 */
legend {
  border: 0;
  /* 1 */
  padding: 0;
  /* 2 */
}

/**
 * Remove default vertical scrollbar in IE 8/9/10/11.
 */
textarea {
  overflow: auto;
}

/**
 * Don't inherit the `font-weight` (applied by a rule above).
 * NOTE: the default cannot safely be changed in Chrome and Safari on OS X.
 */
optgroup {
  font-weight: bold;
}

/* Tables
   ========================================================================== */
/**
 * Remove most spacing between table cells.
 */
table {
  border-collapse: collapse;
  border-spacing: 0;
}

td, th {
  padding: 0;
}

/*csslint important:false*/
/* ==========================================================================
   Pure Base Extras
   ========================================================================== */
/**
 * Extra rules that Pure adds on top of Normalize.css
 */
/**
 * Always hide an element when it has the `hidden` HTML attribute.
 */
.hidden, [hidden] {
  display: none !important;
}

/**
 * Add this class to an image to make it fit within it's fluid parent wrapper while maintaining
 * aspect ratio.
 */
.pure-img {
  max-width: 100%;
  height: auto;
  display: block;
}

/*!
Pure v0.6.2
Copyright 2013 Yahoo!
Licensed under the BSD License.
https://github.com/yahoo/pure/blob/master/LICENSE.md
*/
.pure-button {
  /* Structure */
  display: inline-block;
  zoom: 1;
  line-height: normal;
  white-space: nowrap;
  vertical-align: middle;
  text-align: center;
  cursor: pointer;
  -webkit-user-drag: none;
  -webkit-user-select: none;
  -moz-user-select: none;
  -ms-user-select: none;
  user-select: none;
  box-sizing: border-box;
}
.pure-button::-moz-focus-inner {
  padding: 0;
  border: 0;
}

/* Firefox: Get rid of the inner focus border */
/* Inherit .pure-g styles */
.pure-button-group {
  letter-spacing: -0.31em;
  /* Webkit: collapse white-space between units */
  *letter-spacing: normal;
  /* reset IE < 8 */
  *word-spacing: -0.43em;
  /* IE < 8: collapse white-space between units */
  text-rendering: optimizespeed;
  /* Webkit: fixes text-rendering: optimizeLegibility */
}

.opera-only :-o-prefocus {
  word-spacing: -0.43em;
}

.pure-button-group {
  word-spacing: -0.43em;
}
.pure-button-group .pure-button {
  letter-spacing: normal;
  word-spacing: normal;
  vertical-align: top;
  text-rendering: auto;
}

/*csslint outline-none:false*/
.pure-button {
  font-family: inherit;
  font-size: 100%;
  padding: 0.5em 1em;
  color: #444;
  /* rgba not supported (IE 8) */
  color: rgba(0, 0, 0, 0.8);
  /* rgba supported */
  border: 1px solid #999;
  /*IE 6/7/8*/
  border: none rgba(0, 0, 0, 0);
  /*IE9 + everything else*/
  background-color: #E6E6E6;
  text-decoration: none;
  border-radius: 2px;
}

.pure-button-hover {
  /* csslint ignore:start */
  filter: alpha(opacity=90);
  /* csslint ignore:end */
  background-image: -webkit-linear-gradient(transparent, rgba(0, 0, 0, 0.05) 40%, rgba(0, 0, 0, 0.1));
  background-image: linear-gradient(transparent, rgba(0, 0, 0, 0.05) 40%, rgba(0, 0, 0, 0.1));
}

.pure-button:hover {
  /* csslint ignore:start */
  filter: alpha(opacity=90);
  /* csslint ignore:end */
  background-image: -webkit-linear-gradient(transparent, rgba(0, 0, 0, 0.05) 40%, rgba(0, 0, 0, 0.1));
  background-image: linear-gradient(transparent, rgba(0, 0, 0, 0.05) 40%, rgba(0, 0, 0, 0.1));
}
.pure-button:focus {
  /* csslint ignore:start */
  filter: alpha(opacity=90);
  /* csslint ignore:end */
  background-image: -webkit-linear-gradient(transparent, rgba(0, 0, 0, 0.05) 40%, rgba(0, 0, 0, 0.1));
  background-image: linear-gradient(transparent, rgba(0, 0, 0, 0.05) 40%, rgba(0, 0, 0, 0.1));
  outline: 0;
}

.pure-button-active {
  box-shadow: 0 0 0 1px rgba(0, 0, 0, 0.15) inset, 0 0 6px rgba(0, 0, 0, 0.2) inset;
  border-color: #000 \9 ;
}

.pure-button:active {
  box-shadow: 0 0 0 1px rgba(0, 0, 0, 0.15) inset, 0 0 6px rgba(0, 0, 0, 0.2) inset;
  border-color: #000 \9 ;
}
.pure-button[disabled] {
  border: none;
  background-image: none;
  /* csslint ignore:start */
  filter: alpha(opacity=40);
  /* csslint ignore:end */
  opacity: 0.4;
  cursor: not-allowed;
  box-shadow: none;
  pointer-events: none;
}

.pure-button-disabled {
  border: none;
  background-image: none;
  /* csslint ignore:start */
  filter: alpha(opacity=40);
  /* csslint ignore:end */
  opacity: 0.4;
  cursor: not-allowed;
  box-shadow: none;
  pointer-events: none;
}
.pure-button-disabled:hover, .pure-button-disabled:focus, .pure-button-disabled:active {
  border: none;
  background-image: none;
  /* csslint ignore:start */
  filter: alpha(opacity=40);
  /* csslint ignore:end */
  opacity: 0.4;
  cursor: not-allowed;
  box-shadow: none;
  pointer-events: none;
}

.pure-button-hidden {
  display: none;
}

.pure-button-primary, .pure-button-selected {
  background-color: rgb(0, 120, 231);
  color: #fff;
}

a.pure-button-primary, a.pure-button-selected {
  background-color: rgb(0, 120, 231);
  color: #fff;
}

/* Button Groups */
.pure-button-group .pure-button {
  margin: 0;
  border-radius: 0;
  border-right: 1px solid #111;
  /* fallback color for rgba() for IE7/8 */
  border-right: 1px solid rgba(0, 0, 0, 0.2);
}
.pure-button-group .pure-button:first-child {
  border-top-left-radius: 2px;
  border-bottom-left-radius: 2px;
}
.pure-button-group .pure-button:last-child {
  border-top-right-radius: 2px;
  border-bottom-right-radius: 2px;
  border-right: none;
}

/*!
Pure v0.6.2
Copyright 2013 Yahoo!
Licensed under the BSD License.
https://github.com/yahoo/pure/blob/master/LICENSE.md
*/
/*csslint box-model:false*/
/*
Box-model set to false because we're setting a height on select elements, which
also have border and padding. This is done because some browsers don't render
the padding. We explicitly set the box-model for select elements to border-box,
so we can ignore the csslint warning.
*/
.pure-form input[type=text], .pure-form input[type=password], .pure-form input[type=email], .pure-form input[type=url], .pure-form input[type=date], .pure-form input[type=month], .pure-form input[type=time], .pure-form input[type=datetime], .pure-form input[type=datetime-local], .pure-form input[type=week], .pure-form input[type=number], .pure-form input[type=search], .pure-form input[type=tel], .pure-form input[type=color] {
  padding: 0.5em 0.6em;
  display: inline-block;
  border: 1px solid #ccc;
  box-shadow: inset 0 1px 3px #ddd;
  border-radius: 4px;
  vertical-align: middle;
  box-sizing: border-box;
}
.pure-form select, .pure-form textarea {
  padding: 0.5em 0.6em;
  display: inline-block;
  border: 1px solid #ccc;
  box-shadow: inset 0 1px 3px #ddd;
  border-radius: 4px;
  vertical-align: middle;
  box-sizing: border-box;
}
.pure-form input:not([type]) {
  padding: 0.5em 0.6em;
  display: inline-block;
  border: 1px solid #ccc;
  box-shadow: inset 0 1px 3px #ddd;
  border-radius: 4px;
  box-sizing: border-box;
}
.pure-form input[type=color] {
  padding: 0.2em 0.5em;
}
.pure-form input[type=text]:focus, .pure-form input[type=password]:focus, .pure-form input[type=email]:focus, .pure-form input[type=url]:focus, .pure-form input[type=date]:focus, .pure-form input[type=month]:focus, .pure-form input[type=time]:focus, .pure-form input[type=datetime]:focus, .pure-form input[type=datetime-local]:focus, .pure-form input[type=week]:focus, .pure-form input[type=number]:focus, .pure-form input[type=search]:focus, .pure-form input[type=tel]:focus, .pure-form input[type=color]:focus {
  outline: 0;
  border-color: #129FEA;
}
.pure-form select:focus, .pure-form textarea:focus {
  outline: 0;
  border-color: #129FEA;
}
.pure-form input:not([type]):focus {
  outline: 0;
  border-color: #129FEA;
}
.pure-form input[type=file]:focus, .pure-form input[type=radio]:focus, .pure-form input[type=checkbox]:focus {
  outline: thin solid #129FEA;
  outline: 1px auto #129FEA;
}
.pure-form .pure-checkbox, .pure-form .pure-radio {
  margin: 0.5em 0;
  display: block;
}
.pure-form input[type=text][disabled], .pure-form input[type=password][disabled], .pure-form input[type=email][disabled], .pure-form input[type=url][disabled], .pure-form input[type=date][disabled], .pure-form input[type=month][disabled], .pure-form input[type=time][disabled], .pure-form input[type=datetime][disabled], .pure-form input[type=datetime-local][disabled], .pure-form input[type=week][disabled], .pure-form input[type=number][disabled], .pure-form input[type=search][disabled], .pure-form input[type=tel][disabled], .pure-form input[type=color][disabled] {
  cursor: not-allowed;
  background-color: #eaeded;
  color: #cad2d3;
}
.pure-form select[disabled], .pure-form textarea[disabled] {
  cursor: not-allowed;
  background-color: #eaeded;
  color: #cad2d3;
}
.pure-form input:not([type])[disabled] {
  cursor: not-allowed;
  background-color: #eaeded;
  color: #cad2d3;
}
.pure-form input[readonly] {
  background-color: #eee;
  /* menu hover bg color */
  color: #777;
  /* menu text color */
  border-color: #ccc;
}
.pure-form select[readonly], .pure-form textarea[readonly] {
  background-color: #eee;
  /* menu hover bg color */
  color: #777;
  /* menu text color */
  border-color: #ccc;
}
.pure-form input:focus:invalid, .pure-form textarea:focus:invalid, .pure-form select:focus:invalid {
  color: #b94a48;
  border-color: #e9322d;
}
.pure-form input[type=file]:focus:invalid:focus, .pure-form input[type=radio]:focus:invalid:focus, .pure-form input[type=checkbox]:focus:invalid:focus {
  outline-color: #e9322d;
}
.pure-form select {
  /* Normalizes the height; padding is not sufficient. */
  height: 2.25em;
  border: 1px solid #ccc;
  background-color: white;
}
.pure-form select[multiple] {
  height: auto;
}
.pure-form label {
  margin: 0.5em 0 0.2em;
}
.pure-form fieldset {
  margin: 0;
  padding: 0.35em 0 0.75em;
  border: 0;
}
.pure-form legend {
  display: block;
  width: 100%;
  padding: 0.3em 0;
  margin-bottom: 0.3em;
  color: #333;
  border-bottom: 1px solid #e5e5e5;
}

/*
Need to separate out the :not() selector from the rest of the CSS 2.1 selectors
since IE8 won't execute CSS that contains a CSS3 selector.
*/
/* Chrome (as of v.32/34 on OS X) needs additional room for color to display. */
/* May be able to remove this tweak as color inputs become more standardized across browsers. */
/*
Need to separate out the :not() selector from the rest of the CSS 2.1 selectors
since IE8 won't execute CSS that contains a CSS3 selector.
*/
/*
Need to separate out the :not() selector from the rest of the CSS 2.1 selectors
since IE8 won't execute CSS that contains a CSS3 selector.
*/
.pure-form-stacked input[type=text], .pure-form-stacked input[type=password], .pure-form-stacked input[type=email], .pure-form-stacked input[type=url], .pure-form-stacked input[type=date], .pure-form-stacked input[type=month], .pure-form-stacked input[type=time], .pure-form-stacked input[type=datetime], .pure-form-stacked input[type=datetime-local], .pure-form-stacked input[type=week], .pure-form-stacked input[type=number], .pure-form-stacked input[type=search], .pure-form-stacked input[type=tel], .pure-form-stacked input[type=color], .pure-form-stacked input[type=file] {
  display: block;
  margin: 0.25em 0;
}
.pure-form-stacked select, .pure-form-stacked label, .pure-form-stacked textarea, .pure-form-stacked input:not([type]) {
  display: block;
  margin: 0.25em 0;
}

/*
Need to separate out the :not() selector from the rest of the CSS 2.1 selectors
since IE8 won't execute CSS that contains a CSS3 selector.
*/
.pure-form-aligned input, .pure-form-aligned textarea, .pure-form-aligned select, .pure-form-aligned .pure-help-inline {
  display: inline-block;
  *display: inline;
  *zoom: 1;
  vertical-align: middle;
}

.pure-form-message-inline {
  display: inline-block;
  *display: inline;
  *zoom: 1;
  vertical-align: middle;
}

.pure-form-aligned textarea {
  vertical-align: top;
}
.pure-form-aligned .pure-control-group {
  margin-bottom: 0.5em;
}
.pure-form-aligned .pure-control-group label {
  text-align: right;
  display: inline-block;
  vertical-align: middle;
  width: 10em;
  margin: 0 1em 0 0;
}
.pure-form-aligned .pure-controls {
  margin: 1.5em 0 0 11em;
}

/* Aligned Forms */
/* Rounded Inputs */
.pure-form input.pure-input-rounded, .pure-form .pure-input-rounded {
  border-radius: 2em;
  padding: 0.5em 1em;
}
.pure-form .pure-group fieldset {
  margin-bottom: 10px;
}
.pure-form .pure-group input, .pure-form .pure-group textarea {
  display: block;
  padding: 10px;
  margin: 0 0 -1px;
  border-radius: 0;
  position: relative;
  top: -1px;
}
.pure-form .pure-group input:focus, .pure-form .pure-group textarea:focus {
  z-index: 3;
}
.pure-form .pure-group input:first-child, .pure-form .pure-group textarea:first-child {
  top: 1px;
  border-radius: 4px 4px 0 0;
  margin: 0;
}
.pure-form .pure-group input:first-child:last-child, .pure-form .pure-group textarea:first-child:last-child {
  top: 1px;
  border-radius: 4px;
  margin: 0;
}
.pure-form .pure-group input:last-child, .pure-form .pure-group textarea:last-child {
  top: -2px;
  border-radius: 0 0 4px 4px;
  margin: 0;
}
.pure-form .pure-group button {
  margin: 0.35em 0;
}
.pure-form .pure-input-1 {
  width: 100%;
}
.pure-form .pure-input-3-4 {
  width: 75%;
}
.pure-form .pure-input-2-3 {
  width: 66%;
}
.pure-form .pure-input-1-2 {
  width: 50%;
}
.pure-form .pure-input-1-3 {
  width: 33%;
}
.pure-form .pure-input-1-4 {
  width: 25%;
}
.pure-form .pure-help-inline {
  display: inline-block;
  padding-left: 0.3em;
  color: #666;
  vertical-align: middle;
  font-size: 0.875em;
}

/* Grouped Inputs */
/* Inline help for forms */
/* NOTE: pure-help-inline is deprecated. Use .pure-form-message-inline instead. */
.pure-form-message-inline {
  display: inline-block;
  padding-left: 0.3em;
  color: #666;
  vertical-align: middle;
  font-size: 0.875em;
}

/* Block help for forms */
.pure-form-message {
  display: block;
  color: #666;
  font-size: 0.875em;
}

@media only screen and (max-width: 480px) {
  .pure-form button[type=submit] {
    margin: 0.7em 0 0;
  }
  .pure-form input:not([type]), .pure-form input[type=text], .pure-form input[type=password], .pure-form input[type=email], .pure-form input[type=url], .pure-form input[type=date], .pure-form input[type=month], .pure-form input[type=time], .pure-form input[type=datetime], .pure-form input[type=datetime-local], .pure-form input[type=week], .pure-form input[type=number], .pure-form input[type=search], .pure-form input[type=tel], .pure-form input[type=color] {
    margin-bottom: 0.3em;
    display: block;
  }
  .pure-form label {
    margin-bottom: 0.3em;
    display: block;
  }
  .pure-group input:not([type]), .pure-group input[type=text], .pure-group input[type=password], .pure-group input[type=email], .pure-group input[type=url], .pure-group input[type=date], .pure-group input[type=month], .pure-group input[type=time], .pure-group input[type=datetime], .pure-group input[type=datetime-local], .pure-group input[type=week], .pure-group input[type=number], .pure-group input[type=search], .pure-group input[type=tel], .pure-group input[type=color] {
    margin-bottom: 0;
  }
  .pure-form-aligned .pure-control-group label {
    margin-bottom: 0.3em;
    text-align: left;
    display: block;
    width: 100%;
  }
  .pure-form-aligned .pure-controls {
    margin: 1.5em 0 0 0;
  }
  /* NOTE: pure-help-inline is deprecated. Use .pure-form-message-inline instead. */
  .pure-form .pure-help-inline, .pure-form-message-inline, .pure-form-message {
    display: block;
    font-size: 0.75em;
    /* Increased bottom padding to make it group with its related input element. */
    padding: 0.2em 0 0.8em;
  }
}
/*!
Pure v0.6.2
Copyright 2013 Yahoo!
Licensed under the BSD License.
https://github.com/yahoo/pure/blob/master/LICENSE.md
*/
/*csslint regex-selectors:false, known-properties:false, duplicate-properties:false*/
.pure-g {
  letter-spacing: -0.31em;
  /* Webkit: collapse white-space between units */
  *letter-spacing: normal;
  /* reset IE < 8 */
  *word-spacing: -0.43em;
  /* IE < 8: collapse white-space between units */
  text-rendering: optimizespeed;
  /* Webkit: fixes text-rendering: optimizeLegibility */
  /*
  Sets the font stack to fonts known to work properly with the above letter
  and word spacings. See: https://github.com/yahoo/pure/issues/41/

  The following font stack makes Pure Grids work on all known environments.

  * FreeSans: Ships with many Linux distros, including Ubuntu

  * Arimo: Ships with Chrome OS. Arimo has to be defined before Helvetica and
    Arial to get picked up by the browser, even though neither is available
    in Chrome OS.

  * Droid Sans: Ships with all versions of Android.

  * Helvetica, Arial, sans-serif: Common font stack on OS X and Windows.
  */
  font-family: FreeSans, Arimo, "Droid Sans", Helvetica, Arial, sans-serif;
  /* Use flexbox when possible to avoid `letter-spacing` side-effects. */
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-flex-flow: row wrap;
  -ms-flex-flow: row wrap;
  flex-flow: row wrap;
  /* Prevents distributing space between rows */
  -webkit-align-content: flex-start;
  -ms-flex-line-pack: start;
  align-content: flex-start;
}

/* IE10 display: -ms-flexbox (and display: flex in IE 11) does not work inside a table; fall back to block and rely on font hack */
@media all and (-ms-high-contrast: none), (-ms-high-contrast: active) {
  table .pure-g {
    display: block;
  }
}
/* Opera as of 12 on Windows needs word-spacing.
   The ".opera-only" selector is used to prevent actual prefocus styling
   and is not required in markup.
*/
.opera-only :-o-prefocus, .pure-g {
  word-spacing: -0.43em;
}

.pure-u {
  display: inline-block;
  *display: inline;
  /* IE < 8: fake inline-block */
  zoom: 1;
  letter-spacing: normal;
  word-spacing: normal;
  vertical-align: top;
  text-rendering: auto;
}

/*
Resets the font family back to the OS/browser's default sans-serif font,
this the same font stack that Normalize.css sets for the `body`.
*/
.pure-g [class*=pure-u] {
  font-family: sans-serif;
}

.pure-u-1, .pure-u-1-1, .pure-u-1-2, .pure-u-1-3, .pure-u-2-3, .pure-u-1-4, .pure-u-3-4, .pure-u-1-5, .pure-u-2-5, .pure-u-3-5, .pure-u-4-5, .pure-u-5-5, .pure-u-1-6, .pure-u-5-6, .pure-u-1-8, .pure-u-3-8, .pure-u-5-8, .pure-u-7-8, .pure-u-1-12, .pure-u-5-12, .pure-u-7-12, .pure-u-11-12, .pure-u-1-24, .pure-u-2-24, .pure-u-3-24, .pure-u-4-24, .pure-u-5-24, .pure-u-6-24, .pure-u-7-24, .pure-u-8-24, .pure-u-9-24, .pure-u-10-24, .pure-u-11-24, .pure-u-12-24, .pure-u-13-24, .pure-u-14-24, .pure-u-15-24, .pure-u-16-24, .pure-u-17-24, .pure-u-18-24, .pure-u-19-24, .pure-u-20-24, .pure-u-21-24, .pure-u-22-24, .pure-u-23-24, .pure-u-24-24 {
  display: inline-block;
  *display: inline;
  zoom: 1;
  letter-spacing: normal;
  word-spacing: normal;
  vertical-align: top;
  text-rendering: auto;
}

.pure-u-1-24 {
  width: 4.1667%;
  *width: 4.1357%;
}

.pure-u-1-12, .pure-u-2-24 {
  width: 8.3333%;
  *width: 8.3023%;
}

.pure-u-1-8, .pure-u-3-24 {
  width: 12.5%;
  *width: 12.469%;
}

.pure-u-1-6, .pure-u-4-24 {
  width: 16.6667%;
  *width: 16.6357%;
}

.pure-u-1-5 {
  width: 20%;
  *width: 19.969%;
}

.pure-u-5-24 {
  width: 20.8333%;
  *width: 20.8023%;
}

.pure-u-1-4, .pure-u-6-24 {
  width: 25%;
  *width: 24.969%;
}

.pure-u-7-24 {
  width: 29.1667%;
  *width: 29.1357%;
}

.pure-u-1-3, .pure-u-8-24 {
  width: 33.3333%;
  *width: 33.3023%;
}

.pure-u-3-8, .pure-u-9-24 {
  width: 37.5%;
  *width: 37.469%;
}

.pure-u-2-5 {
  width: 40%;
  *width: 39.969%;
}

.pure-u-5-12, .pure-u-10-24 {
  width: 41.6667%;
  *width: 41.6357%;
}

.pure-u-11-24 {
  width: 45.8333%;
  *width: 45.8023%;
}

.pure-u-1-2, .pure-u-12-24 {
  width: 50%;
  *width: 49.969%;
}

.pure-u-13-24 {
  width: 54.1667%;
  *width: 54.1357%;
}

.pure-u-7-12, .pure-u-14-24 {
  width: 58.3333%;
  *width: 58.3023%;
}

.pure-u-3-5 {
  width: 60%;
  *width: 59.969%;
}

.pure-u-5-8, .pure-u-15-24 {
  width: 62.5%;
  *width: 62.469%;
}

.pure-u-2-3, .pure-u-16-24 {
  width: 66.6667%;
  *width: 66.6357%;
}

.pure-u-17-24 {
  width: 70.8333%;
  *width: 70.8023%;
}

.pure-u-3-4, .pure-u-18-24 {
  width: 75%;
  *width: 74.969%;
}

.pure-u-19-24 {
  width: 79.1667%;
  *width: 79.1357%;
}

.pure-u-4-5 {
  width: 80%;
  *width: 79.969%;
}

.pure-u-5-6, .pure-u-20-24 {
  width: 83.3333%;
  *width: 83.3023%;
}

.pure-u-7-8, .pure-u-21-24 {
  width: 87.5%;
  *width: 87.469%;
}

.pure-u-11-12, .pure-u-22-24 {
  width: 91.6667%;
  *width: 91.6357%;
}

.pure-u-23-24 {
  width: 95.8333%;
  *width: 95.8023%;
}

.pure-u-1, .pure-u-1-1, .pure-u-5-5, .pure-u-24-24 {
  width: 100%;
}

/*!
Pure v0.6.2
Copyright 2013 Yahoo!
Licensed under the BSD License.
https://github.com/yahoo/pure/blob/master/LICENSE.md
*/
@media screen and (min-width: 35.5em) {
  .pure-u-sm-1, .pure-u-sm-1-1, .pure-u-sm-1-2, .pure-u-sm-1-3, .pure-u-sm-2-3, .pure-u-sm-1-4, .pure-u-sm-3-4, .pure-u-sm-1-5, .pure-u-sm-2-5, .pure-u-sm-3-5, .pure-u-sm-4-5, .pure-u-sm-5-5, .pure-u-sm-1-6, .pure-u-sm-5-6, .pure-u-sm-1-8, .pure-u-sm-3-8, .pure-u-sm-5-8, .pure-u-sm-7-8, .pure-u-sm-1-12, .pure-u-sm-5-12, .pure-u-sm-7-12, .pure-u-sm-11-12, .pure-u-sm-1-24, .pure-u-sm-2-24, .pure-u-sm-3-24, .pure-u-sm-4-24, .pure-u-sm-5-24, .pure-u-sm-6-24, .pure-u-sm-7-24, .pure-u-sm-8-24, .pure-u-sm-9-24, .pure-u-sm-10-24, .pure-u-sm-11-24, .pure-u-sm-12-24, .pure-u-sm-13-24, .pure-u-sm-14-24, .pure-u-sm-15-24, .pure-u-sm-16-24, .pure-u-sm-17-24, .pure-u-sm-18-24, .pure-u-sm-19-24, .pure-u-sm-20-24, .pure-u-sm-21-24, .pure-u-sm-22-24, .pure-u-sm-23-24, .pure-u-sm-24-24 {
    display: inline-block;
    *display: inline;
    zoom: 1;
    letter-spacing: normal;
    word-spacing: normal;
    vertical-align: top;
    text-rendering: auto;
  }
  .pure-u-sm-1-24 {
    width: 4.1667%;
    *width: 4.1357%;
  }
  .pure-u-sm-1-12, .pure-u-sm-2-24 {
    width: 8.3333%;
    *width: 8.3023%;
  }
  .pure-u-sm-1-8, .pure-u-sm-3-24 {
    width: 12.5%;
    *width: 12.469%;
  }
  .pure-u-sm-1-6, .pure-u-sm-4-24 {
    width: 16.6667%;
    *width: 16.6357%;
  }
  .pure-u-sm-1-5 {
    width: 20%;
    *width: 19.969%;
  }
  .pure-u-sm-5-24 {
    width: 20.8333%;
    *width: 20.8023%;
  }
  .pure-u-sm-1-4, .pure-u-sm-6-24 {
    width: 25%;
    *width: 24.969%;
  }
  .pure-u-sm-7-24 {
    width: 29.1667%;
    *width: 29.1357%;
  }
  .pure-u-sm-1-3, .pure-u-sm-8-24 {
    width: 33.3333%;
    *width: 33.3023%;
  }
  .pure-u-sm-3-8, .pure-u-sm-9-24 {
    width: 37.5%;
    *width: 37.469%;
  }
  .pure-u-sm-2-5 {
    width: 40%;
    *width: 39.969%;
  }
  .pure-u-sm-5-12, .pure-u-sm-10-24 {
    width: 41.6667%;
    *width: 41.6357%;
  }
  .pure-u-sm-11-24 {
    width: 45.8333%;
    *width: 45.8023%;
  }
  .pure-u-sm-1-2, .pure-u-sm-12-24 {
    width: 50%;
    *width: 49.969%;
  }
  .pure-u-sm-13-24 {
    width: 54.1667%;
    *width: 54.1357%;
  }
  .pure-u-sm-7-12, .pure-u-sm-14-24 {
    width: 58.3333%;
    *width: 58.3023%;
  }
  .pure-u-sm-3-5 {
    width: 60%;
    *width: 59.969%;
  }
  .pure-u-sm-5-8, .pure-u-sm-15-24 {
    width: 62.5%;
    *width: 62.469%;
  }
  .pure-u-sm-2-3, .pure-u-sm-16-24 {
    width: 66.6667%;
    *width: 66.6357%;
  }
  .pure-u-sm-17-24 {
    width: 70.8333%;
    *width: 70.8023%;
  }
  .pure-u-sm-3-4, .pure-u-sm-18-24 {
    width: 75%;
    *width: 74.969%;
  }
  .pure-u-sm-19-24 {
    width: 79.1667%;
    *width: 79.1357%;
  }
  .pure-u-sm-4-5 {
    width: 80%;
    *width: 79.969%;
  }
  .pure-u-sm-5-6, .pure-u-sm-20-24 {
    width: 83.3333%;
    *width: 83.3023%;
  }
  .pure-u-sm-7-8, .pure-u-sm-21-24 {
    width: 87.5%;
    *width: 87.469%;
  }
  .pure-u-sm-11-12, .pure-u-sm-22-24 {
    width: 91.6667%;
    *width: 91.6357%;
  }
  .pure-u-sm-23-24 {
    width: 95.8333%;
    *width: 95.8023%;
  }
  .pure-u-sm-1, .pure-u-sm-1-1, .pure-u-sm-5-5, .pure-u-sm-24-24 {
    width: 100%;
  }
}
@media screen and (min-width: 48em) {
  .pure-u-md-1, .pure-u-md-1-1, .pure-u-md-1-2, .pure-u-md-1-3, .pure-u-md-2-3, .pure-u-md-1-4, .pure-u-md-3-4, .pure-u-md-1-5, .pure-u-md-2-5, .pure-u-md-3-5, .pure-u-md-4-5, .pure-u-md-5-5, .pure-u-md-1-6, .pure-u-md-5-6, .pure-u-md-1-8, .pure-u-md-3-8, .pure-u-md-5-8, .pure-u-md-7-8, .pure-u-md-1-12, .pure-u-md-5-12, .pure-u-md-7-12, .pure-u-md-11-12, .pure-u-md-1-24, .pure-u-md-2-24, .pure-u-md-3-24, .pure-u-md-4-24, .pure-u-md-5-24, .pure-u-md-6-24, .pure-u-md-7-24, .pure-u-md-8-24, .pure-u-md-9-24, .pure-u-md-10-24, .pure-u-md-11-24, .pure-u-md-12-24, .pure-u-md-13-24, .pure-u-md-14-24, .pure-u-md-15-24, .pure-u-md-16-24, .pure-u-md-17-24, .pure-u-md-18-24, .pure-u-md-19-24, .pure-u-md-20-24, .pure-u-md-21-24, .pure-u-md-22-24, .pure-u-md-23-24, .pure-u-md-24-24 {
    display: inline-block;
    *display: inline;
    zoom: 1;
    letter-spacing: normal;
    word-spacing: normal;
    vertical-align: top;
    text-rendering: auto;
  }
  .pure-u-md-1-24 {
    width: 4.1667%;
    *width: 4.1357%;
  }
  .pure-u-md-1-12, .pure-u-md-2-24 {
    width: 8.3333%;
    *width: 8.3023%;
  }
  .pure-u-md-1-8, .pure-u-md-3-24 {
    width: 12.5%;
    *width: 12.469%;
  }
  .pure-u-md-1-6, .pure-u-md-4-24 {
    width: 16.6667%;
    *width: 16.6357%;
  }
  .pure-u-md-1-5 {
    width: 20%;
    *width: 19.969%;
  }
  .pure-u-md-5-24 {
    width: 20.8333%;
    *width: 20.8023%;
  }
  .pure-u-md-1-4, .pure-u-md-6-24 {
    width: 25%;
    *width: 24.969%;
  }
  .pure-u-md-7-24 {
    width: 29.1667%;
    *width: 29.1357%;
  }
  .pure-u-md-1-3, .pure-u-md-8-24 {
    width: 33.3333%;
    *width: 33.3023%;
  }
  .pure-u-md-3-8, .pure-u-md-9-24 {
    width: 37.5%;
    *width: 37.469%;
  }
  .pure-u-md-2-5 {
    width: 40%;
    *width: 39.969%;
  }
  .pure-u-md-5-12, .pure-u-md-10-24 {
    width: 41.6667%;
    *width: 41.6357%;
  }
  .pure-u-md-11-24 {
    width: 45.8333%;
    *width: 45.8023%;
  }
  .pure-u-md-1-2, .pure-u-md-12-24 {
    width: 50%;
    *width: 49.969%;
  }
  .pure-u-md-13-24 {
    width: 54.1667%;
    *width: 54.1357%;
  }
  .pure-u-md-7-12, .pure-u-md-14-24 {
    width: 58.3333%;
    *width: 58.3023%;
  }
  .pure-u-md-3-5 {
    width: 60%;
    *width: 59.969%;
  }
  .pure-u-md-5-8, .pure-u-md-15-24 {
    width: 62.5%;
    *width: 62.469%;
  }
  .pure-u-md-2-3, .pure-u-md-16-24 {
    width: 66.6667%;
    *width: 66.6357%;
  }
  .pure-u-md-17-24 {
    width: 70.8333%;
    *width: 70.8023%;
  }
  .pure-u-md-3-4, .pure-u-md-18-24 {
    width: 75%;
    *width: 74.969%;
  }
  .pure-u-md-19-24 {
    width: 79.1667%;
    *width: 79.1357%;
  }
  .pure-u-md-4-5 {
    width: 80%;
    *width: 79.969%;
  }
  .pure-u-md-5-6, .pure-u-md-20-24 {
    width: 83.3333%;
    *width: 83.3023%;
  }
  .pure-u-md-7-8, .pure-u-md-21-24 {
    width: 87.5%;
    *width: 87.469%;
  }
  .pure-u-md-11-12, .pure-u-md-22-24 {
    width: 91.6667%;
    *width: 91.6357%;
  }
  .pure-u-md-23-24 {
    width: 95.8333%;
    *width: 95.8023%;
  }
  .pure-u-md-1, .pure-u-md-1-1, .pure-u-md-5-5, .pure-u-md-24-24 {
    width: 100%;
  }
}
@media screen and (min-width: 64em) {
  .pure-u-lg-1, .pure-u-lg-1-1, .pure-u-lg-1-2, .pure-u-lg-1-3, .pure-u-lg-2-3, .pure-u-lg-1-4, .pure-u-lg-3-4, .pure-u-lg-1-5, .pure-u-lg-2-5, .pure-u-lg-3-5, .pure-u-lg-4-5, .pure-u-lg-5-5, .pure-u-lg-1-6, .pure-u-lg-5-6, .pure-u-lg-1-8, .pure-u-lg-3-8, .pure-u-lg-5-8, .pure-u-lg-7-8, .pure-u-lg-1-12, .pure-u-lg-5-12, .pure-u-lg-7-12, .pure-u-lg-11-12, .pure-u-lg-1-24, .pure-u-lg-2-24, .pure-u-lg-3-24, .pure-u-lg-4-24, .pure-u-lg-5-24, .pure-u-lg-6-24, .pure-u-lg-7-24, .pure-u-lg-8-24, .pure-u-lg-9-24, .pure-u-lg-10-24, .pure-u-lg-11-24, .pure-u-lg-12-24, .pure-u-lg-13-24, .pure-u-lg-14-24, .pure-u-lg-15-24, .pure-u-lg-16-24, .pure-u-lg-17-24, .pure-u-lg-18-24, .pure-u-lg-19-24, .pure-u-lg-20-24, .pure-u-lg-21-24, .pure-u-lg-22-24, .pure-u-lg-23-24, .pure-u-lg-24-24 {
    display: inline-block;
    *display: inline;
    zoom: 1;
    letter-spacing: normal;
    word-spacing: normal;
    vertical-align: top;
    text-rendering: auto;
  }
  .pure-u-lg-1-24 {
    width: 4.1667%;
    *width: 4.1357%;
  }
  .pure-u-lg-1-12, .pure-u-lg-2-24 {
    width: 8.3333%;
    *width: 8.3023%;
  }
  .pure-u-lg-1-8, .pure-u-lg-3-24 {
    width: 12.5%;
    *width: 12.469%;
  }
  .pure-u-lg-1-6, .pure-u-lg-4-24 {
    width: 16.6667%;
    *width: 16.6357%;
  }
  .pure-u-lg-1-5 {
    width: 20%;
    *width: 19.969%;
  }
  .pure-u-lg-5-24 {
    width: 20.8333%;
    *width: 20.8023%;
  }
  .pure-u-lg-1-4, .pure-u-lg-6-24 {
    width: 25%;
    *width: 24.969%;
  }
  .pure-u-lg-7-24 {
    width: 29.1667%;
    *width: 29.1357%;
  }
  .pure-u-lg-1-3, .pure-u-lg-8-24 {
    width: 33.3333%;
    *width: 33.3023%;
  }
  .pure-u-lg-3-8, .pure-u-lg-9-24 {
    width: 37.5%;
    *width: 37.469%;
  }
  .pure-u-lg-2-5 {
    width: 40%;
    *width: 39.969%;
  }
  .pure-u-lg-5-12, .pure-u-lg-10-24 {
    width: 41.6667%;
    *width: 41.6357%;
  }
  .pure-u-lg-11-24 {
    width: 45.8333%;
    *width: 45.8023%;
  }
  .pure-u-lg-1-2, .pure-u-lg-12-24 {
    width: 50%;
    *width: 49.969%;
  }
  .pure-u-lg-13-24 {
    width: 54.1667%;
    *width: 54.1357%;
  }
  .pure-u-lg-7-12, .pure-u-lg-14-24 {
    width: 58.3333%;
    *width: 58.3023%;
  }
  .pure-u-lg-3-5 {
    width: 60%;
    *width: 59.969%;
  }
  .pure-u-lg-5-8, .pure-u-lg-15-24 {
    width: 62.5%;
    *width: 62.469%;
  }
  .pure-u-lg-2-3, .pure-u-lg-16-24 {
    width: 66.6667%;
    *width: 66.6357%;
  }
  .pure-u-lg-17-24 {
    width: 70.8333%;
    *width: 70.8023%;
  }
  .pure-u-lg-3-4, .pure-u-lg-18-24 {
    width: 75%;
    *width: 74.969%;
  }
  .pure-u-lg-19-24 {
    width: 79.1667%;
    *width: 79.1357%;
  }
  .pure-u-lg-4-5 {
    width: 80%;
    *width: 79.969%;
  }
  .pure-u-lg-5-6, .pure-u-lg-20-24 {
    width: 83.3333%;
    *width: 83.3023%;
  }
  .pure-u-lg-7-8, .pure-u-lg-21-24 {
    width: 87.5%;
    *width: 87.469%;
  }
  .pure-u-lg-11-12, .pure-u-lg-22-24 {
    width: 91.6667%;
    *width: 91.6357%;
  }
  .pure-u-lg-23-24 {
    width: 95.8333%;
    *width: 95.8023%;
  }
  .pure-u-lg-1, .pure-u-lg-1-1, .pure-u-lg-5-5, .pure-u-lg-24-24 {
    width: 100%;
  }
}
@media screen and (min-width: 80em) {
  .pure-u-xl-1, .pure-u-xl-1-1, .pure-u-xl-1-2, .pure-u-xl-1-3, .pure-u-xl-2-3, .pure-u-xl-1-4, .pure-u-xl-3-4, .pure-u-xl-1-5, .pure-u-xl-2-5, .pure-u-xl-3-5, .pure-u-xl-4-5, .pure-u-xl-5-5, .pure-u-xl-1-6, .pure-u-xl-5-6, .pure-u-xl-1-8, .pure-u-xl-3-8, .pure-u-xl-5-8, .pure-u-xl-7-8, .pure-u-xl-1-12, .pure-u-xl-5-12, .pure-u-xl-7-12, .pure-u-xl-11-12, .pure-u-xl-1-24, .pure-u-xl-2-24, .pure-u-xl-3-24, .pure-u-xl-4-24, .pure-u-xl-5-24, .pure-u-xl-6-24, .pure-u-xl-7-24, .pure-u-xl-8-24, .pure-u-xl-9-24, .pure-u-xl-10-24, .pure-u-xl-11-24, .pure-u-xl-12-24, .pure-u-xl-13-24, .pure-u-xl-14-24, .pure-u-xl-15-24, .pure-u-xl-16-24, .pure-u-xl-17-24, .pure-u-xl-18-24, .pure-u-xl-19-24, .pure-u-xl-20-24, .pure-u-xl-21-24, .pure-u-xl-22-24, .pure-u-xl-23-24, .pure-u-xl-24-24 {
    display: inline-block;
    *display: inline;
    zoom: 1;
    letter-spacing: normal;
    word-spacing: normal;
    vertical-align: top;
    text-rendering: auto;
  }
  .pure-u-xl-1-24 {
    width: 4.1667%;
    *width: 4.1357%;
  }
  .pure-u-xl-1-12, .pure-u-xl-2-24 {
    width: 8.3333%;
    *width: 8.3023%;
  }
  .pure-u-xl-1-8, .pure-u-xl-3-24 {
    width: 12.5%;
    *width: 12.469%;
  }
  .pure-u-xl-1-6, .pure-u-xl-4-24 {
    width: 16.6667%;
    *width: 16.6357%;
  }
  .pure-u-xl-1-5 {
    width: 20%;
    *width: 19.969%;
  }
  .pure-u-xl-5-24 {
    width: 20.8333%;
    *width: 20.8023%;
  }
  .pure-u-xl-1-4, .pure-u-xl-6-24 {
    width: 25%;
    *width: 24.969%;
  }
  .pure-u-xl-7-24 {
    width: 29.1667%;
    *width: 29.1357%;
  }
  .pure-u-xl-1-3, .pure-u-xl-8-24 {
    width: 33.3333%;
    *width: 33.3023%;
  }
  .pure-u-xl-3-8, .pure-u-xl-9-24 {
    width: 37.5%;
    *width: 37.469%;
  }
  .pure-u-xl-2-5 {
    width: 40%;
    *width: 39.969%;
  }
  .pure-u-xl-5-12, .pure-u-xl-10-24 {
    width: 41.6667%;
    *width: 41.6357%;
  }
  .pure-u-xl-11-24 {
    width: 45.8333%;
    *width: 45.8023%;
  }
  .pure-u-xl-1-2, .pure-u-xl-12-24 {
    width: 50%;
    *width: 49.969%;
  }
  .pure-u-xl-13-24 {
    width: 54.1667%;
    *width: 54.1357%;
  }
  .pure-u-xl-7-12, .pure-u-xl-14-24 {
    width: 58.3333%;
    *width: 58.3023%;
  }
  .pure-u-xl-3-5 {
    width: 60%;
    *width: 59.969%;
  }
  .pure-u-xl-5-8, .pure-u-xl-15-24 {
    width: 62.5%;
    *width: 62.469%;
  }
  .pure-u-xl-2-3, .pure-u-xl-16-24 {
    width: 66.6667%;
    *width: 66.6357%;
  }
  .pure-u-xl-17-24 {
    width: 70.8333%;
    *width: 70.8023%;
  }
  .pure-u-xl-3-4, .pure-u-xl-18-24 {
    width: 75%;
    *width: 74.969%;
  }
  .pure-u-xl-19-24 {
    width: 79.1667%;
    *width: 79.1357%;
  }
  .pure-u-xl-4-5 {
    width: 80%;
    *width: 79.969%;
  }
  .pure-u-xl-5-6, .pure-u-xl-20-24 {
    width: 83.3333%;
    *width: 83.3023%;
  }
  .pure-u-xl-7-8, .pure-u-xl-21-24 {
    width: 87.5%;
    *width: 87.469%;
  }
  .pure-u-xl-11-12, .pure-u-xl-22-24 {
    width: 91.6667%;
    *width: 91.6357%;
  }
  .pure-u-xl-23-24 {
    width: 95.8333%;
    *width: 95.8023%;
  }
  .pure-u-xl-1, .pure-u-xl-1-1, .pure-u-xl-5-5, .pure-u-xl-24-24 {
    width: 100%;
  }
}
/*!
Pure v0.6.2
Copyright 2013 Yahoo!
Licensed under the BSD License.
https://github.com/yahoo/pure/blob/master/LICENSE.md
*/
/*csslint adjoining-classes: false, box-model:false*/
.pure-menu {
  box-sizing: border-box;
}

.pure-menu-fixed {
  position: fixed;
  left: 0;
  top: 0;
  z-index: 3;
}

.pure-menu-list, .pure-menu-item {
  position: relative;
}

.pure-menu-list {
  list-style: none;
  margin: 0;
  padding: 0;
}

.pure-menu-item {
  padding: 0;
  margin: 0;
  height: 100%;
}

.pure-menu-link, .pure-menu-heading {
  display: block;
  text-decoration: none;
  white-space: nowrap;
}

/* HORIZONTAL MENU */
.pure-menu-horizontal {
  width: 100%;
  white-space: nowrap;
}
.pure-menu-horizontal .pure-menu-list {
  display: inline-block;
}
.pure-menu-horizontal .pure-menu-item, .pure-menu-horizontal .pure-menu-heading, .pure-menu-horizontal .pure-menu-separator {
  display: inline-block;
  *display: inline;
  zoom: 1;
  vertical-align: middle;
}

/* Initial menus should be inline-block so that they are horizontal */
/* Submenus should still be display: block; */
.pure-menu-item .pure-menu-item {
  display: block;
}

.pure-menu-children {
  display: none;
  position: absolute;
  left: 100%;
  top: 0;
  margin: 0;
  padding: 0;
  z-index: 3;
}

.pure-menu-horizontal .pure-menu-children {
  left: 0;
  top: auto;
  width: inherit;
}

.pure-menu-allow-hover:hover > .pure-menu-children, .pure-menu-active > .pure-menu-children {
  display: block;
  position: absolute;
}

/* Vertical Menus - show the dropdown arrow */
.pure-menu-has-children > .pure-menu-link:after {
  padding-left: 0.5em;
  content: "▸";
  font-size: small;
}

/* Horizontal Menus - show the dropdown arrow */
.pure-menu-horizontal .pure-menu-has-children > .pure-menu-link:after {
  content: "▾";
}

/* scrollable menus */
.pure-menu-scrollable {
  overflow-y: scroll;
  overflow-x: hidden;
}
.pure-menu-scrollable .pure-menu-list {
  display: block;
}

.pure-menu-horizontal.pure-menu-scrollable {
  white-space: nowrap;
  overflow-y: hidden;
  overflow-x: auto;
  -ms-overflow-style: none;
  -webkit-overflow-scrolling: touch;
  /* a little extra padding for this style to allow for scrollbars */
  padding: 0.5em 0;
}
.pure-menu-horizontal.pure-menu-scrollable .pure-menu-list {
  display: inline-block;
}
.pure-menu-horizontal.pure-menu-scrollable::-webkit-scrollbar {
  display: none;
}

/* misc default styling */
.pure-menu-separator {
  background-color: #ccc;
  height: 1px;
  margin: 0.3em 0;
}

.pure-menu-horizontal .pure-menu-children .pure-menu-separator {
  background-color: #ccc;
  height: 1px;
  margin: 0.3em 0;
}
.pure-menu-horizontal .pure-menu-separator {
  width: 1px;
  height: 1.3em;
  margin: 0 0.3em;
}
.pure-menu-horizontal .pure-menu-children .pure-menu-separator {
  display: block;
  width: auto;
}

/* Need to reset the separator since submenu is vertical */
.pure-menu-heading {
  text-transform: uppercase;
  color: #565d64;
}

.pure-menu-link {
  color: #777;
}

.pure-menu-children {
  background-color: #fff;
}

.pure-menu-link, .pure-menu-disabled, .pure-menu-heading {
  padding: 0.5em 1em;
}

.pure-menu-disabled {
  opacity: 0.5;
}
.pure-menu-disabled .pure-menu-link:hover {
  background-color: transparent;
}

.pure-menu-active > .pure-menu-link {
  background-color: #eee;
}

.pure-menu-link:hover, .pure-menu-link:focus {
  background-color: #eee;
}

.pure-menu-selected .pure-menu-link {
  color: #000;
}
.pure-menu-selected .pure-menu-link:visited {
  color: #000;
}

/*!
Pure v0.6.2
Copyright 2013 Yahoo!
Licensed under the BSD License.
https://github.com/yahoo/pure/blob/master/LICENSE.md
*/
.pure-table {
  /* Remove spacing between table cells (from Normalize.css) */
  border-collapse: collapse;
  border-spacing: 0;
  empty-cells: show;
  border: 1px solid #cbcbcb;
}
.pure-table caption {
  color: #000;
  font: italic 85%/1 arial, sans-serif;
  padding: 1em 0;
  text-align: center;
}
.pure-table td, .pure-table th {
  border-left: 1px solid #cbcbcb;
  /*  inner column border */
  border-width: 0 0 0 1px;
  font-size: inherit;
  margin: 0;
  overflow: visible;
  /*to make ths where the title is really long work*/
  padding: 0.5em 1em;
  /* cell padding */
}
.pure-table td:first-child, .pure-table th:first-child {
  border-left-width: 0;
}
.pure-table thead {
  background-color: #e0e0e0;
  color: #000;
  text-align: left;
  vertical-align: bottom;
}
.pure-table td {
  background-color: transparent;
}

/* Consider removing this next declaration block, as it causes problems when
there's a rowspan on the first cell. Case added to the tests. issue#432 */
/*
striping:
   even - #fff (white)
   odd  - #f2f2f2 (light gray)
*/
.pure-table-odd td, .pure-table-striped tr:nth-child(2n-1) td {
  background-color: #f2f2f2;
}

/* nth-child selector for modern browsers */
/* BORDERED TABLES */
.pure-table-bordered td {
  border-bottom: 1px solid #cbcbcb;
}
.pure-table-bordered tbody > tr:last-child > td {
  border-bottom-width: 0;
}

/* HORIZONTAL BORDERED TABLES */
.pure-table-horizontal td, .pure-table-horizontal th {
  border-width: 0 0 1px 0;
  border-bottom: 1px solid #cbcbcb;
}
.pure-table-horizontal tbody > tr:last-child > td {
  border-bottom-width: 0;
}

/*
 * Populities
 * CSS and JS utilities by Populate
 *
 * https://github.com/PopulateTools/populities
 * Version: 0.31
 *
 * TODO: Create and index, document...
 *
 */
.clearfix:after, .clearfix:before {
  content: "";
  display: table;
}
.clearfix:after {
  clear: both;
}

.col-1-2, .col-2-2 {
  width: 48%;
  float: left;
  margin: 0 4% 0 0;
  text-align: center;
}

.col-2-2 {
  float: right;
  margin: 0;
}

.col-1-3, .col-2-3, .col-3-3 {
  width: 32%;
  float: left;
  margin: 0 2% 0 0;
  text-align: center;
}

.col-3-3 {
  float: right;
  margin: 0;
}

.left {
  text-align: left;
}

.right {
  text-align: right;
}

.center {
  text-align: center;
}

.ib {
  display: inline-block;
}

.f_left {
  float: left;
}

.f_right {
  float: right;
}

.hidden, .soft_hidden {
  display: none;
}

.fixed {
  position: fixed;
}

.soft {
  opacity: 0.5;
}

.v_top {
  vertical-align: top;
}

.p_1 {
  padding: 1em;
}

.p_2 {
  padding: 2em;
}

.p_3 {
  padding: 3em;
}

.p_4 {
  padding: 4em;
}

.m_0 {
  margin: 0;
}

.m_1 {
  margin: 1em;
}

.m_2 {
  margin: 2em;
}

.m_3 {
  margin: 3em;
}

.m_4 {
  margin: 4em;
}

.p_h_1 {
  padding: 0 1em;
  box-sizing: border-box;
}

.p_h_2 {
  padding: 0 2em;
  box-sizing: border-box;
}

.p_h_3 {
  padding: 0 3em;
  box-sizing: border-box;
}

.p_h_4 {
  padding: 0 4em;
  box-sizing: border-box;
}

.p_v_1 {
  padding: 1em 0;
  box-sizing: border-box;
}

.p_v_2 {
  padding: 2em 0;
  box-sizing: border-box;
}

.p_v_3 {
  padding: 3em 0;
  box-sizing: border-box;
}

.p_v_4 {
  padding: 4em 0;
  box-sizing: border-box;
}

.m_v_0 {
  margin-top: 0;
  margin-bottom: 0;
}

.m_v_1 {
  margin: 1em 0;
}

.m_v_2 {
  margin: 2em 0;
}

.m_v_3 {
  margin: 3em 0;
}

.m_v_4 {
  margin: 4em 0;
}

.m_v_b_1 {
  margin-bottom: 1em;
}

.m_v_b_2 {
  margin-bottom: 2em;
}

.m_v_b_3 {
  margin-bottom: 3em;
}

.m_v_b_4 {
  margin-bottom: 4em;
}

.p_h_r_1 {
  padding: 0 1em 0 0;
  box-sizing: border-box;
}

.p_h_r_2 {
  padding: 0 2em 0 0;
  box-sizing: border-box;
}

.p_h_r_3 {
  padding: 0 3em 0 0;
  box-sizing: border-box;
}

.p_h_l_1 {
  padding: 0 0 0 1em;
  box-sizing: border-box;
}

.p_h_l_2 {
  padding: 0 0 0 2em;
  box-sizing: border-box;
}

.p_h_l_3 {
  padding: 0 0 0 3em;
  box-sizing: border-box;
}

/*

Mixins
------

Chunks of code to help us along the way. If you need to perform some calculation
place that in the `generic/_functions.scss` file, mixins is more for CSS
properties.

*/
/*
* @include triangle within a pseudo element and add positioning properties (ie. top, left)
* $direction: up, down, left, right
*/
/* Responsive mixin
   ----------------
  @include screen(768, 1280) {
    background: black;
  }
  @include min-screen(320) {
    width: 300px;
  }
*/
@media screen and (max-width: 740px) {
  .desktop_only {
    display: none;
  }
  .mobile_only {
    display: block;
    width: 100%;
  }
}
@media screen and (min-width: 741px) {
  .desktop_only {
    width: 100%;
    display: block;
  }
  .mobile_only {
    display: none;
  }
}
/* Padded Cols hack */
.padded_cols [class*=pure-u] {
  box-sizing: border-box;
}
.padded_cols .padded {
  margin: 0;
}
@media screen and (min-width: 768px) {
  .padded_cols .padded {
    margin: 1em;
  }
}
@media screen and (min-width: 768px) {
  .padded_cols [class*=pure-u]:first-child {
    margin-left: -1em;
  }
}

.padded_cols.example {
  background: rgba(204, 204, 204, 0.9);
}
.padded_cols.example [class*=pure-u] {
  background: #DFDFDF;
}
.padded_cols.example .padded {
  background: green;
  color: #FFF;
  text-align: center;
  padding: 2em;
}

/* Slider */
.slick-loading .slick-list {
  background: #fff url(".//assets/img/ajax-loader.gif") center center no-repeat;
}

/* Icons */
/* Arrows */
.slick-prev,
.slick-next {
  position: absolute;
  display: block;
  height: 20px;
  width: 20px;
  line-height: 0px;
  font-size: 0px;
  cursor: pointer;
  background: transparent;
  color: transparent;
  top: 50%;
  -webkit-transform: translate(0, -50%);
  -ms-transform: translate(0, -50%);
  transform: translate(0, -50%);
  padding: 0;
  border: none;
  outline: none;
}
.slick-prev:hover, .slick-prev:focus,
.slick-next:hover,
.slick-next:focus {
  outline: none;
  background: transparent;
  color: transparent;
}
.slick-prev:hover:before, .slick-prev:focus:before,
.slick-next:hover:before,
.slick-next:focus:before {
  opacity: 1;
}
.slick-prev.slick-disabled:before,
.slick-next.slick-disabled:before {
  opacity: 0.25;
}
.slick-prev:before,
.slick-next:before {
  font-family: "";
  font-size: 20px;
  line-height: 1;
  color: white;
  opacity: 0.75;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

.slick-prev {
  left: -25px;
}
[dir=rtl] .slick-prev {
  left: auto;
  right: -25px;
}
.slick-prev:before {
  content: "←";
}
[dir=rtl] .slick-prev:before {
  content: "→";
}

.slick-next {
  right: -25px;
}
[dir=rtl] .slick-next {
  left: -25px;
  right: auto;
}
.slick-next:before {
  content: "→";
}
[dir=rtl] .slick-next:before {
  content: "←";
}

/* Dots */
.slick-dotted.slick-slider {
  margin-bottom: 30px;
}

.slick-dots {
  position: absolute;
  bottom: -25px;
  list-style: none;
  display: block;
  text-align: center;
  padding: 0;
  margin: 0;
  width: 100%;
}
.slick-dots li {
  position: relative;
  display: inline-block;
  height: 20px;
  width: 20px;
  margin: 0 5px;
  padding: 0;
  cursor: pointer;
}
.slick-dots li button {
  border: 0;
  background: transparent;
  display: block;
  height: 20px;
  width: 20px;
  outline: none;
  line-height: 0px;
  font-size: 0px;
  color: transparent;
  padding: 5px;
  cursor: pointer;
}
.slick-dots li button:hover, .slick-dots li button:focus {
  outline: none;
}
.slick-dots li button:hover:before, .slick-dots li button:focus:before {
  opacity: 1;
}
.slick-dots li button:before {
  position: absolute;
  top: 0;
  left: 0;
  content: "•";
  width: 20px;
  height: 20px;
  font-family: "";
  font-size: 30px;
  line-height: 20px;
  text-align: center;
  color: black;
  opacity: 0.25;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}
.slick-dots li.slick-active button:before {
  color: black;
  opacity: 0.75;
}

.highlight .hll {
  background-color: #49483e;
}

.highlight {
  background: #272822;
  color: #f8f8f2;
}

.highlight .c {
  color: #75715e;
} /* Comment */
.highlight .err {
  color: #960050;
  background-color: #1e0010;
} /* Error */
.highlight .k {
  color: #66d9ef;
} /* Keyword */
.highlight .l {
  color: #ae81ff;
} /* Literal */
.highlight .n {
  color: #f8f8f2;
} /* Name */
.highlight .o {
  color: #f92672;
} /* Operator */
.highlight .p {
  color: #f8f8f2;
} /* Punctuation */
.highlight .ch {
  color: #75715e;
} /* Comment.Hashbang */
.highlight .cm {
  color: #75715e;
} /* Comment.Multiline */
.highlight .cp {
  color: #75715e;
} /* Comment.Preproc */
.highlight .cpf {
  color: #75715e;
} /* Comment.PreprocFile */
.highlight .c1 {
  color: #75715e;
} /* Comment.Single */
.highlight .cs {
  color: #75715e;
} /* Comment.Special */
.highlight .gd {
  color: #f92672;
} /* Generic.Deleted */
.highlight .ge {
  font-style: italic;
} /* Generic.Emph */
.highlight .gi {
  color: #a6e22e;
} /* Generic.Inserted */
.highlight .gs {
  font-weight: bold;
} /* Generic.Strong */
.highlight .gu {
  color: #75715e;
} /* Generic.Subheading */
.highlight .kc {
  color: #66d9ef;
} /* Keyword.Constant */
.highlight .kd {
  color: #66d9ef;
} /* Keyword.Declaration */
.highlight .kn {
  color: #f92672;
} /* Keyword.Namespace */
.highlight .kp {
  color: #66d9ef;
} /* Keyword.Pseudo */
.highlight .kr {
  color: #66d9ef;
} /* Keyword.Reserved */
.highlight .kt {
  color: #66d9ef;
} /* Keyword.Type */
.highlight .ld {
  color: #e6db74;
} /* Literal.Date */
.highlight .m {
  color: #ae81ff;
} /* Literal.Number */
.highlight .s {
  color: #e6db74;
} /* Literal.String */
.highlight .na {
  color: #a6e22e;
} /* Name.Attribute */
.highlight .nb {
  color: #f8f8f2;
} /* Name.Builtin */
.highlight .nc {
  color: #a6e22e;
} /* Name.Class */
.highlight .no {
  color: #66d9ef;
} /* Name.Constant */
.highlight .nd {
  color: #a6e22e;
} /* Name.Decorator */
.highlight .ni {
  color: #f8f8f2;
} /* Name.Entity */
.highlight .ne {
  color: #a6e22e;
} /* Name.Exception */
.highlight .nf {
  color: #a6e22e;
} /* Name.Function */
.highlight .nl {
  color: #f8f8f2;
} /* Name.Label */
.highlight .nn {
  color: #f8f8f2;
} /* Name.Namespace */
.highlight .nx {
  color: #a6e22e;
} /* Name.Other */
.highlight .py {
  color: #f8f8f2;
} /* Name.Property */
.highlight .nt {
  color: #f92672;
} /* Name.Tag */
.highlight .nv {
  color: #f8f8f2;
} /* Name.Variable */
.highlight .ow {
  color: #f92672;
} /* Operator.Word */
.highlight .w {
  color: #f8f8f2;
} /* Text.Whitespace */
.highlight .mb {
  color: #ae81ff;
} /* Literal.Number.Bin */
.highlight .mf {
  color: #ae81ff;
} /* Literal.Number.Float */
.highlight .mh {
  color: #ae81ff;
} /* Literal.Number.Hex */
.highlight .mi {
  color: #ae81ff;
} /* Literal.Number.Integer */
.highlight .mo {
  color: #ae81ff;
} /* Literal.Number.Oct */
.highlight .sa {
  color: #e6db74;
} /* Literal.String.Affix */
.highlight .sb {
  color: #e6db74;
} /* Literal.String.Backtick */
.highlight .sc {
  color: #e6db74;
} /* Literal.String.Char */
.highlight .dl {
  color: #e6db74;
} /* Literal.String.Delimiter */
.highlight .sd {
  color: #e6db74;
} /* Literal.String.Doc */
.highlight .s2 {
  color: #e6db74;
} /* Literal.String.Double */
.highlight .se {
  color: #ae81ff;
} /* Literal.String.Escape */
.highlight .sh {
  color: #e6db74;
} /* Literal.String.Heredoc */
.highlight .si {
  color: #e6db74;
} /* Literal.String.Interpol */
.highlight .sx {
  color: #e6db74;
} /* Literal.String.Other */
.highlight .sr {
  color: #e6db74;
} /* Literal.String.Regex */
.highlight .s1 {
  color: #e6db74;
} /* Literal.String.Single */
.highlight .ss {
  color: #e6db74;
} /* Literal.String.Symbol */
.highlight .bp {
  color: #f8f8f2;
} /* Name.Builtin.Pseudo */
.highlight .fm {
  color: #a6e22e;
} /* Name.Function.Magic */
.highlight .vc {
  color: #f8f8f2;
} /* Name.Variable.Class */
.highlight .vg {
  color: #f8f8f2;
} /* Name.Variable.Global */
.highlight .vi {
  color: #f8f8f2;
} /* Name.Variable.Instance */
.highlight .vm {
  color: #f8f8f2;
} /* Name.Variable.Magic */
.highlight .il {
  color: #ae81ff;
} /* Literal.Number.Integer.Long */
/* Populate */
/* Website */
/* Social Networks */
/* Transition Times */
:root {
  --color-main: #038ba4;
  --color-second: #ee3624;
  --color-third: #554d42;
  --color-underline: #e6ebbb;
}

/* Variables */
/* Scale */
h1 {
  font-size: 2.441rem;
  text-indent: -3px;
}

h2 {
  font-size: 1.953rem;
}

h3 {
  font-size: 1.563rem;
}

h4 {
  font-size: 1.25rem;
}

h5 {
  font-size: 1rem;
}

h6 {
  font-size: 0.8rem;
}

.center {
  text-align: center;
}

.no-underline {
  text-decoration: none;
}

.header {
  padding: 1rem 0;
}

.desktop-menu {
  display: flex;
  justify-content: space-between;
  align-items: self-start;
  margin: 0 0 4rem 0;
}

.logo-header {
  display: inline-block;
  max-width: 8rem;
  margin-left: -18px;
}
@media screen and (max-width: 800px) {
  .logo-header {
    margin-left: 0;
  }
}

body.section_home .logo-header {
  max-width: 16rem;
  margin-top: 36vh;
  margin-bottom: 12vh;
}
@media screen and (max-width: 800px) {
  body.section_home .logo-header {
    max-width: 12rem;
    margin-left: 0;
  }
}

.header-list {
  display: inline-block;
  list-style: none;
  margin: 0;
  padding-left: 0;
  text-align: right;
}
.header-list li {
  display: inline-block;
  padding-left: 2rem;
}
.header-list li.sep {
  padding-left: 3rem;
  position: relative;
}
.header-list li.sep::before {
  content: "";
  position: absolute;
  width: 1px;
  height: 20px;
  margin: 0 0 0 -1.5em;
  background: #DFDFDF;
}
.header-list li a {
  color: rgb(100, 100, 100);
  text-decoration: none;
}

.header-section {
  font-weight: 500;
}

.header-subsection {
  color: #828282;
  font-weight: 300;
}

.newsletter {
  display: block;
  position: relative;
  max-width: 3400px;
  margin: 0 0 2rem;
}
.newsletter .ml-subscribe-form {
  margin: auto;
  position: relative;
  border-bottom: 1px solid #ccc;
}

.newsletter #member_email {
  background: #F3F3F3;
  width: 100%;
  padding: 10px 15px;
  font-size: 0.85em;
  box-sizing: border-box;
}

.newsletter #member_submit {
  position: absolute;
  right: 6px;
  top: 7px;
  font-size: 1.2em;
}

.newsletter p {
  margin-bottom: 0.5rem;
}

.newsletter input, button {
  border: none;
}

.newsletter input[type=submit], button {
  background: none;
}

@media screen and (min-width: 768px) {
  .mobile-menu .logo {
    display: none;
  }
}

.mobile_menu .mfp-container {
  padding: 0;
}

.mobile_menu .mfp-close {
  font-size: 2.5em;
  right: 20px;
  top: 5px;
  color: white;
  opacity: 1;
}

.mobile_menu .mfp-container .mfp-content {
  padding: 0;
  vertical-align: top;
}

.mfp-inline-holder .mfp-content, .mfp-ajax-holder .mfp-content {
  width: 100%;
}

.mobile_menu .mfp-container .mfp-content .modal {
  border-radius: 0;
  margin: 0;
}

.mobile_menu header {
  background: #038ba4;
}

.mobile_menu menu {
  margin: 0;
  padding: 4.5rem 2rem;
}

.mobile-link {
  text-align: center;
  border-top: 1px solid rgba(255, 255, 255, 0.2);
  color: white;
  display: block;
  padding: 2rem;
  font-size: 1rem;
}

.mobile-link:hover {
  color: white;
}

html {
  font-size: 100%;
}

body {
  font-family: "Libre Franklin", sans-serif;
  color: #333;
  -webkit-font-feature-settings: "kern" 1;
  -moz-font-feature-settings: "kern" 1;
  -o-font-feature-settings: "kern" 1;
}
h1, h2, h3,
h4, h5, h6 {
  -webkit-font-feature-settings: "dlig" 1, "liga" 1, "lnum" 1, "kern" 1;
  -moz-font-feature-settings: "dlig" 1, "liga" 1, "lnum" 1, "kern" 1;
  -o-font-feature-settings: "dlig" 1, "liga" 1, "lnum" 1, "kern" 1;
  line-height: 1.25;
  margin: 0 0 0.4em 0;
  font-family: "Libre Franklin", sans-serif;
  color: #038ba4;
}

a {
  color: rgb(100, 100, 100);
  transition: color 0.3s ease;
}

a:hover {
  color: #333;
}

p, ul, ol, dl {
  font-family: "Libre Franklin", sans-serif;
  -webkit-font-feature-settings: "liga" 1, "onum" 1, "kern" 1;
  -moz-font-feature-settings: "liga" 1, "onum" 1, "kern" 1;
  -o-font-feature-settings: "liga" 1, "onum" 1, "kern" 1;
  margin: 0 0 1.75em 0;
}

ol ol, ul ul,
ul ol, ol ul {
  margin: 0 0 0.4em 0;
  padding-left: 2em;
}

ul.no_li {
  margin: 0 0 2em 0;
  padding: 0;
  list-style-type: none;
}
ul.no_li li {
  padding: 0;
}

dl dt {
  float: left;
  width: 180px;
  overflow: hidden;
  clear: left;
  text-align: right;
  text-overflow: ellipsis;
  white-space: nowrap;
  font-weight: 700;
  margin-bottom: 1em;
}

dl dd {
  margin-left: 200px;
  margin-bottom: 1em;
}

li li {
  margin: 0;
}

li > p:last-of-type {
  margin-bottom: 0;
}

hr {
  display: block;
  height: 1px;
  border: 0;
  border-top: #ccc 1px solid;
  margin: 3.2em 0;
  padding: 0;
}

::-moz-selection {
  background: #D6EDFF;
}

::selection {
  background: #D6EDFF;
}

.relative {
  position: relative;
}

.lazy {
  -webkit-transition: opacity 500ms ease-in-out;
  -moz-transition: opacity 500ms ease-in-out;
  -o-transition: opacity 500ms ease-in-out;
  transition: opacity 500ms ease-in-out;
  max-width: 100%;
  opacity: 0;
}

.lazy.loaded {
  opacity: 1;
}

.video_wrapper {
  width: 100%;
  position: relative;
  padding-bottom: 56.25%; /* 16:9 */
  padding-top: 25px;
  height: 0;
}

.video_wrapper iframe {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
}

.small {
  font-size: 0.8em;
  line-height: 1.3;
}

body.about .container li {
  font-size: 0.85em;
  padding: 0 1em 0 0;
}
body.about .container h1 {
  color: #038ba4;
}
body.about .container .main-msg {
  font-size: 1.4em;
  line-height: 1.6;
}
body.about .container.section-color-1 {
  background: #038ba4;
  color: #FFF;
}
body.about .container.section-color-2 {
  background: #E1656D;
  color: #FFF;
}
body.about .container.section-color-3 {
  background: #419D78;
  color: #FFF;
}
body.about .container.section-color-1 a, body.about .container.section-color-2 a, body.about .container.section-color-3 a {
  color: #FFF;
}

.toc {
  font-size: 0.8em;
  line-height: 1.4;
}
.toc ol {
  margin: 0;
  padding: 0;
}
.toc ol ol {
  margin: 0 0 0 1em;
  display: none;
}
.toc .active > a,
.toc .active-child > a {
  font-weight: bold;
}
.toc .active-child > ol {
  display: block;
}

.stuck {
  max-width: none;
  z-index: 1;
  position: fixed;
  top: 0;
}

.toc.stuck {
  top: 100px;
  width: 17%;
}
@media screen and (max-width: 768px) {
  .toc.stuck {
    display: none;
  }
}

.separator {
  border-bottom: 1px solid rgba(0, 0, 0, 0.1);
  height: 1px;
  width: 100%;
  margin: 0 0 1.85rem 0;
}

.share-icons a {
  color: #FFF;
  text-decoration: none;
}
.share-icons a:hover {
  color: #FFF;
}
.share-icons i {
  border-radius: 50%;
  padding: 8px;
  margin: 0 0 0 6px;
  transition: background 150ms ease-in-out;
}
.share-icons i.fa-twitter {
  background: #00ABEF;
}
.share-icons i.fa-facebook {
  background: #3A589A;
}
.share-icons i.fa-linkedin-in {
  background: #0074B5;
}
.share-icons i.fa-envelope-open {
  background: #038ba4;
}
.share-icons i.fa-twitter:hover {
  background: rgb(0, 134.510460251, 188);
}
.share-icons i.fa-facebook:hover {
  background: rgb(44.0471698113, 66.8301886792, 116.9528301887);
}
.share-icons i.fa-linkedin-in:hover {
  background: rgb(0, 83.3149171271, 130);
}
.share-icons i.fa-envelope-open:hover {
  background: rgb(2.0838323353, 96.5508982036, 113.9161676647);
}

body.story header.story .share-icons i.fa-twitter,
body.story header.story .share-icons i.fa-facebook,
body.story header.story .share-icons i.fa-linkedin-in,
body.story header.story .share-icons i.fa-envelope-open {
  background: #FFF;
  color: #038ba4;
  transition: opacity 150ms ease-in-out;
}
body.story header.story .share-icons i.fa-twitter:hover,
body.story header.story .share-icons i.fa-facebook:hover,
body.story header.story .share-icons i.fa-linkedin-in:hover,
body.story header.story .share-icons i.fa-envelope-open:hover {
  opacity: 0.8;
}

#mlb2-1431216.ml-form-embedContainer .ml-form-embedWrapper .ml-form-embedBody, #mlb2-1431216.ml-form-embedContainer .ml-form-embedWrapper .ml-form-successBody {
  padding: 0;
  width: 50%;
}
@media screen and (max-width: 768px) {
  #mlb2-1431216.ml-form-embedContainer .ml-form-embedWrapper .ml-form-embedBody, #mlb2-1431216.ml-form-embedContainer .ml-form-embedWrapper .ml-form-successBody {
    width: 100%;
  }
}

@media only screen and (max-width: 400px) {
  .ml-form-formContent.horozintalForm .ml-form-horizontalRow .ml-input-horizontal {
    width: auto;
  }
}
img {
  max-width: 100%;
}

.hero {
  color: #FFF;
}
.hero h1, .hero h2, .hero h3, .hero h4, .hero p {
  color: #FFF;
}

.hero-logo {
  position: relative;
  max-width: 1440px;
  margin: 0 auto;
}
.hero-logo .container {
  padding: 2rem 1rem;
}
@media screen and (min-width: 768px) {
  .hero-logo {
    padding: 2rem 6rem 8rem;
  }
}

.hero-logo img {
  padding-top: 10vh;
  max-width: 12rem;
}
@media screen and (min-width: 768px) {
  .hero-logo img {
    max-width: 12rem;
  }
}
@media screen and (min-width: 1200px) {
  .hero-logo img {
    max-width: 14rem;
  }
}

.lang-switcher {
  position: absolute;
  bottom: 1rem;
  right: 2rem;
}
@media screen and (min-width: 768px) {
  .lang-switcher {
    right: 6rem;
  }
}
@media screen and (min-width: 1600px) {
  .lang-switcher {
    right: 2rem;
  }
}

.lang-switcher {
  color: #828282;
}
.lang-switcher span {
  margin: 0 0.5em;
}
.lang-switcher a {
  text-decoration: none;
}
.lang-switcher a.active {
  font-weight: 700;
  opacity: 1;
}

/* Description */
.hero-content {
  background: #038ba4;
  color: white;
  position: relative;
  margin-bottom: 7rem;
}

.hero-lead {
  bottom: 0;
  padding: 9rem 0 4rem;
  margin: 0 auto;
  max-width: 1440px;
}

.hero-headline {
  font-size: 1.953rem;
}
@media screen and (min-width: 1000px) {
  .hero-headline {
    font-size: 2.5rem;
  }
}
@media screen and (min-width: 1440px) {
  .hero-headline {
    font-size: 4rem;
  }
}

.hero-subheading {
  font-size: 1.25rem;
  font-weight: 300;
  font-family: "Libre Franklin", sans-serif;
  margin-bottom: 5vh;
}
@media screen and (min-width: 768px) {
  .hero-subheading {
    max-width: 75%;
    font-size: 1.563rem;
  }
}

.hero-list {
  border-top: 1px solid rgba(255, 255, 255, 0.3);
  padding-top: 2rem;
}
@media screen and (min-width: 768px) {
  .hero-list {
    padding-top: 2rem;
  }
}

.hero-point {
  font-weight: 400;
  font-size: 1rem;
  line-height: 1.4rem;
  opacity: 0.5;
}

@media screen and (min-width: 768px) {
  .hero-point p {
    max-width: 70%;
  }
}

.section_home .header {
  position: relative;
}

.container {
  --container-padding-x: 2rem;
  margin: 0 auto;
  padding-left: var(--container-padding-x);
  padding-right: var(--container-padding-x);
  max-width: 1100px;
}
@media screen and (max-width: 768px) {
  .container {
    --container-padding-x: 1rem;
  }
}
@media screen and (min-width: 1400px) {
  .container {
    max-width: 1200px;
  }
}

@media screen and (min-width: 768px) {
  .embed_full_width {
    font-size: 1rem;
    margin-left: -6em;
    margin-right: -6em;
  }
}

.section {
  margin-bottom: 2rem;
}
@media screen and (min-width: 768px) {
  .section {
    margin-bottom: 6rem;
  }
}
@media screen and (min-width: 1600px) {
  .section {
    margin-bottom: 7rem;
  }
}

.section-title {
  color: #038ba4;
  margin-bottom: 1rem;
}

.container#about {
  margin-right: 5%;
  margin-left: 5%;
}
@media screen and (min-width: 768px) {
  .container#about {
    margin-right: 15%;
    margin-left: 15%;
  }
}
@media screen and (min-width: 1600px) {
  .container#about {
    max-width: 800px;
    margin: auto;
  }
}

.pieces-sep img {
  margin: 6em auto;
  display: block;
}
.pieces-sep .rot-45 {
  transform: rotate(45deg);
  max-width: 200px;
}
.pieces-sep .rot-90 {
  transform: rotate(90deg);
  max-width: 165px;
}
.pieces-sep .rot-135 {
  transform: rotate(135deg);
  max-width: 175px;
}
.pieces-sep .rot-180 {
  transform: rotate(180deg);
  max-width: 250px;
}

#contact .fas {
  margin: 0 1em 0 0;
  color: #ee3624;
}
@media screen and (min-width: 768px) {
  #contact .fas {
    margin: 0 1em 0 3em;
  }
}
#contact .contact_links p {
  margin: 0 0 1.25em 0;
}
@media screen and (max-width: 768px) {
  #contact .contact_links p {
    font-size: 0.85em;
  }
}

.intro-text {
  display: flex;
  margin-bottom: 6rem;
  scroll-margin-top: 1em;
  scroll-padding-top: 1em;
}
@media screen and (max-width: 800px) {
  .intro-text {
    display: block;
  }
}
.intro-text .sidebar {
  width: 60%;
  line-height: 150%;
  font-size: 130%;
}
.intro-text .sidebar p strong {
  font-size: 1.8rem;
  line-height: 1.4;
}
.intro-text .sidebar small p {
  font-size: 1rem;
  line-height: 120%;
  color: #828282;
  margin: 0 0 0.5rem 0;
}
@media screen and (max-width: 800px) {
  .intro-text .sidebar {
    width: 100%;
  }
}
.intro-text .sidebar [data-target] {
  display: inline;
  scroll-margin-top: 1em;
  opacity: 1;
  border-bottom: 3px solid var(--color-underline);
  cursor: pointer;
  padding: 2px;
  line-height: 100%;
  border-radius: 3px;
  transition: background-color 0.2s ease-in-out;
}
.intro-text .sidebar [data-target]:hover, .intro-text .sidebar [data-target]:focus {
  background: var(--color-underline);
}
.intro-text .main {
  width: 40%;
  padding-left: 5rem;
  font-size: 90%;
  line-height: 1.4;
  color: #828282;
  position: relative;
}

.hyper-card {
  position: absolute;
  scroll-margin-top: 2em;
  left: 0;
  right: 0;
  margin: auto;
  width: 100%;
  height: 100%;
  padding: 0 0 0 120px;
  box-shadow: 0px 3px 14px 0px rgba(255, 255, 255, 0.2);
  background: #FFF;
  will-change: transform;
  z-index: 100;
}
@media screen and (max-width: 800px) {
  .hyper-card {
    top: 50vh;
    height: 50vh;
    padding: 32px;
    position: fixed;
    box-shadow: 0px -13px 13px rgba(0, 0, 0, 0.15);
    overflow-y: auto;
  }
}
.hyper-card button.close {
  position: absolute;
  top: 0;
  right: -45px;
  background: #038ba4;
  padding: 0.4rem 0.5rem;
  line-height: 1;
  font-size: 0.75rem;
  transition: background-color 0.2s ease-in-out;
  color: #FFF;
}
@media screen and (max-width: 800px) {
  .hyper-card button.close {
    position: fixed;
    right: 0px;
  }
}
.hyper-card button.close:hover {
  background: rgba(3, 139, 164, 0.75);
}

.post-list {
  margin: 6rem 0;
  text-align: center;
}
.post-list h2 {
  display: inline;
}
.post-list h2 a {
  font: 1.5rem/1 "Libre Franklin", sans-serif;
  text-decoration: none;
  color: rgba(3, 139, 164, 0.3);
  transition: color 0.2s ease-in-out, font-size 0.2s ease-in-out;
}
.post-list h2 a:hover {
  color: #038ba4;
}

/* Products */
.product-list {
  display: flex;
  flex-direction: row;
  flex-wrap: wrap;
}
@media screen and (min-width: 768px) {
  .product-list {
    flex-wrap: nowrap;
  }
}

@media screen and (min-width: 768px) {
  .product {
    width: 33%;
  }
}

@media screen and (min-width: 768px) {
  .product:first-child {
    padding-right: 2rem;
  }
}

@media screen and (min-width: 768px) {
  .product:last-child {
    padding-left: 2rem;
  }
}

.product-name {
  margin-bottom: 0.5rem;
  font-weight: 600;
}

.product-link {
  text-decoration: none;
}

.product-description {
  font-family: "Libre Franklin", sans-serif;
  font-weight: 400;
}

.product-img {
  max-width: 100%;
  margin-bottom: 1rem;
}

.project-teaser {
  background-size: cover;
  background-position: center center;
  background-repeat: no-repeat;
  height: 100%;
  transition: color 0.15s ease-in;
}

.project-teaser:hover .project-hover {
  opacity: 1;
}

.project-hover {
  display: flex;
  justify-content: center;
  align-items: center;
  text-align: center;
  opacity: 0;
  color: white;
  vertical-align: middle;
  background-color: rgba(0, 0, 0, 0.6);
  width: 100%;
  height: 100%;
  -webkit-transition: opacity 0.15s ease-in;
  transition: opacity 0.15s ease-in;
  position: absolute;
}

.hover-name {
  font-family: "Libre Franklin", sans-serif;
  font-size: 1.953rem;
  font-weight: 600;
}

.hover-client {
  text-transform: uppercase;
  letter-spacing: 2px;
  font-size: 0.8rem;
}
@media screen and (min-width: 1600px) {
  .hover-client {
    margin: 0 auto;
    max-width: 60%;
  }
}

.w1,
.w2,
.w3,
.w4,
.w5,
.w6 {
  height: 300px;
  width: 100%;
}

.project.wide {
  width: 100%;
  height: 300px;
}

@media screen and (min-width: 768px) {
  .w1 {
    width: calc(50% - 2.5px);
  }
}

@media screen and (min-width: 768px) {
  .w2 {
    width: calc(50% - 2.5px);
  }
}

@media screen and (min-width: 768px) {
  .w3 {
    width: calc(70% - 2.5px);
  }
}

@media screen and (min-width: 768px) {
  .w4 {
    width: calc(30% - 2.5px);
  }
}

@media screen and (min-width: 768px) {
  .w5 {
    width: calc(30% - 2.5px);
  }
}

@media screen and (min-width: 768px) {
  .w6 {
    width: calc(70% - 2.5px);
  }
}

/* Project image */
.project-popup-img {
  margin: 0 auto;
  width: 100%;
  height: auto;
  margin-bottom: 0.5rem;
  padding-bottom: 0.5rem;
}

/* Styles for dialog window */
.dialog {
  background: white;
  text-align: left;
  max-width: 1200px;
  margin: 40px auto;
  position: relative;
}
@media screen and (min-width: 1600px) {
  .dialog {
    max-width: 1440px;
  }
}

.project-name {
  margin-bottom: 0.5rem;
}

@media screen and (min-width: 768px) {
  .project-description {
    padding: 1rem 0 1rem 5rem;
  }
}

.project-client {
  text-transform: uppercase;
  letter-spacing: 2px;
  color: #828282;
  display: block;
  line-height: 1.5;
  margin-bottom: 0.5rem;
}

.project-text {
  margin-top: 0;
}

.project-button {
  background: #038ba4;
  color: white;
  transition: 0.3s;
  border-radius: 4px;
  margin-bottom: 1rem;
  padding: 0.75rem;
}

.project-tags {
  margin: 0 0 1rem 0;
  font-size: 0.75em;
  text-transform: uppercase;
  color: #828282;
  opacity: 0.5;
}
.project-tags .project-tag {
  background: #828282;
  color: #F8F8F8;
  padding: 5px 6px 3px;
  display: inline-block;
  border-radius: 3px;
}

.project-button:hover {
  background: rgb(2.0838323353, 96.5508982036, 113.9161676647);
  color: white;
  filter: none;
  background-image: none;
}

.mfp-arrow-right {
  right: -20px;
}

.mfp-arrow-left {
  left: -20px;
}

.img-slider-container {
  position: relative;
  margin-bottom: 5em;
}

.img-slide {
  overflow: hidden;
  box-shadow: 0 0 25px 0 rgba(0, 0, 0, 0.25);
}
.img-slide .item {
  height: auto;
  float: left;
  width: 100%;
  min-height: 1px;
}
.img-slide .item img {
  width: 100%;
  height: auto;
}

@media screen and (max-width: 768px) {
  .slick-prev,
  .slick-next {
    display: none;
  }
}
.slick-dots {
  bottom: -35px;
}

.slick-next {
  right: -35px;
}

.slick-prev {
  left: -35px;
}

.slick-prev::before,
.slick-next::before {
  color: #038ba4;
  opacity: 0.3;
  transition: opacity 0.15s ease-in;
}

.projects-nav {
  border-top: 1px solid rgba(0, 0, 0, 0.1);
  padding: 3em 0;
}

body.project_v2 {
  color: #4a4a4a;
  line-height: 1.31;
  --sidebar-top: 5rem;
  --sidebar-width: 17.18%;
  --column-width: 26.08%;
}
body.project_v2 .hero {
  height: 427px;
  background-image: linear-gradient(180deg, #0656f9 45%, #033cae 100%);
}
body.project_v2 .sidebar {
  position: -webkit-sticky;
  position: sticky;
  top: 5rem;
  top: var(--sidebar-top);
  height: 50%;
  width: 17.18%;
  width: var(--sidebar-width);
}
@media screen and (min-width: 30em) {
  body.project_v2 .full-width {
    width: calc(100vw - 12px);
    position: relative;
    left: calc(50% - var(--sidebar-width) / 2 - 1rem);
    right: calc(50% - var(--sidebar-width) / 2 - 1rem);
    margin-left: -50vw;
    margin-right: -50vw;
  }
}
@media screen and (max-width: 30em) {
  body.project_v2 .image-gallery img {
    height: 150px;
  }
}
body.project_v2 .anchor {
  height: 5rem;
  height: var(--sidebar-top);
  margin-top: -5rem;
  margin-top: calc(-1 * var(--sidebar-top));
}
@media screen and (min-width: 30em) {
  body.project_v2 .main {
    width: 65.64%;
    width: calc(100% - (var(--sidebar-width)));
  }
  body.project_v2 .w-col-a-ns {
    width: 26.08%;
    width: var(--column-width);
  }
  body.project_v2 .w-col-b-ns {
    width: 73.92%;
    width: calc(100% - var(--column-width));
  }
}

.article {
  margin-bottom: 2rem;
}

.article-headline {
  font-family: "Libre Franklin", sans-serif;
  font-weight: 600;
  display: inline-block;
  padding-right: 1rem;
  margin-bottom: 0.25rem;
}

.article-link {
  text-decoration: none;
}

.article-time {
  font-size: 0.8rem;
  letter-spacing: 0.075rem;
  text-transform: uppercase;
  color: #828282;
  font-weight: 300;
}

.clients {
  text-align: center;
}

.clients-title {
  font-weight: 400;
  color: #038ba4;
  margin-bottom: 2rem;
}

.clients-grid {
  padding: 4rem 0;
  max-width: 1500px;
  margin: 0 auto;
}
@media screen and (min-width: 1200px) {
  .clients-grid {
    padding: 2rem 6rem;
  }
}
@media screen and (min-width: 1600px) {
  .clients-grid {
    padding: 2rem 0;
  }
}

.clients-grid .col-3,
.clients-grid .col-4 {
  border-top: 1px solid #ccc;
}
@media screen and (min-width: 768px) {
  .clients-grid .col-3,
  .clients-grid .col-4 {
    border-top: none;
  }
}

.clients-grid .col-5,
.clients-grid .col-6,
.clients-grid .col-7,
.clients-grid .col-8 {
  border-top: 1px solid #ccc;
}

.clients-grid .col-1,
.clients-grid .col-2,
.clients-grid .col-3,
.clients-grid .col-5,
.clients-grid .col-6,
.clients-grid .col-7 {
  border-right: 1px solid #ccc;
}

.client {
  text-align: center;
  margin-bottom: 1rem;
}

.client-wrapper {
  padding: 2rem;
  height: 120px;
  -webkit-filter: grayscale(100%); /* Safari 6.0 - 9.0 */
  filter: grayscale(100%);
  transition: all 1s ease;
}
@media screen and (min-width: 1200px) {
  .client-wrapper {
    padding: 1rem;
  }
}

.client-wrapper:hover {
  -webkit-filter: grayscale(0%);
  filter: grayscale(0%);
}

.clients-grid .client-img {
  background-position: center;
  background-repeat: no-repeat;
  -webkit-background-size: contain;
  -moz-background-size: contain;
  -o-background-size: contain;
  background-size: contain;
  height: 100%;
  width: 75%;
  margin: auto;
}

.team-grid {
  display: flex;
  flex-direction: row;
  flex-wrap: wrap;
  justify-content: center;
}

.member {
  padding: 1rem;
  text-align: center;
  width: 200px;
}

.member-img {
  margin: 0 auto;
  border-radius: 50%;
  max-width: 100px;
}

.member-name {
  margin-top: 1rem;
  font-weight: 600;
  margin-bottom: 0.5rem;
}

.member-role {
  opacity: 0.5;
  font-size: 0.85rem;
}

/* Base */
body.post .post-page, body.report .post-page {
  max-width: 800px;
  margin: 0 auto 0 290px;
  padding: 0;
}
@media screen and (max-width: 768px) {
  body.post .post-page, body.report .post-page {
    margin: 2em 1em;
  }
}
@media screen and (max-width: 1108px) {
  body.post .post-page, body.report .post-page {
    margin: 1rem;
  }
}
body.post h1, body.report h1 {
  color: #333;
  margin-bottom: 1rem;
  font-size: 1.953rem;
}
@media screen and (min-width: 768px) {
  body.post h1, body.report h1 {
    font-size: 2.441rem;
  }
}
body.post h2, body.report h2 {
  margin-top: 2rem;
  font-weight: 600;
}
body.post h2.subtitle, body.report h2.subtitle {
  font-weight: 300;
  font-size: 1.6em;
  margin: 0 0 1em 0;
}
body.post h3,
body.post h4,
body.post h5, body.report h3,
body.report h4,
body.report h5 {
  font-weight: 600;
}
body.post p, body.report p {
  margin-bottom: 1.85rem;
}
body.post .author-link, body.report .author-link {
  text-decoration: none;
}
body.post .meta, body.report .meta {
  color: #828282;
  margin-bottom: 1.5rem;
}
@media screen and (min-width: 768px) {
  body.post .meta, body.report .meta {
    margin-bottom: 2.5rem;
  }
}

body.report .container {
  max-width: 1050px;
  margin: 2em 0;
}
body.report .content {
  font-size: 1em;
}

.content img,
article header img {
  max-width: 100%;
  height: auto;
  display: block;
  border: 1px solid #DFDFDF;
}

.content {
  font-size: 0.9rem;
  line-height: 1.5;
  border-bottom: 1px solid rgba(0, 0, 0, 0.1);
  padding-bottom: 3em;
  margin-bottom: 3em;
}
@media screen and (min-width: 768px) {
  .content {
    font-size: 1.15em;
    line-height: 1.6;
  }
}
.content a {
  word-wrap: break-word;
}
.content hr {
  margin: 2.5rem 0;
  max-width: 700px;
}
.content caption {
  width: 100%;
  display: block;
  font-size: 0.85em;
  color: #999;
  line-height: 1.3em;
  margin: 0.5em 0 0 0;
}
.content blockquote {
  margin: 2rem 0;
  font-size: 0.9em;
  line-height: 1.8;
  padding-left: 1.5rem;
  border-left: 2px solid #828282;
}

@media screen and (max-width: 768px) {
  .posts-index h2 {
    font-size: 1.2em;
  }
  .posts-index .story {
    padding: 0 2em 0 0;
  }
}
.posts-index .article {
  padding: 0 4rem 0 0;
}
.posts-index .article h2 {
  font-size: 1.2em;
}

.latest-articles {
  margin: 3rem 0;
}
.latest-articles h4 {
  margin: 2em 0;
}
.latest-articles article h2 {
  font-size: 1.5rem;
  margin-top: 0;
}

.small-title {
  font-weight: bold;
  color: #ee3624;
  font-size: 1em;
  margin: 0 0 2em 0;
  text-transform: uppercase;
}

/* Post meta */
.post .info {
  display: inline-block;
  vertical-align: 5px;
}

.meta p {
  margin-bottom: 0;
}

.meta time {
  display: block;
}

.avatar {
  display: inline-block;
  margin-right: 0.5rem;
  max-width: 45px;
  border-radius: 50%;
}

code {
  padding: 0.2em 0.5em;
  background: #F8F8F8;
}

figure {
  margin: 0;
}

.highlight {
  font-size: 0.85em;
  margin: 0 0 2em 0;
  padding: 0.5em;
}
.highlight code {
  background: initial;
  padding: initial;
}
.highlight pre {
  margin: 0;
}

/* Base */
.page article {
  max-width: 1000px;
  padding: 0 1rem 6rem 0;
}
@media screen and (min-width: 768px) {
  .page article {
    padding: 0 6rem 4rem 0;
  }
}
@media screen and (min-width: 1600px) {
  .page article {
    padding: 0 2rem 6rem 0;
  }
}

.page h1 {
  margin-bottom: 1rem;
  font-size: 1.953rem;
}
@media screen and (min-width: 768px) {
  .page h1 {
    font-size: 2.441rem;
    max-width: 875px;
  }
}
@media screen and (min-width: 1600px) {
  .page h1 {
    max-width: 945px;
  }
}

.page .content a {
  word-wrap: break-word;
}

.page .content h2 {
  margin-top: 2rem;
  margin-bottom: 1rem;
  font-weight: 600;
  max-width: 700px;
  font-size: 1.25rem;
}

.page .content h3,
.page .content h4,
.page .content h5 {
  font-weight: 600;
}

.page .content img {
  width: 100%;
  height: auto;
  display: block;
}

.page .content hr {
  margin: 2.5rem 0;
  max-width: 700px;
}

.content blockquote {
  margin: 1rem 0;
  font-style: italic;
  font-family: "Libre Franklin", serif;
  padding-left: 1.5rem;
  border-left: 2px solid #F8F8F8;
}

.careers .careers-list {
  display: flex;
  margin-right: -1em;
  margin-left: -1em;
}
.careers .careers-list .careers-list-item {
  margin: 1em;
  padding: 1em;
  border-radius: 6px;
  flex: 1;
  background: #F8F8F8;
  text-align: center;
}
.careers .careers-list .careers-list-item h2 {
  font-size: 1rem;
  margin: 1em 0;
}

ul h2 {
  font-size: 1.25rem;
}

.footer {
  border-top: 1px solid rgba(0, 0, 0, 0.1);
  position: relative;
  font-family: "Libre Franklin", sans-serif;
  padding: 2rem 0;
}
.footer a {
  text-decoration: none;
}
@media screen and (min-width: 768px) {
  .footer {
    padding: 2rem 0 6rem 0;
  }
}
@media screen and (min-width: 1600px) {
  .footer {
    padding: 2rem 0 20rem 0;
  }
}

.footer-link {
  font-family: "Libre Franklin", sans-serif;
  margin-bottom: 2rem;
  display: inline-block;
}

.footer-link:not(:last-child) {
  padding-right: 2rem;
}

.social-links i {
  font-size: 1.2em;
  padding: 0 0.8em;
}

.legal-links a {
  font-size: 0.85rem;
  opacity: 0.75;
}

html {
  scroll-behavior: smooth;
}

body.populate_data h1, body.populate_data h2, body.populate_data h3, body.populate_data h4 {
  font-family: "Source Code Pro";
}
body.populate_data .column {
  width: 95%;
  max-width: 1000px;
  margin: auto;
  position: relative;
}
@media screen and (max-width: 768px) {
  body.populate_data .column {
    width: 90%;
  }
}
body.populate_data header.top {
  background: #F7F7F7;
  display: flex;
  justify-content: space-between;
  height: 66px;
  position: fixed;
  z-index: 10;
  width: 100%;
}
body.populate_data header.top img {
  max-height: 100%;
}
body.populate_data header.top menu {
  margin: 0;
  padding: 0;
  align-self: center;
}
@media screen and (max-width: 768px) {
  body.populate_data header.top menu {
    display: none;
  }
  body.populate_data header.top menu.menu_open {
    display: block;
    position: absolute;
    background: red;
    width: 100%;
    height: 100%;
    top: 0;
    left: 0;
    z-index: 100;
  }
}
body.populate_data header.top menu a {
  text-decoration: none;
  color: #0F2560;
  font-size: 0.9em;
  font-weight: 600;
  margin: 0 1em;
}
@media screen and (max-width: 768px) {
  body.populate_data header.top .a_product_by {
    display: none;
  }
}
body.populate_data header.top .mobile_menu_handler {
  display: none;
}
@media screen and (max-width: 768px) {
  body.populate_data header.top .mobile_menu_handler {
    display: block;
  }
}
body.populate_data section.intro {
  border-top: 1px solid #FFF;
  background: url(asset_path("data/bg_front.jpg")) no-repeat top center;
  background-size: cover;
  position: relative;
  padding-top: 66px;
}
body.populate_data section.intro .column {
  display: flex;
  justify-content: space-between;
}
@media screen and (max-width: 768px) {
  body.populate_data section.intro .column {
    display: block;
  }
}
body.populate_data section.intro .intro_title {
  width: 35%;
  padding-top: 12%;
}
@media screen and (max-width: 768px) {
  body.populate_data section.intro .intro_title {
    width: 100%;
  }
}
body.populate_data section.intro .intro_title h1 {
  color: #FFF;
  position: relative;
  font-size: 70px;
  padding-bottom: 40px;
  color: #FFF;
}
@media screen and (max-width: 768px) {
  body.populate_data section.intro .intro_title h1 {
    font-size: 48px;
  }
}
body.populate_data section.intro .intro_title h1:after {
  position: absolute;
  content: "";
  width: 115px;
  height: 13px;
  background: #EE3624;
  bottom: 0;
  left: 0;
}
body.populate_data section.intro .intro_title p.intro {
  font-size: 24px;
  color: #FFF;
  padding-bottom: 12%;
}
body.populate_data section.intro .featured_items {
  width: 45%;
  display: flex;
  flex-direction: column;
  align-content: flex-end;
  position: absolute;
  right: 0;
  bottom: -105px;
}
@media screen and (max-width: 768px) {
  body.populate_data section.intro .featured_items {
    width: 100%;
    position: relative;
    right: initial;
    bottom: initial;
  }
}
body.populate_data section.intro .featured_items div.item {
  background: #EE3624;
  color: #FFF;
  font-size: 18px;
  height: 104px;
  display: flex;
}
body.populate_data section.intro .featured_items div.item div {
  align-items: center;
  display: flex;
  padding: 0 2vw;
}
body.populate_data section.intro .featured_items div.item div p {
  margin: 0;
  font-family: "Source Code Pro";
  font-size: 0.9em;
}
body.populate_data section.intro .featured_items div.item div .icon {
  margin: 0 20px 0 0;
  font-size: 24px;
}
@media screen and (max-width: 768px) {
  body.populate_data section.intro .featured_items div.item div .icon {
    margin: 0 20px 0 12px;
  }
}
body.populate_data section.intro .featured_items div:not(:last-child) {
  border-bottom: 1px solid #FFF;
}
body.populate_data section.about {
  padding: 26vh 0 0;
  margin-top: 4em;
  margin-bottom: -50px;
  background: url(asset_path("data/bg_random_whole.svg")) no-repeat top center;
  background-size: cover;
}
@media screen and (max-width: 768px) {
  body.populate_data section.about {
    padding-top: 0;
  }
}
body.populate_data section.about .inner {
  font-size: 18px;
  width: 50vw;
  margin: auto;
  text-align: center;
  color: #102663;
}
@media screen and (max-width: 768px) {
  body.populate_data section.about .inner {
    width: 77%;
    text-align: left;
  }
}
body.populate_data section.on_demand {
  padding-top: 6em;
}
body.populate_data section.on_demand .box {
  width: 50%;
  background: #EE3624;
  padding: 3em 3em 4em 3em;
  position: relative;
  margin-bottom: -50px;
  z-index: 1;
}
@media screen and (max-width: 768px) {
  body.populate_data section.on_demand .box {
    width: 100%;
  }
}
body.populate_data section.on_demand .box h2 {
  position: relative;
  margin: 5px 0;
  padding: 30px 0 0 0;
  color: #FFF;
}
@media screen and (max-width: 768px) {
  body.populate_data section.on_demand .box h2 {
    font-size: 24px;
  }
}
body.populate_data section.on_demand .box h2:before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  width: 62px;
  height: 8px;
  background: #0F2560;
}
body.populate_data section.on_demand .box p {
  color: #FFF;
}
body.populate_data section.on_demand .box a.button.more_info {
  position: absolute;
  bottom: 0;
  right: 0;
  background: #FFF;
  padding: 1em 3em;
  color: #0F2560;
  font-weight: bold;
  text-decoration: none;
}
body.populate_data section.on_demand .box a.button.more_info:hover {
  background: #0F2560;
  color: #FFF;
}
body.populate_data section.process {
  background: #0F2560;
  overflow: scroll;
}
body.populate_data section.process .column {
  padding-top: 15vh;
  padding-bottom: 10vh;
}
body.populate_data section.process h2 {
  position: relative;
  margin: 5px 0;
  padding: 30px 0 0 0;
  color: #FFF;
}
body.populate_data section.process h2:before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  width: 62px;
  height: 8px;
  background: #EE3624;
}
body.populate_data section.process img.diagram-process {
  margin: 3em auto;
  width: 100%;
  max-width: 1200px;
}
@media screen and (max-width: 768px) {
  body.populate_data section.process img.diagram-process {
    min-width: 900px;
  }
}
body.populate_data section.data {
  padding: 5em 0;
}
body.populate_data section.data h2 {
  color: #102663;
}
body.populate_data section.data .notice {
  padding: 1em;
  margin-bottom: 1em;
  background: rgba(238, 54, 36, 0.1);
}
body.populate_data section.use_cases {
  margin: 5em 0;
  padding: 7em 0;
  background: #F3F3F3;
}
body.populate_data section.use_cases .column {
  max-width: 850px;
}
body.populate_data section.use_cases h2 {
  font-size: 1em;
  width: 20%;
  padding-bottom: 10px;
  margin-bottom: 10px;
  color: #102663;
  position: relative;
  z-index: 3;
}
body.populate_data section.use_cases .use_case {
  margin-bottom: 5em;
  display: flex;
}
@media screen and (max-width: 768px) {
  body.populate_data section.use_cases .use_case {
    flex-flow: row-reverse wrap-reverse;
  }
}
body.populate_data section.use_cases .use_case .use_case_main {
  width: 50%;
  margin-bottom: 2em;
  padding-right: 10%;
}
@media screen and (max-width: 768px) {
  body.populate_data section.use_cases .use_case .use_case_main {
    width: 100%;
    margin-bottom: 0;
  }
}
body.populate_data section.use_cases .use_case h3 {
  position: relative;
  font-size: 1.25em;
  color: #102663;
  padding-top: 10px;
  z-index: 2;
}
body.populate_data section.use_cases .use_case h3 span {
  font-size: 1.7em;
  width: 40px;
  display: inline-block;
}
body.populate_data section.use_cases .use_case h3::after {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  width: 40%;
  height: 4px;
  background: #EE3624;
}
body.populate_data section.use_cases .use_case h3::before {
  content: "";
  position: absolute;
  display: inline-block;
  width: 150px;
  height: 150px;
  border-radius: 150px;
  background-color: #FFF;
  top: -50px;
  left: -75px;
  z-index: -1;
}
body.populate_data section.use_cases .use_case .user_case_description {
  color: #102663;
  font-size: 0.85em;
  line-height: 1.4;
  z-index: 2;
  position: relative;
}
body.populate_data section.use_cases .use_case .user_case_description p {
  margin: 1em 0;
}
body.populate_data section.use_cases .use_case .use_case_image {
  width: 50%;
  box-shadow: 0px 0px 10px 5px rgba(0, 0, 0, 0.1);
}
@media screen and (max-width: 768px) {
  body.populate_data section.use_cases .use_case .use_case_image {
    width: 100%;
    margin: 0 0 1em 0;
  }
}
body.populate_data section.start_using {
  padding: 7em 0;
}

.nav ul,
.nav ul li {
  list-style-type: none;
  margin: 0;
  padding: 0;
}

.nav {
  width: 100%;
  position: fixed;
  z-index: 10;
  clear: both;
  top: 0;
}

ul#menu {
  display: none;
  width: 100%;
  position: absolute;
  top: 0;
  z-index: -1;
  padding: 0;
  margin: 0;
}

ul#menu li a {
  width: 100%;
  display: block;
  background-color: #000;
  color: #fff;
  font-size: 1em;
  padding: 1.5em 1.6em;
  transition: background 0.2s;
  text-decoration: none;
}

ul#menu a:hover {
  background-color: #303030;
}

@media screen and (min-width: 1280px) {
  .hamburger-container {
    display: none;
  }
  .nav ul#menu {
    display: inline;
  }
  .nav ul#menu li {
    display: inline-block;
    margin-right: -5px;
  }
}
ul.hamburger li {
  height: 4px;
  background: #102663;
  content: "";
  position: relative;
  transition: 0.25s ease-in-out;
}

.hidden {
  opacity: 0;
}

.rot45deg {
  transform: rotate(45deg);
  top: 10px !important;
}

.rot-45deg {
  transform: rotate(-45deg);
}

ul.hamburger {
  display: block;
}

ul.hamburger li:nth-child(1) {
  top: 0;
}

ul.hamburger li:nth-child(2) {
  top: 5px;
}

ul.hamburger li:nth-child(3) {
  top: 10px;
}

.hamburger-container {
  width: 30px;
  margin: 1.2em 1.6em;
  height: 30px;
  cursor: pointer;
  float: right;
}

body.story a {
  transition: all 0.15s ease-in-out;
}
body.story header.header {
  padding-bottom: 0;
}
body.story.story_merca header.story {
  height: initial;
  padding: 0;
}
body.story.story_merca header.story .container {
  margin: 0;
  max-width: initial;
  display: flex;
  padding: initial;
  justify-content: flex-end;
}
body.story.story_merca header.story .visual_feature {
  align-self: stretch;
  background: url(asset_path("190901-mercamadrid-ilu-intro.png")) center right no-repeat;
  width: 605px;
  height: 534px;
}
body.story.story_merca header.story .header-text {
  align-self: center;
  padding: 0 5em 0 2em;
  width: 50%;
}
body.story.story_merca header.story .header-text p.author {
  margin-bottom: 0;
}
@media screen and (max-width: 768px) {
  body.story.story_merca header.story .container {
    flex-flow: column-reverse;
  }
  body.story.story_merca header.story .visual_feature {
    width: 100%;
    height: 325px;
  }
  body.story.story_merca header.story .header-text {
    width: 100%;
    padding: 1.5em;
  }
}
body.story .news_list {
  margin-bottom: 5em;
  display: flex;
  justify-content: center;
  padding: 2em;
}
body.story .news_list .news_item {
  background: #038ba4;
  width: 50%;
  margin: 1em;
  transition: box-shadow 0.15s ease-in-out;
}
body.story .news_list .news_item a {
  color: #FFF;
  text-decoration: none;
}
body.story .news_list .news_item:hover {
  box-shadow: 0 0 10px 0 rgba(0, 0, 0, 0.3);
}
body.story .news_list .news_item .header-text {
  padding: 1em;
}
body.story .news_list .news_item .header-text h1 {
  font-size: 1.25rem;
  color: #FFF;
}
body.story .news_list .news_item .header-text h2 {
  font-size: 0.8rem;
  font-weight: normal;
  color: #FFF;
  opacity: 0.5;
}
body.story .news_list .news_item .visual_feature {
  height: 100px;
  background: url(asset_path("190901-mercamadrid-ilu-intro.png")) center right no-repeat;
}
body.story header.story {
  background: #038ba4;
  padding: 4em 0;
  color: #FFF;
  margin: 0;
  height: 80vh;
}
body.story header.story h1, body.story header.story h2 {
  color: #FFF;
}
body.story header.story h2 {
  font-weight: normal;
  opacity: 0.6;
}
body.story header.story p.author {
  margin: 4em 0;
  opacity: 0.6;
}
@media screen and (max-width: 768px) {
  body.story header.story {
    margin-top: 1em;
    height: 100vh;
  }
  body.story header.story .container {
    padding: 0;
    margin: 1em;
  }
  body.story header.story .visual_feature {
    width: initial;
    height: initial;
    float: none;
  }
  body.story header.story h1 {
    font-size: 1.8em;
  }
  body.story header.story h2 {
    font-size: 1.5em;
  }
}
body.story .header-story-menu {
  display: flex;
  padding: 0.35em 1em;
  background: #038ba4;
  justify-content: space-around;
  position: sticky;
  top: 0;
  z-index: 1000;
}
body.story .header-story-menu a {
  font-size: 0.75em;
  color: #FFF;
  text-transform: uppercase;
  text-decoration: none;
}
body.story .header-story-menu.is-sticky {
  padding: 0.5em 1em;
}
body.story .row-col {
  justify-content: space-around;
  max-width: 800px;
  margin: auto;
}
@media screen and (max-width: 768px) {
  body.story .row-col {
    margin: 0 1em;
  }
}
body.story .story-content-full {
  width: 96vw;
  margin-left: calc(-47vw + 380px);
}
@media screen and (max-width: 768px) {
  body.story .story-content-full {
    width: initial;
    margin-left: initial;
  }
}
body.story .story-content-overcolumn {
  margin-left: -100px;
  margin-right: -100px;
}
@media screen and (max-width: 1000px) {
  body.story .story-content-overcolumn {
    margin-left: -50px;
    margin-right: -50px;
  }
}
@media screen and (max-width: 768px) {
  body.story .story-content-overcolumn {
    margin-left: initial;
    margin-right: initial;
  }
}
body.story .story-menu {
  margin-top: 5em;
  margin-bottom: 5em;
  align-self: flex-start;
  border: 1px solid red;
  width: 200px;
  position: sticky;
  padding: 0.35em 1em;
}
body.story .story-menu a {
  font-size: 0.75em;
  text-decoration: none;
  display: block;
}
body.story .story-content.with-story-menu {
  width: 800px;
  padding-left: 50px;
}
body.story .story-content.with-story-menu .story-content-full {
  margin-left: -200px;
}
body.story .narrow-col {
  max-width: 700px;
  margin: auto;
}
body.story .section {
  margin-top: 5em;
  margin-bottom: 5em;
}
body.story .section-cover {
  background: #038ba4;
  padding: 2em;
}
body.story .section-cover h2 {
  color: #FFF;
}
body.story .section-cover p {
  color: #FFF;
  margin: 0;
}
body.story .sources {
  font-size: 0.85em;
  color: #777;
}
body.story .notes {
  padding: 1.5em;
  font-size: 0.75em;
  background: #F8F8F8;
  color: #828282;
}
body.story .notes p:last-child {
  margin-bottom: 0;
}
body.story .note {
  border-radius: 5px;
  padding: 2em;
  font-size: 0.7em;
  line-height: 1.4;
  color: #828282;
  background: rgb(244, 244, 244);
}
body.story .flex {
  display: flex;
}
body.story table {
  width: 100%;
}
body.story table th {
  font-size: 12px;
  font-weight: 200;
  color: rgba(51, 51, 51, 0.5);
  text-transform: uppercase;
}
body.story table th.tb-kilos {
  min-width: 100px;
}
@media screen and (max-width: 768px) {
  body.story table th.tb-kilos {
    min-width: initial;
  }
}
body.story table th.tb-percentage {
  min-width: 100px;
}
@media screen and (max-width: 768px) {
  body.story table th.tb-percentage {
    min-width: initial;
  }
}
body.story table td {
  padding: 6px;
  font-size: 1rem;
  border-bottom: 1px solid rgba(216, 216, 216, 0.3);
}
@media screen and (max-width: 768px) {
  body.story table td {
    font-size: 0.8rem;
  }
}
body.story table td i.fas {
  margin-right: 10px;
  width: 30px;
  text-align: center;
  color: rgba(74, 74, 74, 0.3);
  transition: color 0.15s ease-in-out;
}
body.story table td a {
  color: #038ba4;
}
body.story table tbody.tb-secondary td {
  padding: 3px 6px;
  font-size: 0.75rem;
  border-bottom: 1px solid rgba(216, 216, 216, 0.15);
}
body.story table tbody.tb-secondary td.td-big {
  padding-left: 50px;
}
body.story table tbody.tb-secondary td.td-bar-chart {
  padding-left: 16px;
}
body.story table td.tb-kilos, body.story table td.tb-percentage {
  font-weight: 200;
}
body.story table td.td-bar-chart {
  width: 300px;
  padding-left: 16px;
}
@media screen and (max-width: 768px) {
  body.story table td.td-bar-chart {
    width: 20%;
  }
}
body.story table td.td-big {
  font-size: 1.25rem;
  padding-top: 8px;
  padding-bottom: 8px;
}
body.story table td.td-big a {
  text-decoration: none;
}
body.story table td.td-big a:hover i.fas {
  color: #038ba4;
}
body.story table td.tb-percentage {
  opacity: 0.5;
}
body.story input {
  border-radius: 3px;
  padding: 4px;
}
body.story .bar-chart-cont {
  position: relative;
  background: #F8F8F8;
  border-radius: 3px;
  height: 9px;
}
body.story .bar-chart {
  position: absolute;
  background: #038ba4;
  border-radius: 3px;
  height: 100%;
  left: 0;
  top: 0;
}
body.story .small-multiples {
  display: flex;
  flex-wrap: wrap;
  margin: 0 -15px;
}
@media screen and (max-width: 768px) {
  body.story .small-multiples {
    margin: 0 -10px;
  }
}
body.story .small-multiples .multiple {
  width: 20%;
  padding: 15px;
}
@media screen and (max-width: 768px) {
  body.story .small-multiples .multiple {
    width: 33.3333333333%;
    overflow: hidden;
    padding: 10px;
  }
}
body.story .small-multiples .multiple h3 {
  font-size: 12px;
  color: #333;
  text-transform: uppercase;
}
body.story .small-multiples .multiple td, body.story .small-multiples .multiple th {
  padding: 1px 2px 1px 0;
  font-size: 12px;
  text-transform: capitalize;
  text-align: left;
  color: #333;
  border: none;
}
body.story .small-multiples .multiple td.td-bar-chart {
  width: 50%;
}
body.story .small-multiples .multiple td.td-bar-chart .bar-chart-cont {
  height: 7px;
}
body.story .story-newsletter-promo {
  border-top: 1px solid rgba(51, 51, 51, 0.1);
  border-bottom: 1px solid rgba(51, 51, 51, 0.1);
  font-size: 14px;
  padding: 1.5em 0 0 0;
}
body.story .story-newsletter-promo p {
  padding: 0 20px;
  margin: 0;
}
body.story .menu-story {
  position: fixed;
  bottom: 1.25em;
  left: 1.25em;
  padding: 0.5em;
  font-size: 14px;
  line-height: 1.2;
  z-index: 100;
  height: 33px;
  width: 90px;
  transition: all 0.2s ease-in-out;
  background: #FFF;
  border: 1px solid #EAEAEA;
  box-shadow: 0 0 18px 0 rgba(0, 0, 0, 0.22);
  border-radius: 3px;
}
body.story .menu-story:hover {
  height: 40vh;
  width: 65vw;
  background: linear-gradient(90deg, #038ba4 50%, #FFF 50%);
}
body.story .menu-story:hover .menu-story-open {
  visibility: visible;
}
@media screen and (max-width: 768px) {
  body.story .menu-story:hover {
    height: 80vh;
    width: 90vw;
    background: #FFF;
  }
}
body.story .menu-story .menu-story-cue {
  position: absolute;
  bottom: 0.5em;
  left: 0.5em;
}
body.story .menu-story .menu-story-cue a {
  text-decoration: none;
}
body.story .menu-story .menu-story-container {
  padding-right: 1em;
  color: #FFF;
}
@media screen and (max-width: 768px) {
  body.story .menu-story .menu-story-container {
    padding-right: 0;
    padding-bottom: 4em;
  }
}
body.story .menu-story .menu-story-container h2 {
  font-size: 1.5em;
  margin-bottom: 1.5em;
  color: #FFF;
}
@media screen and (max-width: 768px) {
  body.story .menu-story .menu-story-container h2 {
    color: initial;
  }
}
body.story .menu-story .menu-story-container .menu-story-items a {
  display: block;
  margin-bottom: 0.5em;
  color: #FFF;
  transition: font-weight 150ms ease-in-out;
}
@media screen and (max-width: 768px) {
  body.story .menu-story .menu-story-container .menu-story-items a {
    color: initial;
  }
}
body.story .menu-story .menu-story-container .menu-story-items a:hover {
  font-weight: bold;
}
body.story .menu-story .menu-story-about {
  padding-left: 2em;
}
@media screen and (max-width: 768px) {
  body.story .menu-story .menu-story-about {
    padding-left: 0;
  }
}
body.story .menu-story .menu-story-open {
  visibility: hidden;
  padding: 1em;
}
body.story .menu-story #mlb2-1431216.ml-form-embedContainer .ml-form-embedWrapper .ml-form-embedBody, body.story .menu-story #mlb2-1431216.ml-form-embedContainer .ml-form-embedWrapper .ml-form-successBody {
  padding: 0;
  width: 100%;
}
body.story .product-browser {
  padding: 0 2em;
}
@media screen and (max-width: 768px) {
  body.story .product-browser {
    padding: 0 0.5em;
  }
}
body.story .product-browser .product-browser-sidebar {
  width: 25%;
  padding-right: 5%;
}
body.story .product-browser .product-browser-sidebar input {
  width: 100%;
  font-size: 0.85em;
}
body.story .product-browser .product-browser-sidebar .category_products {
  padding-left: 1em;
}
body.story .product-browser .product-browser-content {
  width: 75%;
}
body.story .product-browser .product-browser-content-header h2 {
  margin: 0;
  line-height: 1;
  font-size: 1.5em;
}
body.story .product-browser .product-browser-content-header h2 .button_small {
  padding: 0.35em 0.45em 0.25em;
  margin: 0 0.12em;
  font-size: 1.5rem;
}
body.story .product-browser .category_products {
  display: none;
}
body.story .product-browser .item-list {
  line-height: 1.2;
}
body.story .product-browser .item-list a {
  padding: 0.25em;
  border-radius: 3px;
  background: #FFF;
  display: block;
  color: #038ba4;
  font-size: 0.75em;
}
body.story .product-browser .item-list a:hover {
  background: rgba(3, 139, 164, 0.1);
}
body.story .story-container {
  padding: 0;
}
body.story .story-container.container {
  margin: auto;
  max-width: 1400px;
}
body.story .story-container .embed_full_width {
  margin-left: initial;
  margin-right: initial;
}
body.story .story-container .section-text {
  padding-left: 3em;
  padding-right: 3em;
}
@media screen and (max-width: 768px) {
  body.story .story-container .section-text {
    padding-left: 1em;
    padding-right: 1em;
  }
}
body.story .story-container .content img {
  border: none;
}
body.story .story-container .content .img_cont.shadow {
  box-shadow: 0 0 20px 0 rgba(0, 0, 0, 0.25);
}
body.story .story-container .content .img_cont.shadow img {
  width: 100%;
  height: auto;
}
body.story .story-container .separator {
  margin: 5em 0;
}
@media screen and (min-width: 768px) {
  body.story .story-container .sub_section_header {
    margin-left: 160px;
  }
}
body.story .story-container .scrolling-text {
  position: relative;
  z-index: 100;
  max-width: 700px;
  padding: 2.5em 3em;
  border-radius: 5px;
  background: #FFF;
  margin: auto;
  background: #FFFFFF;
  box-shadow: 0 0 20px 0 rgba(0, 0, 0, 0.25);
  margin-bottom: 4em;
}
@media screen and (max-width: 768px) {
  body.story .story-container .scrolling-text {
    padding: 1.5em;
    margin: auto 1em;
  }
}
body.story .story-container .scrolling-text p:last-child {
  margin-bottom: 0;
}
body.story .story-container .scrolling-text.note {
  margin-bottom: 50vh;
  width: 40%;
  margin-right: 0;
  font-size: 0.7em;
  padding: 1.5em 2em;
}
@media screen and (max-width: 768px) {
  body.story .story-container .scrolling-text.note {
    font-size: 0.9em;
    width: 94%;
  }
}
body.story .story-container .scrolling-text.biggy {
  max-width: 90%;
}
body.story .story-container .tabs {
  margin: 0 0 1em 0;
}
body.story .story-container .tab-content {
  display: none;
}
body.story .story-container .tab-content.current {
  display: inherit;
  transition: opacity 0.5s ease-in-out;
}
body.story .story-container .button_small {
  position: relative;
  background: rgba(3, 139, 164, 0.1);
  color: rgba(3, 139, 164, 0.3);
  padding: 0.5em 1em;
  border-radius: 5px;
  display: inline-block;
  margin: 0 1em 0 0;
  text-decoration: none;
}
body.story .story-container .button_small.current, body.story .story-container .button_small:hover {
  background: rgba(3, 139, 164, 0.2);
  color: #038ba4;
}
body.story .story-container .color-start {
  padding-left: 2em;
}
body.story .story-container .color-start:before {
  content: "";
  position: absolute;
  border-radius: 50px;
  width: 0.65em;
  height: 0.65em;
  background: #FAAB18;
  top: 0.95em;
  left: 0.75em;
}
body.story .story-container .color-end {
  padding-left: 2em;
}
body.story .story-container .color-end:before {
  content: "";
  position: absolute;
  border-radius: 50px;
  width: 0.65em;
  height: 0.65em;
  background: #1380A1;
  top: 0.95em;
  left: 0.75em;
}
body.story .story-container .sticky {
  position: sticky;
  top: 0;
}
body.story .story-container .fixed {
  position: fixed;
  top: 0;
}
body.story .story-container .scrolling-container {
  position: relative;
}
body.story .story-container .scrolling-container .scrolling-content {
  width: 100%;
  top: 120vh;
  position: absolute;
  height: 0;
}
body.story .story-container .scrolling-container .scrolling-content .scrolling-text {
  margin-bottom: 110vh;
}
@media screen and (max-width: 768px) {
  body.story .story-container .scrolling-container .scrolling-content {
    top: 120vh;
  }
}
body.story .story-container .section.section_map .scrolling-container .scrolling-content {
  width: 25vw;
  right: 51px;
}
@media screen and (max-width: 768px) {
  body.story .story-container .section.section_map .scrolling-container .scrolling-content {
    width: 75vw;
    right: 51px;
  }
}
body.story .story-container .section.section_map .scrolling-container .scrolling-content .scrolling-text {
  padding: 1em;
  font-size: 0.8rem;
}
body.story .story-container #pinned_map {
  position: relative;
}
body.story .story-container #pinned_map #legend {
  padding: 10px;
  box-shadow: 0 1px 2px rgba(0, 0, 0, 0.1);
  border-radius: 4px;
  line-height: 18px;
  margin-bottom: 40px;
  top: 25px;
  left: 25px;
  position: absolute;
  background: #FFF;
  font-size: 11px;
  color: #999;
}
body.story .story-container #pinned_map .legend-key {
  display: inline-block;
  border-radius: 20%;
  width: 10px;
  height: 10px;
  margin-right: 5px;
}
body.story .story-container #pinned_map #map {
  height: 100vh;
}
body.story .story-container #pinned_empleo h2 {
  position: absolute;
  top: 2em;
  font-size: 2.5em;
  left: 6rem;
  color: #333;
}
@media screen and (max-width: 768px) {
  body.story .story-container #pinned_empleo h2 {
    top: 1em;
    font-size: 2em;
    left: 2rem;
  }
}
@media screen and (max-width: 768px) {
  body.story .story-container .text-container {
    padding: 1em;
  }
}
body.story .story-container .source {
  font-size: 0.65rem;
  margin: 1em 0;
  color: #999;
}
body.story .story-container .source a {
  color: #999;
}
body.story .graph-container {
  max-width: 850px;
  margin: auto;
}
body.story .mapboxgl-popup-content td {
  padding-right: 15px;
}
@media screen and (max-width: 768px) {
  body.story .desktop {
    display: none;
  }
  body.story .mobile {
    display: block;
  }
}
@media screen and (min-width: 768px) {
  body.story .desktop {
    display: block;
  }
  body.story .mobile {
    display: none;
  }
}

.tooltipped {
  position: relative;
  padding: 12px 24px;
  color: #fff;
  border: 2px solid #fff;
  transition: all 0.3s ease;
  text-transform: uppercase;
  text-decoration: none;
}
.tooltipped:before {
  content: "";
  position: absolute;
  opacity: 0;
  pointer-events: none;
  left: 50%;
  transform: translate3d(-50%, 0%, 0);
  transition: all 0.3s ease;
  transition-delay: 0.1s;
  width: 0;
  height: 0;
  border-style: solid;
  border-width: 10px 10px 0 10px;
  border-color: #282828 transparent transparent transparent;
}
.tooltipped:after {
  text-transform: none;
  content: attr(data-tooltip);
  font-size: 14px;
  position: absolute;
  color: #fff;
  background: #282828;
  padding: 8px 12px;
  width: -webkit-max-content;
  width: -moz-max-content;
  width: max-content;
  max-width: 200px;
  opacity: 0;
  pointer-events: none;
  left: 50%;
  top: 0;
  border-radius: 4px;
  transform: translate3d(-50%, 0%, 0);
  transition: all 0.3s ease;
  transition-delay: 0.1s;
}
.tooltipped:hover:before, .tooltipped:hover:after {
  opacity: 1;
}
.tooltipped:hover:before {
  transform: translate3d(-50%, calc(-100% - 18px), 0);
}
.tooltipped:hover:after {
  transform: translate3d(-50%, calc(-100% - 16px), 0);
}

/*# sourceMappingURL=main.css.map */