@charset "UTF-8";
/* ==========================================================================
   #MAIN
   ========================================================================== */
/**
 * TABLE OF CONTENTS
 *
 * 01. SETTINGS
 * Global..............Unique brand identity values.
 * Colors..............The color palette.
 * Fonts...............Font family, sizing and weights.
 * Responsive..........Breakpoints for media queries.
 *
 * 02. TOOLS
 * Mixins..............Functions for DRY code.
 *
 * 03. GENERIC
 * Normalize.css.......Render all elements more consistently.
 * Reset...............A tiny reset.
 * Box Sizing..........Default box sizing of all elements.
 * Shared..............Rules that apply to multiple selectors.
 *
 * 04. ELEMENTS
 * Page................The defaults of the document.
 * Headings............Setup of h1 to h6.
 * Type................Basic typographic elements.
 * Links...............The default anchor style.
 * Lists...............Styles for lists.
 * Forms...............Basic form elements.
 * Figures.............Represent self-contained content.
 * Images..............Ensure images are fluid.
 * Quotes..............Cater for block and inline quotes.
 * Tables..............Tabular data styles.
 *
 * 05. OBJECTS
 * Wrapper.............Content width constraints.
 * Grid................Basic grid layout.
 * Lists...............Custom list styles.
 * Media...............An image with descriptive contents.
 *
 * 06. COMPONENTS
 * Alerts..............Provides feedback to the interface.
 * Badges..............Highlight a piece of information.
 * Breadcrumbs.........Displays the hierarchy between content.
 * Forms...............Form control styling and layout.
 * Buttons.............Button styles.
 * Button Groups.......Grouping of related buttons.
 * Pagination..........Controls to navigate pages of data.
 * Footer..............Page footer styles.
 *
 * 07. UTILITIES
 * Print...............Default styles from HTML5 Boilerplate.
 * Colors..............Background and foreground color overrides.
 * Clearfix............Provides a class for the clearfix mixin.
 * Floats..............Pull a child element to the left or right.
 * Headings............Maintain heading hierarchy, but change font sizing.
 * Spacing.............Set the margin or padding on an element.
 * Visibility..........Control the visibility of elements.
 * Widths..............Specify the width of an element.
 */
/* #SETTINGS
   ========================================================================== */
/* stylelint-disable scss/dollar-variable-colon-space-after */
/* ==========================================================================
   #GLOBAL
   ========================================================================== */
/* #BRAND
   ========================================================================== */
/* Color */
/* Font */
/* #BASE
   ========================================================================== */
/* Font */
/* Spacing */
/* Borders */
/* Shadows */
/* stylelint-disable scss/dollar-variable-colon-space-after */
/* ==========================================================================
   #COLORS
   ========================================================================== */
/* Brand */
/* Neutral */
/* Social */
/* Utility */
/* stylelint-disable scss/dollar-variable-colon-space-after */
/* ==========================================================================
   #FONTS
   ========================================================================== */
/* Family */
/* Size */
/* 32 / 16 */
/* 28 / 16 */
/* 24 / 16 */
/* 20 / 16 */
/* 18 / 16 */
/* 16 / 16 */
/* Weight */
/* stylelint-disable scss/dollar-variable-colon-space-after */
/* ==========================================================================
   #RESPONSIVE
   ========================================================================== */
/* Breakpoints */
/*  576 / 16 */
/*  768 / 16 */
/*  992 / 16 */
/* 1200 / 16 */
/* #TOOLS
   ========================================================================== */
/* ==========================================================================
   #MIXINS
   ========================================================================== */
/**
 * Clearfix: contain floats.
 *
 * For modern browsers
 * 1. The space content is one way to avoid an Opera bug when the
 *    `contenteditable` attribute is included anywhere else in the document.
 *    Otherwise it causes space to appear at the top and bottom of elements
 *    that receive the `clearfix` class.
 * 2. The use of `table` rather than `block` is only necessary if using
 *    `:before` to contain the top-margins of child elements.
 */
/**
 * Set font size with a relative line height.
 *
 * The `$font-size` argument should be specified in `rem` units.
 * The `$line-height` argument, if specified, should be unitless.
 */
/**
 * Remove the default styles from lists.
 */
/* #GENERIC
   ========================================================================== */
/*! normalize.css v8.0.1 | 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 iOS.
 */
html {
  line-height: 1.15;
  /* 1 */
  -webkit-text-size-adjust: 100%;
  /* 2 */
}

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

/**
 * Render the `main` element consistently in IE.
 */
