@import url(font-awesome.min.css);
@import url("https://fonts.googleapis.com/css?family=Merriweather:300,700,300italic,700italic|Source+Sans+Pro:900");

/*
	Massively by HTML5 UP
	html5up.net | @ajlkn
	Free for personal and commercial use under the CCA 3.0 license (html5up.net/license)
*/

html, body, div, span, applet, object, iframe, h1, h2, h3, h4, h5, h6, p, blockquote, pre, a, abbr, acronym, address, big, cite, code, del, dfn, em, img, ins, kbd, q, s, samp, small, strike, strong, sub, sup, tt, var, b, u, i, center, dl, dt, dd, ol, ul, li, fieldset, form, label, legend, table, caption, tbody, tfoot, thead, tr, th, td, article, aside, canvas, details, embed, figure, figcaption, footer, header, hgroup, menu, nav, output, ruby, section, summary, time, mark, audio, video {
    margin: 0;
    padding: 0;
    border: 0;
    font: inherit;
    vertical-align: baseline;
}

article, aside, details, figcaption, figure, footer, header, hgroup, menu, nav, section {
    display: block;
}

body {
    line-height: 1;
}

ol, ul {
    list-style: none;
}

blockquote, q {
    quotes: none;
}

blockquote:before, blockquote:after, q:before, q:after {
    content: none;
}

table {
    border-collapse: collapse;
    border-spacing: 0;
}

/* Box Model */

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

/* Basic */

@media screen and (max-width: 480px) {

    html, body {
        min-width: 320px;
    }

}

body {
    background-color: #1e252d;
}

body.is-loading *, body.is-loading *:before, body.is-loading *:after {
    animation: none !important;
    transition: none !important;
}

/* Type */

html {
    font-size: 16pt;
}

@media screen and (max-width: 1680px) {

    html {
        font-size: 12pt;
    }

}

@media screen and (max-width: 1280px) {

    html {
        font-size: 11pt;
    }

}

@media screen and (max-width: 360px) {

    html {
        font-size: 10pt;
    }

}

body {
    color: var(--main-bg-color);
}

body, input, select, textarea {
    font-family: "Merriweather", Georgia, serif;
    font-weight: 300;
    font-size: 1rem;
    line-height: 2.375;
}

a {
    transition: color 0.2s ease-in-out, background-color 0.2s ease-in-out, border-color 0.2s ease-in-out, box-shadow 0.2s ease-in-out;
    border-bottom: dotted 1px;
    text-decoration: none;
}

a:hover {
    border-bottom-color: transparent;
}

strong, b {
    font-weight: 600;
}

em, i {
    font-style: italic;
}

p {
    text-align: justify;
    margin: 0 0 2rem 0;
}

h1, h2, h3, h4, h5, h6 {
    font-family: "Source Sans Pro", Helvetica, sans-serif;
    font-weight: 900;
    line-height: 1.5;
    letter-spacing: 0.075em;
    text-transform: uppercase;
    margin: 0 0 1rem 0;
}

figcaption {
    font-family: "Merriweather", "Source Sans Pro", Helvetica, sans-serif;
    font-weight: 100;
    line-height: 1.5;
    letter-spacing: 0.075em;
    margin: 0 0 1rem 0;
}

h1 a, h2 a, h3 a, h4 a, h5 a, h6 a {
    border-bottom: 0;
    color: inherit;
    text-decoration: none;
}

h1 {
    font-size: 4rem;
    line-height: 1.1;
    margin: 0 0 2rem 0;
}

h2 {
    font-size: 1.75rem;
    line-height: 1.3;
    margin: 0 0 1.5rem 0;
}

h3 {
    font-size: 1.25rem;
    margin: 0 0 1.5rem 0;
}

h4 {
    font-size: 1rem;
}

h5 {
    font-size: 0.9rem;
}

h6 {
    font-size: 0.8rem;
}

figure {
    display: inline-block;
}

figure img {
    vertical-align: top;
}

figure figcaption {
    text-align: center;
}

sub {
    font-size: 0.8rem;
    position: relative;
    top: 0.5rem;
}

sup {
    font-size: 0.8rem;
    position: relative;
    top: -0.5rem;
}

