@charset "UTF-8";
html {
    color: #222
}

img {
    vertical-align: middle
}

fieldset {
    border: 0;
    margin: 0;
    padding: 0
}

textarea {
    resize: vertical
}

.nocallout {
    -webkit-touch-callout: none
}

.pressed {
    background-color: rgba(0, 0, 0, .7)
}

textarea[contenteditable] {
    -webkit-appearance: none
}

.gifhidden {
    position: absolute;
    left: -100%
}

.ir {
    background-color: transparent;
    background-repeat: no-repeat;
    border: 0;
    direction: ltr;
    display: block;
    overflow: hidden;
    text-align: left;
    text-indent: -999em
}

.ir br {
    display: none
}

.hidden {
    display: none!important;
    visibility: hidden
}

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

.visuallyhidden.focusable:active,
.visuallyhidden.focusable:focus {
    clip: auto;
    height: auto;
    margin: 0;
    overflow: visible;
    position: static;
    width: auto
}

.invisible {
    visibility: hidden
}

.clearfix::before,
.clearfix::after {
    content: "";
    display: table
}

.clearfix::after {
    clear: both
}

.highlight {
    background: #fff
}

.highlight .c {
    color: #998;
    font-style: italic
}

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

.highlight .k,
.highlight .o {
    font-weight: 700
}

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

.highlight .cp {
    color: #999;
    font-weight: 700
}

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

.highlight .cs {
    color: #999;
    font-weight: 700;
    font-style: italic
}

.highlight .gd {
    color: #000;
    background-color: #fdd
}

.highlight .gd .x {
    color: #000;
    background-color: #faa
}

.highlight .ge {
    font-style: italic
}

.highlight .gr {
    color: #a00
}

.highlight .gh {
    color: #999
}

.highlight .gi {
    color: #000;
    background-color: #dfd
}

.highlight .gi .x {
    color: #000;
    background-color: #afa
}

.highlight .go {
    color: #888
}

.highlight .gp {
    color: #555
}

.highlight .gs {
    font-weight: 700
}

.highlight .gu {
    color: #aaa
}

.highlight .gt {
    color: #a00
}

.highlight .kc,
.highlight .kd,
.highlight .kp,
.highlight .kr,
.highlight .kt {
    font-weight: 700
}

.highlight .kt {
    color: #458
}

.highlight .m {
    color: #099
}

.highlight .s {
    color: #d14
}

.highlight .na {
    color: teal
}

.highlight .nb {
    color: #0086B3
}

.highlight .nc {
    color: #458;
    font-weight: 700
}

.highlight .no {
    color: teal
}

.highlight .ni {
    color: purple
}

.highlight .ne,
.highlight .nf {
    color: #900;
    font-weight: 700
}

.highlight .nn {
    color: #555
}

.highlight .nt {
    color: navy
}

.highlight .nv {
    color: teal
}

.highlight .ow {
    font-weight: 700
}

.highlight .w {
    color: #bbb
}

.highlight .mf,
.highlight .mh,
.highlight .mi,
.highlight .mo {
    color: #099
}

.highlight .sb,
.highlight .sc,
.highlight .sd,
.highlight .s2,
.highlight .se,
.highlight .sh,
.highlight .si,
.highlight .sx {
    color: #d14
}

.highlight .sr {
    color: #009926
}

.highlight .s1 {
    color: #d14
}

.highlight .ss {
    color: #990073
}

.highlight .bp {
    color: #999
}

.highlight .vc,
.highlight .vg,
.highlight .vi {
    color: teal
}

.highlight .il {
    color: #099
}

.highlight .lineno {
    color: #ccc;
    display: inline-block;
    padding: 0 5px;
    border-right: 1px solid #ccc
}

.highlight pre code {
    display: block;
    white-space: pre;
    overflow-x: auto;
    word-wrap: normal
}

html {
    font-family: sans-serif;
    -ms-text-size-adjust: 100%;
    -webkit-text-size-adjust: 100%
}

article,
aside,
details,
figcaption,
figure,
footer,
header,
main,
nav,
section,
summary {
    display: block
}

