@charset "UTF-8";
/*! sanitize.css v5.0.0 | CC0 License | github.com/jonathantneal/sanitize.css */
/* Document (https://html.spec.whatwg.org/multipage/semantics.html#semantics)
   ========================================================================== */
/**
 * 1. Remove repeating backgrounds in all browsers (opinionated).
 * 2. Add box sizing inheritence in all browsers (opinionated).
 */
*,
::before,
::after {
  background-repeat: no-repeat;
  /* 1 */
  box-sizing: inherit;
  /* 2 */ }

/**
 * 1. Add text decoration inheritance in all browsers (opinionated).
 * 2. Add vertical alignment inheritence in all browsers (opinionated).
 */
::before,
::after {
  text-decoration: inherit;
  /* 1 */
  vertical-align: inherit;
  /* 2 */ }

/**
 * 1. Add border box sizing in all browsers (opinionated).
 * 2. Add the default cursor in all browsers (opinionated).
 * 3. Prevent font size adjustments after orientation changes in IE and iOS.
 */
html {
  box-sizing: border-box;
  /* 1 */
  cursor: default;
  /* 2 */
  -ms-text-size-adjust: 100%;
  /* 3 */
  -webkit-text-size-adjust: 100%;
  /* 3 */ }

/* Sections (https://html.spec.whatwg.org/multipage/semantics.html#sections)
   ========================================================================== */
/**
 * Add the correct display in IE 9-.
 */
article,
aside,
footer,
header,
nav,
section {
  display: block; }

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

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

/* Grouping content (https://html.spec.whatwg.org/multipage/semantics.html#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 0; }

/**
 * 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 */ }

/**
 * Remove the list style on navigation lists in all browsers (opinionated).
 */
nav ol,
nav ul {
  list-style: none; }

/**
 * 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 (https://html.spec.whatwg.org/multipage/semantics.html#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 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: #ffff00;
  color: #000000; }

/**
 * 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: -.25em; }

sup {
  top: -.5em; }

/*
 * Remove the text shadow on text selections (opinionated).
 * 1. Restore the coloring undone by defining the text shadow (opinionated).
 */
::-moz-selection {
  background-color: #b3d4fc;
  /* 1 */
  color: #000000;
  /* 1 */
  text-shadow: none; }

::selection {
  background-color: #b3d4fc;
  /* 1 */
  color: #000000;
  /* 1 */
  text-shadow: none; }

/* Embedded content (https://html.spec.whatwg.org/multipage/embedded-content.html#embedded-content)
   ========================================================================== */
/*
 * Change the alignment on media elements in all browers (opinionated).
 */
audio,
canvas,
iframe,
img,
svg,
video {
  vertical-align: middle; }

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

/**
 * Change the fill color to match the text color in all browsers (opinionated).
 */
svg {
  fill: currentColor; }

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

/* Tabular data (https://html.spec.whatwg.org/multipage/tables.html#tables)
   ========================================================================== */
/**
 * Collapse border spacing
 */
table {
  border-collapse: collapse; }

/* Forms (https://html.spec.whatwg.org/multipage/forms.html#forms)
   ========================================================================== */
/**
 * Remove the margin in Firefox and Safari.
 */
button,
input,
optgroup,
select,
textarea {
  margin: 0; }

/**
 * Inherit styling in all browsers (opinionated).
 */
button,
input,
select,
textarea {
  background-color: transparent;
  color: inherit;
  font-size: inherit;
  line-height: inherit; }

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

/**
 * 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 */ }

/**
 * 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 */ }

/**
 * 1. Remove the default vertical scrollbar in IE.
 * 2. Change the resize direction on textareas in all browsers (opinionated).
 */
textarea {
  overflow: auto;
  /* 1 */
  resize: vertical;
  /* 2 */ }

/**
 * 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 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 elements (https://html.spec.whatwg.org/multipage/forms.html#interactive-elements)
   ========================================================================== */
/*
 * 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 (https://html.spec.whatwg.org/multipage/scripting.html#scripting-3)
   ========================================================================== */
/**
 * Add the correct display in IE 9-.
 */
canvas {
  display: inline-block; }

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

/* User interaction (https://html.spec.whatwg.org/multipage/interaction.html#editing)
   ========================================================================== */
/*
 * Remove the tapping delay on clickable elements (opinionated).
 * 1. Remove the tapping delay in IE 10.
 */
a,
area,
button,
input,
label,
select,
summary,
textarea,
[tabindex] {
  -ms-touch-action: manipulation;
  /* 1 */
  touch-action: manipulation; }

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

/* ARIA (https://w3c.github.io/html-aria/)
   ========================================================================== */
/**
 * Change the cursor on busy elements (opinionated).
 */
[aria-busy="true"] {
  cursor: progress; }

/*
 * Change the cursor on control elements (opinionated).
 */
[aria-controls] {
  cursor: pointer; }

/*
 * Change the display on visually hidden accessible elements (opinionated).
 */
[aria-hidden="false"][hidden]:not(:focus) {
  clip: rect(0, 0, 0, 0);
  display: inherit;
  position: absolute; }

/*
 * Change the cursor on disabled, not-editable, or otherwise
 * inoperable elements (opinionated).
 */
[aria-disabled] {
  cursor: default; }

.footnote-container {
  display: inline-block;
  position: relative; }

.footnote-backdrop {
  cursor: pointer; }