blockquote {
    border-left: solid 4px;
    font-style: italic;
    margin: 0 0 2rem 0;
    padding: 0.5rem 0 0.5rem 2rem;
}

code {
    border: solid 2px;
    font-family: "Courier New", monospace;
    font-size: 0.9rem;
    margin: 0 0.25rem;
    padding: 0.25rem 0.65rem;
}

pre {
    font-family: "Courier New", monospace;
    font-size: 0.9rem;
    margin: 0 0 2rem 0;
}

pre code {
    display: block;
    line-height: 1.75;
    padding: 1rem 1.5rem;
    overflow-x: auto;
}

hr {
    border: 0;
    border-bottom: solid 2px;
    margin: 3rem 0;
}

hr.major {
    margin: 5rem 0;
}

.align-left {
    text-align: left;
}

.align-center {
    text-align: center;
}

.align-right {
    text-align: right;
}

input, select, textarea {
    color: var(--main-bg-color);
}

a {
    color: var(--main-bg-color);
    border-bottom-color: rgba(33, 41, 49, 0.5);
}

a:hover {
    border-bottom-color: transparent;
    color: #18bfef !important;
}

strong, b {
    color: var(--main-bg-color);
}

h1, h2, h3, h4, h5, h6 {
    color: var(--main-bg-color);
}

blockquote {
    border-left-color: #eeeeee;
}

code {
    background: rgba(220, 220, 220, 0.25);
    border-color: #eeeeee;
}

hr {
    border-bottom-color: #eeeeee;
}

/* Box */

.box {
    border: solid 2px;
    margin-bottom: 2rem;
    padding: 1.5rem;
}

.box > :last-child,
.box > :last-child > :last-child,
.box > :last-child > :last-child > :last-child {
    margin-bottom: 0;
}

.box.alt {
    border: 0;
    border-radius: 0;
    padding: 0;
}

.box {
    border-color: #eeeeee;
}

/* Icon */

.icon {
    text-decoration: none;
    border-bottom: none;
    position: relative;
}

.icon:before {
    font-family: FontAwesome, serif;
    font-style: normal;
    font-weight: normal;
    text-transform: none !important;
}

.icon > .label {
    display: none;
}

/* Image */

.image {
    border: 0;
    display: inline-block;
    position: relative;
}

.image img {
    display: block;
}

.image.left, .image.right {
    max-width: 40%;
}

.image.left img, .image.right img {
    width: 100%;
}

.image.left {
    float: left;
    margin: 0 2rem 2rem 0;
    top: 0.75rem;
}

.image.right {
    float: right;
    margin: 0 0 2rem 2rem;
    top: 0.75rem;
}

.image.fit {
    display: block;
    margin: 2.5rem 0;
    width: 100%;
}

.image.fit:first-child {
    margin-top: 0;
}

.image.fit img {
    width: 100%;
}

.image.main {
    display: block;
    margin: 4rem 0;
    width: 100%;
}

.image.main:first-child {
    margin-top: 0;
}

.image.main img {
    width: 100%;
}

@media screen and (max-width: 736px) {

    .image.fit {
        margin: 2rem 0;
    }

    .image.main {
        margin: 2rem 0;
    }

}

a.image {
    overflow: hidden;
}

a.image img {
    transition: transform 0.2s ease-out;
}

a.image:hover img {
    transform: scale(1.05);
}

/* List */

ol {
    list-style: decimal;
    margin: 0 0 2rem 0;
    padding-left: 1.25rem;
}

ol li {
    padding-left: 0.25rem;
}

ul {
    list-style: disc;
    margin: 0 0 2rem 0;
    padding-left: 1rem;
}

ul li {
    padding-left: 0.5rem;
}

ul.divided {
    list-style: none;
    padding-left: 0;
}

ul.divided li {
    border-top: solid 1px;
    padding: 0.5rem 0;
}

ul.divided li:first-child {
    border-top: 0;
    padding-top: 0;
}

ul.icons {
    cursor: default;
    list-style: none;
    padding-left: 0;
}

ul.icons li {
    display: inline-block;
    padding: 0 0.5rem 0 0;
    vertical-align: middle;
}

ul.icons li:last-child {
    padding-right: 0;
}