audio,
canvas,
progress,
video {
    display: inline-block;
    vertical-align: baseline
}

audio:not([controls]) {
    display: none;
    height: 0
}

[hidden],
template {
    display: none
}

a {
    background: 0 0
}

a:active,
a:hover {
    outline: 0
}

abbr[title] {
    border-bottom: 1px dotted
}

b,
strong {
    font-weight: 700
}

dfn {
    font-style: italic
}

mark {
    background: #ff0;
    color: #000
}

sub,
sup {
    font-size: 75%;
    line-height: 0;
    position: relative;
    vertical-align: baseline
}

sup {
    top: -.5em
}

sub {
    bottom: -.25em
}

img {
    border: 0
}

svg:not(:root) {
    overflow: hidden
}

figure {
    margin: 0
}

hr {
    box-sizing: content-box;
    height: 0
}

pre {
    overflow: auto
}

code,
kbd,
pre,
samp {
    font-family: monospace, monospace;
    font-size: 1em
}

button,
input,
optgroup,
select,
textarea {
    color: inherit;
    font: inherit;
    margin: 0
}

button {
    overflow: visible
}

button,
select {
    text-transform: none
}

button,
html input[type="button"],
input[type="reset"],
input[type="submit"] {
    -webkit-appearance: button;
    cursor: pointer
}

button[disabled],
html input[disabled] {
    cursor: default
}

button::-moz-focus-inner,
input::-moz-focus-inner {
    border: 0;
    padding: 0
}

input {
    line-height: normal
}

input[type="checkbox"],
input[type="radio"] {
    box-sizing: border-box;
    padding: 0
}

input[type="number"]::-webkit-inner-spin-button,
input[type="number"]::-webkit-outer-spin-button {
    height: auto
}

input[type="search"] {
    -webkit-appearance: textfield;
    box-sizing: content-box
}

input[type="search"]::-webkit-search-cancel-button,
input[type="search"]::-webkit-search-decoration {
    -webkit-appearance: none
}

legend {
    border: 0;
    padding: 0
}

textarea {
    overflow: auto
}

optgroup {
    font-weight: 700
}

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

td,
th {
    padding: 0
}

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

html,
body,
button {
    -moz-osx-font-smoothing: grayscale;
    -webkit-font-smoothing: antialiased;
    font-smoothing: antialiased
}

body {
    font-size: 18px;
    line-height: 1.625;
    color: #343434
}

body::after {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    bottom: 0;
    right: 0;
    width: 100%;
    z-index: 9;
    display: none;
    background-image: -webkit-linear-gradient(top, rgba(0, 0, 0, .15)95%, rgba(0, 0, 0, .15)100%);
    background-image: linear-gradient(to bottom, rgba(0, 0, 0, .15)95%, rgba(0, 0, 0, .15)100%);
    background-size: 100% 26px
}

body.debug::after {
    display: block;
    pointer-events: none
}

pre {
    background: #f0f0f0;
    padding: 12px;
    margin: 0 0 26px
}

code {
    border: 1px solid #eee;
    padding: 2px
}

blockquote {
    background: #f0f0f0;
    padding: 12px;
    border-left: 6px solid #ccc;
    margin: 0 0 26px
}

blockquote p:last-child {
    padding-bottom: 0
}

.main-container {
    box-sizing: content-box;
    position: relative;
    padding-left: 5%;
    padding-right: 5%;
    margin-left: auto;
    margin-right: auto
}

@media only screen and (min-width:732px) {
    .main-container {
        padding-left: 4.8%;
        padding-right: 4.8%;
        max-width: 732px
    }
}

@media only screen and (min-width:732px) {
    .main-container {
        padding-left: 4.4%;
        padding-right: 4.4%;
        max-width: 864px
    }
}

.container {
    box-sizing: content-box;
    position: relative;
    padding-left: 5%;
    padding-right: 5%;
    margin-left: auto;
    margin-right: auto
}