.footnote-button {
  background: rgba(110, 110, 110, 0.2);
  border: 0;
  border-radius: .475em;
  cursor: pointer;
  display: inline-block;
  font-size: 1rem;
  height: .95em;
  line-height: 0;
  margin: 0 .1em 0 .2em;
  padding: .35em;
  position: relative;
  top: -.2em;
  transition-duration: .25s;
  transition-property: background;
  vertical-align: super;
  width: 1.5em;
  z-index: 3; }
  .footnote-button:after {
    color: rgba(110, 110, 110, 0.5);
    content: attr(data-fn-number);
    display: block;
    font-size: .57em;
    font-weight: bold;
    left: 50%;
    position: absolute;
    top: 50%;
    transform: translate(-50%, -50%);
    transition: color .25s ease; }
  .footnote-button:hover {
    background: rgba(110, 110, 110, 0.5);
    outline: none; }
    .footnote-button:hover:after {
      color: #fafafa; }
  .footnote-button.is-active {
    background: #6e6e6e;
    transition-delay: .1s; }
    .footnote-button.is-active:after {
      color: #fafafa; }

.bf-footnote {
  background: #292929;
  border: 1px solid #303030;
  border-radius: .25em;
  left: 0;
  margin: 1.618em 0;
  max-width: 90vw;
  position: absolute;
  top: 0;
  z-index: 5;
  transform-origin: 50% 0%;
  transform: scale(0.9);
  opacity: 0;
  visibility: hidden;
  transition: transform 250ms ease, opacity 250ms ease; }
  .bf-footnote.footnote-is-active {
    visibility: visible;
    opacity: 1;
    transform: scale(1); }
  .bf-footnote.footnote-is-top {
    bottom: 0;
    top: auto; }

.footnote-wrapper {
  display: flex;
  background: inherit;
  border-radius: .25em;
  overflow: hidden;
  position: relative;
  min-width: 19rem;
  max-width: 22rem;
  z-index: 14; }

.footnote-tooltip {
  background: #292929;
  border: 1px solid #303030;
  height: 1.3em;
  position: absolute;
  top: -.39em;
  margin-left: -1px;
  transform: rotate(45deg);
  width: 1.3em;
  z-index: 12; }
  .footnote-is-top .footnote-tooltip {
    bottom: -.49em;
    top: auto; }

.footnote-content {
  position: relative;
  z-index: 8;
  padding: 0.6rem 1.0rem;
  max-height: 15em;
  font-size: 0.9325rem;
  overflow: auto;
  -webkit-overflow-scrolling: touch;
  background: #292929;
  color: #f7f7f7; }
  .footnote-content *:first-child {
    margin-top: 0;
    padding-top: 0; }
  .footnote-content *:last-child {
    margin-bottom: 0;
    padding-bottom: 0; }
  .footnote-content:focus {
    outline: none;
    border: 0; }

.highlight table td {
  padding: 5px; }

.highlight table pre {
  margin: 0; }

.highlight .cm {
  color: #999988;
  font-style: italic; }

.highlight .cp {
  color: #999999;
  font-weight: bold; }

.highlight .c1 {
  color: #999988;
  font-style: italic; }

.highlight .cs {
  color: #999999;
  font-weight: bold;
  font-style: italic; }

.highlight .c, .highlight .cd {
  color: #999988;
  font-style: italic; }

.highlight .err {
  color: #a61717;
  background-color: #e3d2d2; }

.highlight .gd {
  color: #000000;
  background-color: #ffdddd; }

.highlight .ge {
  color: #000000;
  font-style: italic; }

.highlight .gr {
  color: #aa0000; }

.highlight .gh {
  color: #999999; }

.highlight .gi {
  color: #000000;
  background-color: #ddffdd; }

.highlight .go {
  color: #888888; }

.highlight .gp {
  color: #555555; }

.highlight .gs {
  font-weight: bold; }

.highlight .gu {
  color: #aaaaaa; }

.highlight .gt {
  color: #aa0000; }

.highlight .kc {
  color: #000000;
  font-weight: bold; }

.highlight .kd {
  color: #000000;
  font-weight: bold; }

.highlight .kn {
  color: #000000;
  font-weight: bold; }

.highlight .kp {
  color: #000000;
  font-weight: bold; }

.highlight .kr {
  color: #000000;
  font-weight: bold; }

.highlight .kt {
  color: #445588;
  font-weight: bold; }

.highlight .k, .highlight .kv {
  color: #000000;
  font-weight: bold; }

.highlight .mf {
  color: #009999; }

.highlight .mh {
  color: #009999; }

.highlight .il {
  color: #009999; }

.highlight .mi {
  color: #009999; }

.highlight .mo {
  color: #009999; }

.highlight .m, .highlight .mb, .highlight .mx {
  color: #009999; }

.highlight .sb {
  color: #d14; }

.highlight .sc {
  color: #d14; }

.highlight .sd {
  color: #d14; }

.highlight .s2 {
  color: #d14; }

.highlight .se {
  color: #d14; }

.highlight .sh {
  color: #d14; }

.highlight .si {
  color: #d14; }

.highlight .sx {
  color: #d14; }

.highlight .sr {
  color: #009926; }

.highlight .s1 {
  color: #d14; }

.highlight .ss {
  color: #990073; }

.highlight .s {
  color: #d14; }

.highlight .na {
  color: #008080; }

.highlight .bp {
  color: #999999; }

.highlight .nb {
  color: #0086B3; }

.highlight .nc {
  color: #445588;
  font-weight: bold; }

.highlight .no {
  color: #008080; }

.highlight .nd {
  color: #3c5d5d;
  font-weight: bold; }

.highlight .ni {
  color: #800080; }

.highlight .ne {
  color: #990000;
  font-weight: bold; }

.highlight .nf {
  color: #990000;
  font-weight: bold; }

.highlight .nl {
  color: #990000;
  font-weight: bold; }

.highlight .nn {
  color: #555555; }

.highlight .nt {
  color: #000080; }

.highlight .vc {
  color: #008080; }

.highlight .vg {
  color: #008080; }

.highlight .vi {
  color: #008080; }

.highlight .nv {
  color: #008080; }

.highlight .ow {
  color: #000000;
  font-weight: bold; }

.highlight .o {
  color: #000000;
  font-weight: bold; }

.highlight .w {
  color: #bbbbbb; }

.highlight {
  background-color: #fafafa; }

.highlighter-rouge > .highlight {
  line-height: 1.6;
  background: none; }
  .highlighter-rouge > .highlight > .highlight {
    border: 1px solid rgba(128, 128, 128, 0.1);
    border-radius: 4px; }

.rouge-table {
  width: 100%;
  font-size: 1.0rem; }

.rouge-gutter {
  font-size: 0.875em;
  line-height: 1.8;
  color: #999999;
  border-radius: 4px 0 0 4px; }
  .rouge-gutter.gl {
    text-align: right;
    border-right: 1px solid rgba(128, 128, 128, 0.1);
    width: 1rem;
    padding: 8px 9px !important; }

.rouge-code {
  padding: 5px 9px !important;
  font-weight: 400; }

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

img {
  max-width: 100%; }

input[type=text],
input[type=email] {
  background: none;
  border: 0;
  font-size: 1rem; }

table {
  width: 100%;
  border-spacing: 0;
  border-collapse: collapse;
  font-size: 1rem; }
  table th {
    font-weight: 600;
    text-align: left;
    border: 1px solid #e9ebed; }
  table th,
  table td {
    border: 1px solid #e8eaed;
    padding: 0.3rem 0.7rem; }
  table tr {
    background-color: #fff;
    border-top: 1px solid #e8eaed; }
    table tr:nth-child(odd) td {
      background: rgba(128, 128, 128, 0.05); }

code {
  padding: 0.2rem 0.4rem;
  margin: 0 2px;
  font-size: 0.8125em;
  font-family: Menlo, Monaco, Lucida Console, Liberation Mono, DejaVu Sans Mono, Bitstream Vera Sans Mono, monospace;
  background: #ededed;
  border: 1px solid rgba(128, 128, 128, 0.12);
  color: #4d4d4d;
  border-radius: 3px; }

blockquote {
  padding: 0 0.5rem;
  margin: 1.5rem 0;
  max-width: 720px; }
  @media (min-width: 668px) {
    blockquote {
      margin: 1.8rem 0; } }
  blockquote > p {
    max-width: 100% !important;
    padding: 1rem;
    margin: 1rem 0;
    position: relative;
    font-family: Georgia, serif;
    font-size: 1rem;
    font-weight: 400;
    line-height: 1.7; }
  blockquote cite {
    display: block;
    margin-top: 0.7rem;
    text-align: right;
    font-size: 0.9em;
    font-style: normal;
    opacity: 0.9; }
    blockquote cite:before {
      content: "— "; }

body.is-black blockquote {
  background: #262626; }
body.is-black input[type=text],
body.is-black input[type=email] {
  background: #1c1c1c;
  border-color: #242424; }
  body.is-black input[type=text]:hover, body.is-black input[type=text]:focus,
  body.is-black input[type=email]:hover,
  body.is-black input[type=email]:focus {
    background: #242424; }

ul,
ol {
  margin: 1.2rem 0; }
  ul li,
  ol li {
    margin: 0.4rem 0; }

h1 {
  font-size: 1.5rem; }

hr {
  display: block;
  margin: 0 auto;
  padding: 1rem 0;
  width: 100%;
  max-width: 720px;
  height: auto;
  border: 0;
  opacity: 0.45; }
  hr:after {
    display: block;
    content: "*";
    position: relative;
    width: 100%;
    max-width: 1040px;
    margin: auto 1rem;
    text-align: center; }

figure figcaption {
  display: block;
  margin: 0.6rem 1rem;
  font-size: 0.8125rem;
  color: rgba(51, 51, 51, 0.8); }

body.is-black figure figcaption {
  color: rgba(204, 204, 204, 0.8); }

@media (min-width: 640px) {
  .global {
    padding-top: 1.4rem; } }

html,
body {
  font-family: Inter, -apple-system, sans-serif;
  line-height: 1.6;
  text-rendering: optimizeLegibility;
  background: #f7f7f7;
  color: #03080d; }

html,
body,
.global {
  flex: 1;
  display: flex;
  flex-direction: column;
  min-height: 100%; }

body.is-black {
  background: #1c1c1c;
  color: #e8e8e8; }

a {
  color: #2055f3;
  text-decoration: none;
  padding-top: 2px;
  padding-bottom: 2px;
  border-bottom: 1px solid rgba(128, 128, 128, 0.4); }

.itinerary-wrapper {
  margin: 0 1rem 5rem; }

.itinerary-list {
  margin: 1rem 0; }
  @media (min-width: 620px) {
    .itinerary-list {
      column-count: 2;
      column-gap: 4%; } }
  @media (min-width: 940px) {
    .itinerary-list {
      column-count: 3;
      column-gap: 8%; } }
  .itinerary-list h4 {
    margin: 0 0 0.4rem;
    font-size: 14px;
    font-weight: 600;
    text-transform: uppercase; }
  .itinerary-list > div {
    margin-bottom: 1.5rem; }
    .itinerary-list > div p {
      margin: 0.4rem 0;
      color: #616161; }

.intro-copy {
  font-size: 1rem;
  font-weight: 500;
  max-width: 560px;
  font-weight: 400;
  line-height: 1.8;
  align-self: flex-start;
  margin: 0; }

.intro-copy-portrait {
  min-width: 128px;
  min-height: 128px;
  max-width: 128px;
  max-height: 128px;
  border-radius: 50%;
  display: block;
  margin-bottom: 1.2rem;
  align-self: flex-start; }

.home {
  flex: 1;
  width: 100%;
  max-width: 1040px;
  margin: 0 auto; }

.home-blocks {
  margin: 0 auto;
  padding: 0 1rem; }
  @media (min-width: 800px) {
    .home-blocks {
      display: flex; } }
  .home-blocks > div {
    margin: 2rem 0;
    width: 100%;
    max-width: 840px; }
    @media (min-width: 800px) {
      .home-blocks > div {
        margin-top: 0; } }

.links-list {
  margin: 1rem 0; }
  .links-list .subscribe {
    margin-top: 1rem; }

.links-list-title {
  display: flex;
  align-items: center;
  font-size: 0.875rem;
  font-weight: 500; }

.links-list-title-xevol {
  margin: 0 0.4rem; }

.links-list-view-more {
  margin-top: 0.1rem;
  margin-left: 0.7rem;
  font-size: 0.875em;
  font-weight: 500; }

.latest-list {
  margin: 1rem 1rem;
  list-style: circle;
  list-style-position: outside;
  padding: 0; }

.latest-list li {
  margin: 0 0 0.8rem;
  width: 100%;
  color: #616161;
  font-size: 0.9325rem; }

a.latest-list-item {
  position: relative;
  cursor: pointer;
  color: #2055f3;
  border: 0;
  font-size: 1rem; }
  a.latest-list-item:hover {
    opacity: 0.7; }

.bullet-list {
  margin: 1rem 1rem 1rem 2rem;
  list-style: circle;
  list-style-position: outside;
  padding: 0; }

.bullet-list li {
  margin: 0.1rem 0 0.5rem;
  width: 100%; }

a.bullet-list-item {
  position: relative;
  cursor: pointer;
  font-size: 0.935rem; }
  a.bullet-list-item:hover {
    opacity: 0.7; }

.tags-wrapper {
  margin: 0 1rem 1rem; }

.tags-list {
  padding: 0;
  margin-bottom: 1rem; }
  @media (min-width: 620px) {
    .tags-list {
      column-count: 2;
      column-gap: 4%; } }
  @media (min-width: 940px) {
    .tags-list {
      column-count: 3;
      column-gap: 8%; } }

.tags-list-item {
  display: inline-block;
  width: 100%;
  break-inside: avoid;
  margin-bottom: 1.2rem; }

.tag-title {
  margin: 0 0 0.4rem;
  font-size: 12px;
  font-weight: 600;
  text-transform: uppercase; }

.tag-list {
  margin: 0 0;
  list-style: none;
  list-style-position: outside;
  padding: 0; }

.tag-list li {
  margin: 0 0 0.6rem;
  width: 100%;
  color: #616161; }

a.tag-list-item {
  position: relative;
  cursor: pointer;
  font-size: 1rem;
  border: 0;
  color: #2055f3; }
  a.tag-list-item:hover {
    opacity: 0.7; }

.about-wrapper {
  margin: 0 1rem 1rem; }

.about-list {
  padding: 0;
  margin-bottom: 1rem; }
  @media (min-width: 620px) {
    .about-list {
      column-count: 1;
      column-gap: 4%; } }

.abouts-list-item {
  display: inline-block;
  width: 100%;
  break-inside: avoid;
  margin-bottom: 1.5rem; }

.about-title {
  margin: 0 0 0.4rem;
  font-size: 12px;
  font-weight: 600;
  text-transform: uppercase; }

.about-list {
  margin: 0 0;
  list-style: none;
  list-style-position: outside;
  padding: 0; }

.about-list li {
  margin: 0 0 0.6rem;
  width: 100%;
  color: #616161; }

a.about-list-item {
  position: relative;
  cursor: pointer;
  font-size: 1rem;
  border: 0;
  color: #2055f3; }
  a.about-list-item:hover {
    opacity: 0.7; }

.subscribe {
  margin: 1.5rem 0;
  padding: 1.5rem 0;
  max-width: 720px; }
  .subscribe p {
    margin-top: 0;
    margin-bottom: 0.8rem;
    font-size: 1.2rem;
    font-weight: 500; }
    @media (min-width: 640px) {
      .subscribe p {
        font-size: 1.2rem; } }

.subscribe-page {
  position: relative;
  display: flex;
  flex-direction: column;
  margin: 0 auto;
  padding: 0 0;
  max-width: 840px; }
  .subscribe-page p {
    margin-top: 0;
    margin-bottom: 0.8rem;
    font-size: 1.2rem; }
  @media (min-width: 668px) {
    .subscribe-page {
      flex-direction: column-reverse;
      padding-right: 360px; } }

.subscribe-form-wrapper {
  padding: 0 1rem; }
  @media (min-width: 668px) {
    .subscribe-form-wrapper {
      position: absolute;
      top: 0.3rem;
      right: 0; } }

.subscribe-form {
  align-self: flex-start;
  display: flex;
  width: 100%;
  margin: 0.5rem 0 2.8rem 0;
  padding: 1.2rem;
  border: 1px solid rgba(128, 128, 128, 0.1);
  border-radius: 5px;
  background: rgba(128, 128, 128, 0.08);
  flex-direction: column;
  line-height: 1.5; }
  .subscribe-form h3 {
    font-size: 0.9325rem;
    margin: 0.5rem 0; }
  @media (min-width: 668px) {
    .subscribe-form {
      max-width: 400px; } }
  .subscribe-form input {
    margin: 0.3rem 0 0.5rem;
    border: 1px solid #dde3ee; }
  .subscribe-form input[type=text] {
    padding: 0.4rem 0.8rem;
    background: white;
    font-size: 1rem;
    transition: all 100ms ease; }
    .subscribe-form input[type=text]:hover {
      background: #fcfcfd; }
    .subscribe-form input[type=text]:focus {
      outline: none;
      background: #fcfcfd;
      box-shadow: inset 0 0 0px 1px #3d3d43; }
  .subscribe-form input[type=email] {
    padding: 0.4rem 0.8rem;
    background: white;
    font-size: 1rem;
    transition: all 100ms ease; }
    .subscribe-form input[type=email]:hover {
      background: #fcfcfd; }
    .subscribe-form input[type=email]:focus {
      outline: none;
      background: #fcfcfd;
      box-shadow: inset 0 0 0px 1px #3d3d43; }
  .subscribe-form input[type=submit] {
    display: flex;
    justify-content: center;
    width: 9rem;
    margin-top: 0.6rem;
    padding: 0.4rem 0.6rem;
    font-size: 1rem;
    font-weight: 400;
    border: 0;
    box-shadow: none;
    border-radius: 6px;
    background: #3d3d43;
    color: white;
    cursor: pointer;
    transition: all 100ms ease; }
    .subscribe-form input[type=submit]:hover {
      background: #517af6; }
    .subscribe-form input[type=submit][disabled] {
      background: #a7afbe;
      cursor: default; }
      .subscribe-form input[type=submit][disabled]:hover {
        background: #a7afbe; }

.subscribe-form > .subscribe-form-about {
  margin: 0.3rem 0.4rem 0.6rem;
  padding: 0;
  font-size: 1rem;
  font-weight: 400; }

.subscribe-form-no-spam,
.subscribe-form > .subscribe-form-no-spam {
  margin: 0.4rem 0;
  padding: 0;
  font-size: 0.9325rem;
  font-weight: 400;
  opacity: 0.6; }

.standalone-subscribe-form-wrapper {
  width: 100%;
  margin: 0 auto; }

.standalone-subscribe-form {
  width: 100%;
  display: flex;
  width: 100%;
  max-width: 420px;
  padding: 0 0;
  margin: 0 1rem;
  flex-direction: column;
  line-height: 1.5; }
  .standalone-subscribe-form h3 {
    font-size: 1.3rem;
    font-weight: 500;
    padding: 0; }
  .standalone-subscribe-form input {
    max-width: 370px;
    margin: 0.3rem 0 0.5rem;
    border: 1px solid #dde3ee; }
  .standalone-subscribe-form input[type=text] {
    padding: 0.4rem 0.8rem;
    background: white;
    font-size: 1.1rem;
    transition: all 100ms ease; }
    .standalone-subscribe-form input[type=text]:hover {
      background: #fcfcfd; }
    .standalone-subscribe-form input[type=text]:focus {
      outline: none;
      background: #fcfcfd;
      box-shadow: inset 0 0 0px 1px #3d3d43; }
  .standalone-subscribe-form input[type=email] {
    padding: 0.4rem 0.8rem;
    background: white;
    font-size: 1.1rem;
    transition: all 100ms ease; }
    .standalone-subscribe-form input[type=email]:hover {
      background: #fcfcfd; }
    .standalone-subscribe-form input[type=email]:focus {
      outline: none;
      background: #fcfcfd;
      box-shadow: inset 0 0 0px 1px #3d3d43; }
  .standalone-subscribe-form input[type=submit] {
    display: flex;
    justify-content: center;
    width: 9rem;
    margin-top: 0.6rem;
    padding: 0.4rem 0.6rem;
    font-size: 1rem;
    font-weight: 400;
    border: 0;
    box-shadow: none;
    border-radius: 6px;
    background: #3d3d43;
    color: white;
    cursor: pointer;
    transition: all 100ms ease; }
    .standalone-subscribe-form input[type=submit]:hover {
      background: #517af6; }
    .standalone-subscribe-form input[type=submit][disabled] {
      background: #a7afbe;
      cursor: default; }
      .standalone-subscribe-form input[type=submit][disabled]:hover {
        background: #a7afbe; }

.standalone-subscribe-post {
  width: 100%;
  max-width: 720px;
  display: flex;
  width: 100%;
  margin: 0 auto;
  padding: 0 1rem;
  flex-direction: column;
  line-height: 1.5; }
  .standalone-subscribe-post p {
    padding: 0; }
  .standalone-subscribe-post input {
    max-width: 370px;
    margin: 0.3rem 0 0.5rem;
    border: 1px solid #dde3ee; }
  .standalone-subscribe-post input[type=text] {
    padding: 0.4rem 0.8rem;
    background: white;
    font-size: 1.1rem;
    transition: all 100ms ease; }
    .standalone-subscribe-post input[type=text]:hover {
      background: #fcfcfd; }
    .standalone-subscribe-post input[type=text]:focus {
      outline: none;
      background: #fcfcfd;
      box-shadow: inset 0 0 0px 1px #3d3d43; }
  .standalone-subscribe-post input[type=email] {
    padding: 0.4rem 0.8rem;
    background: white;
    font-size: 1.1rem;
    transition: all 100ms ease; }
    .standalone-subscribe-post input[type=email]:hover {
      background: #fcfcfd; }
    .standalone-subscribe-post input[type=email]:focus {
      outline: none;
      background: #fcfcfd;
      box-shadow: inset 0 0 0px 1px #3d3d43; }
  .standalone-subscribe-post input[type=submit] {
    display: flex;
    justify-content: center;
    width: 9rem;
    margin-top: 0.6rem;
    padding: 0.4rem 0.6rem;
    font-size: 1rem;
    font-weight: 400;
    border: 0;
    box-shadow: none;
    border-radius: 6px;
    background: #3d3d43;
    color: white;
    cursor: pointer;
    transition: all 100ms ease; }
    .standalone-subscribe-post input[type=submit]:hover {
      background: #517af6; }
    .standalone-subscribe-post input[type=submit][disabled] {
      background: #a7afbe;
      cursor: default; }
      .standalone-subscribe-post input[type=submit][disabled]:hover {
        background: #a7afbe; }

.menu-wrapper {
  background: rgba(237, 237, 237, 0.97); }

.menu {
  width: 100%;
  max-width: 1040px;
  padding: 1rem 1rem 0.6rem;
  margin: 0 auto 0;
  display: flex;
  flex-direction: row;
  align-items: center;
  justify-content: space-between; }

.menu-link {
  padding: 0.2rem 0;
  margin: 0 0.3rem;
  font-size: 0.875rem;
  font-weight: 400;
  color: #10324c;
  text-decoration: none; }
  @media (min-width: 668px) {
    .menu-link {
      font-size: 0.9325rem; } }
  .menu-link:hover, .menu-link.active {
    color: #3d3d43; }
  @media (min-width: 668px) {
    .menu-link.cta-mobile {
      display: none; } }
  .menu-link.cta {
    display: flex;
    align-items: center;
    font-weight: 500;
    line-height: 1.2;
    text-align: center;
    color: white;
    background: rgba(235, 240, 255, 0.2);
    background: #2055f3;
    cursor: pointer;
    border: none;
    flex-shrink: 0;
    font-weight: 500;
    font-size: 0.9325rem;
    transition: all 0.1s;
    text-shadow: 0px 3px 8px rgba(0, 0, 0, 0.15);
    border-radius: 4px;
    padding: 0.2rem 0.4rem;
    margin: 0 0 0 0.7rem; }
    @media (min-width: 668px) {
      .menu-link.cta {
        display: block; } }
    @media (min-width: 1280px) {
      .menu-link.cta {
        right: -0.3rem; } }
    .menu-link.cta:hover {
      background: linear-gradient(102deg, #517af6 10%, #456afc 32%, #5072fb 66%); }
      .menu-link.cta:hover span {
        background: rgba(3, 145, 29, 0.85);
        color: white; }
    .menu-link.cta span {
      padding: 0px 4px;
      font-size: 0.875em;
      font-weight: 400;
      line-height: 1.4;
      color: #03911d;
      border: 1px solid rgba(3, 145, 29, 0.8);
      border-radius: 4px; }
      @media (min-width: 668px) {
        .menu-link.cta span {
          display: block;
          margin-top: 0.3rem; } }
  .menu-link.button {
    padding: 0.2rem 0.6rem;
    background: #3d3d43;
    color: white;
    border-radius: 4px;
    font-weight: 400; }
    .menu-link.button:hover {
      color: rgba(255, 255, 255, 0.8); }

body.is-black .menu-wrapper {
  background: rgba(23, 23, 23, 0.98); }
body.is-black .menu-link {
  color: #cccccc; }
  body.is-black .menu-link:hover, body.is-black .menu-link.active {
    color: #3d3d43; }

.menu-block {
  position: relative;
  display: flex;
  align-items: center;
  z-index: 2; }
  @media (max-width: 667px) {
    .menu-block.center {
      margin: 0.3rem 0; } }
  @media (min-width: 668px) {
    .menu-block.center {
      display: flex;
      position: absolute;
      left: 0;
      right: 0;
      z-index: 1;
      justify-content: center; } }
  .menu-block .index-link {
    position: relative;
    z-index: 3;
    font-size: 0.875rem;
    font-weight: 600;
    margin-right: 0.5rem; }
    .menu-block .index-link img {
      display: none;
      position: absolute;
      width: 3rem;
      height: 3rem;
      margin-left: -4rem; }
    @media (max-width: 667px) {
      .menu-block .index-link {
        font-size: 1rem; } }

@media (min-width: 668px) {
  .menu-links {
    display: flex;
    justify-content: space-between; } }
.menu-links .top {
  display: flex;
  align-items: center; }

.menu-portrait {
  margin: 0.1rem 0;
  width: 3rem;
  border-radius: 50%; }
  @media (min-width: 668px) {
    .menu-portrait {
      width: 3.2rem; } }

.message-page {
  align-self: center;
  width: 100%;
  max-width: 1040px;
  padding: 0 1rem;
  margin: auto 0;
  text-align: left; }
  .message-page h1 {
    margin: 0.5rem 0;
    font-size: 2rem;
    font-weight: 700; }
  .message-page p {
    font-size: 1rem;
    font-weight: 400; }
    @media (min-width: 640px) {
      .message-page p {
        font-size: 1.2rem; } }

.contact-content a {
  margin: 0 0.4rem; }
  .contact-content a:first-of-type {
    margin-left: 0; }
  .contact-content a:last-of-type {
    margin-right: 0; }

.footer {
  width: 100%;
  margin: 0.5rem 0 0;
  padding: 1rem 1rem 1rem;
  background: #141414;
  color: whitesmoke; }
  .footer a {
    color: #bdbcc2;
    text-decoration: none; }

.footer-nav-title {
  margin: 0 0 0.8rem;
  font-size: 1rem;
  font-weight: 500; }

.footer-nav {
  margin: 0.5rem 0.3rem 1.5rem;
  font-size: 0.875rem;
  font-weight: 500;
  line-height: 1.8; }
  .footer-nav a {
    margin: 0 0.3rem;
    letter-spacing: 0.4px; }
    .footer-nav a:first-of-type {
      margin-left: 0; }
    .footer-nav a:hover {
      opacity: 0.6; }
  .footer-nav .caption {
    opacity: 0.5;
    font-size: 0.75rem; }

.posts {
  margin: 0 auto;
  padding: 1rem 1rem;
  width: 100%;
  max-width: 1040px; }
  @media (min-width: 740px) {
    .posts {
      display: flex;
      align-items: flex-start; } }

.posts-subscribe {
  margin: 2rem 0; }
  .posts-subscribe p {
    font-size: 1.3rem; }

.posts-tags {
  width: 268px;
  padding: 0 1.2rem; }
  @media (max-width: 739px) {
    .posts-tags {
      width: 100%;
      margin: 1.5rem auto;
      padding: 1.5rem 0.4rem;
      border-top: 1px solid rgba(0, 0, 0, 0.1); } }
  @media (min-width: 740px) {
    .posts-tags {
      border-left: 1px solid rgba(0, 0, 0, 0.1); } }

.posts-tags-title {
  display: block;
  margin: 0;
  padding: 0;
  font-size: 0.9325rem; }

.posts-tags-item {
  margin: 0.3rem 0;
  font-size: 0.9325rem; }
  .posts-tags-item.active a {
    color: #2055f3;
    font-weight: 500; }

.posts-list {
  display: flex;
  flex-direction: column;
  list-style: none;
  padding: 0;
  width: 100%;
  margin: 0; }
  @media (min-width: 740px) {
    .posts-list {
      padding-right: 2rem;
      max-width: calc(100% - 268px); } }

.posts-list-title {
  margin: 0.5rem 0;
  font-size: 1.5rem;
  font-weight: 700; }

.posts-list-item {
  margin-bottom: 0.8rem;
  width: 100%;
  color: #444; }
  .posts-list-item > a {
    color: #444;
    font-size: 1rem;
    font-weight: 500;
    border-bottom: 2px solid rgba(0, 0, 0, 0.3);
    margin-bottom: 0.2rem;
    padding: 0 0 0.1rem;
    transition: all 100ms ease-out; }
  .posts-list-item p {
    font-size: 1rem;
    font-weight: 400;
    line-height: 1.5; }
  @media (min-width: 720px) {
    .posts-list-item {
      flex: 1; } }

.post {
  flex: 1;
  width: 100%;
  padding: 1.3rem 0 1.6rem;
  margin: 0 0.3rem; }
  @media (min-width: 668px) {
    .post {
      padding: 1.3rem 0 1.6rem; } }

.post-nav {
  margin: 1rem 0 1rem;
  padding: 1rem 1rem;
  width: 100%;
  max-width: 720px;
  border-top: 1px solid rgba(128, 128, 128, 0.04);
  font-size: 1rem; }
  @media (min-width: 640px) {
    .post-nav {
      margin: 2rem 0 2rem;
      padding: 1.5rem 1rem;
      display: flex;
      justify-content: space-between; } }
  @media (max-width: 667px) {
    .post-nav div {
      padding: 1rem 0; } }
  @media (min-width: 668px) {
    .post-nav div {
      width: 50%;
      padding-right: 2.5rem; } }
  .post-nav a {
    color: rgba(0, 0, 0, 0.9); }
    .post-nav a span.caption {
      font-size: 0.875em; }
    .post-nav a time,
    .post-nav a span.caption {
      display: block;
      margin: 0.4rem 0;
      color: rgba(0, 0, 0, 0.5); }
    .post-nav a span.title {
      display: block;
      margin: 0.4rem 0;
      font-size: 1rem;
      font-weight: 500; }
    .post-nav a .sub {
      color: rgba(0, 0, 0, 0.6); }

body.is-black .post-nav {
  border-top: 1px solid rgba(255, 255, 255, 0.1); }
  body.is-black .post-nav a {
    color: rgba(255, 255, 255, 0.9); }
    body.is-black .post-nav a time,
    body.is-black .post-nav a span.caption {
      color: rgba(255, 255, 255, 0.5); }
    body.is-black .post-nav a .sub {
      color: rgba(255, 255, 255, 0.9); }

.post-author {
  position: relative;
  margin: 0 0 1rem;
  padding: 1.2rem 0;
  width: 100%;
  max-width: 360px;
  font-size: 1rem; }
  .post-author p {
    margin: 0.4rem 0; }
  .post-author figure {
    display: block;
    margin: 1.2rem 0; }
  .post-author img {
    width: 10rem; }
  @media (min-width: 640px) {
    .post-author {
      display: flex;
      flex-direction: column;
      align-items: flex-start;
      text-align: left; }
      .post-author span.caption {
        color: rgba(0, 0, 0, 0.6); }
      .post-author span.title {
        font-weight: 500; }
      .post-author time {
        color: rgba(0, 0, 0, 0.6); } }
  .post-author a {
    background-color: #3d3d43;
    color: rgba(255, 255, 255, 0.9);
    font-size: 0.9325rem;
    font-weight: 500;
    margin: 0.8rem 0;
    padding: 0.2rem 0.8rem;
    transition: all 100ms ease-out;
    border-radius: 4px; }
    .post-author a:hover {
      background-color: rgba(61, 61, 67, 0.7); }

@media (min-width: 640px) {
  body.is-black .post-author {
    color: rgba(255, 255, 255, 0.9); }
    body.is-black .post-author span.caption {
      color: rgba(255, 255, 255, 0.6); }
    body.is-black .post-author time {
      color: rgba(255, 255, 255, 0.6); } }
body.is-black .post-author a {
  color: #3d3d43; }

.post-author-portrait-wrapper {
  display: flex;
  align-items: center;
  margin-right: 1.3rem;
  width: 11.3rem;
  background: rgba(128, 128, 128, 0.1);
  border-radius: 15px; }

.post-author-portrait {
  display: block;
  width: 100%;
  border-radius: 15px; }

.post-header {
  margin: 0 auto;
  padding: 0.5rem 1rem;
  max-width: 1040px; }
  @media (min-width: 640px) {
    .post-header {
      margin: 0 auto;
      padding: 1rem 1rem; } }

.post-title {
  margin: 1rem auto 0.8rem;
  font-size: 1.6rem;
  font-weight: 600; }

.post-meta {
  font-size: 0.9325rem; }

.post-time time,
.post-time span.reading-time {
  margin: 0;
  color: rgba(51, 51, 51, 0.6); }

.post-tags {
  margin: 0.4rem 0 0; }
  .post-tags .tag-link {
    margin-right: 0.3rem;
    font-size: 0.9325rem;
    color: rgba(51, 51, 51, 0.6); }
    .post-tags .tag-link:hover {
      color: #3d3d43; }

body.is-black time,
body.is-black span.reading-time {
  color: rgba(204, 204, 204, 0.6); }
body.is-black .tag-link {
  color: rgba(204, 204, 204, 0.6); }
  body.is-black .tag-link:hover {
    color: #3d3d43; }

.post-copy-meta {
  opacity: 0.66; }

.post-copy-wrapper {
  margin: 0 auto; }

.table-of-contents {
  margin: 1.5rem auto;
  max-width: 720px; }
  .table-of-contents a {
    color: #3d3d43; }

.post-copy {
  font-size: 1rem;
  line-height: 2;
  width: 100%;
  max-width: 1040px;
  margin: 0 auto; }
  .post-copy > a {
    color: #3d3d43;
    font-size: 1.1rem;
    font-weight: 500;
    border-bottom: 2px solid;
    margin-bottom: 0.2rem;
    padding: 0 0 0.1rem;
    transition: all 100ms ease-out; }
  .post-copy p {
    margin: 2.5rem 0;
    max-width: 720px; }
  .post-copy > h1, .post-copy > h2, .post-copy > h3, .post-copy > h4, .post-copy > h5 {
    margin: 1.8rem 0 0.8rem; }
  .post-copy > p, .post-copy > ul, .post-copy > ol, .post-copy > time, .post-copy > figure {
    margin: 1rem 0; }
  .post-copy > iframe {
    display: block;
    margin: 1.8rem 0;
    width: 100%;
    max-width: 840px; }
  .post-copy > h1, .post-copy > h2, .post-copy > h3, .post-copy > h4, .post-copy > h5, .post-copy > p, .post-copy > ul, .post-copy > ol, .post-copy > time, .post-copy > figure {
    width: 100%;
    max-width: 720px;
    padding: 0 1rem; }
  .post-copy > ul, .post-copy > ol {
    padding: 0 auto;
    max-width: 720px;
    list-style-position: inside; }
  .post-copy .highlighter-rouge {
    padding: 0 0.4rem; }
  .post-copy .highlighter-rouge > .highlight {
    width: 100%;
    max-width: 1040px;
    margin: 1.5rem 0; }
    .post-copy .highlighter-rouge > .highlight > pre {
      margin-left: auto;
      margin-right: auto;
      padding: 0;
      font-size: 1rem;
      overflow: auto; }
      .post-copy .highlighter-rouge > .highlight > pre code {
        padding: inherit;
        margin: inherit;
        font-size: inherit;
        background: inherit;
        border: 0;
        color: inherit;
        border-radius: inherit; }
  .post-copy > figure.wide {
    padding: 0;
    margin: 2rem 0;
    max-width: 1040px; }

.page {
  flex: 1;
  width: 100%;
  padding: 1.2rem 0; }
  @media (min-width: 668px) {
    .page {
      padding: 1rem 0 0.4rem; } }

.page-nav {
  margin: 1rem 0 1rem;
  padding: 1rem 1rem;
  width: 100%;
  max-width: 720px;
  border-top: 1px solid rgba(0, 0, 0, 0.1);
  font-size: 1.1rem; }
  @media (min-width: 640px) {
    .page-nav {
      margin: 2rem 0 2rem;
      padding: 1.5rem 1rem;
      display: flex;
      justify-content: space-between; } }
  @media (max-width: 667px) {
    .page-nav div {
      padding: 1rem 0; } }
  @media (min-width: 668px) {
    .page-nav div {
      width: 50%;
      padding-right: 2.5rem; } }
  .page-nav a {
    color: rgba(0, 0, 0, 0.9); }
    .page-nav a span.caption {
      font-size: 0.875em; }
    .page-nav a time,
    .page-nav a span.caption {
      color: rgba(0, 0, 0, 0.5); }
    .page-nav a span.title {
      font-size: 1.2rem;
      font-weight: 500; }
    .page-nav a .sub {
      color: rgba(0, 0, 0, 0.9); }

body.is-black .page-nav {
  border-top: 1px solid rgba(255, 255, 255, 0.1); }
  body.is-black .page-nav a {
    color: rgba(255, 255, 255, 0.9); }
    body.is-black .page-nav a time,
    body.is-black .page-nav a span.caption {
      color: rgba(255, 255, 255, 0.5); }
    body.is-black .page-nav a .sub {
      color: rgba(255, 255, 255, 0.9); }

.page-author {
  position: relative;
  margin: 0 auto 1rem;
  padding: 2rem 1rem;
  width: 100%;
  max-width: 370px;
  font-size: 1.2rem; }
  .page-author p {
    margin: 0.4rem 0; }
  .page-author figure {
    display: block; }
  .page-author img {
    width: 10rem; }
  @media (min-width: 640px) {
    .page-author {
      display: flex;
      flex-direction: column;
      align-items: center;
      color: rgba(0, 0, 0, 0.9); }
      .page-author span.caption {
        color: rgba(0, 0, 0, 0.6); }
      .page-author span.title {
        font-weight: 500; }
      .page-author time {
        color: rgba(0, 0, 0, 0.6); } }
  .page-author a {
    color: #3d3d43;
    font-size: 1.1rem;
    font-weight: 500;
    border-bottom: 2px solid;
    margin-bottom: 0.2rem;
    padding: 0 0 0.1rem;
    transition: all 100ms ease-out; }

@media (min-width: 640px) {
  body.is-black .page-author {
    color: rgba(255, 255, 255, 0.9); }
    body.is-black .page-author span.caption {
      color: rgba(255, 255, 255, 0.6); }
    body.is-black .page-author time {
      color: rgba(255, 255, 255, 0.6); } }
body.is-black .page-author a {
  color: #3d3d43; }

.page-author-portrait-wrapper {
  display: flex;
  align-items: center;
  margin-right: 1.3rem;
  width: 11.3rem;
  background: rgba(128, 128, 128, 0.1);
  border-radius: 15px; }

.page-author-portrait {
  display: block;
  width: 100%;
  border-radius: 15px; }

.page-header {
  margin: 0rem auto 0;
  padding: 0.5rem 1rem 0;
  width: 100%;
  max-width: 1040px;
  text-align: center; }
  .page-header.left-aligned {
    text-align: left; }

.page-title {
  margin: 0.5rem 0.3rem 0;
  font-size: 1.2rem;
  font-weight: 500; }

.page-meta {
  font-size: 1rem; }
  .page-meta time,
  .page-meta span.reading-time {
    margin: 0 0.3rem;
    color: rgba(51, 51, 51, 0.6); }
  .page-meta .tag-link {
    margin-right: 0.3rem;
    color: rgba(51, 51, 51, 0.6); }
    .page-meta .tag-link:hover {
      color: #3d3d43; }

body.is-black time,
body.is-black span.reading-time {
  color: rgba(204, 204, 204, 0.6); }
body.is-black .tag-link {
  color: rgba(204, 204, 204, 0.6); }
  body.is-black .tag-link:hover {
    color: #3d3d43; }

.page-copy-meta {
  opacity: 0.66; }

.page-copy-wrapper {
  max-width: 1040px;
  padding: 0 0.3rem;
  margin: 0 auto; }

.page-copy {
  font-size: 1rem;
  line-height: 2;
  width: 100%;
  max-width: 720px;
  margin: 0 0; }
  .page-copy.full-width {
    max-width: 1040px; }
  .page-copy.itinerary {
    max-width: 720px;
    margin: 0 auto; }
  .page-copy > a {
    color: #3d3d43;
    font-size: 1rem;
    font-weight: 500;
    border-bottom: 2px solid;
    margin-bottom: 0.2rem;
    padding: 0 0 0.1rem;
    transition: all 100ms ease-out; }
  .page-copy p {
    margin: 2.5rem 0;
    width: 100%;
    max-width: 720px; }
  .page-copy > h1, .page-copy > h2, .page-copy > h3, .page-copy > h4, .page-copy > h5 {
    margin: 1.8rem 0 0.8rem; }
  .page-copy > p, .page-copy > ul, .page-copy > ol, .page-copy > time, .page-copy > figure {
    margin: 1rem 0; }
  .page-copy > iframe {
    display: block;
    margin: 1.8rem 0;
    width: 100%;
    max-width: 840px; }
  .page-copy > h1, .page-copy > h2, .page-copy > h3, .page-copy > h4, .page-copy > h5, .page-copy > p, .page-copy > ul, .page-copy > ol, .page-copy > time, .page-copy > figure {
    width: 100%;
    max-width: 720px;
    padding: 0 1rem; }
  .page-copy > ul, .page-copy > ol {
    padding: 0 auto;
    max-width: 720px;
    list-style-position: inside; }
  .page-copy .highlighter-rouge {
    padding: 0 0.4rem; }
  .page-copy .highlighter-rouge > .highlight {
    width: 100%;
    max-width: 1040px;
    margin: 1.5rem auto; }
    .page-copy .highlighter-rouge > .highlight > pre {
      margin-left: auto;
      margin-right: auto;
      padding: 0;
      font-size: 1rem;
      overflow: auto; }
      .page-copy .highlighter-rouge > .highlight > pre code {
        padding: inherit;
        margin: inherit;
        font-size: inherit;
        background: inherit;
        border: 0;
        color: inherit;
        border-radius: inherit; }
  .page-copy > figure.wide {
    padding: 0;
    margin: 2rem auto;
    max-width: 1040px; }

.product {
  flex: 1;
  width: 100%;
  padding: 1.5rem 0; }
  @media (min-width: 668px) {
    .product {
      padding: 3rem 0; } }

.product-nav {
  margin: 1rem auto 1rem;
  padding: 1rem 1rem;
  width: 100%;
  max-width: 720px;
  border-top: 1px solid rgba(0, 0, 0, 0.1);
  font-size: 1.1rem; }
  @media (min-width: 640px) {
    .product-nav {
      margin: 2rem auto 2rem;
      padding: 1.5rem 1rem;
      display: flex;
      justify-content: space-between; } }
  @media (max-width: 667px) {
    .product-nav div {
      padding: 1rem 0; } }
  @media (min-width: 668px) {
    .product-nav div {
      width: 50%;
      padding-right: 2.5rem; } }
  .product-nav a {
    color: rgba(0, 0, 0, 0.9); }
    .product-nav a span.caption {
      font-size: 0.875em; }
    .product-nav a time,
    .product-nav a span.caption {
      color: rgba(0, 0, 0, 0.5); }
    .product-nav a span.title {
      font-size: 1.2rem;
      font-weight: 500; }
    .product-nav a .sub {
      color: rgba(0, 0, 0, 0.9); }

body.is-black .product-nav {
  border-top: 1px solid rgba(255, 255, 255, 0.1); }
  body.is-black .product-nav a {
    color: rgba(255, 255, 255, 0.9); }
    body.is-black .product-nav a time,
    body.is-black .product-nav a span.caption {
      color: rgba(255, 255, 255, 0.5); }
    body.is-black .product-nav a .sub {
      color: rgba(255, 255, 255, 0.9); }

.product-author {
  position: relative;
  margin: 0 auto 1rem;
  padding: 2rem 1rem;
  width: 100%;
  max-width: 370px;
  font-size: 1.2rem; }
  .product-author p {
    margin: 0.4rem 0; }
  .product-author figure {
    display: block; }
  .product-author img {
    width: 10rem; }
  @media (min-width: 640px) {
    .product-author {
      display: flex;
      flex-direction: column;
      align-items: center;
      color: rgba(0, 0, 0, 0.9); }
      .product-author span.caption {
        color: rgba(0, 0, 0, 0.6); }
      .product-author span.title {
        font-weight: 500; }
      .product-author time {
        color: rgba(0, 0, 0, 0.6); } }
  .product-author a {
    color: #3d3d43;
    font-size: 1.1rem;
    font-weight: 500;
    border-bottom: 2px solid;
    margin-bottom: 0.2rem;
    padding: 0 0 0.1rem;
    transition: all 100ms ease-out; }

@media (min-width: 640px) {
  body.is-black .product-author {
    color: rgba(255, 255, 255, 0.9); }
    body.is-black .product-author span.caption {
      color: rgba(255, 255, 255, 0.6); }
    body.is-black .product-author time {
      color: rgba(255, 255, 255, 0.6); } }
body.is-black .product-author a {
  color: #3d3d43; }

.product-author-portrait-wrapper {
  display: flex;
  align-items: center;
  margin-right: 1.3rem;
  width: 11.3rem;
  background: rgba(128, 128, 128, 0.1);
  border-radius: 15px; }

.product-author-portrait {
  display: block;
  width: 100%;
  border-radius: 15px; }

.product-header {
  margin: 1rem auto;
  padding: 0.5rem 1rem;
  max-width: 1040px;
  text-align: center; }
  @media (min-width: 640px) {
    .product-header {
      margin: 1.5rem auto;
      padding: 1rem 1rem; } }

.product-title {
  margin: 0.5rem 0;
  font-size: 2rem;
  font-weight: 700;
  text-align: center; }

.product-meta {
  font-size: 1.1rem; }
  .product-meta time,
  .product-meta span.reading-time {
    margin: 0 0.3rem;
    color: rgba(51, 51, 51, 0.6); }
  .product-meta .tag-link {
    margin-right: 0.3rem;
    color: rgba(51, 51, 51, 0.6); }
    .product-meta .tag-link:hover {
      color: #3d3d43; }

body.is-black time,
body.is-black span.reading-time {
  color: rgba(204, 204, 204, 0.6); }
body.is-black .tag-link {
  color: rgba(204, 204, 204, 0.6); }
  body.is-black .tag-link:hover {
    color: #3d3d43; }

.product-copy-meta {
  opacity: 0.66; }

.product-copy-wrapper {
  margin: 0 auto; }

.product-cover {
  max-width: 1040px;
  margin: 0 auto; }

.product-copy {
  font-size: 1.2rem;
  line-height: 1.7;
  width: 100%;
  margin: 0 auto; }
  .product-copy > a {
    color: #3d3d43;
    font-size: 1.1rem;
    font-weight: 500;
    border-bottom: 2px solid;
    margin-bottom: 0.2rem;
    padding: 0 0 0.1rem;
    transition: all 100ms ease-out; }
  .product-copy p {
    margin: 2.5rem auto;
    max-width: 720px; }
  .product-copy h1,
  .product-copy h2,
  .product-copy h3,
  .product-copy h4,
  .product-copy h5 {
    margin: 1.8rem auto 0.8rem; }
  .product-copy p,
  .product-copy ul,
  .product-copy ol,
  .product-copy time,
  .product-copy figure {
    margin: 1rem auto; }
  .product-copy iframe {
    display: block;
    margin: 1.8rem auto;
    width: 100%;
    max-width: 840px; }
  .product-copy h1,
  .product-copy h2,
  .product-copy h3,
  .product-copy h4,
  .product-copy h5,
  .product-copy p,
  .product-copy ul,
  .product-copy ol,
  .product-copy time,
  .product-copy figure {
    width: 100%;
    max-width: 720px;
    padding: 0 1rem; }
  .product-copy ul,
  .product-copy ol {
    padding: 0 auto;
    max-width: 720px;
    list-style-position: inside; }
  .product-copy .highlighter-rouge {
    padding: 0 0.4rem; }
  .product-copy .highlighter-rouge > .highlight {
    width: 100%;
    max-width: 1040px;
    margin: 1.5rem auto; }
    .product-copy .highlighter-rouge > .highlight > pre {
      margin-left: auto;
      margin-right: auto;
      padding: 0;
      font-size: 1rem;
      overflow: auto; }
      .product-copy .highlighter-rouge > .highlight > pre code {
        padding: inherit;
        margin: inherit;
        font-size: inherit;
        background: inherit;
        border: 0;
        color: inherit;
        border-radius: inherit; }
  .product-copy figure.wide {
    padding: 0;
    margin: 2rem auto;
    max-width: 1040px; }

.thoughts {
  flex: 1;
  width: 100%;
  padding: 1.3rem 0 1.6rem; }
  @media (min-width: 668px) {
    .thoughts {
      padding: 1.3rem 0 1.6rem; } }

.thoughts-author {
  position: relative;
  margin: 0 0 1rem;
  padding: 1.2rem 0;
  width: 100%;
  max-width: 360px;
  font-size: 1rem; }
  .thoughts-author p {
    margin: 0.4rem 0; }
  .thoughts-author figure {
    display: block;
    margin: 1.2rem 0; }
  .thoughts-author img {
    width: 10rem; }
  @media (min-width: 640px) {
    .thoughts-author {
      display: flex;
      flex-direction: column;
      align-items: flex-start;
      text-align: left; }
      .thoughts-author span.caption {
        color: rgba(0, 0, 0, 0.6); }
      .thoughts-author span.title {
        font-weight: 500; }
      .thoughts-author time {
        color: rgba(0, 0, 0, 0.6); } }
  .thoughts-author a {
    background-color: #3d3d43;
    color: rgba(255, 255, 255, 0.9);
    font-size: 0.9325rem;
    font-weight: 500;
    margin: 0.8rem 0;
    padding: 0.2rem 0.8rem;
    transition: all 100ms ease-out;
    border-radius: 4px; }
    .thoughts-author a:hover {
      background-color: rgba(61, 61, 67, 0.7); }

@media (min-width: 640px) {
  body.is-black .thoughts-author {
    color: rgba(255, 255, 255, 0.9); }
    body.is-black .thoughts-author span.caption {
      color: rgba(255, 255, 255, 0.6); }
    body.is-black .thoughts-author time {
      color: rgba(255, 255, 255, 0.6); } }
body.is-black .thoughts-author a {
  color: #3d3d43; }

.thoughts-author-portrait-wrapper {
  display: flex;
  align-items: center;
  margin-right: 1.3rem;
  width: 11.3rem;
  background: rgba(128, 128, 128, 0.1);
  border-radius: 15px; }

.thoughts-author-portrait {
  display: block;
  width: 100%;
  border-radius: 15px; }

.thoughts-header {
  margin: 0 auto;
  padding: 0.5rem 1rem;
  max-width: 1040px;
  text-align: center; }
  @media (min-width: 640px) {
    .thoughts-header {
      margin: 0 auto;
      padding: 1rem 1rem; } }

.thoughts-title {
  margin: 1rem auto 0.8rem;
  font-size: 1.6rem;
  font-weight: 600; }

.thoughts-meta {
  font-size: 0.9325rem; }

.thoughts-time time,
.thoughts-time span.reading-time {
  margin: 0;
  color: rgba(51, 51, 51, 0.6); }

.thoughts-tags {
  margin: 0.4rem 0 0; }
  .thoughts-tags .tag-link {
    margin-right: 0.3rem;
    font-size: 0.9325rem;
    color: rgba(51, 51, 51, 0.6); }
    .thoughts-tags .tag-link:hover {
      color: #3d3d43; }

body.is-black time,
body.is-black span.reading-time {
  color: rgba(204, 204, 204, 0.6); }
body.is-black .tag-link {
  color: rgba(204, 204, 204, 0.6); }
  body.is-black .tag-link:hover {
    color: #3d3d43; }

.thoughts-copy-meta {
  opacity: 0.66; }

.thoughts-wrapper {
  margin: 0 auto; }
  .thoughts-wrapper ul {
    list-style: none;
    margin: 0 auto;
    padding: 0; }
    .thoughts-wrapper ul li {
      height: 40vh;
      font-size: 1rem;
      padding: 0 1rem;
      margin: 5rem auto;
      display: flex;
      align-items: center;
      justify-content: center;
      max-width: 1040px;
      text-transform: uppercase;
      font-family: Monaco, monospace; }
      .thoughts-wrapper ul li:nth-child(even) {
        background: #1a1a1a;
        color: #fafafa; }

.thoughts-copy {
  font-size: 1rem;
  line-height: 2;
  width: 100%;
  margin: 0 auto; }
  .thoughts-copy > a {
    color: #3d3d43;
    font-size: 1.1rem;
    font-weight: 500;
    border-bottom: 2px solid;
    margin-bottom: 0.2rem;
    padding: 0 0 0.1rem;
    transition: all 100ms ease-out; }
  .thoughts-copy p {
    margin: 2.5rem 0;
    max-width: 720px; }
  .thoughts-copy > h1, .thoughts-copy > h2, .thoughts-copy > h3, .thoughts-copy > h4, .thoughts-copy > h5 {
    margin: 1.8rem 0 0.8rem; }
  .thoughts-copy > p, .thoughts-copy > time, .thoughts-copy > figure {
    margin: 1rem 0; }
  .thoughts-copy > iframe {
    display: block;
    margin: 1.8rem 0;
    width: 100%;
    max-width: 840px; }
  .thoughts-copy > h1, .thoughts-copy > h2, .thoughts-copy > h3, .thoughts-copy > h4, .thoughts-copy > h5, .thoughts-copy > p, .thoughts-copy > time, .thoughts-copy > figure {
    width: 100%;
    max-width: 720px;
    padding: 0 1rem; }
  .thoughts-copy .highlighter-rouge {
    padding: 0 0.4rem; }
  .thoughts-copy .highlighter-rouge > .highlight {
    width: 100%;
    max-width: 1040px;
    margin: 1.5rem 0; }
    .thoughts-copy .highlighter-rouge > .highlight > pre {
      margin-left: auto;
      margin-right: auto;
      padding: 0;
      font-size: 1rem;
      overflow: auto; }
      .thoughts-copy .highlighter-rouge > .highlight > pre code {
        padding: inherit;
        margin: inherit;
        font-size: inherit;
        background: inherit;
        border: 0;
        color: inherit;
        border-radius: inherit; }
  .thoughts-copy > figure.wide {
    padding: 0;
    margin: 2rem 0;
    max-width: 1040px; }

.flex-1 {
  flex: 1; }

.tags {
  margin: 2rem 0;
  padding: 2rem 0; }

.langs {
  z-index: 2;
  margin: 2px 0.5rem 0;
  display: flex; }
  .langs a {
    display: block;
    margin: 0 0.4rem 0 0 !important;
    text-transform: uppercase;
    font-size: 0.8125rem; }
    @media (min-width: 668px) {
      .langs a {
        font-size: 0.875rem !important; } }
    .langs a:hover {
      color: #3d3d43; }
    .langs a.active {
      color: #3d3d43; }

.container {
  display: flex;
  width: 100%;
  padding: 0 0.3rem;
  margin: auto;
  max-width: 1040px; }
  .container.wide {
    max-width: 1040px;
    padding: 0; }
  .container.for-footer {
    display: block;
    max-width: 1040px; }
    @media (min-width: 640px) {
      .container.for-footer {
        padding: 0 1rem; } }
  .container.itinerary {
    max-width: 720px; }

@media (max-width: 667px) {
  .hidden-mobile {
    display: none; } }

.circled-portrait {
  display: block;
  min-width: 240px;
  max-width: 240px;
  min-height: 240px;
  max-height: 240px;
  margin: 0 auto 2rem;
  border-radius: 50%; }

.client-links {
  padding: 0 1rem; }
  .client-links a {
    margin-right: 0.5rem;
    font-size: 1.8rem;
    font-weight: 600; }

.footnotes {
  margin: 3rem 0 2rem;
  max-width: 720px;
  border-top: 1px solid rgba(128, 128, 128, 0.04);
  font-size: 0.9325rem; }
  .footnotes ol {
    margin: 1.5rem 0;
    list-style-position: outside; }
  .footnotes li {
    padding: 0; }
    .footnotes li p {
      margin: 0.6rem 0;
      padding: 0 0.8rem; }