ul.icons li .icon:before {
    width: 2.25rem;
    height: 2.25rem;
    line-height: 2.25rem;
    display: inline-block;
    text-align: center;
    border-radius: 100%;
    font-size: 1.25rem;
}

ul.icons.alt li .icon:before {
    transition: color 0.2s ease-in-out, background-color 0.2s ease-in-out, border-color 0.2s ease-in-out, box-shadow 0.2s ease-in-out;
    font-size: 1rem;
}

ul.actions {
    cursor: default;
    list-style: none;
    padding-left: 0;
}

ul.actions li {
    display: inline-block;
    padding: 0 1rem 0 0;
    vertical-align: middle;
}

ul.actions li:last-child {
    padding-right: 0;
}

ul.actions.small li {
    padding: 0 0.5rem 0 0;
}

ul.actions.vertical li {
    display: block;
    padding: 1rem 0 0 0;
}

ul.actions.vertical li:first-child {
    padding-top: 0;
}

ul.actions.vertical li > * {
    margin-bottom: 0;
}

ul.actions.vertical.small li {
    padding: 0.5rem 0 0 0;
}

ul.actions.vertical.small li:first-child {
    padding-top: 0;
}

ul.actions.fit {
    display: table;
    margin-left: -1rem;
    padding: 0;
    table-layout: fixed;
    width: calc(100% + 1rem);
}

ul.actions.fit li {
    display: table-cell;
    padding: 0 0 0 1rem;
}

ul.actions.fit li > * {
    margin-bottom: 0;
}

ul.actions.fit.small {
    margin-left: -0.5rem;
    width: calc(100% + 0.5rem);
}

ul.actions.fit.small li {
    padding: 0 0 0 0.5rem;
}

@media screen and (max-width: 480px) {

    ul.actions {
        margin: 0 0 2rem 0;
    }

    ul.actions li {
        padding: 1rem 0 0 0;
        display: block;
        text-align: center;
        width: 100%;
    }

    ul.actions li:first-child {
        padding-top: 0;
    }

    ul.actions li > * {
        width: 100%;
        margin: 0 !important;
    }

    ul.actions li > *.icon:before {
        margin-left: -2rem;
    }

    ul.actions.small li {
        padding: 0.5rem 0 0 0;
    }

    ul.actions.small li:first-child {
        padding-top: 0;
    }

}

dl {
    margin: 0 0 2rem 0;
}

dl dt {
    display: block;
    font-weight: 600;
    margin: 0 0 1rem 0;
}

dl dd {
    margin-left: 2rem;
}

ul.divided li {
    border-top-color: #eeeeee;
}

ul.icons li a.icon:hover:before {
    color: #18bfef;
}

ul.icons.alt li .icon:before {
    box-shadow: inset 0 0 0 2px #eeeeee;
}

ul.icons.alt li a.icon:hover:before {
    box-shadow: inset 0 0 0 2px #18bfef;
}

/* Section/Article */

section.special, article.special {
    text-align: center;
}

header {
    cursor: default;
}

header > .date {
    display: block;
    font-size: 0.8rem;
    height: 1rem;
    margin: 0 0 1rem 0;
    position: relative;
}

header > p {
    font-style: italic;
}

header > h1 + p {
    font-size: 1.1rem;
    margin-top: -0.5rem;
    line-height: 2;
}

header > h2 + p {
    font-size: 1rem;
    margin-top: -0.75rem;
}

header > h3 + p {
    font-size: 0.9rem;
    margin-top: -0.75rem;
}

header > h4 + p {
    font-size: 0.8rem;
    margin-top: -0.75rem;
}

header.major {
    margin: 0 0 4rem 0;
    text-align: center;
}

header.major > :last-child {
    margin-bottom: 0;
}

header.major > p {
    margin-top: 0;
    text-align: center;
}

header.major > .date {
    font-size: 1rem;
    margin: 0 0 4rem 0;
}

header.major > .date:before, header.major > .date:after {
    content: '';
    display: block;
    position: absolute;
    top: 50%;
    width: calc(50% - 6rem);
    border-top: solid 2px;
}

header.major > .date:before {
    left: 0;
}

header.major > .date:after {
    right: 0;
}

@media screen and (max-width: 980px) {

    header br {
        display: none;
    }

}