@media only screen and (min-width:732px) {
    .container {
        padding-left: 4.8%;
        padding-right: 4.8%;
        max-width: 732px
    }
}

@media only screen and (min-width:732px) {
    .container {
        padding-left: 4.4%;
        padding-right: 4.4%;
        max-width: 864px
    }
}

@media only screen and (min-width:732px) {
    .container-medium {
        box-sizing: content-box;
        position: relative;
        padding-left: 5%;
        padding-right: 5%;
        margin-left: auto;
        margin-right: auto
    }
}

@media only screen and (min-width:732px) and (min-width:732px) {
    .container-medium {
        padding-left: 4.8%;
        padding-right: 4.8%;
        max-width: 732px
    }
}

@media only screen and (min-width:732px) and (min-width:732px) {
    .container-medium {
        padding-left: 4.4%;
        padding-right: 4.4%;
        max-width: 864px
    }
}

@media only screen and (max-width:731px) {
    .container-small {
        box-sizing: content-box;
        position: relative;
        padding-left: 5%;
        padding-right: 5%;
        margin-left: auto;
        margin-right: auto
    }
}

@media only screen and (max-width:731px) and (min-width:732px) {
    .container-small {
        padding-left: 4.8%;
        padding-right: 4.8%;
        max-width: 732px
    }
}

@media only screen and (max-width:731px) and (min-width:732px) {
    .container-small {
        padding-left: 4.4%;
        padding-right: 4.4%;
        max-width: 864px
    }
}

@media only screen and (min-width:732px) {
    .content {
        margin-right: 25.9%
    }
    .content pre {
        margin-right: -25.9%
    }
}

h1,
h2,
h3,
h4,
h5,
p {
    margin: 0
}

.small,
small {
    font-size: 16px;
    font-weight: 400;
    line-height: 2;
    padding-top: 0;
    padding-bottom: 1.5em
}

.base,
p,
ul,
ol {
    font-size: 18px;
    font-weight: 400;
    line-height: 1.5;
    padding-top: 0;
    padding-bottom: 1.333em
}

@media only screen and (min-width:732px) {
    .base,
    p,
    ul,
    ol {
        font-size: 20px;
        font-weight: 400;
        line-height: 1.5;
        padding-top: 0;
        padding-bottom: 1.333em
    }
}

.medium,
h4 {
    font-size: 20px;
    font-weight: 400;
    padding-top: 0;
    padding-bottom: 1.333em;
    color: #50648C;
    line-height: 1.2
}

@media only screen and (min-width:732px) {
    .medium,
    h4 {
        font-family: "Source Sans Pro", Helvetica Neue, Helvetica, sans-serif;
        font-size: 24px;
        font-weight: 400;
        line-height: 1.3;
        padding-top: 0;
        padding-bottom: .25em
    }
}

.large,
h3 {
    font-size: 20px;
    font-weight: 400;
    padding-top: 0;
    padding-bottom: 1.333em;
    color: #50648C;
    line-height: 1.3
}

@media only screen and (min-width:732px) {
    .large,
    h3 {
        font-family: "Source Sans Pro", Helvetica Neue, Helvetica, sans-serif;
        font-size: 24px;
        font-weight: 400;
        line-height: 1.3;
        padding-top: 0;
        padding-bottom: .25em
    }
}

.xlarge,
h2 {
    font-family: "Source Sans Pro", Helvetica Neue, Helvetica, sans-serif;
    font-size: 24px;
    font-weight: 400;
    padding-top: 0;
    padding-bottom: .25em;
    color: #50648C;
    line-height: 1.3
}

@media only screen and (min-width:732px) {
    .xlarge,
    h2 {
        font-family: "Source Sans Pro", Helvetica Neue, Helvetica, sans-serif;
        font-size: 26px;
        font-weight: 400;
        line-height: 1.2;
        padding-top: 0;
        padding-bottom: .231em
    }
}

.xxlarge,
h1 {
    font-family: "Source Sans Pro", Helvetica Neue, Helvetica, sans-serif;
    font-size: 24px;
    font-weight: 400;
    line-height: 1.3;
    padding-top: 0;
    padding-bottom: .25em;
    color: #50648C
}

