@charset "UTF-8";
/* ==========================================================================
   INUITCSS
   ========================================================================== */
/**
 * inuitcss, by @csswizardry
 *
 * github.com/inuitcss | inuitcss.com
 */
/**
 * CONTENTS
 *
 * SETTINGS
 * Config...............Project-level configuration and feature switches.
 * Core.................inuitcss’ core and setup settings.
 * Global...............Project-wide variables and settings.
 *
 * TOOLS
 * Font-size............A mixin which guarantees baseline-friendly line-heights.
 * Clearfix.............Micro clearfix mixin.
 * Hidden...............Mixin for hiding elements.
 * Sass MQ..............inuitcss’ default media query manager.
 *
 * GENERIC
 * Box-sizing...........Better default `box-sizing`.
 * Normalize.css........A level playing field using @necolas’ Normalize.css.
 * Reset................A tiny reset to complement Normalize.css.
 * Shared...............Sensibly and tersely share some global commonalities
 *                      (particularly useful when managing vertical rhythm).
 *
 * ELEMENTS
 * Page.................Set up our document’s default `font-size` and
 *                      `line-height`.
 * Headings.............Very minimal (i.e. only font-size information) for
 *                      headings 1 through 6.
 * Images...............Base image styles.
 * Tables...............Simple table styles.
 *
 * OBJECTS
 * Wrapper..............Page constraint object.
 * Layout...............Generic layout module.
 * Media................Image- and text-like content side by side. The
 *                      poster-child of OOCSS.
 * Flag.................Table-layout-based advancement on the Media object.
 * List-bare............Lists with no bullets or indents.
 * List-inline..........A list whose items all site in a line.
 * Box..................Simple boxing abstraction.
 * Block................Image-on-top-of-text object.
 * Ratio................A container for maintaining aspect ratio of content.
 * Crop.................Provide a cropping context for media (images, etc.).
 * Table................Classes for manipulating `table`s.
 * Pack.................Pack items into available horizontal space.
 *
 * COMPONENTS
 * Headers..............Header component
 * Skiplinks............Provide an accessible link to skip to main content
 * Paragraphs...........Paragraphs component
 *
 * UTILITIES
 * Clearfix.............Bind our clearfix onto a utility class.
 * Widths...............Simple width helper classes.
 * Headings.............Reassigning our heading styles to helper classes.
 * Spacings.............Nudge bits of the DOM around with these spacing
 *                      classes.
 * Responsive-Spacings..Enhances the function of normal spacings for
 *                      responsive usage.
 * Print................Reset-like styles taken from the HTML5 Boilerplate.
 * Hide.................Helper classes to hide content
 */
html, .c-skiplinks {
  font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Oxygen-Sans, Ubuntu, Cantarell, "Fira Sans", "Droid Sans", "Open Sans", "Helvetica Neue", sans-serif; }

html.fonts-loaded {
  font-family: "Roboto", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Oxygen-Sans, Ubuntu, Cantarell, "Fira Sans", "Droid Sans", "Open Sans", "Helvetica Neue", sans-serif; }

/* ==========================================================================
   #BOX-SIZING
   ========================================================================== */
/**
 * More sensible default box-sizing:
 * css-tricks.com/inheriting-box-sizing-probably-slightly-better-best-practice
 */
html {
  -webkit-box-sizing: border-box;
          box-sizing: border-box; }

*, *:before, *:after {
  -webkit-box-sizing: inherit;
          box-sizing: inherit; }

/*! normalize.css v7.0.0 | MIT License | github.com/necolas/normalize.css */
/* Document
   ========================================================================== */
/**
 * 1. Correct the line height in all browsers.
 * 2. Prevent adjustments of font size after orientation changes in
 *    IE on Windows Phone and in iOS.
 */
html {
  line-height: 1.15;
  /* 1 */
  -ms-text-size-adjust: 100%;
  /* 2 */
  -webkit-text-size-adjust: 100%;
  /* 2 */ }

/* Sections
   ========================================================================== */
/**
 * Remove the margin in all browsers (opinionated).
 */
body {
  margin: 0; }

/**
 * Add the correct display in IE 9-.
 */
article,
aside,
footer,
header,
nav,
section {
  display: block; }

/**
 * Correct the font size and margin on `h1` elements within `section` and
 * `article` contexts in Chrome, Firefox, and Safari.
 */
h1 {
  font-size: 2em;
  margin: 0.67em 0; }

/* Grouping content
   ========================================================================== */
/**
 * Add the correct display in IE 9-.
 * 1. Add the correct display in IE.
 */
figcaption,
figure,
main {
  /* 1 */
  display: block; }

/**
 * Add the correct margin in IE 8.
 */
figure {
  margin: 1em 40px; }

/**
 * 1. Add the correct box sizing in Firefox.
 * 2. Show the overflow in Edge and IE.
 */
hr {
  -webkit-box-sizing: content-box;
          box-sizing: content-box;
  /* 1 */
  height: 0;
  /* 1 */
  overflow: visible;
  /* 2 */ }

/**
 * 1. Correct the inheritance and scaling of font size in all browsers.
 * 2. Correct the odd `em` font sizing in all browsers.
 */
pre {
  font-family: monospace, monospace;
  /* 1 */
  font-size: 1em;
  /* 2 */ }

/* Text-level semantics
   ========================================================================== */
/**
 * 1. Remove the gray background on active links in IE 10.
 * 2. Remove gaps in links underline in iOS 8+ and Safari 8+.
 */
a {
  background-color: transparent;
  /* 1 */
  -webkit-text-decoration-skip: objects;
  /* 2 */ }

/**
 * 1. Remove the bottom border in Chrome 57- and Firefox 39-.
 * 2. Add the correct text decoration in Chrome, Edge, IE, Opera, and Safari.
 */
abbr[title] {
  border-bottom: none;
  /* 1 */
  text-decoration: underline;
  /* 2 */
  text-decoration: underline dotted;
  /* 2 */ }

/**
 * Prevent the duplicate application of `bolder` by the next rule in Safari 6.
 */
b,
strong {
  font-weight: inherit; }

/**
 * Add the correct font weight in Chrome, Edge, and Safari.
 */
b,
strong {
  font-weight: bolder; }

/**
 * 1. Correct the inheritance and scaling of font size in all browsers.
 * 2. Correct the odd `em` font sizing in all browsers.
 */
code,
kbd,
samp {
  font-family: monospace, monospace;
  /* 1 */
  font-size: 1em;
  /* 2 */ }

/**
 * Add the correct font style in Android 4.3-.
 */
dfn {
  font-style: italic; }

/**
 * Add the correct background and color in IE 9-.
 */