@media screen and (max-width: 736px) {

    header.major {
        margin: 0 0 2rem 0;
    }

}

header.major .date:before, header.major .date:after {
    border-top-color: #eeeeee;
}

/* Table */

.table-wrapper {
    overflow-x: auto;
}

table {
    margin: 0 0 2rem 0;
    width: 100%;
}

table tbody tr {
    border: solid 1px;
    border-left: 0;
    border-right: 0;
}

table td {
    padding: 0.75rem 0.75rem;
}

table th {
    font-family: "Source Sans Pro", Helvetica, sans-serif;
    font-size: 0.8rem;
    font-weight: 900;
    letter-spacing: 0.075em;
    line-height: 1.5;
    padding: 0 0.75rem 0.75rem 0.75rem;
    text-align: left;
    text-transform: uppercase;
}

@media screen and (max-width: 980px) {

    table th {
        font-size: 0.9rem;
    }

}

table thead {
    border-bottom: solid 2px;
}

table tfoot {
    border-top: solid 2px;
}

table.alt {
    border-collapse: separate;
}

table.alt tbody tr td {
    border: solid 1px;
    border-left-width: 0;
    border-top-width: 0;
}

table.alt tbody tr td:first-child {
    border-left-width: 1px;
}

table.alt tbody tr:first-child td {
    border-top-width: 1px;
}

table.alt thead {
    border-bottom: 0;
}

table.alt tfoot {
    border-top: 0;
}

table tbody tr {
    border-color: #eeeeee;
}

table tbody tr:nth-child(2n + 1) {
    background-color: rgba(220, 220, 220, 0.25);
}

table th {
    color: var(--main-bg-color);
}

table thead {
    border-bottom-color: #eeeeee;
}

table tfoot {
    border-top-color: #eeeeee;
}

table.alt tbody tr td {
    border-color: #eeeeee;
}

/* Pagination */

.pagination {
    display: inline-flex;
    user-select: none;
    cursor: default;
    list-style: none;
    margin: 0 0 2rem 2px;
    padding: 0;
}

.pagination a, .pagination span {
    transition: background-color 0.2s ease-in-out, border-color 0.2s ease-in-out, box-shadow 0.2s ease-in-out, color 0.2s ease-in-out;
    border: solid 2px;
    display: inline-block;
    font-family: "Source Sans Pro", Helvetica, sans-serif;
    font-size: 0.8rem;
    font-weight: 900;
    height: 3rem;
    letter-spacing: 0.075em;
    line-height: calc(3rem - 4px);
    margin-left: -2px;
    min-width: 3rem;
    position: relative;
    text-align: center;
    text-decoration: none;
    text-transform: uppercase;
}

.pagination .next, .pagination .previous {
    text-decoration: none;
    padding: 0 1.75rem;
}

.pagination .next:before, .pagination .previous:before {
    font-family: FontAwesome, serif;
    font-style: normal;
    font-weight: normal;
    text-transform: none !important;
}

.pagination .next:before, .pagination .previous:before {
    display: inline-block;
    color: inherit !important;
}

.pagination .previous:before {
    content: '\f104';
    margin-right: 0.9375em;
}

.pagination .next:before {
    content: '\f105';
    float: right;
    margin-left: 0.9375em;
}

@media screen and (max-width: 980px) {

    .pagination a, .pagination span {
        font-size: 0.9rem;
    }

}

@media screen and (max-width: 480px) {

    .pagination .page, .pagination .extra {
        display: none;
    }

}

.pagination a, .pagination span {
    border-color: #eeeeee;
}

.pagination a {
    color: var(--main-bg-color) !important;
}

.pagination a:hover {
    color: #18bfef !important;
    border-color: #18bfef;
    z-index: 1;
}

.pagination a:hover + a, .pagination a:hover + span {
    border-left-color: #18bfef;
}

.pagination a.active {
    background-color: #eeeeee;
}

.pagination span {
    color: #eeeeee;
}

/* Wrapper */

#wrapper {
    transition: opacity 0.5s ease;
    position: relative;
    z-index: 1;
    overflow: hidden;
}