@media only screen and (min-width:732px) {
    .xxlarge,
    h1 {
        font-family: "Source Sans Pro", Helvetica Neue, Helvetica, sans-serif;
        font-size: 34px;
        font-weight: 400;
        line-height: 1.2;
        padding-top: 0;
        padding-bottom: .4em
    }
}

.huge {
    font-family: "Source Sans Pro", Helvetica Neue, Helvetica, sans-serif;
    font-size: 34px;
    font-weight: 400;
    line-height: 1.2;
    padding-top: 0;
    padding-bottom: .4em;
    color: #50648C
}

@media only screen and (min-width:732px) {
    .huge {
        font-family: "Source Sans Pro", Helvetica Neue, Helvetica, sans-serif;
        font-size: 110px;
        font-weight: 400;
        line-height: 1.2;
        padding-top: 0;
        padding-bottom: .2em
    }
}

li>p {
    padding-top: 0
}

.button,
.button--primary,
.button--secondary,
.button--secondary-variation {
    display: inline-block;
    padding: 12px 32px;
    margin-bottom: 13px;
    margin-top: 13px;
    min-height: 26px;
    text-align: center;
    font-family: "Source Sans Pro", Helvetica Neue, Helvetica, sans-serif;
    font-weight: 400;
    text-decoration: none;
    outline: 0;
    -webkit-transition: none;
    transition: none
}

.button:hover {
    color: #fff;
    border: 1px solid #50648C
}

.button:hover,
.button--primary:hover,
.button--secondary:hover,
.button--secondary-variation:hover {
    background: #50648C;
    text-decoration: none
}

.button--primary {
    background: #50648C;
    color: #fff;
    border: 1px solid #ccc;
    border-color: transparent
}

.button--primary:visited {
    color: #fff
}

.button--primary:hover {
    background: #9F6577;
    color: #fff;
    border: 1px solid #9F6577
}

.button--secondary {
    background: #fff;
    color: #50648C;
    border: 1px solid #ccc
}

.button--secondary:visited {
    color: #50648C
}

.button--secondary:hover {
    background: #fff;
    color: #9F6577;
    border: 1px solid #eee
}

.button--secondary-variation {
    background: #fff;
    color: #9F6577;
    border: 1px solid #ccc
}

.button--secondary-variation:visited {
    color: #9F6577
}

.button--secondary-variation:hover {
    background: #fff;
    color: #50648C;
    border: 1px solid #eee
}

.input {
    display: inline-block;
    padding: 12px 32px;
    margin-bottom: 13px;
    margin-top: 13px;
    min-height: 26px;
    text-align: center;
    font-family: "Source Sans Pro", Helvetica Neue, Helvetica, sans-serif;
    font-weight: 400;
    color: #50648C;
    text-decoration: none;
    background-color: #fff;
    outline: 0;
    border: 1px solid #ccc;
    -webkit-transition: none;
    transition: none
}

input:focus,
input:hover {
    outline: 0;
    border: 1px solid #eee
}

input::-webkit-input-placeholder {
    color: #ccc
}

input::-moz-placeholder,
input:-moz-placeholder {
    color: #ccc
}

input:-ms-input-placeholder {
    color: #ccc
}

ul,
ol {
    list-style: none;
    margin: 0
}

ul,
ol,
ul li {
    padding-left: 0
}

ul li::before {
    content: "•";
    font-size: 24px;
    padding-right: 12px
}

ol {
    counter-reset: list
}

ol>li {
    position: relative;
    padding-left: 32px
}

ol>li::before {
    counter-increment: list;
    content: "0" counter(list);
    color: inherit;
    font-weight: 400;
    display: inline-block;
    position: absolute;
    left: 0
}

ol>li:nth-child(10n)~li::before,
ol>li:nth-child(10n)::before {
    content: counter(list)
}

ul ol,
ol ul {
    padding-top: 0
}