main {
  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
   ========================================================================== */
/**
 * 1. Add the correct box sizing in Firefox.
 * 2. Show the overflow in Edge and IE.
 */
hr {
  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
   ========================================================================== */
/**
 * Remove the gray background on active links in IE 10.
 */
a {
  background-color: transparent;
}

/**
 * 1. Remove the bottom border in Chrome 57-
 * 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 */
}

/**
 * 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 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
   ========================================================================== */
/**
 * Remove the border on images inside links in IE 10.
 */
img {
  border-style: none;
}

/* Forms
   ========================================================================== */
/**
 * 1. Change the font styles in all browsers.
 * 2. Remove the margin in Firefox and Safari.
 */
button,
input,
optgroup,
select,
textarea {
  font-family: inherit;
  /* 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;
}

/**
 * Correct the inability to style clickable types in iOS and Safari.
 */
button,
[type=button],
[type=reset],
[type=submit] {
  -webkit-appearance: button;
}

/**
 * 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 {
  box-sizing: border-box;
  /* 1 */
  color: inherit;
  /* 2 */
  display: table;
  /* 1 */
  max-width: 100%;
  /* 1 */
  padding: 0;
  /* 3 */
  white-space: normal;
  /* 1 */
}

/**
 * Add the correct vertical alignment in Chrome, Firefox, and Opera.
 */
progress {
  vertical-align: baseline;
}

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

/**
 * 1. Add the correct box sizing in IE 10.
 * 2. Remove the padding in IE 10.
 */
[type=checkbox],
[type=radio] {
  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 in Chrome and Safari on macOS.
 */
[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 Edge, IE 10+, and Firefox.
 */
details {
  display: block;
}

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

/* Misc
   ========================================================================== */
/**
 * Add the correct display in IE 10+.
 */
template {
  display: none;
}

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

/* stylelint-disable selector-list-comma-newline-after */
/* ==========================================================================
   #RESET
   ========================================================================== */
/* Remove margins and padding. */
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 the gap between audio, canvas, iframes, images, videos and the bottom
 * of their containers: https://github.com/h5bp/html5-boilerplate/issues/440
 */
audio,
canvas,
iframe,
img,
svg,
video {
  vertical-align: middle;
}

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

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

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

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

/* stylelint-disable selector-list-comma-newline-after */
/* ==========================================================================
   #SHARED
   ========================================================================== */
html,
body {
  height: 100%;
}

address,
h1, h2, h3, h4, h5, h6,
blockquote, p, pre,
dl, ol, ul,
figure,
hr,
table {
  margin-bottom: 1.5rem;
}

fieldset,
legend {
  margin-bottom: 0.75rem;
}

caption,
th {
  text-align: left;
}

th,
td {
  padding: 0.75rem 1.5rem;
}

/* #ELEMENTS
   ========================================================================== */
/* ==========================================================================
   #PAGE
   ========================================================================== */
/**
 * The page-level setup.
 */
html {
  color: #001f3f;
  font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Helvetica, Arial, sans-serif;
  font-size: 1rem;
  line-height: 1.5;
}

/* ==========================================================================
   #HEADINGS
   ========================================================================== */
h1 {
  font-size: 2rem;
  line-height: 1.25;
}

h2 {
  font-size: 1.75rem;
  line-height: 1.25;
}

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

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

h5 {
  font-size: 1.125rem;
  line-height: 1.25;
}

h6 {
  font-size: 1rem;
  line-height: 1.25;
}

/* ==========================================================================
   #TYPE
   ========================================================================== */
/* Horizontal Rule */
hr {
  border: 0;
  border-top: 0.125em solid #0074d9;
  display: block;
}

/* Mark */
mark {
  background-color: #ffdc00;
}

/* Paragraph */
p:last-child {
  margin-bottom: 0;
}

/* ==========================================================================
   #LINKS
   ========================================================================== */
a {
  color: #001f3f;
  text-decoration: underline;
  transition: color 0.25s;
}
a:active, a:focus, a:hover {
  color: #0074d9;
}

/* stylelint-disable selector-list-comma-newline-after */
/* ==========================================================================
   #LISTS
   ========================================================================== */
dd, ol, ul {
  margin-left: 1.5rem;
}

/* ==========================================================================
   #FORMS
   ========================================================================== */
/* Label */
label {
  display: inline-block;
  font-weight: 700;
  margin-bottom: 0.375rem;
  /* Checkbox or Radio Button */
}
label [type=checkbox],
label [type=radio] {
  margin-right: 0.375rem;
}

/* Legend */
legend {
  font-weight: 700;
}

/* ==========================================================================
   #FIGURES
   ========================================================================== */
figure figcaption {
  color: gray;
  display: block;
  font-size: 0.875rem;
  margin-top: 0.75rem;
}

/* stylelint-disable selector-no-qualifying-type */
/* ==========================================================================
   #IMAGES
   ========================================================================== */
/**
 * 1. Offset `alt` text from surrounding copy.
 * 2. Fluid images for responsive purposes.
 * 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 {
  font-style: italic;
  /* [1] */
  max-width: 100%;
  /* [2] */
  vertical-align: middle;
  /* [3] */
  /**
   * If a `width` and/or `height` attribute has been explicitly defined, let’s
   * not make the image fluid.
   */
}
img[height], img[width] {
  max-width: none;
}

/* ==========================================================================
   #QUOTES
   ========================================================================== */
/* Inline */
q {
  font-style: italic;
  quotes: "‘" "’" "“" "”";
}
q::after {
  content: close-quote;
}
q::before {
  content: open-quote;
}

/* Block */
blockquote {
  border-left: 0.125em solid #0074d9;
  padding-left: 1.5rem;
}
blockquote q {
  quotes: "‘" "’";
}
blockquote q::after {
  content: close-quote;
}
blockquote q::before {
  content: open-quote;
}
blockquote cite {
  display: block;
}

/* ==========================================================================
   #TABLES
   ========================================================================== */
table {
  display: block;
  overflow-x: auto;
  white-space: nowrap;
  width: 100%;
}
table caption {
  caption-side: bottom;
  color: gray;
  font-size: 0.875rem;
  margin-top: 0.75rem;
}
table thead {
  border-bottom: 0.125em solid #001f3f;
}
table td {
  border-bottom: 0.0625em solid #cccccc;
}

/* #OBJECTS
   ========================================================================== */
/* ==========================================================================
   #WRAPPERS
   ========================================================================== */
/* Center the content within a reasonably wide container. */
.o-wrapper {
  margin-left: auto;
  margin-right: auto;
  max-width: 75em;
  /* 1200 / 16 */
}

/**
 * Small
 */
.o-wrapper--small {
  max-width: 30em;
  /* 480 / 16 */
}

/**
 * Medium
 */
.o-wrapper--medium {
  max-width: 40em;
  /* 640 / 16 */
}

/* ==========================================================================
   #GRID
   ========================================================================== */
.o-grid {
  clear: both;
  width: 100%;
}
.o-grid + .o-grid {
  margin-top: 1.5rem;
}

/* Row */
.o-grid__row {
  display: flex;
  flex-wrap: wrap;
  margin-left: -1.5rem;
  margin-top: -1.5rem;
}
.o-grid__row + .o-grid__row {
  margin-top: 0;
}

/* Column */
.o-grid__col {
  padding-left: 1.5rem;
  padding-top: 1.5rem;
}

/* ==========================================================================
   #LIST
   ========================================================================== */
.o-list {
  list-style: none;
  margin: 0;
}

/**
 * Inline
 */
.o-list--inline li {
  display: inline-block;
}

/* ==========================================================================
   #MEDIA
   ========================================================================== */
/**
 * The media object is an image to the left, with descriptive content to the right:
 * http://www.stubbornella.org/content/2010/06/25/the-media-object-saves-hundreds-of-lines-of-code
 */
.o-media {
  display: flex;
}

/* Body */
.o-media__body {
  flex: 1;
}
.o-media__body > :last-child {
  margin-bottom: 0;
}

/* Image */
.o-media__img {
  margin-right: 1.5rem;
}
.o-media__img > img {
  display: block;
}

/* #COMPONENTS
   ========================================================================== */
/* ==========================================================================
   #ALERTS
   ========================================================================== */
.c-alert {
  background-color: #0074d9;
  border-radius: 0.0625em;
  border-top: 0.125em solid #0066c0;
  box-shadow: 0 0 1em rgba(34, 34, 34, 0.125);
  color: #fff;
  margin-bottom: 1.5rem;
  padding: 0.75rem 2.25rem 0.75rem 0.75rem;
  position: relative;
}

/* Body */
.c-alert__body a {
  color: #fff;
  font-weight: 700;
}
.c-alert__body a:focus, .c-alert__body a:hover {
  color: #fff;
}
.c-alert__body ul {
  margin-bottom: 0;
}
.c-alert__body p {
  margin-bottom: 0;
}
.c-alert__body p + p,
.c-alert__body p + ul {
  margin-top: 0.75rem;
}

/* Dismiss */
.c-alert__dismiss {
  background-color: transparent;
  border: 0;
  color: #40a6ff;
  cursor: pointer;
  padding: 0;
  position: absolute;
  right: 0.375rem;
  top: 0.375rem;
  transition: color 0.25s;
}
.c-alert__dismiss:focus, .c-alert__dismiss:hover {
  color: #fff;
  outline: none;
}

/**
 * Success
 */
.c-alert--success {
  background-color: #2ecc40;
  border-top-color: #29b739;
  /* Dismiss */
}
.c-alert--success .c-alert__dismiss {
  color: #7ee289;
}
.c-alert--success .c-alert__dismiss:focus,
.c-alert--success .c-alert__dismiss:hover {
  color: #fff;
}

/**
 * Warning
 */
.c-alert--warning {
  background-color: #ff851b;
  border-top-color: #e76b00;
  /* Dismiss */
}
.c-alert--warning .c-alert__dismiss {
  color: #ffbc81;
}
.c-alert--warning .c-alert__dismiss:focus,
.c-alert--warning .c-alert__dismiss:hover {
  color: #fff;
}

/**
 * Error
 */
.c-alert--error {
  background-color: #ff4136;
  border-top-color: #cf0b00;
  /* Dismiss */
}
.c-alert--error .c-alert__dismiss {
  color: #ffa19c;
}
.c-alert--error .c-alert__dismiss:focus,
.c-alert--error .c-alert__dismiss:hover {
  color: #fff;
}

/* ==========================================================================
   #BADGES
   ========================================================================== */
.c-badge {
  background-color: #0074d9;
  border-radius: 0.25em;
  color: #fff;
  display: inline-block;
  font-size: 0.625rem;
  /* 10 / 16 */
  font-weight: 700;
  padding: 0.125em 0.5em;
  text-align: center;
  text-transform: uppercase;
  transition: background-color 0.25s;
}

/* Link */
.c-badge__link {
  color: #fff;
  text-decoration: none;
}

/**
 * Success
 */
.c-badge--success {
  background-color: #2ecc40;
}

/**
 * Warning
 */
.c-badge--warning {
  background-color: #ff851b;
}

/**
 * Error
 */
.c-badge--error {
  background-color: #ff4136;
}

/* ==========================================================================
   #BREADCRUMBS
   ========================================================================== */
.c-breadcrumbs {
  display: flex;
  overflow-x: auto;
}

/* Item */
.c-breadcrumbs__item {
  color: #0074d9;
  display: flex;
  flex: 0 1 auto;
  font-size: 0.875rem;
  /* 14 / 16 */
  white-space: nowrap;
}
.c-breadcrumbs__item:not(:last-child)::after {
  color: #001f3f;
  content: "/";
  flex: 0 1 auto;
  padding-left: 0.75rem;
  padding-right: 0.75rem;
}

/* Link */
.c-breadcrumbs__link {
  border-bottom: 0.0625em solid transparent;
  color: #001f3f;
  flex: 0 1 auto;
  text-decoration: none;
  transition: border-bottom-color 0.25s, color 0.25s;
}
.c-breadcrumbs__link:focus, .c-breadcrumbs__link:hover {
  border-bottom-color: #0074d9;
  color: #0074d9;
}

/* ==========================================================================
   #FORMS
   ========================================================================== */
/**
 * Inline
 */
.c-form--inline {
  display: flex;
}

/* Group */
.c-form-group {
  margin-bottom: 0.75rem;
}
.c-form-group:last-child {
  margin-bottom: 0;
}

/**
 * Checkbox or Radio Button
 */
.c-form-group--check label {
  display: block;
  font-weight: 400;
  margin-bottom: 0;
}
.c-form-group--check label + label {
  margin-top: 0.75rem;
}

/**
 * Inline
 */
.c-form-group--inline legend {
  margin-bottom: 0;
}
.c-form-group--inline label {
  display: inline-block;
}
.c-form-group--inline label:not(:last-child) {
  margin-right: 0.75rem;
}

/**
 * Flat
 */
.c-form-group--flat {
  margin-bottom: 0;
}

/* Group */
.c-form-group {
  flex: 1;
  margin-bottom: 0;
}
.c-form-group input {
  border-bottom-right-radius: 0;
  border-top-right-radius: 0;
}
.c-form-group + .c-btn {
  border-bottom-left-radius: 0;
  border-top-left-radius: 0;
}

/* Control */
.c-form-control {
  border: 0.0625em solid #cccccc;
  border-radius: 0.125em;
  box-shadow: 0 0 0.25em rgba(34, 34, 34, 0.125) inset;
  display: block;
  font-family: inherit;
  font-size: inherit;
  height: calc(1rem * 1.5 + (0.0625em * 2) + (0.375rem * 2));
  line-height: 1.5;
  padding: 0.375rem 0.75rem;
  transition: border-color 0.25s, box-shadow 0.25s;
  width: 100%;
  /**
   * Error
   */
}
.c-form-control:focus, .c-form-control:hover {
  border-color: #0074d9;
  box-shadow: 0 0 0.5em rgba(0, 169, 151, 0.25);
  outline: 0;
}
.c-form-control[disabled] {
  background-color: #f2f2f2;
  box-shadow: none;
  color: #001f3f;
}
.c-form-control[disabled]:focus, .c-form-control[disabled]:hover {
  border-color: #cccccc;
  box-shadow: none;
  cursor: not-allowed;
}
.c-form-control.is-error {
  border-color: #ff4136;
  box-shadow: 0 0 0.5em rgba(255, 65, 54, 0.25);
}

/**
 * File
 */
.c-form-control--file {
  border: 0;
  box-shadow: none;
  height: auto;
  padding: 0;
  width: auto;
  /**
   * Error
   */
}
.c-form-control--file:focus, .c-form-control--file:hover {
  box-shadow: none;
}
.c-form-control--file.is-error {
  box-shadow: none;
}

/**
 * Textarea
 */
.c-form-control--textarea {
  height: auto;
  resize: vertical;
}

/* Help */
.c-form-help {
  color: gray;
  font-size: 0.75rem;
  /* 14 / 16 */
  margin-top: 0.375rem;
  /**
   * Error
   */
}
.c-form-help.is-error {
  color: #ff4136;
}

@media all and (min-width: 48em) {
  /**
   * Inline
   */
  .c-form--inline {
    /* Group */
  }
  .c-form--inline .c-form-group {
    flex: auto;
  }
}
@media all and (min-width: 62em) {
  .c-form-group {
    margin-bottom: 1.5rem;
  }
}
/* ==========================================================================
   #BUTTONS
   ========================================================================== */
.c-btn {
  background-color: #fff;
  border: 0.0625em solid #002c59;
  border-radius: 0.25em;
  color: #001f3f;
  cursor: pointer;
  display: inline-block;
  font-family: inherit;
  font-size: inherit;
  font-weight: 700;
  line-height: 1.5;
  margin: 0;
  padding: 0.75rem 1.5rem;
  text-align: center;
  text-decoration: none;
  transition: background-color 0.25s, box-shadow 0.25s, transform 0.25s;
  vertical-align: middle;
  white-space: nowrap;
  /* Icon */
  /**
   * Disabled
   */
}
.c-btn:focus, .c-btn:hover {
  border-color: #001f3f;
  box-shadow: 0 0 1em rgba(34, 34, 34, 0.125);
  color: #001f3f;
  outline: 0;
  transform: translateY(-0.0625em);
}
.c-btn:active {
  transform: translateY(0);
}
.c-btn .c-btn__icon {
  margin-right: 0.375rem;
}
.c-btn[disabled] {
  background-color: #e6e6e6;
  border-color: #e6e6e6;
  color: gray;
  cursor: not-allowed;
}
.c-btn[disabled]:focus, .c-btn[disabled]:hover {
  background-color: #e6e6e6;
  box-shadow: none;
  transform: translateY(0);
}

/**
 * Primary
 */
.c-btn--primary {
  background-color: #0074d9;
  border-color: #0074d9;
  color: #fff;
}
.c-btn--primary:focus, .c-btn--primary:hover {
  background-color: #0082f3;
}

/**
 * Secondary
 */
.c-btn--secondary {
  background-color: #001f3f;
  border-color: #001f3f;
  color: #fff;
}
.c-btn--secondary:focus, .c-btn--secondary:hover {
  background-color: #002c59;
}

/**
 * Block
 */
.c-btn--block {
  display: block;
  width: 100%;
}

/**
 * Small
 */
.c-btn--small {
  padding: 0.375rem 0.75rem;
}

/* ==========================================================================
   #BUTTON GROUPS
   ========================================================================== */
.c-btn-group {
  display: flex;
  /* Button */
}
.c-btn-group .c-btn:not(:last-child) {
  margin-right: 0.75rem;
}

@media all and (min-width: 62em) {
  .c-btn-group {
    /* Button */
    /**
     * Small
     */
  }
  .c-btn-group .c-btn:not(:last-child) {
    margin-right: 1.5rem;
  }
  .c-btn-group .c-btn--small:not(:last-child) {
    margin-right: 0.75rem;
  }
}
/* ==========================================================================
   #PAGINATION
   ========================================================================== */
.c-pagination {
  align-items: center;
  display: flex;
  justify-content: flex-end;
  margin-top: 1.5rem;
  /* Meta */
}
.c-pagination::before, .c-pagination::after {
  content: " ";
  /* 1 */
  display: table;
  /* 2 */
}
.c-pagination::after {
  clear: both;
}
.c-pagination .c-pagination__meta {
  font-size: 0.875em;
  margin-right: 0.75rem;
  vertical-align: middle;
}

/* Control */
.c-pagination__control {
  background-color: #fff;
  border: 0.0625em solid #cccccc;
  color: #001f3f;
  line-height: 1;
  padding: 0.375rem 0.75rem;
  position: relative;
  text-decoration: none;
  transition: color 0.25s, transform 0.25s;
  /**
   * Previous
   */
  /**
   * Next
   */
  /**
   * Disabled
   */
}
.c-pagination__control::after {
  border-radius: 0.125em;
  box-shadow: 0 0 1em rgba(34, 34, 34, 0.125);
  content: "";
  height: 100%;
  left: 0;
  opacity: 0;
  position: absolute;
  top: 0;
  transition: opacity 0.25s;
  width: 100%;
  z-index: -1;
}
.c-pagination__control:focus, .c-pagination__control:hover {
  color: #0074d9;
  transform: translateY(-0.0625em);
}
.c-pagination__control:focus::after, .c-pagination__control:hover::after {
  opacity: 1;
}
.c-pagination__control.c-pagination__control--prev {
  border-bottom-left-radius: 0.125em;
  border-top-left-radius: 0.125em;
}
.c-pagination__control.c-pagination__control--next {
  border-bottom-right-radius: 0.125em;
  border-left-width: 0;
  border-top-right-radius: 0.125em;
}
.c-pagination__control:active {
  transform: translateY(0);
}
.c-pagination__control:active::after {
  opacity: 0;
}
.c-pagination__control.is-disabled {
  color: #cccccc;
}
.c-pagination__control.is-disabled:focus, .c-pagination__control.is-disabled:hover {
  color: #cccccc;
  transform: none;
}
.c-pagination__control.is-disabled:focus::after, .c-pagination__control.is-disabled:focus::after {
  opacity: 0;
}

/* #UTILITIES
   ========================================================================== */
/* stylelint-disable */
/* ==========================================================================
   #PRINT
   ========================================================================== */
/**
 * Default print styles from HTML5 Boilerplate:
 * https://github.com/h5bp/html5-boilerplate
 */
@media print {
  *,
*::before,
*::after {
    background: transparent !important;
    /* Black prints faster: http://www.sanbeiji.com/archives/953 */
    color: #000 !important;
    -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 {
    white-space: pre-wrap !important;
  }

  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;
  }

  p,
h2,
h3 {
    orphans: 3;
    widows: 3;
  }

  h2,
h3 {
    page-break-after: avoid;
  }
}
/* stylelint-disable block-opening-brace-space-before */
/* ==========================================================================
   #COLORS
   ========================================================================== */
/* #BACKGROUND
   ========================================================================== */
/* Brand */
.u-bg-color-brand-dark {
  background-color: #0066c0 !important;
}

.u-bg-color-brand {
  background-color: #0074d9 !important;
}

.u-bg-color-brand-light {
  background-color: #0082f3 !important;
}

.u-bg-color-brand-secondary-dark {
  background-color: #001226 !important;
}

.u-bg-color-brand-secondary {
  background-color: #001f3f !important;
}

.u-bg-color-brand-secondary-light {
  background-color: #002c59 !important;
}

/* Neutral */
.u-bg-color-black {
  background-color: #000 !important;
}

.u-bg-color-gray-90 {
  background-color: #1a1a1a !important;
}

.u-bg-color-gray-80 {
  background-color: #404040 !important;
}

.u-bg-color-gray-50 {
  background-color: gray !important;
}

.u-bg-color-gray-20 {
  background-color: #cccccc !important;
}

.u-bg-color-gray-10 {
  background-color: #e6e6e6 !important;
}

.u-bg-color-gray-05 {
  background-color: #f2f2f2 !important;
}

.u-bg-color-white {
  background-color: #fff !important;
}

/* Social */
.u-bg-color-facebook {
  background-color: #3b5998 !important;
}

.u-bg-color-linkedin {
  background-color: #0077b5 !important;
}

.u-bg-color-twitter {
  background-color: #1da1f2 !important;
}

.u-bg-color-youtube {
  background-color: #f00 !important;
}

/* Utility */
.u-bg-color-error {
  background-color: #ff4136 !important;
}

.u-bg-color-warning {
  background-color: #ff851b !important;
}

.u-bg-color-highlight {
  background-color: #ffdc00 !important;
}

.u-bg-color-success {
  background-color: #2ecc40 !important;
}

.u-bg-color-information {
  background-color: #0074d9 !important;
}

/* #FOREGROUND
   ========================================================================== */
/* Brand */
.u-color-brand-dark {
  background-color: #0066c0 !important;
}

.u-color-brand {
  background-color: #0074d9 !important;
}

.u-color-brand-light {
  background-color: #0082f3 !important;
}

.u-color-brand-secondary-dark {
  background-color: #001226 !important;
}

.u-color-brand-secondary {
  background-color: #001f3f !important;
}

.u-color-brand-secondary-light {
  background-color: #002c59 !important;
}

/* Neutral */
.u-color-black {
  background-color: #000 !important;
}

.u-color-gray-90 {
  background-color: #1a1a1a !important;
}

.u-color-gray-80 {
  background-color: #404040 !important;
}

.u-color-gray-50 {
  background-color: gray !important;
}

.u-color-gray-20 {
  background-color: #cccccc !important;
}

.u-color-gray-10 {
  background-color: #e6e6e6 !important;
}

.u-color-gray-05 {
  background-color: #f2f2f2 !important;
}

.u-color-white {
  background-color: #fff !important;
}

/* Social */
.u-color-facebook {
  background-color: #3b5998 !important;
}

.u-color-linkedin {
  background-color: #0077b5 !important;
}

.u-color-twitter {
  background-color: #1da1f2 !important;
}

.u-color-youtube {
  background-color: #f00 !important;
}

/* Utility */
.u-color-error {
  background-color: #ff4136 !important;
}

.u-color-warning {
  background-color: #ff851b !important;
}

.u-color-highlight {
  background-color: #ffdc00 !important;
}

.u-color-success {
  background-color: #2ecc40 !important;
}

.u-color-information {
  background-color: #0074d9 !important;
}

/* ==========================================================================
   #CLEARFIX
   ========================================================================== */
/* Attach the clearfix mixin to a utility class. */
.u-clearfix::before, .u-clearfix::after {
  content: " ";
  /* 1 */
  display: table;
  /* 2 */
}
.u-clearfix::after {
  clear: both;
}

/* -------------------------------------------------------------------------- *\
   #FLOATS
\* -------------------------------------------------------------------------- */
.u-float-left {
  float: left !important;
  margin-right: 1em;
}

.u-float-right {
  float: right !important;
  margin-left: 1em;
}

/* ==========================================================================
   #HEADINGS
   ========================================================================== */
/**
 * Define classes for all headings so that the appearance can change, but the
 * semantic meaning will remain as is. e.g.
 *
 * <h2 class="u-h1"></h2>
 *
 */
.u-h1 {
  font-size: 2rem;
  line-height: 1.5 !important;
}

.u-h2 {
  font-size: 1.75rem;
  line-height: 1.7142857143 !important;
}

.u-h3 {
  font-size: 1.5rem;
  line-height: 1 !important;
}

.u-h4 {
  font-size: 1.25rem;
  line-height: 1.2 !important;
}

.u-h5 {
  font-size: 1.125rem;
  line-height: 1.3333333333 !important;
}

.u-h6 {
  font-size: 1rem;
  line-height: 1.5 !important;
}

/* stylelint-disable block-opening-brace-space-before */
/* ==========================================================================
   #SPACING
   ========================================================================== */
/* Margins */
.u-margin-large {
  margin: 2.25rem !important;
}

.u-margin {
  margin: 1.5rem !important;
}

.u-margin-small {
  margin: 0.75rem !important;
}

.u-margin-bottom-large {
  margin-bottom: 2.25rem !important;
}

.u-margin-bottom {
  margin-bottom: 1.5rem !important;
}

.u-margin-bottom-small {
  margin-bottom: 0.75rem !important;
}

.u-margin-left-large {
  margin-left: 2.25rem !important;
}

.u-margin-left {
  margin-left: 1.5rem !important;
}

.u-margin-left-small {
  margin-left: 0.75rem !important;
}

.u-margin-right-large {
  margin-right: 2.25rem !important;
}

.u-margin-right {
  margin-right: 1.5rem !important;
}

.u-margin-right-small {
  margin-right: 0.75rem !important;
}

.u-margin-top-large {
  margin-top: 2.25rem !important;
}

.u-margin-top {
  margin-top: 1.5rem !important;
}

.u-margin-top-small {
  margin-top: 0.75rem !important;
}

/* Padding */
.u-padding-large {
  padding: 2.25rem !important;
}

.u-padding {
  padding: 1.5rem !important;
}

.u-padding-small {
  padding: 0.75rem !important;
}

.u-padding-bottom-large {
  padding-bottom: 2.25rem !important;
}

.u-padding-bottom {
  padding-bottom: 1.5rem !important;
}

.u-padding-bottom-small {
  padding-bottom: 0.75rem !important;
}

.u-padding-left-large {
  padding-left: 2.25rem !important;
}

.u-padding-left {
  padding-left: 1.5rem !important;
}

.u-padding-left-small {
  padding-left: 0.75rem !important;
}

.u-padding-right-large {
  padding-right: 2.25rem !important;
}

.u-padding-right {
  padding-right: 1.5rem !important;
}

.u-padding-right-small {
  padding-right: 0.75rem !important;
}

.u-padding-top-large {
  padding-top: 2.25rem !important;
}

.u-padding-top {
  padding-top: 1.5rem !important;
}

.u-padding-top-small {
  padding-top: 0.75rem !important;
}

/* ==========================================================================
   #TEXT
   ========================================================================== */
.u-text-capitalize {
  text-transform: capitalize;
}

/* ==========================================================================
   #VISIBILITY
   ========================================================================== */
/**
 * Visibility helper classes from HTML5 Boilerplate:
 * https://github.com/h5bp/html5-boilerplate
 */
/**
 * Hide visually and from screen readers
 */
.u-hidden {
  display: none !important;
}

/**
 * Hide only visually, but have it available for screen readers:
 * https://snook.ca/archives/html_and_css/hiding-content-for-accessibility
 *
 * 1. For long content, line feeds are not interpreted as spaces and small width
 *    causes content to wrap 1 word per line:
 *    https://medium.com/@jessebeach/beware-smushed-off-screen-accessible-text-5952a4c2cbfe
 */
.u-visuallyhidden {
  border: 0;
  clip: rect(0 0 0 0);
  clip-path: inset(50%);
  height: 1px;
  margin: -1px;
  overflow: hidden;
  padding: 0;
  position: absolute;
  white-space: nowrap;
  /* 1 */
  width: 1px;
  /*
   * Extends the .visuallyhidden class to allow the element
   * to be focusable when navigated to via the keyboard:
   * https://www.drupal.org/node/897638
   */
}
.u-visuallyhidden.focusable .u-visuallyhidden:active, .u-visuallyhidden.focusable .u-visuallyhidden:focus {
  clip: auto;
  clip-path: none;
  height: auto;
  margin: 0;
  overflow: visible;
  position: static;
  white-space: inherit;
  width: auto;
}

/**
 * Hide visually and from screen readers, but maintain layout
 */
.u-invisible {
  visibility: hidden;
}

/* stylelint-disable */
/* ==========================================================================
   #WIDTHS
   ========================================================================== */
/* 1/1 */
.u-1\/1 {
  width: 100%;
}

/* 2/3 */
.u-2\/3 {
  width: 66.66%;
}

/* 1/2 */
.u-1\/2 {
  width: 50%;
}

/* 1/3 */
.u-1\/3 {
  width: 33.33%;
}

/* 1/4 */
.u-1\/4 {
  width: 25%;
}

@media all and (min-width: 36em) {
  .u-3\/4\@sm {
    width: 75%;
  }

  .u-2\/3\@sm {
    width: 66.66%;
  }

  .u-1\/2\@sm {
    width: 50%;
  }

  .u-1\/3\@sm {
    width: 33.33%;
  }

  .u-1\/4\@sm {
    width: 25%;
  }
}
@media all and (min-width: 48em) {
  .u-3\/4\@md {
    width: 75%;
  }

  .u-2\/3\@md {
    width: 66.66%;
  }

  .u-1\/2\@md {
    width: 50%;
  }

  .u-1\/3\@md {
    width: 33.33%;
  }

  .u-1\/4\@md {
    width: 25%;
  }
}
@media all and (min-width: 62em) {
  .u-3\/4\@lg {
    width: 75%;
  }

  .u-2\/3\@lg {
    width: 66.66%;
  }

  .u-1\/2\@lg {
    width: 50%;
  }

  .u-1\/3\@lg {
    width: 33.33%;
  }

  .u-1\/4\@lg {
    width: 25%;
  }
}
@media all and (min-width: 75em) {
  .u-3\/4\@xl {
    width: 75%;
  }

  .u-2\/3\@xl {
    width: 66.66%;
  }

  .u-1\/2\@xl {
    width: 50%;
  }

  .u-1\/3\@xl {
    width: 33.33%;
  }

  .u-1\/4\@xl {
    width: 25%;
  }
}