#wrapper > .bg {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background-color: var(--main-bg-color);
    background-image: url("../../images/overlay.png"), linear-gradient(0deg, rgba(0, 0, 0, 0.1), rgba(0, 0, 0, 0.1)), url("../../images/bg.250.png");
    background-size: auto, auto, 100% auto;
    background-position: center, center, top center;
    background-repeat: repeat, no-repeat, no-repeat;
    background-attachment: scroll, scroll, scroll;
    z-index: -1;
}

#wrapper > .bg.fixed {
    position: fixed;
    width: 100vw;
    height: 100vh;
}

#wrapper.fade-in:before {
    pointer-events: none;
    transition: opacity 1s ease-in-out;
    transition-delay: 0.75s;
    background: #1e252d;
    content: '';
    display: block;
    height: 100%;
    left: 0;
    opacity: 0;
    position: fixed;
    top: 0;
    width: 100%;
}

body.is-loading #wrapper.fade-in:before {
    opacity: 1;
}

@media screen and (orientation: portrait) {

    #wrapper > .bg {
        background-size: auto, auto, auto 175%;
    }

}

/* Intro */

#intro {
    color: var(--main-fg-color);
    padding: 8rem 4rem 6rem 4rem;
    align-items: center;
    display: flex;
    flex-direction: column;
    justify-content: flex-end;
    transition: opacity 1s ease, transform 1s ease;
    position: relative;
    cursor: default;
    text-align: center;
    z-index: 1;
    min-height: 100vh;
}

#intro input, #intro select, #intro textarea {
    color: var(--main-fg-color);
}

#intro a {
    color: var(--main-fg-color);
    border-bottom-color: rgba(255, 255, 255, 0.5);
}

#intro a:hover {
    border-bottom-color: transparent;
    color: #18bfef !important;
}

#intro strong, #intro b {
    color: var(--main-fg-color);
}

#intro h1, #intro h2, #intro h3, #intro h4, #intro h5, #intro h6 {
    color: var(--main-fg-color);
}

#intro blockquote {
    border-left-color: var(--main-fg-color);
}

#intro code {
    background: rgba(255, 255, 255, 0.075);
    border-color: var(--main-fg-color);
}

#intro hr {
    border-bottom-color: var(--main-fg-color);
}

#intro input[type="submit"],
#intro input[type="reset"],
#intro input[type="button"],
#intro button,
#intro .button {
    background-color: transparent;
    box-shadow: inset 0 0 0 2px var(--main-fg-color);
    color: var(--main-fg-color) !important;
}

#intro input[type="submit"]:hover,
#intro input[type="reset"]:hover,
#intro input[type="button"]:hover,
#intro button:hover,
#intro .button:hover {
    box-shadow: inset 0 0 0 2px #18bfef;
    color: #18bfef !important;
}

#intro input[type="submit"].special,
#intro input[type="reset"].special,
#intro input[type="button"].special,
#intro button.special,
#intro .button.special {
    background-color: var(--main-fg-color);
    box-shadow: none;
    color: #1e252d !important;
}

#intro input[type="submit"].special:hover,
#intro input[type="reset"].special:hover,
#intro input[type="button"].special:hover,
#intro button.special:hover,
#intro .button.special:hover {
    background-color: #18bfef;
}

#intro h1 {
    font-size: 5rem;
    line-height: 1;
}

#intro p {
    font-size: 1.25rem;
    font-style: italic;
    margin-top: -0.25rem;
    text-align: center;
}

#intro + #header {
    margin-top: -20rem;
}

#intro + #header .logo {
    transform: translateY(2rem);
    opacity: 0;
    visibility: hidden;
}

#intro.hidden {
    pointer-events: none;
    transform: translateY(2rem);
    transition: opacity 0.5s ease, transform 0.5s ease, visibility 0.5s;
    opacity: 0;
    visibility: hidden;
}

#intro.hidden + #header .logo {
    transform: translateY(0);
    opacity: 1;
    visibility: visible;
}

body.is-loading #intro {
    transform: translateY(2rem);
    opacity: 0;
}

body.is-loading #intro:not(.hidden) + #header + #nav {
    transform: translateY(4rem);
    opacity: 0;
}

@media screen and (max-width: 980px) {

    #intro {
        padding: 4rem 4rem 2rem 4rem;
        min-height: 90vh;
    }

    #intro p br {
        display: none;
    }

    #intro + #header {
        margin-top: -14rem;
    }

}