mark {
  background-color: #ff0;
  color: #000; }

/**
 * Add the correct font size in all browsers.
 */
small {
  font-size: 80%; }

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

sub {
  bottom: -0.25em; }

sup {
  top: -0.5em; }

/* Embedded content
   ========================================================================== */
/**
 * Add the correct display in IE 9-.
 */
audio,
video {
  display: inline-block; }

/**
 * Add the correct display in iOS 4-7.
 */
audio:not([controls]) {
  display: none;
  height: 0; }

/**
 * Remove the border on images inside links in IE 10-.
 */
img {
  border-style: none; }

/**
 * Hide the overflow in IE.
 */
svg:not(:root) {
  overflow: hidden; }

/* Forms
   ========================================================================== */
/**
 * 1. Change the font styles in all browsers (opinionated).
 * 2. Remove the margin in Firefox and Safari.
 */
button,
input,
optgroup,
select,
textarea {
  font-family: sans-serif;
  /* 1 */
  font-size: 100%;
  /* 1 */
  line-height: 1.15;
  /* 1 */
  margin: 0;
  /* 2 */ }

/**
 * Show the overflow in IE.
 * 1. Show the overflow in Edge.
 */
button,
input {
  /* 1 */
  overflow: visible; }

/**
 * Remove the inheritance of text transform in Edge, Firefox, and IE.
 * 1. Remove the inheritance of text transform in Firefox.
 */
button,
select {
  /* 1 */
  text-transform: none; }

/**
 * 1. Prevent a WebKit bug where (2) destroys native `audio` and `video`
 *    controls in Android 4.
 * 2. Correct the inability to style clickable types in iOS and Safari.
 */
button,
html [type="button"],
[type="reset"],
[type="submit"] {
  -webkit-appearance: button;
  /* 2 */ }

/**
 * Remove the inner border and padding in Firefox.
 */
button::-moz-focus-inner,
[type="button"]::-moz-focus-inner,
[type="reset"]::-moz-focus-inner,
[type="submit"]::-moz-focus-inner {
  border-style: none;
  padding: 0; }

/**
 * Restore the focus styles unset by the previous rule.
 */
button:-moz-focusring,
[type="button"]:-moz-focusring,
[type="reset"]:-moz-focusring,
[type="submit"]:-moz-focusring {
  outline: 1px dotted ButtonText; }

/**
 * Correct the padding in Firefox.
 */
fieldset {
  padding: 0.35em 0.75em 0.625em; }

/**
 * 1. Correct the text wrapping in Edge and IE.
 * 2. Correct the color inheritance from `fieldset` elements in IE.
 * 3. Remove the padding so developers are not caught out when they zero out
 *    `fieldset` elements in all browsers.
 */
legend {
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
  /* 1 */
  color: inherit;
  /* 2 */
  display: table;
  /* 1 */
  max-width: 100%;
  /* 1 */
  padding: 0;
  /* 3 */
  white-space: normal;
  /* 1 */ }

/**
 * 1. Add the correct display in IE 9-.
 * 2. Add the correct vertical alignment in Chrome, Firefox, and Opera.
 */
progress {
  display: inline-block;
  /* 1 */
  vertical-align: baseline;
  /* 2 */ }

/**
 * Remove the default vertical scrollbar in IE.
 */
textarea {
  overflow: auto; }

/**
 * 1. Add the correct box sizing in IE 10-.
 * 2. Remove the padding in IE 10-.
 */
[type="checkbox"],
[type="radio"] {
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
  /* 1 */
  padding: 0;
  /* 2 */ }

/**
 * Correct the cursor style of increment and decrement buttons in Chrome.
 */
[type="number"]::-webkit-inner-spin-button,
[type="number"]::-webkit-outer-spin-button {
  height: auto; }

/**
 * 1. Correct the odd appearance in Chrome and Safari.
 * 2. Correct the outline style in Safari.
 */
[type="search"] {
  -webkit-appearance: textfield;
  /* 1 */
  outline-offset: -2px;
  /* 2 */ }

/**
 * Remove the inner padding and cancel buttons in Chrome and Safari on macOS.
 */
[type="search"]::-webkit-search-cancel-button,
[type="search"]::-webkit-search-decoration {
  -webkit-appearance: none; }

/**
 * 1. Correct the inability to style clickable types in iOS and Safari.
 * 2. Change font properties to `inherit` in Safari.
 */
::-webkit-file-upload-button {
  -webkit-appearance: button;
  /* 1 */
  font: inherit;
  /* 2 */ }

/* Interactive
   ========================================================================== */
/*
 * Add the correct display in IE 9-.
 * 1. Add the correct display in Edge, IE, and Firefox.
 */
details,
menu {
  display: block; }

/*
 * Add the correct display in all browsers.
 */
summary {
  display: list-item; }

/* Scripting
   ========================================================================== */
/**
 * Add the correct display in IE 9-.
 */
canvas {
  display: inline-block; }

/**
 * Add the correct display in IE.
 */
template {
  display: none; }

/* Hidden
   ========================================================================== */
/**
 * Add the correct display in IE 10-.
 */
[hidden] {
  display: none; }

/* ==========================================================================
   #RESET
   ========================================================================== */
/**
 * A very simple reset that sits on top of Normalize.css.
 */
body,
h1, h2, h3, h4, h5, h6,
blockquote, p, pre,
dl, dd, ol, ul,
figure,
hr,
fieldset, legend {
  margin: 0;
  padding: 0; }

/**
 * Remove trailing margins from nested lists.
 */
li > ol,
li > ul {
  margin-bottom: 0; }

/**
 * Remove default table spacing.
 */
table {
  border-collapse: collapse;
  border-spacing: 0; }

/**
 * 1. Reset Chrome and Firefox behaviour which sets a `min-width: min-content;`
 *    on fieldsets.
 */
fieldset {
  min-width: 0;
  /* [1] */
  border: 0; }

/* ==========================================================================
   #SHARED
   ========================================================================== */
/**
 * Shared declarations for certain elements.
 */
/**
 * Always declare margins in the same direction:
 * csswizardry.com/2012/06/single-direction-margin-declarations
 */
/* stylelint-disable selector-list-comma-newline-after */
address,
h1, h2, h3, h4, h5, h6,
blockquote, p, pre,
dl, ol, ul,
figure,
hr,
table,
fieldset {
  margin-bottom: 24px; }

/**
 * Consistent indentation for lists.
 */
dd, ol, ul {
  margin-left: 24px; }

/* stylelint-enable selector-list-comma-newline-after */
/* ==========================================================================
   #PAGE
   ========================================================================== */
/**
 * Simple page-level setup.
 *
 * 1. Set the default `font-size` and `line-height` for the entire project,
 *    sourced from our default variables. The `font-size` is calculated to exist
 *    in ems, the `line-height` is calculated to exist unitlessly.
 * 2. Force scrollbars to always be visible to prevent awkward ‘jumps’ when
 *    navigating between pages that do/do not have enough content to produce
 *    scrollbars naturally.
 * 3. Ensure the page always fills at least the entire height of the viewport.
 */
html {
  font-size: 1em;
  /* [1] */
  line-height: 1.5;
  /* [1] */
  overflow-y: scroll;
  /* [2] */
  min-height: 100%;
  /* [3] */ }

/* ==========================================================================
   #PAGE
   ========================================================================== */
html {
  overflow-x: hidden; }

body {
  color: #222;
  overflow-x: hidden;
  min-width: 320px; }

p {
  font-size: 17px; }

h1 {
  font-size: 58px;
  font-weight: 100; }

h2 {
  font-size: 17px;
  font-weight: 300; }

h3 {
  font-size: 19px;
  font-weight: 400; }

h4 {
  font-size: 17px;
  font-weight: 500; }

a {
  color: #000;
  font-weight: 400;
  text-decoration: none;
  -webkit-transition: color 0.2s ease;
  transition: color 0.2s ease; }
  a:focus, a:hover {
    color: #CD222A; }

:focus {
  outline-color: #CD222A;
  outline-width: 1px; }

/* ==========================================================================
   #HEADINGS
   ========================================================================== */
/**
 * Simple default styles for headings 1 through 6. Anything more opinionated
 * than simple font-size changes should likely be applied via classes (see:
 * http://csswizardry.com/2016/02/managing-typography-on-large-apps/).
 */
h1 {
  font-size: 36px;
  font-size: 2.25rem;
  line-height: 1.1666666667; }

h2 {
  font-size: 28px;
  font-size: 1.75rem;
  line-height: 1.2857142857; }

h3 {
  font-size: 24px;
  font-size: 1.5rem;
  line-height: 1.25; }

h4 {
  font-size: 20px;
  font-size: 1.25rem;
  line-height: 1.5; }

h5 {
  font-size: 18px;
  font-size: 1.125rem;
  line-height: 1.3333333333; }

h6 {
  font-size: 16px;
  font-size: 1rem;
  line-height: 1.5; }

/* ==========================================================================
   #IMAGES
   ========================================================================== */
/**
 * 1. Fluid images for responsive purposes.
 * 2. Offset `alt` text from surrounding copy.
 * 3. Setting `vertical-align` removes the whitespace that appears under `img`
 *    elements when they are dropped into a page as-is. Safer alternative to
 *    using `display: block;`.
 */
img {
  max-width: 100%;
  /* [1] */
  font-style: italic;
  /* [2] */
  vertical-align: middle;
  /* [3] */ }

/**
 * 1. If a `width` and/or `height` attribute have been explicitly defined, let’s
 *    not make the image fluid.
 */
img[width],
img[height] {
  /* [1] */
  max-width: none; }

/* ==========================================================================
   #TABLES
   ========================================================================== */
/**
 * 1. Ensure tables fill up as much space as possible.
 */
table {
  width: 100%;
  /* [1] */ }

/* ==========================================================================
   #WRAPPER
   ========================================================================== */
/**
 * Page-level constraining and wrapping elements.
 */
/* stylelint-disable */
/* stylelint-enable */
.o-wrapper {
  padding-right: 24px;
  padding-left: 24px;
  margin-right: auto;
  margin-left: auto;
  max-width: 1200px; }
  .o-wrapper:after {
    content: "" !important;
    display: block !important;
    clear: both !important; }

/* Size variants.
   ========================================================================== */
.o-wrapper--tiny {
  padding-right: 6px;
  padding-left: 6px; }

.o-wrapper--small {
  padding-right: 12px;
  padding-left: 12px; }

.o-wrapper--large {
  padding-right: 48px;
  padding-left: 48px; }

.o-wrapper--huge {
  padding-right: 96px;
  padding-left: 96px; }

/* ==========================================================================
   #WRAPPER
   ========================================================================== */
/* Responsive variants.
   ========================================================================== */
.o-wrapper {
  max-width: 1500px; }

@media (min-width: 61.25em) {
  .o-wrapper--huge\@desktop {
    padding-right: 96px;
    padding-left: 96px; } }

.o-wrapper--main {
  max-width: 1080px; }
  @media (min-width: 81.25em) {
    .o-wrapper--main {
      max-width: 84.5vw; } }

@media (min-width: 61.25em) {
  .o-wrapper--article {
    padding-right: 72px;
    padding-left: 72px; } }

.o-wrapper--legalnotices,
.o-wrapper--fees {
  max-width: 1110px; }

.o-wrapper--expertise {
  max-width: 1150px; }

/* ==========================================================================
   #LAYOUT
   ========================================================================== */
/**
 * Grid-like layout system.
 *
 * The layout object provides us with a column-style layout system. This file
 * contains the basic structural elements, but classes should be complemented
 * with width utilities, for example:
 *
 *   <div class="o-layout">
 *     <div class="o-layout__item  u-1/2">
 *     </div>
 *     <div class="o-layout__item  u-1/2">
 *     </div>
 *   </div>
 *
 * The above will create a two-column structure in which each column will
 * fluidly fill half of the width of the parent. We can have more complex
 * systems:
 *
 *   <div class="o-layout">
 *     <div class="o-layout__item  u-1/1  u-1/3@medium">
 *     </div>
 *     <div class="o-layout__item  u-1/2  u-1/3@medium">
 *     </div>
 *     <div class="o-layout__item  u-1/2  u-1/3@medium">
 *     </div>
 *   </div>
 *
 * The above will create a system in which the first item will be 100% width
 * until we enter our medium breakpoint, when it will become 33.333% width. The
 * second and third items will be 50% of their parent, until they also become
 * 33.333% width at the medium breakpoint.
 *
 * We can also manipulate entire layout systems by adding a series of modifiers
 * to the `.o-layout` block. For example:
 *
 *   <div class="o-layout  o-layout--reverse">
 *
 * This will reverse the displayed order of the system so that it runs in the
 * opposite order to our source, effectively flipping the system over.
 *
 *   <div class="o-layout  o-layout--[right|center]">
 *
 * This will cause the system to fill up from either the centre or the right
 * hand side. Default behaviour is to fill up the layout system from the left.
 *
 * There are plenty more options available to us: explore them below.
 */
/* Default/mandatory classes.
   ========================================================================== */
/**
 * 1. Allows us to use the layout object on any type of element.
 * 2. We need to defensively reset any box-model properties.
 * 3. Use the negative margin trick for multi-row grids:
 *    http://csswizardry.com/2011/08/building-better-grid-systems/
 */
.o-layout {
  display: block;
  /* [1] */
  margin: 0;
  /* [2] */
  padding: 0;
  /* [2] */
  list-style: none;
  /* [1] */
  margin-left: -24px;
  /* [3] */
  font-size: 0; }

/**
   * 1. Required in order to combine fluid widths with fixed gutters.
   * 2. Allows us to manipulate grids vertically, with text-level properties,
   *    etc.
   * 3. Default item alignment is with the tops of each other, like most
   *    traditional grid/layout systems.
   * 4. By default, all layout items are full-width (mobile first).
   * 5. Gutters provided by left padding:
   *    http://csswizardry.com/2011/08/building-better-grid-systems/
   * 6. Fallback for old IEs not supporting `rem` values.
   */
.o-layout__item {
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
  /* [1] */
  display: inline-block;
  /* [2] */
  vertical-align: top;
  /* [3] */
  width: 100%;
  /* [4] */
  padding-left: 24px;
  /* [5] */
  font-size: 16px;
  /* [6] */
  font-size: 1rem; }

/* Gutter size modifiers.
   ========================================================================== */
.o-layout--flush {
  margin-left: 0; }
  .o-layout--flush > .o-layout__item {
    padding-left: 0; }

.o-layout--tiny {
  margin-left: -6px; }
  .o-layout--tiny > .o-layout__item {
    padding-left: 6px; }

.o-layout--small {
  margin-left: -12px; }
  .o-layout--small > .o-layout__item {
    padding-left: 12px; }

.o-layout--large {
  margin-left: -48px; }
  .o-layout--large > .o-layout__item {
    padding-left: 48px; }

.o-layout--huge {
  margin-left: -96px; }
  .o-layout--huge > .o-layout__item {
    padding-left: 96px; }

/* Vertical alignment modifiers.
   ========================================================================== */
/**
 * Align all grid items to the middles of each other.
 */
.o-layout--middle > .o-layout__item {
  vertical-align: middle; }

/**
 * Align all grid items to the bottoms of each other.
 */
.o-layout--bottom > .o-layout__item {
  vertical-align: bottom; }

/**
 * Stretch all grid items of each row to have an equal-height.
 * Please be aware that this modifier class doesn't take any effect in IE9 and
 * below and other older browsers due to the lack of `display: flex` support.
 */
.o-layout--stretch {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-flex-wrap: wrap;
      -ms-flex-wrap: wrap;
          flex-wrap: wrap; }
  .o-layout--stretch > .o-layout__item {
    display: -webkit-box;
    display: -webkit-flex;
    display: -ms-flexbox;
    display: flex; }

/* Fill order modifiers.
   ========================================================================== */
/**
 * Fill up the layout system from the centre.
 */
.o-layout--center {
  text-align: center; }
  .o-layout--center > .o-layout__item {
    text-align: left; }

/**
 * Fill up the layout system from the right-hand side.
 */
.o-layout--right {
  text-align: right; }
  .o-layout--right > .o-layout__item {
    text-align: left; }

/**
 * Fill up the layout system from the left-hand side. This will likely only be
 * needed when using in conjunction with `.o-layout--reverse`.
 */
.o-layout--left {
  text-align: left; }
  .o-layout--left > .o-layout__item {
    text-align: left; }

/**
 * Reverse the rendered order of the grid system.
 */
.o-layout--reverse {
  direction: rtl; }
  .o-layout--reverse > .o-layout__item {
    direction: ltr; }

/* Auto-widths modifier.
   ========================================================================== */
/**
 * Cause layout items to take up a non-explicit amount of width.
 */
.o-layout--auto > .o-layout__item {
  width: auto; }

/* ==========================================================================
   #FLAG
   ========================================================================== */
/**
 * The flag object is a design pattern similar to the media object, however it
 * utilises `display: table[-cell];` to give us control over the vertical
 * alignments of the text and image.
 *
 * http://csswizardry.com/2013/05/the-flag-object/
 *
 * 1. Allows us to control vertical alignments.
 * 2. Force the object to be the full width of its parent. Combined with [1],
 *    this makes the object behave in a quasi-`display: block;` manner.
 * 3. Reset inherited `border-spacing` declarations.
 */
.o-flag {
  display: table;
  /* [1] */
  width: 100%;
  /* [2] */
  border-spacing: 0;
  /* [3] */ }

/**
   * Items within a flag object. There should only ever be one of each.
   *
   * 1. Default to aligning content to their middles.
   */
.o-flag__img,
.o-flag__body {
  display: table-cell;
  vertical-align: middle;
  /* [1] */ }

/**
   * Flag images have a space between them and the body of the object.
   *
   * 1. Force `.flag__img` to take up as little space as possible:
   *    https://pixelsvsbytes.com/2012/02/this-css-layout-grid-is-no-holy-grail/
   */
.o-flag__img {
  width: 1px;
  /* [1] */
  padding-right: 24px;
  /**
     * 1. Fixes problem with images disappearing.
     */ }
  .o-flag__img > img {
    max-width: none;
    /* [1] */ }

/**
   * The container for the main content of the flag object.
   *
   * 1. Forces the `.flag__body` to take up all remaining space.
   */
.o-flag__body {
  width: auto;
  /* [1] */ }
  .o-flag__body,
  .o-flag__body > :last-child {
    margin-bottom: 0; }

/* Size variants.
   ========================================================================== */
.o-flag--flush > .o-flag__img {
  padding-right: 0;
  padding-left: 0; }

.o-flag--tiny > .o-flag__img {
  padding-right: 6px; }

.o-flag--tiny.o-flag--reverse > .o-flag__img {
  padding-right: 0;
  padding-left: 6px; }

.o-flag--small > .o-flag__img {
  padding-right: 12px; }

.o-flag--small.o-flag--reverse > .o-flag__img {
  padding-right: 0;
  padding-left: 12px; }

.o-flag--large > .o-flag__img {
  padding-right: 48px; }

.o-flag--large.o-flag--reverse > .o-flag__img {
  padding-right: 0;
  padding-left: 48px; }

.o-flag--huge > .o-flag__img {
  padding-right: 96px; }

.o-flag--huge.o-flag--reverse > .o-flag__img {
  padding-right: 0;
  padding-left: 96px; }

/* Reversed flag.
   ========================================================================== */
/**
 * 1. Swap the rendered direction of the object…
 * 2. …and reset it.
 * 3. Reassign margins to the correct sides.
 */
.o-flag--reverse {
  direction: rtl;
  /* [1] */ }
  .o-flag--reverse > .o-flag__img,
  .o-flag--reverse > .o-flag__body {
    direction: ltr;
    /* [2] */ }
  .o-flag--reverse > .o-flag__img {
    padding-right: 0;
    /* [3] */
    padding-left: 24px;
    /* [3] */ }

/* Alignment variants.
   ========================================================================== */
/**
 * Vertically align the image- and body-content differently. Defaults to middle.
 */
.o-flag--top > .o-flag__img,
.o-flag--top > .o-flag__body {
  vertical-align: top; }

.o-flag--bottom > .o-flag__img,
.o-flag--bottom > .o-flag__body {
  vertical-align: bottom; }

/* ==========================================================================
   #LIST-INLINE
   ========================================================================== */
/**
 * The list-inline object simply displays a list of items in one line.
 */
.o-list-inline {
  margin-left: 0;
  list-style: none; }

.o-list-inline__item {
  display: inline-block; }

/* ==========================================================================
   #RATIO
   ========================================================================== */
/**
 * Create ratio-bound content blocks, to keep media (e.g. images, videos) in
 * their correct aspect ratios.
 *
 * http://alistapart.com/article/creating-intrinsic-ratios-for-video
 *
 * 1. Default is a 1:1 ratio (i.e. a perfect square).
 */
.o-ratio {
  position: relative;
  display: block; }
  .o-ratio:before {
    content: "";
    display: block;
    width: 100%;
    padding-bottom: 100%;
    /* [1] */ }

.o-ratio__content,
.o-ratio > iframe,
.o-ratio > embed,
.o-ratio > object {
  position: absolute;
  top: 0;
  bottom: 0;
  left: 0;
  height: 100%;
  width: 100%; }

/* Ratio variants.
   ========================================================================== */
/**
 * Generate a series of ratio classes to be used like so:
 *
 *   <div class="o-ratio  o-ratio--golden-ratio">
 *
 */
.o-ratio--2\:1:before {
  padding-bottom: 50%; }

.o-ratio--4\:3:before {
  padding-bottom: 75%; }

.o-ratio--16\:9:before {
  padding-bottom: 56.25%; }

.o-ratio--683\:1024:before {
  padding-bottom: 149.926793558%; }

.o-ratio--1280\:500:before {
  padding-bottom: 39.0625%; }

.o-ratio--1024\:683:before {
  padding-bottom: 66.69921875%; }

/* ==========================================================================
   #INLINEFLEX
   ========================================================================== */
.o-inline-flex {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex; }

.o-inline-flex__content {
  -webkit-box-flex: 1;
  -webkit-flex: 1;
      -ms-flex: 1;
          flex: 1; }

@media (max-width: 46.24em) {
  .o-inline-flex--unhook\@mobile {
    display: block; } }

/* Crop-ratio variants
   ========================================================================== */
/**
 * Generate a series of crop classes to be used like so:
 *
 *   <div class="o-crop  o-crop--golden-ratio">
 *
 */
.o-inline-flex__content--landscape {
  -webkit-box-flex: 1.4992679356;
  -webkit-flex: 1.4992679356;
      -ms-flex: 1.4992679356;
          flex: 1.4992679356; }

.o-inline-flex__content--portrait {
  -webkit-box-flex: 0.6669921875;
  -webkit-flex: 0.6669921875;
      -ms-flex: 0.6669921875;
          flex: 0.6669921875; }

/* Slider */
.slick-slider {
  position: relative;
  display: block;
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
  -webkit-touch-callout: none;
  -webkit-user-select: none;
  -khtml-user-select: none;
  -moz-user-select: none;
  -ms-user-select: none;
  user-select: none;
  -ms-touch-action: pan-y;
  touch-action: pan-y;
  -webkit-tap-highlight-color: transparent; }

.slick-list {
  position: relative;
  overflow: hidden;
  display: block;
  margin: 0;
  padding: 0; }
  .slick-list:focus {
    outline: none; }
  .slick-list.dragging {
    cursor: pointer;
    cursor: hand; }

.slick-slider .slick-track,
.slick-slider .slick-list {
  -webkit-transform: translate3d(0, 0, 0);
  -moz-transform: translate3d(0, 0, 0);
  -ms-transform: translate3d(0, 0, 0);
  -o-transform: translate3d(0, 0, 0);
  transform: translate3d(0, 0, 0); }

.slick-track {
  position: relative;
  left: 0;
  top: 0;
  display: block;
  margin-left: auto;
  margin-right: auto; }
  .slick-track:before, .slick-track:after {
    content: "";
    display: table; }
  .slick-track:after {
    clear: both; }
  .slick-loading .slick-track {
    visibility: hidden; }

.slick-slide {
  float: left;
  height: 100%;
  min-height: 1px;
  display: none; }
  [dir="rtl"] .slick-slide {
    float: right; }
  .slick-slide img {
    display: block; }
  .slick-slide.slick-loading img {
    display: none; }
  .slick-slide.dragging img {
    pointer-events: none; }
  .slick-initialized .slick-slide {
    display: block; }
  .slick-loading .slick-slide {
    visibility: hidden; }
  .slick-vertical .slick-slide {
    display: block;
    height: auto;
    border: 1px solid transparent; }

.slick-arrow.slick-hidden {
  display: none; }

body[data-aos-duration='1200'] [data-aos], [data-aos][data-aos][data-aos-duration='1200'] {
  -webkit-transition-duration: 1200ms;
          transition-duration: 1200ms; }

body[data-aos-delay='1200'] [data-aos], [data-aos][data-aos][data-aos-delay='1200'] {
  -webkit-transition-delay: 0;
          transition-delay: 0; }
  body[data-aos-delay='1200'] [data-aos].aos-animate, [data-aos][data-aos][data-aos-delay='1200'].aos-animate {
    -webkit-transition-delay: 1200ms;
            transition-delay: 1200ms; }

body[data-aos-easing="ease"] [data-aos], [data-aos][data-aos][data-aos-easing="ease"] {
  -webkit-transition-timing-function: cubic-bezier(0.25, 0.1, 0.25, 1);
          transition-timing-function: cubic-bezier(0.25, 0.1, 0.25, 1); }

/**
 * Fade animations:
 * fade
 * fade-up, fade-down, fade-left, fade-right
 * fade-up-right, fade-up-left, fade-down-right, fade-down-left
 */
[data-aos^='fade'][data-aos^='fade'] {
  opacity: 0;
  -webkit-transition-property: opacity, -webkit-transform;
  transition-property: opacity, -webkit-transform;
  transition-property: opacity, transform;
  transition-property: opacity, transform, -webkit-transform; }
  [data-aos^='fade'][data-aos^='fade'].aos-animate {
    opacity: 1;
    -webkit-transform: translate(0, 0);
        -ms-transform: translate(0, 0);
            transform: translate(0, 0); }

[data-aos='fade-right'] {
  -webkit-transform: translate(-100px, 0);
      -ms-transform: translate(-100px, 0);
          transform: translate(-100px, 0); }

[data-aos='fade-left'] {
  -webkit-transform: translate(100px, 0);
      -ms-transform: translate(100px, 0);
          transform: translate(100px, 0); }

/* ==========================================================================
   #HEADERS
   ========================================================================== */
.c-header {
  background: #fff;
  padding: 15px 0 19px; }

.c-header__logo-wrapper {
  max-width: -webkit-calc(10.3rem + 10vw);
  max-width: calc(10.3rem + 10vw);
  display: block;
  margin: 0 auto;
  padding-left: 4px; }

@media (max-width: 46.24em) {
  .c-header {
    padding: 12px 0 22px; }
  .c-header__logo-wrapper {
    max-width: -webkit-calc(15.3rem + 10vw);
    max-width: calc(15.3rem + 10vw);
    padding-left: 0; } }

@media (max-width: 28.75em) {
  .c-header__logo-wrapper {
    padding-left: 30px; } }

/* ==========================================================================
   #SKIPLINKS
   ========================================================================== */
/**
 * Styles for accessible c-skiplinks.
 */
.c-skiplinks {
  left: 50%;
  margin-left: -7em;
  position: absolute;
  width: 14em;
  z-index: 9999; }

.c-skiplinks__link,
.c-skiplinks__link:visited,
.c-skiplinks__link:focus {
  background-color: #333;
  border: 2px solid #eee;
  -webkit-border-bottom-left-radius: 5px;
          border-bottom-left-radius: 5px;
  -webkit-border-bottom-right-radius: 5px;
          border-bottom-right-radius: 5px;
  border-top: 0;
  -webkit-box-shadow: 0 0 6px rgba(0, 0, 0, 0.3);
          box-shadow: 0 0 6px rgba(0, 0, 0, 0.3);
  color: #eee;
  display: inline-block;
  font-weight: bold;
  line-height: 1.5;
  margin: 0;
  outline: 0;
  padding: 0.25em 0.5em;
  text-align: center;
  text-decoration: none;
  width: 14em; }

#main:focus {
  outline: 0; }

/* ==========================================================================
   #PARAGRAPHS
   ========================================================================== */
.c-paragraph {
  line-height: 1.2; }
  .c-paragraph > :first-child:before {
    content: "/// ";
    color: #CD222A;
    font-size: 0.7em; }
  .c-paragraph > :last-child:after {
    content: " ///";
    color: #CD222A;
    font-size: 0.7em; }
  .c-paragraph > p {
    letter-spacing: -0.2px;
    margin-bottom: 22px; }

/* ==========================================================================
   #FOOTERS
   ========================================================================== */
.c-footer__bar {
  background-color: #626262; }

.c-footer__bar--office #wpgmza_map {
  float: none !important;
  height: 500px !important; }

/* ==========================================================================
   #NAVIGATION
   ========================================================================== */
.c-navigation--primary {
  padding-right: 24px;
  padding-left: 24px;
  margin-right: auto;
  margin-left: auto;
  text-align: center;
  max-width: 980px;
  margin-top: 11px; }
  .c-navigation--primary:after {
    content: "" !important;
    display: block !important;
    clear: both !important; }
  .c-navigation--primary .c-navigation__item {
    margin-bottom: 10px; }

.c-navigation--secondary {
  max-width: 100%;
  padding-left: 24px;
  background-color: #626262; }
  .c-navigation--secondary .c-navigation__list {
    margin-bottom: 0;
    -webkit-box-pack: left;
    -webkit-justify-content: left;
        -ms-flex-pack: left;
            justify-content: left; }
  .c-navigation--secondary .is-active .c-navigation__link {
    color: #EEEEEE; }
  .c-navigation--secondary .c-navigation__link {
    color: #fff;
    font-size: 13px;
    text-transform: inherit;
    font-weight: 100; }
    .c-navigation--secondary .c-navigation__link:before, .c-navigation--secondary .c-navigation__link:after {
      content: normal;
      display: none; }
    .c-navigation--secondary .c-navigation__link:hover, .c-navigation--secondary .c-navigation__link:focus {
      color: #EEEEEE; }
  .c-navigation--secondary .c-navigation__anim-line {
    content: normal;
    display: none; }
  .c-navigation--secondary .c-navigation__list {
    margin-bottom: 0; }

.c-navigation__list {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-justify-content: space-around;
      -ms-flex-pack: distribute;
          justify-content: space-around;
  -webkit-flex-wrap: wrap;
      -ms-flex-wrap: wrap;
          flex-wrap: wrap; }

.c-navigation__link {
  color: #222;
  text-decoration: none;
  position: relative;
  padding: 0px 12px;
  letter-spacing: 0.24px;
  font-size: 20px;
  text-transform: uppercase;
  -webkit-transition: color 0.2s ease;
  transition: color 0.2s ease;
  white-space: nowrap; }
  .c-navigation__link:before, .c-navigation__link:after {
    content: "";
    position: absolute;
    left: 0;
    width: 1px;
    bottom: 5px;
    top: 4px;
    height: auto;
    background-color: #CD222A;
    -webkit-transition: all 0.2s ease;
    transition: all 0.2s ease; }
  .c-navigation__link:after {
    right: 0;
    left: auto; }
  .is-active > .c-navigation__link, .c-navigation__link:hover, .c-navigation__link:focus {
    color: #CD222A; }
    .is-active > .c-navigation__link:before, .is-active > .c-navigation__link:after, .c-navigation__link:hover:before, .c-navigation__link:hover:after, .c-navigation__link:focus:before, .c-navigation__link:focus:after {
      bottom: 7px;
      top: 8px;
      background-color: #CD222A; }

.c-navigation__anim-line {
  content: "";
  position: absolute;
  left: -4px;
  height: 1px;
  width: 9px;
  -webkit-transform: scale(0);
      -ms-transform: scale(0);
          transform: scale(0);
  top: 50%;
  background-color: #CD222A;
  -webkit-transition: all 0.2s ease;
  transition: all 0.2s ease; }
  .is-active > .c-navigation__link .c-navigation__anim-line,
  .c-navigation__link:hover .c-navigation__anim-line,
  .c-navigation__link:focus .c-navigation__anim-line {
    -webkit-transform: scale(1);
        -ms-transform: scale(1);
            transform: scale(1); }
    .is-active > .c-navigation__link .c-navigation__anim-line:last-child,
    .c-navigation__link:hover .c-navigation__anim-line:last-child,
    .c-navigation__link:focus .c-navigation__anim-line:last-child {
      right: -4px;
      left: auto; }

.c-navigation-pusher {
  background-color: white; }

@media (max-width: 46.24em) {
  .c-navigation--primary {
    text-align: left;
    margin-top: 0; }
    .c-navigation--primary .c-navigation__list {
      -webkit-box-pack: start;
      -webkit-justify-content: start;
          -ms-flex-pack: start;
              justify-content: start;
      height: 100%;
      -webkit-box-orient: vertical;
      -webkit-box-direction: normal;
      -webkit-flex-direction: column;
          -ms-flex-direction: column;
              flex-direction: column;
      position: absolute;
      top: 0;
      left: 0;
      width: 300px;
      -webkit-transform: translateX(-276px);
          -ms-transform: translateX(-276px);
              transform: translateX(-276px);
      -webkit-transition: -webkit-transform 0.2s ease;
      transition: -webkit-transform 0.2s ease;
      transition: transform 0.2s ease;
      transition: transform 0.2s ease, -webkit-transform 0.2s ease;
      background: -webkit-gradient(linear, left bottom, left top, from(#efefef), color-stop(60%, #efefef), to(white));
      background: linear-gradient(0deg, #efefef, #efefef 60%, white 100%); }
    .c-navigation--primary .c-navigation__link {
      font-size: 22px;
      font-weight: 300;
      padding: 19px 12px 19px 40px;
      display: block;
      background-color: #fff; }
      .c-navigation--primary .c-navigation__link:before, .c-navigation--primary .c-navigation__link:after {
        content: normal;
        display: none; }
      .c-navigation--primary .c-navigation__link:focus, .c-navigation--primary .c-navigation__link:hover {
        background: -webkit-gradient(linear, left bottom, left top, from(#efefef), color-stop(40%, white));
        background: linear-gradient(0deg, #efefef, white 40%); }
    .c-navigation--primary .is-active > .c-navigation__link {
      background: -webkit-gradient(linear, left bottom, left top, from(#efefef), color-stop(40%, white));
      background: linear-gradient(0deg, #efefef, white 40%); }
    .c-navigation--primary .c-navigation__anim-line {
      content: normal;
      display: none; }
    .c-navigation--primary .c-navigation__item {
      margin-bottom: 0;
      border-bottom: 1px solid #000;
      padding-left: 0; }
  .c-navigation-pusher {
    -webkit-transform: translateX(0);
        -ms-transform: translateX(0);
            transform: translateX(0);
    -webkit-transition: -webkit-transform 0.2s ease;
    transition: -webkit-transform 0.2s ease;
    transition: transform 0.2s ease;
    transition: transform 0.2s ease, -webkit-transform 0.2s ease; }
    .c-navigation-pusher.is-active {
      -webkit-transform: translateX(300px);
          -ms-transform: translateX(300px);
              transform: translateX(300px); } }

@media (min-width: 46.25em) {
  .c-navigation__item--hiddenfrom-tablet {
    display: none; }
  .c-navigation--secondary {
    padding-left: 60px; } }

/* ==========================================================================
   #STICKYLINK
   ========================================================================== */
.c-stickylink {
  -webkit-transform: rotate(-90deg) translateX(55px);
      -ms-transform: rotate(-90deg) translateX(55px);
          transform: rotate(-90deg) translateX(55px);
  padding: 19px 1.4vw;
  letter-spacing: 0.4px;
  position: fixed;
  right: 0;
  top: 0;
  -webkit-transform-origin: right bottom 0;
      -ms-transform-origin: right bottom 0;
          transform-origin: right bottom 0;
  z-index: 1;
  background-color: #000;
  color: #fff;
  text-transform: uppercase;
  text-decoration: none;
  -webkit-transition: background-color 0.2s ease-in, color 0.2s ease-in;
  transition: background-color 0.2s ease-in, color 0.2s ease-in;
  font-size: 12px; }
  .c-stickylink:hover {
    background-color: #333;
    color: #e37477; }
  @media (max-width: 46.24em) {
    .c-stickylink {
      display: none; } }

.c-stickylink__emphased {
  color: #e37477; }

/* ==========================================================================
   #BLADE
   ========================================================================== */
.c-blade {
  margin-bottom: -webkit-calc(1.2rem + 4vw);
  margin-bottom: calc(1.2rem + 4vw);
  position: relative; }

.c-blade--main {
  margin-bottom: -webkit-calc(2.5rem + 4vw);
  margin-bottom: calc(2.5rem + 4vw); }

.c-blade__body {
  text-align: justify;
  font-size: -webkit-calc(1rem + 0.4vw);
  font-size: calc(1rem + 0.4vw);
  line-height: 1.3;
  padding-bottom: 15px; }
  .c-blade__body:after {
    content: "";
    display: block;
    height: 2px;
    background-color: #CD222A; }

.c-blade__body--main p {
  font-size: 18px; }

.c-blade__img {
  width: 100%; }

.c-blade__item {
  margin-bottom: 24px; }

@media (min-width: 46.25em) {
  .c-blade__item {
    width: 32%;
    margin-bottom: 0; }
  .c-blade__body {
    width: 68%;
    padding-left: 48px; }
    .c-blade__body:after {
      width: 23%;
      left: -webkit-calc(32% + 48px);
      left: calc(32% + 48px);
      bottom: 0;
      position: absolute; }
  .c-blade--reverse .c-blade__item {
    padding-left: 0; }
  .c-blade--reverse .c-blade__body {
    width: 68%;
    padding-right: 48px;
    padding-left: 24px; }
    .c-blade--reverse .c-blade__body:after {
      left: 24px; } }

/* ==========================================================================
   #FIELD
   ========================================================================== */
.c-field {
  background-color: #EEEEEE;
  border: 0 none;
  padding: 6px 12px;
  width: 100%;
  margin-top: 8px; }
  .c-field::-webkit-input-placeholder {
    color: #000;
    font-size: 15px; }
  .c-field::-moz-placeholder {
    color: #000;
    font-size: 15px; }
  .c-field:-ms-input-placeholder {
    color: #000;
    font-size: 15px; }
  .c-field::placeholder {
    color: #000;
    font-size: 15px; }

/* ==========================================================================
   #BUTTONS
   ========================================================================== */
/**
 * This is an example component. Extend inuitcss by building your own components
 * that make up your UI. Component classes are prefixed with a `c-`.
 */
/**
 * 1. Allow us to style box model properties.
 * 2. Line different sized buttons up a little nicer.
 * 3. Make buttons inherit font styles (often necessary when styling `input`s as
 *    buttons).
 * 4. Reset/normalize some styles.
 * 5. Force all button-styled elements to appear clickable.
 */
.c-btn {
  display: inline-block;
  /* [1] */
  vertical-align: middle;
  /* [2] */
  font: inherit;
  /* [3] */
  text-align: center;
  /* [4] */
  margin: 0;
  /* [4] */
  cursor: pointer;
  /* [5] */
  padding: 12px 24px;
  -webkit-transition: all 300ms ease-in-out;
  transition: all 300ms ease-in-out;
  -webkit-border-radius: 3px;
          border-radius: 3px; }

/* Style variants
   ========================================================================== */
.c-btn--primary {
  background-color: #4a8ec2; }
  .c-btn--primary, .c-btn--primary:hover, .c-btn--primary:active, .c-btn--primary:focus {
    text-decoration: none;
    /* [4] */
    color: #fff; }
  .c-btn--primary:hover, .c-btn--primary:focus {
    background-color: #3774a2; }

.c-btn--secondary {
  background-color: #2f4054; }
  .c-btn--secondary, .c-btn--secondary:hover, .c-btn--secondary:active, .c-btn--secondary:focus {
    text-decoration: none;
    color: #fff; }
  .c-btn--secondary:hover, .c-btn--secondary:focus {
    background-color: #1d2733; }

.c-btn--tertiary {
  background-color: #fff;
  color: #4a8ec2; }
  .c-btn--tertiary, .c-btn--tertiary:hover, .c-btn--tertiary:active, .c-btn--tertiary:focus {
    text-decoration: none;
    color: #4a8ec2; }
  .c-btn--tertiary:hover, .c-btn--tertiary:focus {
    color: #3774a2; }

/* Size variants
   ========================================================================== */
.c-btn--small {
  padding: 6px 12px; }

.c-btn--large {
  padding: 24px 48px; }

/* Ghost buttons
   ========================================================================== */
/**
 * Ghost buttons have see-through backgrounds and are bordered.
 */
.c-btn--ghost {
  border: 2px solid currentColor;
  padding: 10px 22px; }
  .c-btn--ghost, .c-btn--ghost:hover, .c-btn--ghost:active, .c-btn--ghost:focus {
    background: black;
    color: white;
    text-transform: uppercase; }
  .c-btn--ghost.c-btn--small {
    padding: 4px 10px; }
  .c-btn--ghost.c-btn--large {
    padding: 22px 46px; }
  .c-btn--ghost.c-btn--primary {
    color: #4a8ec2; }
    .c-btn--ghost.c-btn--primary:hover, .c-btn--ghost.c-btn--primary:focus {
      color: #3774a2; }
  .c-btn--ghost.c-btn--secondary {
    color: #2f4054; }
    .c-btn--ghost.c-btn--secondary:hover, .c-btn--ghost.c-btn--secondary:focus {
      color: #1d2733; }
  .c-btn--ghost.c-btn--tertiary {
    color: #fff; }
    .c-btn--ghost.c-btn--tertiary:hover, .c-btn--ghost.c-btn--tertiary:focus {
      color: #fff; }

/* ==========================================================================
   #CAROUSEL
   ========================================================================== */
.c-carousel p:last-child {
  margin-bottom: 0; }

.c-carousel:before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background-size: cover;
  background: -webkit-gradient(linear, left top, left bottom, from(#efefef), to(white));
  background: linear-gradient(180deg, #efefef, white 100%);
  z-index: -1; }

.c-carousel__content {
  background-size: cover;
  background-repeat: no-repeat;
  background-position: bottom center; }

.c-carousel__background {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover; }

.c-carousel .c-carousel__img {
  padding-right: 38px; }

.c-carousel__picto {
  width: 200px;
  fill: #626262; }

.c-carousel__title {
  text-transform: uppercase;
  font-size: 56px;
  margin-top: 40px;
  font-weight: 100;
  letter-spacing: 1.1px;
  position: relative;
  margin-bottom: 34px;
  padding-bottom: 4px;
  color: #626262; }
  .c-carousel__title:after {
    content: "";
    display: block;
    position: absolute;
    left: 5px;
    bottom: -8px;
    width: 33%;
    height: 1px;
    background-color: #CD222A;
    -webkit-border-radius: 3px;
            border-radius: 3px; }

.c-carousel__text {
  margin-left: 5px;
  font-size: 16px;
  line-height: 1.3;
  text-shadow: 0px 0px 30px #fff, 0px 0px 40px #fff;
  padding-bottom: 24px; }
  .c-carousel__text p:last-child {
    margin-bottom: 0; }

.c-carousel__wrapper {
  max-width: 1070px; }

.slick-prev,
.slick-next {
  display: none !important; }

@media (min-width: 46.25em) {
  .slick-slide {
    height: 295px; } }

@media (min-width: 100em) {
  .slick-slide {
    height: 395px; } }

@media (max-width: 46.24em) {
  .c-carousel .c-carousel__img {
    display: block;
    width: 100%;
    margin-top: 0;
    padding-right: 0;
    text-align: center; }
  .slick-slide img {
    display: block;
    margin: 0 auto;
    max-width: 100%; }
  .c-carousel__content--empty {
    display: none !important; }
  .c-carousel__wrapper {
    display: block; }
  .c-carousel__title {
    font-size: 2.5em;
    margin-top: 0; }
  .c-carousel__picto {
    width: 150px; } }

.c-carousel--small .slick-slide {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -webkit-align-items: center;
      -ms-flex-align: center;
          align-items: center;
  min-height: 90px;
  height: auto; }

.c-carousel--small .c-carousel__picto {
  max-height: 90px;
  width: auto; }

.c-carousel--small .slick-prev.slick-arrow {
  position: absolute;
  left: 0;
  border: 0 none;
  display: block !important;
  height: 100%;
  top: 0;
  width: 50px;
  background-size: contain;
  background: transparent url(../images/Font-confiance-gauche.png) no-repeat center; }

.c-carousel--small .slick-next.slick-arrow {
  position: absolute;
  right: 0;
  border: 0 none;
  display: block !important;
  height: 100%;
  top: 0;
  width: 50px;
  background-size: contain;
  background: transparent url(../images/Font-confiance-droite.png) no-repeat center; }

.c-carousel--small {
  margin-bottom: 50px;
  max-width: 1134px;
  padding: 0 130px; }
  .c-carousel--small:before {
    content: normal; }
  .c-carousel--small .c-carousel__text {
    padding-bottom: 0; }

@media (max-width: 46.24em) {
  .c-carousel__img,
  .c-carousel__body {
    display: block;
    margin-bottom: 24px; }
  .c-carousel--small {
    padding: 0 70px; } }

.c-carousel__content--text h1 {
  font-size: 38px;
  font-weight: 400;
  letter-spacing: 1.4px;
  margin-bottom: 2px; }

.c-carousel__content--text hr {
  border: 0 none;
  margin-bottom: 4px; }
  .c-carousel__content--text hr:before {
    content: "";
    display: block;
    height: 1px;
    background-color: #CD222A;
    width: 70px;
    left: 50%;
    position: absolute;
    margin-left: -35px; }

.c-carousel__content--text h2 {
  font-size: 1.8rem;
  color: #CD222A;
  font-weight: 300;
  margin-bottom: 0px; }

.c-carousel__content--text p {
  margin-bottom: 0;
  font-size: 23px;
  line-height: 1.05;
  font-weight: 300;
  letter-spacing: 0.7px; }

.c-carousel__content--text .c-carousel__text {
  margin-left: 33px;
  padding-top: 73px; }

.c-carousel__content--text .c-carousel__img {
  position: absolute;
  width: 73%;
  bottom: 37px; }

.c-carousel__content--text .c-carousel__picto {
  width: 100%; }

.c-carousel__content--text .c-carousel__wrapper {
  max-width: 1370px;
  padding: 0px 87px;
  position: relative;
  text-align: center;
  height: 100%; }

.c-carousel__content--text .c-carousel__title:after {
  content: normal;
  display: none; }

@media (min-width: 100em) {
  .c-carousel__content--text .c-carousel__img {
    bottom: 84px; }
  .c-carousel__content--text .c-carousel__text {
    padding-top: 113px; } }

@media (max-width: 63.9375em) {
  .c-carousel__content--text .c-carousel__img {
    bottom: 56px;
    left: 30px; } }

@media (max-width: 46.24em) {
  .c-carousel__content--text .c-carousel__text {
    padding-top: 0;
    margin-left: 0; }
  .c-carousel__content--text .c-carousel__img {
    position: static;
    width: 100%; }
  .c-carousel__content--text .c-carousel__wrapper {
    padding: 24px; } }

/* Dots */
.slick-dots {
  position: absolute;
  bottom: 0;
  display: block;
  width: 100%;
  padding: 0;
  list-style: none;
  text-align: center;
  margin-bottom: 20px; }

.slick-dots li {
  position: relative;
  display: inline-block;
  width: 20px;
  height: 20px;
  margin: 0 5px;
  padding: 0;
  cursor: pointer; }

.slick-dots li button {
  font-size: 0;
  line-height: 0;
  display: block;
  width: 20px;
  height: 20px;
  padding: 5px;
  cursor: pointer;
  color: transparent;
  border: 0;
  outline: none;
  background: transparent; }

.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 {
  font-size: 66px;
  line-height: 20px;
  position: absolute;
  top: 0;
  left: 0;
  width: 20px;
  height: 20px;
  content: '•';
  text-align: center;
  opacity: .25;
  color: #626262;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  -webkit-transition: opacity 0.2s ease;
  transition: opacity 0.2s ease; }

.slick-dots li.slick-active button:before {
  opacity: 1;
  color: #626262; }

/* ==========================================================================
   #TITLES
   ========================================================================== */
.c-title {
  font-size: 26px;
  line-height: 1;
  margin-bottom: 26px;
  font-weight: 900; }

.c-title--office p {
  font-size: 32px;
  font-size: 2rem;
  line-height: 1;
  font-weight: 400; }

.c-title-office {
  font-size: 24px;
  font-size: 1.5rem;
  line-height: 1;
  margin-bottom: 24px;
  font-weight: 400;
  text-transform: uppercase; }

.c-title-hero {
  font-size: 41px;
  line-height: 1.2;
  font-weight: 300;
  text-transform: uppercase; }
  @media (max-width: 46.24em) {
    .c-title-hero br {
      display: none; } }
  .c-title-hero:after {
    content: " ///";
    color: #CD222A;
    font-size: 0.7em; }

.c-title-hero__letter {
  color: #CD222A; }

.c-title-section {
  font-size: 34px;
  line-height: 1;
  margin-bottom: 50px;
  color: #CD222A;
  font-weight: 300;
  text-transform: uppercase; }

.c-title-secondary {
  font-size: 30px;
  color: #000;
  font-weight: 900;
  text-transform: uppercase; }

.t-fees h2,
.c-title-fees {
  font-size: 19px;
  font-size: 1.1875rem;
  line-height: 1.5789473684;
  color: #CD222A;
  font-weight: 500;
  text-transform: uppercase;
  margin-bottom: 0; }

.t-fees h3,
.c-title-fees--subtitle {
  color: #000;
  font-weight: normal;
  margin-bottom: 0;
  font-size: 19px;
  font-size: 1.1875rem;
  line-height: 1.5789473684;
  text-transform: uppercase; }

.t-fees h4,
.c-title-fees--subsubtitle {
  color: #000;
  font-weight: normal;
  margin-bottom: 0;
  text-transform: uppercase;
  font-size: 17px;
  font-size: 1.0625rem;
  line-height: 1.4117647059; }

.t-expertise h3,
.c-title-fees {
  font-size: 20px;
  font-size: 1.25rem;
  line-height: 1.5;
  color: #CD222A;
  font-weight: 500;
  margin-bottom: 6px; }
  @media (min-width: 46.25em) {
    .t-expertise h3,
    .c-title-fees {
      margin-bottom: 0; } }

.c-title-bicolor {
  font-size: 25px;
  font-size: 1.5625rem;
  line-height: 1.44;
  color: #000;
  text-align: center;
  font-weight: 400;
  text-transform: uppercase; }
  .c-title-bicolor::first-letter {
    color: #CD222A; }

.t-legalnotices h2 {
  font-size: 15px;
  font-size: 0.9375rem;
  line-height: 1.6;
  color: #CD222A;
  font-weight: 500;
  margin-bottom: 0; }

.t-legalnotices h3 {
  font-size: 14px;
  font-size: 0.875rem;
  line-height: 1.7142857143;
  color: #000;
  font-weight: 500;
  margin-bottom: 0; }

.t-legalnotices,
.t-legalnotices p {
  font-size: 14px;
  font-size: 0.875rem;
  line-height: 1.7142857143; }

/* ==========================================================================
   #MAIN
   ========================================================================== */
.c-main {
  padding-top: 72px;
  background: linear-gradient(180deg, #efefef, white 50px);
  margin-bottom: 50px; }

.c-main--article {
  padding-top: 42px; }

.c-main--office {
  padding-top: 42px; }

/* ==========================================================================
   #BANNER
   ========================================================================== */
.c-banner {
  background: #D8D8D8;
  padding: 15px 0 12px;
  text-align: center;
  margin-bottom: 24px; }

.c-banner__text {
  color: #222;
  padding: 0px 12px;
  position: relative;
  font-size: 23px;
  text-transform: uppercase;
  letter-spacing: 0.9px; }
  .c-banner__text:before, .c-banner__text:after {
    content: "";
    position: absolute;
    left: 0;
    width: 1px;
    bottom: 5px;
    top: 4px;
    height: auto;
    background-color: #CD222A; }
  .c-banner__text:after {
    right: 0;
    left: auto; }

/* ==========================================================================
   #CONTACT
   ========================================================================== */
.c-contact h3 {
  margin-bottom: 10px; }

.c-contact p {
  line-height: 1.2; }

.c-contact__map img {
  width: 100%; }

@media (min-width: 46.25em) {
  .c-contact__text {
    padding-left: 0;
    width: 30%; }
  .c-contact__form {
    width: 33%; }
  .c-contact__map {
    width: 37%;
    padding-left: 16px; } }

.c-contact__field {
  margin-top: 8px; }

.c-contact__form textarea {
  padding-top: 10px; }

.c-contact__form input[type="submit"] {
  margin-top: 8px; }

/* ==========================================================================
   #ARTICLE
   ========================================================================== */
.c-article p {
  text-align: justify;
  line-height: 1.2; }

.c-article__title {
  font-weight: 900;
  font-size: 30px;
  font-size: 1.875rem;
  line-height: 0.9;
  text-transform: uppercase;
  letter-spacing: 1px;
  margin-bottom: 10px; }
  @media (min-width: 46.25em) {
    .c-article__title {
      font-size: 40px;
      font-size: 2.5rem;
      line-height: 0.9; } }

.c-article__header {
  position: relative;
  padding-bottom: 18px;
  margin-bottom: 20px; }
  .c-article__header:after {
    content: "";
    margin-top: 24px;
    display: block;
    height: 2px;
    background-color: #CD222A; }

.c-article__header--with-link {
  padding-bottom: 30px; }

.c-article__author {
  font-size: 12px; }

.c-article__share {
  font-size: 12px; }
  .c-article__share img {
    width: 25px; }

.c-article__meta {
  margin-bottom: 20px; }

.c-article__content {
  text-align: justify;
  margin-bottom: 10px; }

.c-article__category {
  margin-bottom: 10px;
  text-transform: uppercase; }

@media (min-width: 46.25em) {
  .c-article__header:after {
    width: 23%;
    margin-top: 0;
    right: 0;
    bottom: 0;
    position: absolute; }
  .c-article__header--with-link:after {
    width: 19%;
    height: 1px; } }

.c-article--small .c-title-secondary {
  font-weight: 400;
  font-size: 16px;
  font-size: 1rem;
  line-height: 1.5; }

.c-article--small .c-article__title {
  font-weight: 400;
  font-size: 16px;
  font-size: 1rem;
  line-height: 1.5;
  line-height: 1.4;
  margin-bottom: 0; }

.c-article--small .c-article__content {
  text-align: left; }

.c-article--small .read-more {
  font-size: 18px;
  font-weight: 400;
  text-transform: inherit; }

.c-article--small .c-article__header--with-link:after {
  content: normal;
  display: none; }

/* ==========================================================================
   #PAGER
   ========================================================================== */
.pager {
  clear: both;
  list-style: none;
  margin: 12px 0;
  padding: 0;
  text-align: center; }

.pager__item {
  display: inline-block;
  font-weight: 900;
  line-height: 1;
  margin: 0;
  padding: 0;
  margin-left: 10px;
  text-align: center;
  vertical-align: top; }
  .pager__item:not([class*=pager__item--]) {
    display: none; }
    @media (min-width: 37.5em) {
      .pager__item:not([class*=pager__item--]) {
        display: inline-block; } }
  .pager__item:first-child {
    margin-left: 0; }

.pager__item--current, .pager__link {
  background-color: transparent;
  color: #212121;
  min-width: 33px;
  padding: 8px;
  border: 1px solid black; }

.pager__item--current {
  background-color: #EEEEEE; }

.pager__link {
  display: inline-block;
  text-decoration: none;
  -webkit-transition: background-color 0.2s ease;
  transition: background-color 0.2s ease; }
  .pager__link:focus, .pager__link:hover {
    background-color: #EEEEEE;
    color: inherit; }

/* ==========================================================================
   #TABLE
   ========================================================================== */
.c-table tr:nth-child(odd) {
  background: #EEEEEE; }

.c-table td:first-child {
  text-align: left; }

.c-table td:last-child {
  text-align: right; }

.c-table td {
  padding: 6px 13px; }

/* ==========================================================================
   #SECTIONS
   ========================================================================== */
.c-section-fees-tables {
  max-width: 800px;
  margin-right: auto;
  margin-left: auto;
  margin-bottom: 24px; }
  .c-section-fees-tables:last-child {
    margin-bottom: 50px; }

.c-section-fees-text {
  margin-bottom: 50px;
  text-align: center;
  line-height: 1.2; }

.t-expertise p {
  line-height: 1.2; }

/* ==========================================================================
   #ACCORDION
   ========================================================================== */
.c-accordion:last-child {
  margin-bottom: 24px; }
  .c-accordion:last-child .c-accordion__content {
    border-bottom-width: 1px; }
  .c-accordion:last-child .c-accordion__button {
    border-bottom-color: #000; }

.c-accordion__button {
  background: none;
  cursor: pointer;
  width: 100%;
  border: 1px solid #000;
  border-bottom-color: transparent;
  text-transform: uppercase;
  font-size: 25px;
  padding: 13px 62px 13px 13px;
  display: block;
  text-align: center; }
  .c-accordion__button::first-letter {
    color: #CD222A; }
  .c-accordion__button[aria-expanded="true"] {
    border-bottom-color: #000; }

.c-accordion__button--no-icon {
  padding: 13px; }

.c-accordion__icon {
  width: 37px;
  position: absolute;
  right: 12px;
  top: 50%;
  margin-top: -18px; }
  .no-object-fit .c-accordion__icon {
    margin-top: -26px; }

.c-accordion__title {
  margin-bottom: 0;
  position: relative; }

.c-accordion__content {
  padding: 16px 24px;
  border: 1px solid #000;
  border-width: 0 1px 0px 1px; }
  @media (min-width: 46.25em) {
    .c-accordion__content {
      padding: 30px 50px; } }
  .c-accordion__content p:last-child {
    margin-bottom: 0; }

[aria-expanded="true"] .c-accordion__plus-bar {
  display: none; }

/* ==========================================================================
   #CAROUSEL
   ========================================================================== */
.c-gallery {
  margin: 0 auto;
  max-width: 90%;
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-flex-wrap: wrap;
      -ms-flex-wrap: wrap;
          flex-wrap: wrap; }

/* Create four equal columns that sits next to each other */
.c-gallery__column {
  -webkit-box-flex: 100%;
  -webkit-flex: 100%;
      -ms-flex: 100%;
          flex: 100%;
  max-width: 100%;
  padding: 0 12px; }

.c-gallery__column img {
  vertical-align: middle;
  width: 100%; }

/* Responsive layout - makes a two column-layout instead of four columns */
@media (min-width: 46.25em) {
  .c-gallery__column {
    -webkit-box-flex: 33.333%;
    -webkit-flex: 33.333%;
        -ms-flex: 33.333%;
            flex: 33.333%;
    max-width: 33.333%; } }

@media (min-width: 61.25em) {
  .c-gallery__column {
    -webkit-box-flex: 25%;
    -webkit-flex: 25%;
        -ms-flex: 25%;
            flex: 25%;
    max-width: 25%; } }

/* ==========================================================================
   #CLEARFIX
   ========================================================================== */
/**
 * Attach our clearfix mixin to a utility class.
 */
.u-clearfix:after {
  content: "" !important;
  display: block !important;
  clear: both !important; }

.u-1\/1 {
  width: 100% !important; }

@media (min-width: 46.25em) {
  .u-1\/2\@tablet {
    width: 50% !important; }
  .u-1\/4\@tablet {
    width: 25% !important; }
  .u-1\/3\@tablet {
    width: 33.33333333333% !important; }
  .u-3\/4\@tablet {
    width: 75% !important; } }

/* ==========================================================================
   #PRINT
   ========================================================================== */
/**
 * Very crude, reset-like styles taken from the HTML5 Boilerplate:
 * https://github.com/h5bp/html5-boilerplate/blob/5.3.0/dist/doc/css.md#print-styles
 * https://github.com/h5bp/html5-boilerplate/blob/master/dist/css/main.css#L205-L282
 */
@media print {
  /**
   * 1. Black prints faster: http://www.sanbeiji.com/archives/953
   */
  *,
  *:before,
  *:after,
  *:first-letter,
  *:first-line {
    background: transparent !important;
    color: #000 !important;
    /* [1] */
    -webkit-box-shadow: none !important;
            box-shadow: none !important;
    text-shadow: none !important; }
  a,
  a:visited {
    text-decoration: underline; }
  a[href]:after {
    content: " (" attr(href) ")"; }
  abbr[title]:after {
    content: " (" attr(title) ")"; }
  /**
   * Don't show links that are fragment identifiers, or use the `javascript:`
   * pseudo protocol.
   */
  a[href^="#"]:after,
  a[href^="javascript:"]:after {
    content: ""; }
  pre,
  blockquote {
    border: 1px solid #999;
    page-break-inside: avoid; }
  /**
   * Printing Tables: http://css-discuss.incutio.com/wiki/Printing_Tables
   */
  thead {
    display: table-header-group; }
  tr,
  img {
    page-break-inside: avoid; }
  img {
    max-width: 100% !important; }
  p,
  h2,
  h3 {
    orphans: 3;
    widows: 3; }
  h2,
  h3 {
    page-break-after: avoid; } }

/* ==========================================================================
   #HIDE
   ========================================================================== */
/**
 * Hide only visually, but have it available for screen readers:
 * http://snook.ca/archives/html_and_css/hiding-content-for-accessibility
 */
.u-hidden-visually {
  border: 0 !important;
  clip: rect(0 0 0 0) !important;
  -webkit-clip-path: inset(50%) !important;
          clip-path: inset(50%) !important;
  height: 1px !important;
  margin: -1px !important;
  overflow: hidden !important;
  padding: 0 !important;
  position: absolute !important;
  white-space: nowrap !important;
  width: 1px !important; }

/**
 * Hide visually and from screen readers.
 */
.u-hidden {
  display: none !important; }

.u-visually-hidden {
  clip: rect(1px, 1px, 1px, 1px) !important;
  height: 1px !important;
  overflow: hidden !important;
  position: absolute !important;
  width: 1px !important;
  word-wrap: normal !important; }

.u-focusable:active, .u-focusable:focus {
  clip: auto !important;
  height: auto !important;
  overflow: visible !important;
  position: static !important;
  width: auto !important; }

.u-full-height {
  height: 100% !important; }

.u-middle {
  vertical-align: middle !important; }

.u-clearfix:after {
  content: "" !important;
  display: block !important;
  clear: both !important; }

.u-pull-right {
  float: right !important; }

.u-color-carmine {
  color: #CD222A !important; }

.u-color-black {
  color: #000 !important; }

.u-text-tiny {
  font-size: 10px !important; }

.u-text-large {
  font-size: 18px !important; }

.u-text-italic {
  font-style: italic !important; }

.u-text-center {
  text-align: center !important; }

.u-hidden {
  display: none !important; }

.u-margin-bottom {
  margin-bottom: 24px !important; }

.u-margin-top {
  margin-top: 24px !important; }

.u-margin-top-huge {
  margin-top: 96px !important; }

.u-margin-bottom-medium {
  margin-bottom: 50px !important; }

.screen-reader-response {
  position: absolute;
  overflow: hidden;
  clip: rect(1px, 1px, 1px, 1px);
  height: 1px;
  width: 1px;
  margin: 0;
  padding: 0;
  border: 0; }

@media all and (-ms-high-contrast: none) {
  *::-ms-backdrop,
  [data-aos^=fade][data-aos^=fade], [data-aos^=zoom][data-aos^=zoom] {
    opacity: 1; } }

.c-btn--ghost {
  padding: 7px 31px; }

.read-more {
  position: absolute;
  right: 4px;
  bottom: 30px;
  font-weight: bold;
  font-size: 21px;
  text-transform: uppercase;
  color: #CD222A; }
  @media (min-width: 46.25em) {
    .read-more {
      bottom: 4px; } }

.widget {
  margin-bottom: 40px; }
  .widget ul {
    margin: 0; }
  .widget li {
    list-style: none;
    margin: 0;
    padding: 0;
    margin-bottom: 40px; }
  .widget .post-date {
    font-size: 12px; }

.widget__title {
  color: #CD222A;
  text-transform: uppercase;
  font-size: 18px;
  padding-bottom: 17px;
  position: relative; }
  .widget__title:after {
    content: "";
    display: block;
    height: 1px;
    width: 100%;
    background-color: #CD222A;
    position: absolute;
    bottom: 0;
    left: 0; }

.cookiecnil-more {
  display: none; }

.cookiecnil {
  width: 100%;
  text-align: center;
  background: rgba(0, 0, 0, 0.8);
  color: #fff;
  padding: 5px 0 5px 0;
  display: none;
  position: fixed;
  bottom: 0;
  font-size: 14px;
  font-weight: 100; }
  .cookiecnil a {
    color: white; }

.cookiecnil button {
  background: #555;
  border: none;
  cursor: pointer;
  color: #fff; }

[data-src] {
  -webkit-transition: opacity 0.3s ease;
  transition: opacity 0.3s ease;
  opacity: 0; }

[data-src].fade-in {
  opacity: 1; }


lite-youtube {
  background-color: #000;
  position: relative;
  display: block;
  contain: content;
  background-position: center center;
  background-size: cover;
  cursor: pointer;
  /*max-width: 720px;*/
}

/* gradient */
lite-youtube::before {
  content: '';
  display: block;
  position: absolute;
  top: 0;
  background-image: url(data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAAEAAADGCAYAAAAT+OqFAAAAdklEQVQoz42QQQ7AIAgEF/T/D+kbq/RWAlnQyyazA4aoAB4FsBSA/bFjuF1EOL7VbrIrBuusmrt4ZZORfb6ehbWdnRHEIiITaEUKa5EJqUakRSaEYBJSCY2dEstQY7AuxahwXFrvZmWl2rh4JZ07z9dLtesfNj5q0FU3A5ObbwAAAABJRU5ErkJggg==);
  background-position: top;
  background-repeat: repeat-x;
  height: 110px;
  opacity: 0.5;
  padding-bottom: 50px;
  width: 100%;
  transition: all 0.2s cubic-bezier(0, 0, 0.2, 1);
}

/* responsive iframe with a 16:9 aspect ratio
    thanks https://css-tricks.com/responsive-iframes/
*/
lite-youtube::after {
  content: "";
  display: block;
  padding-bottom: calc(100% / (16 / 9));
}
lite-youtube > iframe {
  width: 100%;
  height: 100%;
  position: absolute;
  top: 0;
  left: 0;
  border: 0;
}

/* play button */
lite-youtube > .lty-playbtn {
  width: 68px;
  height: 48px;
  position: absolute;
  cursor: pointer;
  transform: translate3d(-50%, -50%, 0);
  top: 50%;
  left: 50%;
  z-index: 1;
  background-color: transparent;
  /* YT's actual play button svg */
  background-image: url('data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg" version="1.1" viewBox="0 0 68 48"><path fill="%23f00" fill-opacity="0.8" d="M66.52,7.74c-0.78-2.93-2.49-5.41-5.42-6.19C55.79,.13,34,0,34,0S12.21,.13,6.9,1.55 C3.97,2.33,2.27,4.81,1.48,7.74C0.06,13.05,0,24,0,24s0.06,10.95,1.48,16.26c0.78,2.93,2.49,5.41,5.42,6.19 C12.21,47.87,34,48,34,48s21.79-0.13,27.1-1.55c2.93-0.78,4.64-3.26,5.42-6.19C67.94,34.95,68,24,68,24S67.94,13.05,66.52,7.74z"></path><path d="M 45,24 27,14 27,34" fill="%23fff"></path></svg>');
  filter: grayscale(100%);
  transition: filter .1s cubic-bezier(0, 0, 0.2, 1);
  border: none;
}

lite-youtube:hover > .lty-playbtn,
lite-youtube .lty-playbtn:focus {
  filter: none;
}

/* Post-click styles */
lite-youtube.lyt-activated {
  cursor: unset;
}
lite-youtube.lyt-activated::before,
lite-youtube.lyt-activated > .lty-playbtn {
  opacity: 0;
  pointer-events: none;
}

.lyt-visually-hidden {
  clip: rect(0 0 0 0);
  clip-path: inset(50%);
  height: 1px;
  overflow: hidden;
  position: absolute;
  white-space: nowrap;
  width: 1px;
}
/*# sourceMappingURL=styles.css.map */