@media only screen and (min-width:732px) {
    .list-small li {
        font-size: 16px;
        font-weight: 400;
        line-height: 2;
        padding-bottom: 1.5em;
        padding-top: 0
    }
}

.list-centered {
    text-align: center;
    padding-left: 0
}

.list--reset,
.list--reset li {
    padding-left: 0
}

.list--reset.list-links a::before,
.list--reset li::before {
    display: none!important
}

a,
a:visited {
    color: #9F6577;
    text-decoration: none
}

a:hover {
    color: #50648C;
    text-decoration: none
}

table {
    margin-bottom: 26px;
    width: 100%
}

table thead {
    background: #50648C;
    color: #fff
}

table th {
    text-align: left;
    display: none;
    font-family: "Source Sans Pro", Helvetica Neue, Helvetica, sans-serif;
    font-size: 18px;
    font-weight: 400;
    line-height: 1.5;
    padding-top: 0;
    padding-bottom: 1.333em
}

@media only screen and (min-width:732px) {
    table th {
        font-size: 20px;
        font-weight: 400;
        line-height: 1.5;
        padding-top: 0;
        padding-bottom: 1.333em
    }
}

@media only screen and (min-width:732px) {
    table tr {
        border-bottom: 2px solid #fff
    }
}

table tbody {
    background: #f0f0f0
}

table td {
    display: block;
    padding-top: 13px;
    padding-bottom: 13px
}

table td::before {
    content: attr(data-th)" :";
    display: inline-block;
    color: #50648C;
    background: #f0f0f0;
    border-right: 2px solid #fff;
    position: absolute;
    top: 0;
    left: 0;
    bottom: 0;
    width: 100px;
    max-height: 100%;
    font-family: "Source Sans Pro", Helvetica Neue, Helvetica, sans-serif;
    font-size: 16px;
    font-weight: 400;
    padding-left: 13px;
    padding-top: 13px
}

@media only screen and (min-width:732px) {
    table td::before {
        display: none
    }
}

table th,
table td {
    position: relative;
    padding-left: 140px
}

@media only screen and (min-width:732px) {
    table th,
    table td {
        display: table-cell
    }
}

@media only screen and (min-width:732px) {
    table th {
        padding: 13px 26px 12px
    }
}

@media only screen and (min-width:732px) {
    table td {
        padding: 26px 26px 25px
    }
}

td:last-child::after {
    content: "";
    display: block;
    background: #fff;
    height: 1px;
    left: 0;
    position: absolute;
    bottom: 0;
    width: 100%
}

@media only screen and (min-width:732px) {
    td:last-child::after {
        display: none
    }
}

.table-2 col {
    width: 366px
}

@media only screen and (min-width:732px) {
    .table-2 col {
        width: 432px
    }
}

@media only screen and (min-width:732px) {
    .table-2 th:first-child,
    .table-2 td:first-child {
        border-right: 2px solid #fff
    }
}

.table-3 col {
    width: 244px
}

@media only screen and (min-width:732px) {
    .table-3 col {
        width: 288px
    }
}

@media only screen and (min-width:732px) {
    .table-3 th:nth-child(2),
    .table-3 td:nth-child(2) {
        border-left: 2px solid #fff;
        border-right: 2px solid #fff
    }
}

.table-4 col {
    width: 183px
}

@media only screen and (min-width:732px) {
    .table-4 col {
        width: 216px
    }
}

@media only screen and (min-width:732px) {
    .table-4 th:nth-child(2),
    .table-4 th:nth-child(3),
    .table-4 td:nth-child(2),
    .table-4 td:nth-child(3) {
        border-left: 2px solid #fff;
        border-right: 2px solid #fff
    }
}

@media only screen and (min-width:732px) {
    .table-condensed td {
        padding: 13px 26px 12px
    }
}

img,
video,
object {
    max-width: 100%
}

.content img {
    margin-top: 26px;
    margin-bottom: 26px
}

.clear::before,
.clear::after {
    content: '';
    display: table
}

.clear::after {
    clear: both
}

.color--blue {
    color: #3372df
}