@media screen and (max-width: 736px) {

    #intro {
        padding: 3rem 2rem 1rem 2rem;
        min-height: 80vh;
    }

    #intro h1 {
        font-size: 3.25rem;
        line-height: 1.1;
        margin-bottom: 1rem;
    }

    #intro p {
        font-size: 1rem;
        margin-top: 0;
    }

    #intro .actions {
        display: none;
    }

}

/* Header */

#header {
    color: var(--main-fg-color);
    align-items: center;
    display: flex;
    flex-direction: column;
    justify-content: flex-end;
    pointer-events: none;
    user-select: none;
    height: 20rem;
    padding-bottom: 8rem;
    position: relative;
    text-align: center;
    z-index: 2;
}

#header input, #header select, #header textarea {
    color: var(--main-fg-color);
}

#header a {
    color: var(--main-fg-color);
    border-bottom-color: rgba(255, 255, 255, 0.5);
}

#header a:hover {
    border-bottom-color: transparent;
    color: #18bfef !important;
}

#header strong, #header b {
    color: var(--main-fg-color);
}

#header h1, #header h2, #header h3, #header h4, #header h5, #header h6 {
    color: var(--main-fg-color);
}

#header blockquote {
    border-left-color: var(--main-fg-color);
}

#header code {
    background: rgba(255, 255, 255, 0.075);
    border-color: var(--main-fg-color);
}

#header hr {
    border-bottom-color: var(--main-fg-color);
}

#header .logo {
    transition: border-color 0.2s ease-in-out, color 0.2s ease-in-out, opacity 0.5s ease, transform 0.5s ease, visibility 0.5s;
    pointer-events: auto;
    border-style: solid;
    border-color: var(--main-fg-color);
    border-width: 5px !important;
    font-family: Pacifico, "Source Sans Pro", Helvetica, sans-serif;
    font-size: 2.25rem;
    font-weight: 400;
    letter-spacing: 0.075em;
    line-height: 1;
    padding: 1rem 1.75rem;
    visibility: visible;
}

#header .logo:hover {
    border-color: #18bfef !important;
    color: #18bfef !important;
}

@media screen and (max-width: 980px) {

    #header {
        height: 14rem;
        padding-bottom: 4rem;
    }

}

@media screen and (max-width: 736px) {

    #header {
        padding-bottom: 3rem;
    }

    #header .logo {
        font-size: 1.75rem;
        border-width: 3px !important;
    }

}

/* Nav */

#nav {
    color: var(--main-fg-color);
    display: flex;
    transition: transform 1s ease, opacity 1s ease;
    background: rgba(255, 255, 255, 0.175);
    height: 4rem;
    line-height: 4rem;
    margin: -4rem auto 0 auto;
    overflow: hidden;
    padding: 0 2rem 0 0;
    position: relative;
    width: calc(100% - 4rem);
    max-width: 72rem;
    z-index: 2;
}

#nav ul.divided li {
    border-top-color: var(--main-fg-color);
}

#nav ul.icons li a.icon:hover:before {
    color: #18bfef;
}

#nav ul.icons.alt li .icon:before {
    box-shadow: inset 0 0 0 2px var(--main-fg-color);
}

#nav ul.icons.alt li a.icon:hover:before {
    box-shadow: inset 0 0 0 2px #18bfef;
}

#nav input, #nav select, #nav textarea {
    color: var(--main-fg-color);
}

#nav a {
    color: var(--main-fg-color);
    border-bottom-color: rgba(255, 255, 255, 0.5);
}

#nav a:hover {
    border-bottom-color: transparent;
    color: #18bfef !important;
}

#nav strong, #nav b {
    color: var(--main-fg-color);
}

#nav h1, #nav h2, #nav h3, #nav h4, #nav h5, #nav h6 {
    color: var(--main-fg-color);
}

#nav blockquote {
    border-left-color: var(--main-fg-color);
}

#nav code {
    background: rgba(255, 255, 255, 0.075);
    border-color: var(--main-fg-color);
}

#nav hr {
    border-bottom-color: var(--main-fg-color);
}