.color--red {
    color: #cb4437
}

.color--green {
    color: #0f9d58
}

.color--yellow {
    color: #f4b400
}

.color--blue-secondary {
    color: #b7cdf4
}

.color--red-secondary {
    color: #ebb6b0
}

.color--green-secondary {
    color: #56efa5
}

.color--yellow-secondary {
    color: #ffd45b
}

.color--mx-blue {
    color: #50648C
}

.color--mx-purple {
    color: #9F6577
}

.color--gray-background {
    color: #f0f0f0
}

.color--gray-keyline {
    color: #eee
}

.color--gray {
    color: #ccc
}

.color--gray-dark,
.color--text {
    color: #343434
}

.color--highlight {
    color: #3372df
}

.color--warning {
    color: #ffd45b
}

.color--danger {
    color: #cb4437
}

.color--muted {
    color: #ccc
}

.color--remember {
    color: #09829a
}

.color--learning {
    color: #da2e75
}

.color--layouts {
    color: #297ea9
}

.color--user {
    color: #2c8566
}

.color--media {
    color: #cf423a
}

.color--performance {
    color: #7b5294
}

.color--layouts-secondary {
    color: #89c4e2
}

.color--user-secondary {
    color: #78d2b3
}

.color--media-secondary {
    color: #edb8b5
}

.color--performance-secondary {
    color: #c4add2
}

.text-divider {
    position: relative;
    margin-bottom: 26px
}

.text-divider::after {
    content: '';
    display: block;
    position: absolute;
    width: 40%;
    height: 1px;
    box-shadow: 0 1px 0 0 #eee;
    left: 30%;
    bottom: -13px
}

.text-divider.xlarge {
    margin-bottom: 52px
}

.text-divider.xlarge::after {
    bottom: -26px
}

.text-divider.xxlarge {
    margin-bottom: 78px
}

.text-divider.xxlarge::after {
    bottom: -39px
}

.text-divider.huge {
    margin-bottom: 78px
}

.text-divider.huge::after {
    bottom: -39px
}

.centered {
    text-align: center
}

.tag {
    font-size: 16px;
    line-height: 2;
    padding-top: 0;
    padding-bottom: 1.5em;
    font-family: "Source Sans Pro", Helvetica Neue, Helvetica, sans-serif;
    text-transform: uppercase;
    font-weight: 700;
    display: inline-block;
    text-decoration: none
}

.tag:hover {
    color: #343434
}

.tag::before {
    content: '# ';
    display: inline-block
}

html,
body {
    width: 100%;
    height: 100%;
    margin: 0;
    padding: 0
}

body {
    position: relative;
    font-family: "Source Sans Pro", Helvetica Neue, Helvetica, Arial, sans-serif;
    font-weight: 400;
    background-color: #fff;
    box-sizing: border-box;
    min-height: 100%
}

@media screen {
    main {
        margin: 0 auto;
        padding: 0 0 34px
    }
    main h1 {
        text-align: center
    }
    article {
        padding: 32px 16px 0
    }
    section {
        padding: 32px 0 0
    }
    input,
    textarea,
    select {
        -webkit-appearance: none;
        border-radius: 0
    }
    code,
    kbd,
    pre,
    samp {
        font-size: 16px!important;
        line-height: 1.6
    }
    hr {
        height: 2px;
        width: 32px;
        border: 0;
        background: #eee;
        margin: 6px 0 32px
    }
    .nav-bar {
        display: block;
        text-align: center;
        padding: 12px 0
    }
    .nav-bar ul {
        display: inline;
        padding: 0
    }
    .nav-bar li {
        list-style: none;
        display: inline-block;
        font-size: 20px;
        padding: 12px 12px 10px
    }
    .nav-bar a {
        display: block;
        color: #ccc
    }
    .nav-bar a:hover,
    .faq-q,
    .page-list h3 a {
        color: #50648C
    }
    .nav-bar li::before,
    .page-list li::before,
    .index-article-list li::before,
    .project-list li::before {
        content: none
    }
    .mobile-logo {
        text-align: center;
        padding-top: 34px
    }
    .header-line {
        height: 1px;
        width: 100%;
        margin: 0
    }
    .article-page p {
        line-height: 1.6
    }
    .article-page ul,
    .article-page ol {
        padding-left: 12px
    }
    .article-page h2,
    .article-page h3,
    .article-page h4 {
        padding-top: 2px;
        padding-bottom: 6px
    }
    .article-page h1 {
        padding-bottom: 6px
    }
    .page h1 {
        padding-bottom: 32px
    }
    .index-page h1 {
        text-align: left
    }
    .index-page h2,
    .index-page h3 {
        font-size: 24px;
        padding: 8px 0 6px
    }
    .post-meta {
        color: #ccc;
        padding-bottom: 16px
    }
    .page-list li {
        padding: 0 0 16px
    }
    .project-list li {
        padding: 0 0 24px
    }
    .index-article-list li {
        line-height: 1!important;
        padding: 0 0 8px
    }
    .page-list h3 {
        font-size: 20px;
        font-family: "Source Sans Pro", Helvetica Neue, Helvetica, Arial, sans-serif;
        padding-bottom: 6px
    }
    .index-article-list h4 {
        font-size: 18px
    }
    .page-list h3 a:hover {
        color: #9F6577
    }
    .page-list-extended li p {
        padding-bottom: 12px
    }
    .archive-meta,
    .ial-meta {
        color: #ccc;
        padding-bottom: 0
    }
    .button-design-history {
        width: 100%;
        padding: 16px 16px 0
    }
    .button-design-history a {
        width: 100%;
        margin: 0
    }
    .newsletter,
    #legal {
        padding-top: 32px
    }
    .newsletter {
        font-weight: 700
    }
    .index-page form input {
        width: 100%;
        margin: 0
    }
    .index-page form input[type="submit"] {
        margin-top: 12px
    }
    .call-to-action {
        color: #ccc;
        padding: 8px 16px 0
    }
    .call-to-action p {
        padding: 12px 0 0
    }
    .card-half {
        position: relative;
        overflow: hidden;
        min-height: 120px;
        margin-bottom: 4px
    }
    .card-overlay {
        position: absolute;
        top: 0;
        left: 0;
        width: 100%;
        height: 100%;
        color: #fff;
        background: rgba(80, 100, 140, .8);
        -webkit-transition: background .3s ease;
        transition: background .3s ease
    }
    .card-overlay:hover {
        background: rgba(159, 101, 119, .8)
    }
    .card-meta {
        position: absolute;
        top: 50%;
        width: 100%;
        padding: 0 16px;
        -webkit-transform: translate(0, -50%);
        transform: translate(0, -50%)
    }
    .card-meta h3 {
        color: #fff;
        padding-bottom: 0
    }
    .card-half a {
        position: absolute;
        top: 0;
        left: 0;
        width: 100%;
        height: 100%;
        font-size: 0;
        opacity: 0
    }
    .no-js img.lazyload,
    .non-mobile-only,
    .script-content {
        display: none
    }
    .inline {
        display: inline
    }
    .padding-zero,
    ul.page-list {
        padding: 0
    }
    .btm-zero,
    .page-list p,
    ul.page-list,
    .page-list li:last-child,
    ul.index-article-list,
    .index-article-list li:last-child {
        padding-bottom: 0
    }
    .full-wide {
        width: 100%
    }
    a.gray-link {
        color: #ccc
    }
    a.gray-link:hover {
        color: #50648C
    }
    img.lazy {
        opacity: 0;
        -webkit-transition: all .3s ease-in;
        transition: all .3s ease-in
    }
}