#nav ul.links {
    display: flex;
    flex-grow: 1;
    flex-shrink: 1;
    font-family: "Source Sans Pro", Helvetica, sans-serif;
    font-weight: 900;
    letter-spacing: 0.075em;
    list-style: none;
    margin-bottom: 0;
    padding-left: 0;
    text-transform: uppercase;
}

#nav ul.links li {
    display: block;
    padding-left: 0;
}

#nav ul.links li a {
    transition: background-color 0.2s ease-in-out, color 0.2s ease-in-out;
    display: block;
    font-size: 0.8rem;
    outline: none;
    padding: 0 2rem;
}

#nav ul.links li a:hover {
    color: inherit !important;
    background-color: rgba(255, 255, 255, 0.1);
}

#nav ul.links li.active {
    background-color: var(--main-fg-color);
}

#nav ul.links li.active a {
    color: #1e252d;
}

#nav ul.links li.active a:hover {
    color: #18bfef !important;
}

#nav ul.icons {
    flex-grow: 0;
    flex-shrink: 0;
    margin-bottom: 0;
}

@media screen and (max-width: 980px) {

    #nav {
        display: none;
    }

}

/* Main */

#main {
    background-color: var(--main-fg-color);
    position: relative;
    margin: 0 auto;
    width: calc(100% - 4rem);
    max-width: 72rem;
    z-index: 2;
}

#main > * {
    padding: 4rem 4rem 2rem 4rem;
    border-top: solid 2px #eeeeee;
    margin: 0;
}

#main > *:first-child {
    border-top: 0;
}

#main > footer {
    text-align: center;
}

#main > .post {
    padding: 8rem 8rem 6rem 8rem;
}

#main > .post header.major > .date {
    margin-top: -2rem;
}

#main > .post header.major > h1, #main > .post header.major h2 {
    font-size: 4rem;
    line-height: 1.1;
    margin: 0 0 2rem 0;
}

#main > .post.featured {
    text-align: center;
}

@media screen and (max-width: 1280px) {

    #main > .post {
        padding: 6rem 4rem 4rem 4rem;
    }

}

@media screen and (max-width: 736px) {

    #main > .post {
        padding: 4rem 2rem 2rem 2rem;
    }

    #main > .post header.major > .date {
        margin-top: -1rem;
        margin-bottom: 2rem;
    }

    #main > .post header.major > h1, #main > .post header.major h2 {
        font-size: 2.5rem;
        line-height: 1.2;
        margin: 0 0 1.5rem 0;
    }

}

#main > .posts {
    display: flex;
    flex-wrap: wrap;
    align-items: stretch;
    text-align: center;
    width: 100%;
    padding: 0;
}

#main > .posts > * {
    flex-shrink: 1;
    flex-grow: 0;
}

#main > .posts > * {
    width: 50%;
}

#main > .posts > * {
    padding: 4rem;
    width: 50%;
}

#main > .posts > article {
    border-color: #eeeeee;
    border-left-width: 2px;
    border-style: solid;
    border-top-width: 2px;
    text-align: center;
}

#main > .posts > article > :last-child {
    margin-bottom: 0;
}

#main > .posts > article:nth-child(2n - 1) {
    border-left-width: 0;
}

#main > .posts > article:nth-child(-n + 2) {
    border-top-width: 0;
}

@media screen and (max-width: 980px) {

    #main > .posts > * {
        width: 50%;
    }

    #main > .posts > * {
        padding: 2.5rem;
        width: 50%;
    }

}

@media screen and (max-width: 736px) {

    #main > .posts > * {
        width: 100%;
    }

    #main > .posts > * {
        padding: 2rem;
        width: 100%;
    }

    #main > .posts > article:nth-child(2n - 1) {
        border-left-width: 2px;
    }

    #main > .posts > article:nth-child(-n + 2) {
        border-top-width: 2px;
    }

    #main > .posts > article:nth-child(n) {
        border-left-width: 0;
    }

    #main > .posts > article:nth-child(-n + 1) {
        border-top-width: 0;
    }

    #main > .posts > article .image {
        max-width: 25rem;
        margin-left: auto;
        margin-right: auto;
    }

}

@media screen and (max-width: 736px) {

    #main > * {
        padding: 2rem 2rem 0.1rem 2rem;
    }

}

@media screen and (max-width: 480px) {

    #main {
        width: 100%;
    }

}