@media screen and (min-width:414px) {
    header {
        margin: 0 auto;
        padding: 32px 16px 0
    }
    header,
    main {
        max-width: 700px
    }
    main {
        padding: 24px 0 32px;
        min-height: initial
    }
    article {
        max-width: 700px;
        margin: 0 auto
    }
    .header-bar {
        height: 33px
    }
    .header-line {
        width: initial;
        max-width: 668px;
        padding: 0 16px
    }
    .nav-bar {
        display: inline-block;
        float: right;
        line-height: 33px;
        padding: 0
    }
    .nav-bar li {
        padding: 0 12px
    }
    .nav-bar li:last-child {
        padding-right: 0
    }
    .cards-container {
        position: relative;
        width: 100%;
        overflow: hidden
    }
    .card-half {
        float: left;
        max-width: 49.6%
    }
    .non-mobile-only {
        display: inline-block
    }
    .mobile-only,
    .ial-meta {
        display: none
    }
    .float-r {
        float: right
    }
}

@media screen and (min-width:732px) {
    header,
    article,
    section {
        padding: 64px 0 0
    }
    main {
        padding: 32px 0 64px
    }
    .header-line {
        max-width: 700px;
        padding: 0
    }
    .article-page h1 {
        padding-bottom: 8px
    }
    .article-page h2,
    .article-page h3,
    .article-page h4 {
        padding-top: 4px;
        padding-bottom: 8px
    }
    .page h1 {
        padding-bottom: 64px
    }
    .index-page h2,
    .index-page h3 {
        padding-top: 16px
    }
    .post-meta {
        font-size: 20px;
        line-height: 1.6;
        padding-bottom: 48px
    }
    .page-list li,
    .project-list li {
        padding-bottom: 32px
    }
    .page-list h3 {
        font-size: 26px
    }
    .page-list-extended li p {
        padding-bottom: 16px
    }
    .page-list-extended li p:last-child {
        padding-bottom: 0
    }
    .archive-meta {
        font-size: 18px
    }
    .ial-meta {
        display: inline-block;
        font-size: 20px
    }
    .button-design-history {
        padding: 32px 0 0
    }
    .index-article-list li {
        padding: 0 0 2px
    }
    .index-article-list h4 {
        font-size: 20px;
        line-height: 1.4
    }
    .newsletter {
        padding-top: 42px
    }
    .call-to-action {
        padding: 16px 0 0
    }
    .call-to-action p {
        padding-top: 16px
    }
    .card-half {
        max-width: 348px
    }
    .lr-padding-16 {
        padding-left: 16px;
        padding-right: 16px
    }
    .lr-padding-32 {
        padding-left: 32px;
        padding-right: 32px
    }
    .lr-padding-48 {
        padding-left: 48px;
        padding-right: 48px
    }
    .lr-padding-64 {
        padding-left: 64px;
        padding-right: 64px
    }
    .lr-padding-84 {
        padding-left: 84px;
        padding-right: 84px
    }
}

@media print {
    body {
        font: fit-to-print;
        color: #000
    }
    footer,
    .mobile-only,
    .nav-bar,
    .header-image,
    .header-line,
    .call-to-action p,
    .ial-meta,
    .newsletter,
    #mc-embedded-subscribe-form,
    .button-design-history a {
        display: none
    }
    header {
        padding-bottom: 24px
    }
    .logo {
        text-align: right
    }
    h2,
    h3,
    h4,
    h5 {
        page-break-after: avoid;
        padding: 4px 0 8px
    }
    .post-meta {
        text-align: left
    }
    img {
        max-width: 100%!important
    }
    ul,
    ol,
    img {
        page-break-inside: avoid
    }
    article a:after {
        content: " [" attr(href)"] "
    }
    article a[href^="#"]:after {
        content: ""
    }
    .post-meta time:before {
        content: "Published on "
    }
    .call-to-action:after {
        color: #ccc;
        content: "Thanks for reading! I sent new articles to my newsletter list first. You can subscribe here: http://michaelxander.com"
    }
    .index-article-list h4 {
        font-size: 18px
    }
    .page-list li::before,
    .index-article-list li::before,
    .project-list li::before {
        content: none
    }
    .page-list img {
        padding-bottom: 2px
    }
    .button-design-history:after {
        color: #ccc;
        content: "Browse a Selection of Past Projects: http://michaelxander.com/past-projects/";
        font-size: 16px;
        text-align: left
    }
}