@font-face {
    font-family: Inter;
    font-style: normal;
    font-weight: 300;
    font-display: swap;
    src: url("../../assets/fonts/Inter/static/Inter-Thin.ttf")format("woff2");
    unicode-range: U+??, U+131, U+152-153, U+2BB-2BC, U+2C6, U+2DA, U+2DC, U+2000-206F, U+2074, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD
}

@font-face {
    font-family: Inter;
    font-style: normal;
    font-weight: 500;
    font-display: swap;
    src: url("../../assets/fonts/Inter/static/Inter-Light.ttf")format("woff2");
    unicode-range: U+??, U+131, U+152-153, U+2BB-2BC, U+2C6, U+2DA, U+2DC, U+2000-206F, U+2074, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD
}

@font-face {
    font-family: Inter;
    font-style: normal;
    font-weight: 600;
    font-display: swap;
    src: url("../../assets/fonts/Inter/static/Inter-Bold.ttf")format("woff2");
    unicode-range: U+??, U+131, U+152-153, U+2BB-2BC, U+2C6, U+2DA, U+2DC, U+2000-206F, U+2074, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD
}

@font-face {
    font-family: Nunito;
    font-style: italic;
    font-weight: 700;
    font-display: swap;
    src: url("../../assets/fonts/Nunito/static/Nunito-Italic.ttf")format("woff");
    unicode-range: U+??, U+131, U+152-153, U+2BB-2BC, U+2C6, U+2DA, U+2DC, U+304, U+308, U+329, U+2000-206F, U+2074, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD
}

@font-face {
    font-family: Nunito;
    font-style: italic;
    font-weight: 900;
    font-display: swap;
    src: url("../../assets/fonts/Nunito/static/Nunito-BoldItalic.ttf")format("woff");
    unicode-range: U+??, U+131, U+152-153, U+2BB-2BC, U+2C6, U+2DA, U+2DC, U+304, U+308, U+329, U+2000-206F, U+2074, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD
}

@font-face {
    font-family: Nunito;
    font-style: normal;
    font-weight: 700;
    font-display: swap;
    src: url("../../assets/fonts/Nunito/Nunito-VariableFont_wght.ttf")format("woff2");
    unicode-range: U+??, U+131, U+152-153, U+2BB-2BC, U+2C6, U+2DA, U+2DC, U+304, U+308, U+329, U+2000-206F, U+2074, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD
}

@font-face {
    font-family: Nunito;
    font-style: normal;
    font-weight: 900;
    font-display: swap;
    src: url("../../assets/fonts/Nunito/static/Nunito-Bold.ttf")format("woff2");
    unicode-range: U+??, U+131, U+152-153, U+2BB-2BC, U+2C6, U+2DA, U+2DC, U+304, U+308, U+329, U+2000-206F, U+2074, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD
}

html {
    -webkit-text-size-adjust: 100%;
    line-height: 1.15
}

body {
    margin: 0
}

main {
    display: block
}

h1 {
    margin: .67em 0;
    font-size: 2em
}

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

pre {
    font-family: monospace;
    font-size: 1em
}

a {
    background-color: transparent
}

abbr[title] {
    border-bottom: none;
    -webkit-text-decoration: underline dotted;
    text-decoration: underline dotted
}

b,
strong {
    font-weight: 600
}

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

small {
    font-size: 80%
}

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

sub {
    bottom: -.25em
}

sup {
    top: -.5em
}

img {
    border-style: none
}

button,
input,
optgroup,
select,
textarea {
    margin: 0;
    font-family: inherit;
    font-size: 100%;
    line-height: 1.15
}

button,
input {
    overflow: visible
}

button,
select {
    text-transform: none
}

button {
    -webkit-appearance: button
}

[type=button] {
    -webkit-appearance: button
}

[type=reset] {
    -webkit-appearance: button
}

[type=submit] {
    -webkit-appearance: button
}

button::-moz-focus-inner {
    border-style: none;
    padding: 0
}

[type=button]::-moz-focus-inner {
    border-style: none;
    padding: 0
}

[type=reset]::-moz-focus-inner {
    border-style: none;
    padding: 0
}

[type=submit]::-moz-focus-inner {
    border-style: none;
    padding: 0
}

button:-moz-focusring {
    outline: 1px dotted ButtonText
}

[type=button]:-moz-focusring {
    outline: 1px dotted ButtonText
}

[type=reset]:-moz-focusring {
    outline: 1px dotted ButtonText
}

[type=submit]:-moz-focusring {
    outline: 1px dotted ButtonText
}

fieldset {
    padding: .35em .75em .625em
}

legend {
    box-sizing: border-box;
    color: inherit;
    white-space: normal;
    max-width: 100%;
    padding: 0;
    display: table
}

progress {
    vertical-align: baseline
}

textarea {
    overflow: auto
}

[type=checkbox] {
    box-sizing: border-box;
    padding: 0
}

[type=radio] {
    box-sizing: border-box;
    padding: 0
}

[type=number]::-webkit-inner-spin-button {
    height: auto
}

[type=number]::-webkit-outer-spin-button {
    height: auto
}

[type=search] {
    -webkit-appearance: textfield;
    outline-offset: -2px
}

[type=search]::-webkit-search-decoration {
    -webkit-appearance: none
}

::-webkit-file-upload-button {
    -webkit-appearance: button;
    font: inherit
}

details {
    display: block
}

summary {
    display: list-item
}

template,
[hidden] {
    display: none
}

* {
    box-sizing: border-box
}

.img,
svg {
    max-width: 100%
}

::selection {
    background: var(--accent-color);
    color: #fff;
    text-shadow: none
}

hr {
    border: 0;
    border-top: 1px solid var(--text-color);
    height: 1px;
    margin: 1em 0;
    padding: 0;
    display: block
}

audio,
canvas,
iframe,
img,
svg,
video {
    vertical-align: middle
}

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

textarea {
    resize: vertical
}

.hidden,
[hidden] {
    display: none !important
}

.sr-only {
    clip: rect(0, 0, 0, 0);
    white-space: nowrap;
    border: 0;
    width: 1px;
    height: 1px;
    margin: -1px;
    padding: 0;
    position: absolute;
    overflow: hidden
}

.sr-only.focusable:active,
.sr-only.focusable:focus {
    clip: auto;
    white-space: inherit;
    width: auto;
    height: auto;
    margin: 0;
    position: static;
    overflow: visible
}

.invisible {
    visibility: hidden
}

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

.clearfix:after {
    clear: both
}

.gray-bg {
    background-color: #f8f9fa;
}

@media print {

    *,
    :before,
    :after {
        color: #000 !important;
        box-shadow: none !important;
        text-shadow: none !important;
        background: #fff !important
    }

    a,
    a:visited {
        text-decoration: underline
    }

    a[href]:after {
        content: " (" attr(href)")"
    }

    abbr[title]:after {
        content: " (" attr(title)")"
    }

    a[href^=\#]:after,
    a[href^=javascript\:]:after {
        content: ""
    }

    pre {
        white-space: pre-wrap !important
    }

    pre,
    blockquote {
        page-break-inside: avoid;
        border: 1px solid #999
    }

    thead {
        display: table-header-group
    }

    tr,
    img {
        page-break-inside: avoid
    }

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

    h2,
    h3 {
        page-break-after: avoid
    }
}

:root {
    --body-bg: #f0f2f2;
    --body-bg-alpha-90: rgba(240, 242, 242, .9);
    --card-bg: #fff;
    --text-color-vals: 0, 0%, 16%;
    --text-color: hsla(var(--text-color-vals), 1);
    --text-color-alpha-80: hsla(var(--text-color-vals), .8);
    --text-color-alpha-65: hsla(var(--text-color-vals), .65);
    --text-color-alpha-40: hsla(var(--text-color-vals), .4);
    --text-color-alpha-15: hsla(var(--text-color-vals), .15);
    --brand-color-vals: 207, 79%, 56%;
    --brand-color: hsla(var(--brand-color-vals), 1);
    --brand-color-alpha-50: hsla(var(--brand-color-vals), .5);
    --brand-color-alpha-30: hsla(var(--brand-color-vals), .3);
    --brand-color-alpha-10: hsla(var(--brand-color-vals), .1);
    --brand-color-dark: #3699e8;
    --brand-color-dark-hover: #25a5cb;
    --accent-color: #ff893d;
    --bg-blend-mode: multiply;
    --global-radius: 4px;
    --large-radius: 12px;
    --footer-bg: var(--text-color);
    --footer-nav-link-color: var(--body-bg);
    --nav-bg: var(--card-bg);
    --nav-button-bg: var(--card-bg);
    --nav-button-bg-hover: var(--brand-color);
    --nav-button-color-hover: var(--text-bg);
    --nav-button-border: 1.5px solid var(--text-color-alpha-80);
    --brand-shadow: 0px 0px 30px rgba(118, 204, 214, .3);
    --brand-shadow-medium: 0px 0px 50px #52afcb;
    --focus-outline: 0px 0px 0px 4px var(--brand-color-alpha-50);
    --field-border-color: var(--card-bg);
    --button-bg: var(--text-color);
    --button-bg-hover: #222;
    --figure-box-shadow: 0 0 50px var(--brand-color-alpha-50);
    --figure-box-shadow-half: 0 0 25px var(--brand-color-alpha-30);
    --figure-bg-opacity: .2;
    --centered-circle-bg-opacity: .3;
    --about-grid-border-color: var(--brand-color);
    --text-gradient: linear-gradient(324.15deg, #04272a 18.83%, #074046 35.56%);
    --loading-gradient: linear-gradient(324.15deg, #f0f2f2 18.83%, #d6eded 35.56%, #f0f2f2 100%);
    --listicle-number-color: var(--body-bg);
    --highlight-comment-color: var(--text-color-alpha-40);
    --highlight-text-color: var(--text-color);
    --highlight-keyword-color: #629301;
    --highlight-generic-deleted: #e15d05;
    --highlight-generic-output: #243cdb;
    --highlight-keyword-declaration: #0076a8;
    --highlight-literal-number: #bf95f9;
    --highlight-name-attr: #dd4b68;
    --highlight-attribute-color: #0076a8
}



.container {
    width: 100%;
    max-width: 1280px;
    margin-left: auto;
    margin-right: auto;
    padding-left: 1rem;
    padding-right: 1rem
}

.container.is-skinny {
    max-width: 680px
}

.container.is-prose-width {
    max-width: 1200px
}

.container.is-profile-width {
    max-width: 878px
}

.section-pad {
    padding-top: 4vh;
    padding-bottom: 4vh
}

.half-pad {
    padding-top: 2rem;
    padding-bottom: 2rem
}

.section-pad.bottom-pad-sm {
    padding-bottom: var(--font-size-body)
}

.section-pad.top-0-pad {
    padding-top: 0
}

.header-waction {
    flex-flow: wrap;
    align-items: center;
    gap: 4rem 2rem;
    display: flex
}

.header-waction h2 {
    margin-top: 0
}

@media only screen and (min-width: 50em) {
    .section-pad {
        padding-top: 8vh;
        padding-bottom: 8vh
    }

    .section-pad.has-pull-up {
        margin-top: calc(12rem - 8vh)
    }

    .section-pad .pull-up {
        margin-top: -12rem
    }

    .section-pad-2x {
        padding-top: 16vh;
        padding-bottom: 16vh
    }
}

.flex-grid,
.half-grid {
    flex-direction: column;
    gap: 1rem;
    display: flex
}

.flex-grid>* {
    flex: 100%;
    width: 100%
}

.align-center {
    align-items: center
}

.justify-center {
    justify-content: center
}

.align-end {
    align-items: flex-end
}

@media only screen and (min-width: 50em) {
    .figure-header {
        grid-template-columns: repeat(3, 1fr);
        align-items: center;
        gap: 4rem;
        display: grid
    }

    .figure-header-text {
        grid-column: 2/-1;
        margin-bottom: 4rem
    }

    .content-aside-flex {
        display: flex;
        justify-content: center;
    }

    .content-aside-grid {
        grid-template-columns: 1fr 1fr;
        grid-template-areas: "main aside";
        gap: 2rem;
        display: grid
    }

    .content-aside-grid--main {
        grid-area: main
    }

    .content-aside-grid--aside {
        grid-area: aside
    }

    .content-aside-grid--main h2 {
        max-width: 20ch
    }

    .half-grid {
        grid-template-columns: repeat(2, 1fr);
        grid-template-areas: "main form";
        gap: 2rem;
        display: grid
    }

    .flex-grid {
        flex-direction: row;
        gap: 4rem
    }

    .flex-grid.sm-gap {
        gap: 2rem
    }

    .reverse-on-large {
        flex-direction: row-reverse
    }
}

@media only screen and (min-width: 65em) {
    .half-grid {
        gap: 4rem
    }

    .content-aside-grid {
        grid-template-columns: 5fr 4fr;
        gap: 4rem
    }
}

:root {
    --font-family: "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Helvetica, Arial, sans-serif, "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol";
    --heading-font-family: "Nunito", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Helvetica, Arial, sans-serif, "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol";
    --heading-font-weight: 700;
    --font-size-small: .90625rem;
    --font-size-body: 1rem;
    --font-size-lead: 1.375rem;
    --font-size-h1: 2.75rem;
    --font-size-h2: 2rem;
    --font-size-h3: 1.75rem;
    --font-size-h4: 1.40625rem;
    --font-size-h5: 1.25rem
}

@media only screen and (min-width: 50em) {
    :root {
        --font-size-body: 1.125rem;
        --font-size-marketing: 1.25rem;
        --font-size-lead: 1.75rem;
        --font-size-h1: 3.4375rem;
        --font-size-h2: 2.75rem;
        --font-size-h3: 2.1875rem;
        --font-size-h4: 1.5rem;
        --font-size-h5: 1.40625rem
    }
}

html {
    line-height: 1.65;
    font-family: var(--font-family);
    background-color: var(--body-bg);
    color: var(--text-color);
    accent-color: var(--accent-color);
    font-weight: 300
}

body {
    font-size: var(--font-size-body);
    flex-direction: column;
    min-height: 100vh;
    display: flex;
    overflow-x: hidden
}

.main {
    overflow: hidden
}

h1,
h2,
h3,
h4,
h5,
h6 {
    line-height: 1.2;
    font-weight: var(--heading-font-weight);
    font-family: var(--heading-font-family);
    margin: var(--font-size-body)0;
    letter-spacing: -.02em
}

h1 a,
h2 a,
h3 a,
h4 a,
h5 a,
h6 a {
    text-decoration: none
}

h1 small,
h2 small,
h3 small,
h4 small,
h5 small,
h6 small {
    font-size: var(--font-size-body)
}

h2 a.has-internal-arrow {
    color: var(--text-color);
    padding-left: 1rem;
    text-decoration: underline
}

h2 a.has-internal-arrow:hover {
    color: var(--accent-color)
}

p {
    margin: var(--font-size-body)0
}

h1,
.h1 {
    font-size: var(--font-size-h1)
}

h2,
.h2 {
    font-size: var(--font-size-h2)
}

h3,
.h3 {
    font-size: var(--font-size-lead)
}

h4,
h5,
h6,
.h4,
.h5,
.h6,
.large {
    font-size: var(--font-size-lead);
    letter-spacing: -.03em
}

.h5 {
    font-size: 1.5rem
}

.post-body .highlight>pre {
    margin: 0
}

.post-body h2,
.post-body .h2,
.post-body h3,
.post-body .h3,
.post-body h4,
.post-body .h4,
.post-body h5,
.post-body .h5,
.post-body h6,
.post-body .h6 {
    margin-top: calc(var(--font-size-body)*3);
    margin-bottom: var(--font-size-body)
}

.post-body h2,
.post-body .h2 {
    font-size: 1.75rem
}

.post-body h4,
.post-body .h4 {
    font-size: var(--font-size-h4);
    color: var(--text-color-alpha-65)
}

.post-body p,
.post-body ul {
    margin: calc(var(--font-size-body)*1.5)0
}

[data-listicle] {
    position: relative
}

[data-listicle]:before {
    content: attr(data-listicle);
    color: var(--listicle-number-color);
    z-index: -1;
    font-size: 14rem;
    line-height: .6;
    position: absolute;
    left: -2rem
}

@media only screen and (min-width: 50em) {

    .post-body h2,
    .post-body .h2 {
        font-size: 2.125rem
    }
}

.marketing {
    font-size: var(--font-size-marketing);
    letter-spacing: 0
}

.marketing li {
    margin-bottom: 1rem
}

ul.marketing {
    padding-left: 1rem
}

ul.large li {
    margin-bottom: 1rem
}

.bolder {
    font-weight: 500
}

.subheading {
    font-size: var(--font-size-lead);
    color: var(--text-color-alpha-80);
    letter-spacing: -.03em;
    max-width: 37ch
}

figcaption,
.small {
    font-size: var(--font-size-small)
}

a {
    color: var(--text-color)
}

a:hover,
a:focus {
    color: var(--accent-color)
}

a.has-external-arrow,
a.has-internal-arrow {
    display: inline
}

a.has-external-arrow:after,
a.has-internal-arrow:after {
    vertical-align: middle;
    content: "";
    background-color: currentColor;
    width: 14px;
    height: 14px;
    margin-left: 8px;
    display: inline-block;
    -webkit-mask-image: url(/assets/icons/arrow-right.svg);
    mask-image: url(/assets/icons/arrow-right.svg);
    -webkit-mask-size: contain;
    mask-size: contain
}

a.has-internal-arrow:after {
    content: ' \F138';
}

a.has-internal-arrow {
    color: var(--text-color-alpha-65);
    font-weight: 600;
    text-decoration: none
}

a.has-internal-arrow:hover {
    color: var(--text-color);
    text-decoration: none
}

a.has-external-arrow.is-small:after {
    width: 10px;
    height: 10px
}

.subdued-text {
    color: var(--text-color-alpha-80)
}

.accent-text {
    color: var(--accent-color)
}

.sr-only:not(:focus):not(:active) {
    clip: rect(0 0 0 0);
    -webkit-clip-path: inset(50%);
    clip-path: inset(50%);
    white-space: nowrap;
    width: 1px;
    height: 1px;
    position: absolute;
    overflow: hidden
}

blockquote,
blockquote>p {
    margin: 0
}

blockquote>p:first-of-type:before {
    content: "“"
}

blockquote>p:last-of-type:after {
    content: "”"
}

blockquote cite {
    align-items: center;
    gap: 1rem;
    margin: 2rem 0 0;
    font-style: normal;
    display: flex
}

blockquote .name {
    font-size: var(--font-size-body);
    font-weight: 600;
    display: block
}

blockquote .title {
    font-size: var(--font-size-small)
}

blockquote .avatar {
    border-radius: 50%;
    width: 86px;
    height: 86px
}

.strong {
    font-weight: 600
}

.full-width-section-header {
    text-align: center
}

.full-width-section-header .subheading {
    max-width: 52ch;
    margin: 1rem auto 4rem
}

@media only screen and (min-width: 50em) {
    .item-v-margin {
        margin: 2rem 0
    }

    .two-column-list {
        columns: 12rem auto;
        column-gap: 3rem;
        margin-top: .5rem
    }

    .two-column-list li {
        -webkit-column-break-inside: avoid;
        page-break-inside: avoid;
        break-inside: avoid;
        padding: .5rem 0
    }
}

.field+.field {
    margin-top: 1.5rem
}

textarea,
select {
    -webkit-appearance: none;
    appearance: none;
    font-size: var(--font-size-body);
    border: 1.5px solid var(--field-border-color);
    background: var(--card-bg);
    border-radius: var(--global-radius);
    color: var(--text-color);
    width: 100%;
    padding: .5rem
}

[type=text] {
    -webkit-appearance: none;
    appearance: none;
    font-size: var(--font-size-body);
    border: 1.5px solid var(--field-border-color);
    background: var(--card-bg);
    border-radius: var(--global-radius);
    color: var(--text-color);
    width: 100%;
    padding: .5rem
}

[type=email] {
    -webkit-appearance: none;
    appearance: none;
    font-size: var(--font-size-body);
    border: 1.5px solid var(--field-border-color);
    background: var(--card-bg);
    border-radius: var(--global-radius);
    color: var(--text-color);
    width: 100%;
    padding: .5rem
}

[type=password] {
    -webkit-appearance: none;
    appearance: none;
    font-size: var(--font-size-body);
    border: 1.5px solid var(--field-border-color);
    background: var(--card-bg);
    border-radius: var(--global-radius);
    color: var(--text-color);
    width: 100%;
    padding: .5rem
}

[type=checkbox] {
    margin-right: .3rem
}

select,
.ao-form select {
    background-repeat: no-repeat;
    padding-right: 40px;
    background-image: url(select-arrow.7d8f0b0f.b8ad47726f77.svg) !important;
    background-position: right 10px top 10px !important;
    background-size: 14px 14px !important
}



.has-teal-fields {
    --field-border-color: var(--brand-color)
}


textarea:focus,
select:focus {
    box-shadow: var(--focus-outline);
    outline: 0
}

[type=text]:focus {
    box-shadow: var(--focus-outline);
    outline: 0
}

[type=email]:focus {
    box-shadow: var(--focus-outline);
    outline: 0
}

[type=password]:focus {
    box-shadow: var(--focus-outline);
    outline: 0
}

label {
    font-size: var(--font-size-small);
    font-weight: 600
}

.honeypot {
    display: none
}

.button,
.ao-form-submit {
    cursor: pointer;
    text-decoration: none;
    display: inline-flex;
    background: #22a9c8 !important;
    color: var(--body-bg) !important;
    -webkit-appearance: none !important;
    appearance: none !important;
    border-radius: var(--global-radius) !important;
    font-weight: 600 !important;
    font-size: var(--font-size-body) !important;
    border: 0 !important;
    padding: 1rem 3rem !important
}

.blog-cta .button,
.blog-cta .ao-form-submit {
    padding: 1rem 2rem !important
}




.button.brand-bg:hover {
    background: var(--brand-color-dark-hover) !important
}

.button.small {
    padding: .5rem 2rem !important
}

.button:hover,
.ao-form-submit:hover {
    background: var(--button-bg-hover) !important
}

.button.is-full {
    width: 100%
}

.button.has-internal-arrow {
    align-items: center;
    display: inline-flex
}

.button-wrap {
    gap: 1rem;
    padding: 2rem 0 0;
    display: flex
}

.button-wrap.sm-pad {
    padding-top: 1rem
}

.copy-button {
    -webkit-appearance: none;
    appearance: none;
    background-color: var(--text-color);
    cursor: pointer;
    border: 0;
    width: 40px;
    height: 40px;
    padding: 0;
    display: inline-flex
}

.copy-button span {
    background-color: var(--body-bg);
    text-indent: -999rem;
    width: 100%;
    height: 100%;
    display: inline-block;
    -webkit-mask-image: url(copy-paste.679e65d6.513c213d9e9c.svg);
    mask-image: url(copy-paste.679e65d6.513c213d9e9c.svg);
    -webkit-mask-position: 50%;
    mask-position: 50%;
    -webkit-mask-size: 18px 18px;
    mask-size: 18px 18px;
    -webkit-mask-repeat: no-repeat;
    mask-repeat: no-repeat
}

.copy-button.success {
    background-color: var(--brand-color)
}

.copy-button.success span {
    background-color: #292929;
    -webkit-mask-image: url(check-circle.735f774a.bbc39be926c3.svg);
    mask-image: url(check-circle.735f774a.bbc39be926c3.svg)
}

.cta-form-bullets {
    flex-direction: column;
    gap: 1.25rem;
    padding-left: 0;
    list-style: none;
    display: flex
}

.cta-form-bullets,
.cta-form-bullet-heading {
    font-size: var(--font-size-marketing)
}

.cta-form-bullets p {
    margin: 0
}

.cta-form-bullets li {
    padding-left: calc(24px + 1.35rem);
    position: relative
}

.cta-form-bullets li:before {
    background-color: var(--text-color);
    content: "";
    flex: 1 0 auto;
    width: 24px;
    height: 24px;
    margin-top: 4px;
    display: flex;
    position: absolute;
    left: 0;
    -webkit-mask-image: url(data:image/svg+xml;base64,PHN2ZyBmaWxsPSdub25lJyB4bWxucz0naHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmcnIHZpZXdCb3g9JzAgMCAzMiAzMic+PHBhdGggZD0nbTggMTcuNjMgMy4yNjcgNC42MzdhMS4zOTggMS4zOTggMCAwIDAgMi4yNzYuMDY4TDI0IDkuMTA0JyBzdHJva2U9JyMyOTI5MjknIHN0cm9rZS13aWR0aD0nMi41JyBzdHJva2UtbGluZWNhcD0ncm91bmQnIHN0cm9rZS1saW5lam9pbj0ncm91bmQnLz48cGF0aCBkPSdNMSAxNS45OTlhMTUgMTUgMCAxIDAgMzAgMCAxNSAxNSAwIDAgMC0zMCAwWicgc3Ryb2tlPScjMjkyOTI5JyBzdHJva2Utd2lkdGg9JzIuNScgc3Ryb2tlLWxpbmVjYXA9J3JvdW5kJyBzdHJva2UtbGluZWpvaW49J3JvdW5kJy8+PC9zdmc+Cg==);
    mask-image: url(data:image/svg+xml;base64,PHN2ZyBmaWxsPSdub25lJyB4bWxucz0naHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmcnIHZpZXdCb3g9JzAgMCAzMiAzMic+PHBhdGggZD0nbTggMTcuNjMgMy4yNjcgNC42MzdhMS4zOTggMS4zOTggMCAwIDAgMi4yNzYuMDY4TDI0IDkuMTA0JyBzdHJva2U9JyMyOTI5MjknIHN0cm9rZS13aWR0aD0nMi41JyBzdHJva2UtbGluZWNhcD0ncm91bmQnIHN0cm9rZS1saW5lam9pbj0ncm91bmQnLz48cGF0aCBkPSdNMSAxNS45OTlhMTUgMTUgMCAxIDAgMzAgMCAxNSAxNSAwIDAgMC0zMCAwWicgc3Ryb2tlPScjMjkyOTI5JyBzdHJva2Utd2lkdGg9JzIuNScgc3Ryb2tlLWxpbmVjYXA9J3JvdW5kJyBzdHJva2UtbGluZWpvaW49J3JvdW5kJy8+PC9zdmc+Cg==);
    -webkit-mask-size: contain;
    mask-size: contain;
    -webkit-mask-repeat: no-repeat;
    mask-repeat: no-repeat
}

.cta-form-bullet-heading {
    font-weight: 600
}



.m-0 {
    margin: 0
}

.m-v-1 {
    margin: var(--font-size-body)0
}

.mt-0 {
    margin-top: 0
}

.mt-auto {
    margin-top: auto
}

.mb-0 {
    margin-bottom: 0
}

.mb-1 {
    margin-bottom: var(--font-size-body)
}

.mt-2 {
    margin-top: calc(var(--font-size-body)*2)
}

.mb-2 {
    margin-bottom: calc(var(--font-size-body)*2)
}

.pt-1 {
    padding-top: var(--font-size-body)
}

.pt-2 {
    padding-top: calc(var(--font-size-body)*2)
}

.pb-1 {
    padding-bottom: var(--font-size-body)
}

.pb-2 {
    padding-bottom: calc(var(--font-size-body)*2)
}

.text-center {
    text-align: center
}

.overflow-hidden-on-mobile {
    overflow: hidden
}

img {
    /* background-image: var(--loading-gradient); */
    color: var(--text-color-alpha-65);
    justify-content: center;
    align-items: center;
    font-size: 12px;
    display: flex
}

img[src*=\.svg],
img[src*=\.png] {
    background-image: none
}

.hide-on-mobile {
    display: none
}

@media only screen and (min-width: 50em) {
    .overflow-hidden-on-mobile {
        overflow: visible
    }

    .hide-on-mobile {
        display: revert
    }
}

.expand-this-link:before {
    z-index: 3;
    content: "";
    position: absolute;
    top: 0;
    bottom: 0;
    left: 0;
    right: 0
}

.faded-brand-bg {
    background: var(--brand-color-alpha-30)
}

.waves-bg,
.pos-rel {
    position: relative
}

.waves-bg:after {
    mix-blend-mode: var(--bg-blend-mode);
    opacity: var(--figure-bg-opacity);
    content: "";
    z-index: -1;
    background-image: url(/assets/images/abstract-gray.jpeg);
    position: absolute;
    top: 10vh;
    bottom: 10vh;
    left: 0;
    right: 0
}

.card-bg-color {
    background: var(--card-bg)
}

.body-bg-color {
    background: var(--body-bg)
}

.cursors-man-wrapper {
    background: url("teal-floor-texture.a6799233.202fa4b7de60.png") 100% 100%/1484.75px 102.75px no-repeat;
    padding-bottom: 320px;
    position: relative;
    overflow: hidden
}

.cursors-man-wrapper h1 {
    max-width: 26ch
}

.cursors-man {
    width: 100vw;
    max-width: 480px;
    position: absolute;
    bottom: 50px;
    right: 0
}

@media only screen and (min-width: 50em) {
    .cursors-man-wrapper {
        background-size: 2969.5px 202.5px;
        padding-bottom: 160px
    }

    .cursors-man {
        width: 60vw;
        max-width: 1200px;
        bottom: 100px;
        right: -80px
    }

    .cursors-man-wrapper p:nth-of-type(3) {
        max-width: 33ch
    }
}

@media only screen and (min-width: 70em) {
    .about-grid .cell {
        padding: 3rem
    }
}

@media only screen and (min-width: 58em) {
    .cursors-man {
        width: 80vw;
        max-width: 1000px;
        bottom: 87px;
        right: -26%
    }

    .cursors-man-wrapper p:first-of-type {
        max-width: 50ch
    }

    .cursors-man-wrapper p:nth-of-type(2) {
        max-width: 44ch
    }

    .cursors-man-wrapper p:nth-of-type(3) {
        max-width: 40ch
    }
}

@media only screen and (min-width: 77em) {
    .cursors-man {
        right: -21%
    }
}

@media only screen and (min-width: 80em) {
    .cursors-man {
        width: 69vw;
        max-width: 1100px;
        right: -10.2%
    }
}

@media only screen and (min-width: 107em) {

    .cursors-man-wrapper p:first-of-type,
    .cursors-man-wrapper p:nth-of-type(2),
    .cursors-man-wrapper p:nth-of-type(3) {
        max-width: 44ch
    }

    .cursors-man {
        width: 66vw;
        max-width: 1240px;
        right: -12%
    }
}

@media only screen and (min-width: 136em) {
    .cursors-man {
        right: -3%
    }
}

.at-a-glance-grid .cell {
    text-align: center;
    background-image: url(data:image/svg+xml;base64,PHN2ZyBmaWxsPVwibm9uZVwiIHhtbG5zPVwiaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmdcIiB2aWV3Qm94PVwiMCAwIDE5ODMgMlwiPjxwYXRoIGQ9XCJNMSAxaDE5ODFcIiBzdHJva2U9XCIjMjkyOTI5XCIgc3Ryb2tlLXdpZHRoPVwiMlwiIHN0cm9rZS1saW5lY2FwPVwicm91bmRcIiBzdHJva2UtbGluZWpvaW49XCJyb3VuZFwiIHN0cm9rZS1kYXNoYXJyYXk9XCIxIDIwXCIvPjwvc3ZnPg==);
    background-position: 100% 100%;
    background-repeat: no-repeat;
    background-size: 1983px 3px;
    align-items: center;
    padding: 1.25rem
}


.cell.financials img {
    width: 240px;
    margin: 0 auto -40px
}

.glance-heading,
.glance-heading .small,
.cell .numbers {
    color: var(--accent-color);
    font-family: var(--heading-font-family);
    font-size: 1.5rem;
    font-weight: 100;
    line-height: 1.2
}

.glance-heading .small {
    font-size: 1.375rem;
    display: block
}

.cell .numbers {
    font-size: 4rem;
    display: block
}

.cell.os,
.cell.countries {
    flex-direction: column;
    gap: 1rem;
    display: flex
}

.cell.countries figure,
.cell.os img {
    width: 60%;
    margin: 0 auto;
    padding: 0
}





@media only screen and (max-width: 50em) {
    .cell.financials {
        background: 0 0
    }
}

@media only screen and (min-width: 50em) {
    .at-a-glance-grid {
        grid-template-rows: repeat(4, min-content);
        grid-template-columns: repeat(12, 1fr);
        gap: 0;
        margin: 2rem 0;
        display: grid
    }

    .cell.countries {
        text-align: left;
        grid-area: 1/1/span 2/span 8
    }

    .cell.since-07 {
        grid-area: 1/9/auto/span 4
    }

    .cell.os {
        text-align: left;
        background: 0 0;
        grid-area: 4/7/auto/span 6
    }

    .at-a-glance-grid .cell.countries,
    .at-a-glance-grid .cell.years {
        background-image: url(data:image/svg+xml;base64,PHN2ZyBmaWxsPVwibm9uZVwiIHhtbG5zPVwiaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmdcIiB2aWV3Qm94PVwiMCAwIDIgMTg4N1wiPjxwYXRoIGQ9XCJNMSAxdjE4ODVcIiBzdHJva2U9XCIjMjkyOTI5XCIgc3Ryb2tlLXdpZHRoPVwiMlwiIHN0cm9rZS1saW5lY2FwPVwicm91bmRcIiBzdHJva2UtbGluZWpvaW49XCJyb3VuZFwiIHN0cm9rZS1kYXNoYXJyYXk9XCIxIDIwXCIvPjwvc3ZnPg==), url(data:image/svg+xml;base64,PHN2ZyBmaWxsPVwibm9uZVwiIHhtbG5zPVwiaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmdcIiB2aWV3Qm94PVwiMCAwIDE5ODMgMlwiPjxwYXRoIGQ9XCJNMSAxaDE5ODFcIiBzdHJva2U9XCIjMjkyOTI5XCIgc3Ryb2tlLXdpZHRoPVwiMlwiIHN0cm9rZS1saW5lY2FwPVwicm91bmRcIiBzdHJva2UtbGluZWpvaW49XCJyb3VuZFwiIHN0cm9rZS1kYXNoYXJyYXk9XCIxIDIwXCIvPjwvc3ZnPg==);
        background-position: 100% 100%, 100% 100%;
        background-repeat: no-repeat, no-repeat;
        background-size: 2px 1887px, 1983px 3px
    }


    .cell.async {
        background-image: url(data:image/svg+xml;base64,PHN2ZyBmaWxsPVwibm9uZVwiIHhtbG5zPVwiaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmdcIiB2aWV3Qm94PVwiMCAwIDIgMTg4N1wiPjxwYXRoIGQ9XCJNMSAxdjE4ODVcIiBzdHJva2U9XCIjMjkyOTI5XCIgc3Ryb2tlLXdpZHRoPVwiMlwiIHN0cm9rZS1saW5lY2FwPVwicm91bmRcIiBzdHJva2UtbGluZWpvaW49XCJyb3VuZFwiIHN0cm9rZS1kYXNoYXJyYXk9XCIxIDIwXCIvPjwvc3ZnPg==);
        background-position: 100% 100%;
        background-repeat: no-repeat;
        background-size: 2px 1887px;
        grid-area: 4/1/auto/span 6
    }


    .cell.years {
        grid-area: 3/1/auto/span 8
    }

    .cell.financials {
        grid-area: 2/9/span 2/span 4
    }

    .cell figure,
    .cell img {
        width: 50%;
        margin: auto;
        transition: all .3s ease-in-out
    }

    .cell:hover img {
        -webkit-transform: scale(1.05);
        -ms-transform: scale(1.05);
        transform: scale(1.05);
        zoom: 1.05;
    }

    .cell.os,
    .cell.countries {
        flex-direction: row
    }
}

@media only screen and (min-width: 64em) {
    .at-a-glance-grid .cell p {
        margin: .625rem
    }

    .cell.countries {
        grid-area: 1/1/span 2/span 6
    }

    .cell.years {
        grid-area: 1/7/span 2/span 3;
        display: flex
    }

    .cell.since-07 {
        grid-area: 1/10/auto/span 3
    }

    .cell.async,
    .cell.os {
        background-image: url(data:image/svg+xml;base64,PHN2ZyBmaWxsPVwibm9uZVwiIHhtbG5zPVwiaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmdcIiB2aWV3Qm94PVwiMCAwIDIgMTg4N1wiPjxwYXRoIGQ9XCJNMSAxdjE4ODVcIiBzdHJva2U9XCIjMjkyOTI5XCIgc3Ryb2tlLXdpZHRoPVwiMlwiIHN0cm9rZS1saW5lY2FwPVwicm91bmRcIiBzdHJva2UtbGluZWpvaW49XCJyb3VuZFwiIHN0cm9rZS1kYXNoYXJyYXk9XCIxIDIwXCIvPjwvc3ZnPg==);
        background-position: 100% 100%;
        background-repeat: no-repeat;
        background-size: 2px 1887px
    }


    .cell.async {
        grid-area: 3/1/auto/span 4
    }

    .cell.os {
        grid-area: 3/5/auto/span 5
    }

    .cell.financials {
        background: 0 0;
        grid-area: 2/10/span 2/span 3
    }

    .cell .years {
        justify-content: center
    }
}

.use-the-whole-grid {
    flex-direction: column;
    padding-left: 1rem;
    padding-right: 1rem;
    display: flex
}

.anatomical-heart {
    width: 97vw;
    max-width: 960px
}

.values-list {
    list-style-type: url(/assets/icons/icons8-asterisk-24.png);
    margin: 1rem 0;
    padding: 0;
    list-style: none
}

.values-list li {
    counter-increment: item;
    padding: 0 0 2rem 4rem;
    position: relative
}

.values-list p,
.values-list h3 {
    margin: 0;
    line-height: 1.8;
}

.values-list li:before {
    font-family: var(--heading-font-family);
    content: url(/assets/icons/icons8-asterisk-24.png);
    background: var(--card-bg);
    border-radius: 50%;
    justify-content: center;
    align-items: center;
    width: 3rem;
    height: 3rem;
    font-size: 2.5rem;
    display: flex;
    position: absolute;
    top: 0;
    left: 0
}

.donated-since {
    aspect-ratio: 2.109;
    font-family: var(--heading-font-family);
    text-transform: uppercase;
    color: #fff;
    background: url("donated-since-bg.c9f5015c.911bbc458648.png") 0 0/contain no-repeat;
    flex-direction: column;
    justify-content: center;
    align-items: center;
    max-width: 400px;
    margin: -40px auto 0;
    font-weight: 900;
    line-height: 1.2;
    display: flex
}

.stat-total,
.stat-desc {
    margin: 0;
    display: block
}

.stat-total {
    font-size: 3rem
}

.stat-desc {
    font-size: var(--font-size-lead)
}

.half-wide-figure {
    margin: 0
}

.donations-grid {
    flex-direction: column;
    gap: 1rem;
    display: flex
}

.donations-heading h2 {
    text-transform: uppercase;
    color: var(--accent-color);
    font-weight: 900
}

@media only screen and (min-width: 50em) {
    .use-the-whole-grid {
        grid-template-columns: 1fr min(624px, 50% - 3rem) min(624px, 50% - 3rem) 1fr;
        grid-template-areas: "gutter1 leftcontent rightcontent rightcontent";
        gap: 1rem;
        padding-left: 0;
        padding-right: 0;
        display: grid;
        overflow: hidden
    }

    .half-wide-content {
        grid-area: leftcontent
    }

    .half-wide-figure {
        grid-area: rightcontent
    }

    .anatomical-heart {
        width: 65vw
    }

    .donations-grid {
        grid-template: "heading logos" "cta logos" minmax(0, 1fr)/1fr 3fr;
        gap: 1rem;
        display: grid
    }

    .donations-heading {
        grid-area: heading
    }

    .donations-cta {
        grid-area: cta
    }

    .donations-logos {
        grid-area: logos
    }
}

.post-grid {
    margin: 0 -1rem;
    padding: 2rem 1rem;
    overflow: hidden
}

.post-header {
    position: relative
}

.post-primary-figure-cell {
    display: none
}

.post-body {
    background: var(--card-bg);
    z-index: 2;
    border-radius: var(--global-radius);
    min-width: 0;
    padding: 1rem;
    position: relative
}

.post-body hr {
    border-top: 2px dashed var(--body-bg);
    min-width: 20rem;
    margin: 3rem auto 1.5rem 0
}

.post-body figure {
    margin-top: 2rem;
    margin-bottom: 2rem
}

.post-body figure img {
    margin-left: auto;
    margin-right: auto;
    display: block
}

.post-body figcaption {
    margin-top: .5rem
}

.post-primary-figure-mobile {
    z-index: -1;
    width: 200px;
    position: absolute;
    bottom: -128px;
    right: -128px
}

.post-primary-figure {
    aspect-ratio: 1;
    border-radius: 50%;
    width: 100%;
    margin: 0;
    padding: 0;
    position: relative
}

.post-title {
    margin-bottom: 3rem
}

.post-primary-figure-mobile:after,
.post-primary-figure:after {
    opacity: var(--figure-bg-opacity);
    content: "";
    z-index: -1;
    background-image: url(waves.653b8304.54685e368761.svg);
    border-radius: 50%;
    position: absolute;
    top: -3rem;
    bottom: -3rem;
    left: -3rem;
    right: -3rem
}

.post-primary-figure-mobile:after {
    top: -2rem;
    bottom: -2rem;
    left: -2rem;
    right: -2rem
}

.post-primary-img {
    object-fit: cover;
    box-shadow: var(--figure-box-shadow);
    z-index: 1;
    border-radius: 50%;
    width: 100%;
    height: 100%
}

.article-by-line {
    font-size: var(--font-size-small);
    align-items: center;
    gap: .5rem;
    margin-bottom: 1rem;
    padding-right: 120px;
    display: flex
}

.article-by-line .avatar {
    object-fit: cover;
    box-shadow: var(--brand-shadow);
    border-radius: 50%;
    width: 48px;
    height: 48px
}

.apppack-ad .apppack-logo {
    margin: 0 auto 1rem 0
}

.post-sidebar {
    background: var(--brand-color-alpha-10);
    flex-direction: column;
    gap: 2rem;
    margin: 0 -1rem -2rem;
    padding: 2rem 1rem;
    display: flex
}

.post-sidebar [type=text] {
    background: var(--body-bg)
}

.post-sidebar [type=email] {
    background: var(--body-bg)
}

.post-sidebar-group.push-to-bottom {
    margin-top: auto
}

.will-be-stuck {
    display: none
}

.is-sticky {
    position: -webkit-sticky;
    position: sticky;
    top: 20px
}

.post-grid .team-member {
    padding: 2rem 0
}

.content-upgrade {
    --field-border-color: var(--brand-color);
    background-color: var(--brand-color-alpha-10);
    margin: 4rem -1rem 2rem;
    padding: 4rem 1rem
}

.content-upgrade>* {
    max-width: 500px;
    margin-left: auto;
    margin-right: auto
}

.content-upgrade>.content-upgrade-grid {
    max-width: none
}

.content-upgrade:last-child {
    margin-bottom: -1rem
}

.post-body .content-upgrade h2 {
    margin-top: 0
}

.post-body .content-upgrade-figure {
    max-width: 180px;
    margin: -6rem auto 0;
    -webkit-transform: rotate(-7deg);
    transform: rotate(-7deg)
}

.content-upgrade-grid h2 {
    font-size: var(--font-size-h4);
    color: var(--text-color-alpha-65);
    margin-top: 0
}

.post-checklist ul {
    flex-direction: column;
    gap: 1rem;
    margin: 0;
    display: flex
}

.post-checklist ul ul {
    margin: var(--font-size-body)0 .5rem
}

.post-checklist>ul {
    box-shadow: var(--figure-box-shadow-half);
    border: 1px solid var(--brand-color-alpha-50);
    padding: 1.5rem
}

.post-checklist>ul>li {
    padding-left: 2rem;
    list-style: none;
    position: relative
}

.post-checklist input[type=checkbox] {
    width: 1.35rem;
    height: 1.35rem;
    position: absolute;
    top: .25rem;
    left: 0
}

@media only screen and (min-width: 50em) {
    .post-grid {
        grid-gap: 2rem;
        grid-template-rows: min-content 360px min-content min-content;
        grid-template-columns: 1fr repeat(2, min(25vw, 300px));
        grid-template-areas: "header fig1 fig1" "body1 fig2 fig2" "body2 body2 aside" "author author author";
        margin: 0;
        padding: 2rem 0;
        display: grid;
        overflow: visible
    }

    .post-header {
        grid-area: header;
        align-self: end;
        padding: 8vh 0 0 2rem
    }

    .article-by-line {
        margin-bottom: 0
    }

    .post-primary-figure-mobile {
        display: none
    }

    .post-primary-figure-cell {
        grid-area: fig1/2/fig2/-1;
        align-self: center;
        padding: 1rem 2rem 0 0;
        display: flex
    }

    .post-primary-figure {
        padding: 0;
        position: relative
    }

    .post-body {
        grid-area: body1/1/body2/3;
        padding: 2rem
    }

    .post-grid .team-member {
        padding: 2rem
    }

    .post-sidebar {
        background: 0 0;
        grid-area: aside;
        gap: 4rem;
        margin: 0;
        padding: 0
    }

    .post-sidebar [type=text] {
        background: var(--card-bg)
    }

    .post-sidebar [type=email] {
        background: var(--card-bg)
    }

    .author-card {
        grid-area: author
    }

    .post-title {
        margin-bottom: 1rem;
        margin-right: -2rem
    }

    .has-sticky-element {
        flex: 100%
    }

    .will-be-stuck {
        opacity: 0;
        padding-top: 20px;
        transition: opacity .3s linear;
        display: block;
        position: -webkit-sticky;
        position: sticky;
        top: -10px
    }

    .will-be-stuck.is-stuck {
        opacity: 1
    }

    .content-upgrade {
        margin-left: -2rem;
        margin-right: -2rem
    }

    .content-upgrade:last-child {
        margin-bottom: -2rem
    }

    .content-upgrade-grid {
        gap: 2rem;
        display: flex
    }

    .post-body .content-upgrade-figure {
        max-width: 33%;
        margin: auto auto auto -2rem
    }
}

@media only screen and (min-width: 60em) {
    .post-grid {
        grid-template-areas: "header fig1 fig1" "body1 fig2 fig2" "body2 body2 aside" "author author."
    }
}

@media only screen and (min-width: 70em) {
    .post-header {
        padding: 8vh 0 0 4rem
    }

    .post-body,
    .post-grid .team-member {
        padding: 2rem 4rem
    }

    .content-upgrade {
        margin: 4rem -4rem 2rem;
        padding: 4rem
    }

    .post-body .content-upgrade-figure {
        max-width: 46%;
        margin-left: -6rem
    }
}

@media only screen and (min-width: 80em) {
    .post-title {
        margin-right: -7rem
    }

    .post-primary-figure {
        -webkit-transform: translate(4vw);
        transform: translate(4vw)
    }
}

.blog-main-heading {
    font-size: var(--font-size-h2);
    max-width: 22ch;
    margin: 0
}

.blog-main-heading .small-block {
    font-size: var(--font-size-h4);
    display: block
}

.blog-cta-heading {
    font-size: var(--font-size-h5);
    margin-top: 0
}

.blog-grid {
    grid-gap: 2rem;
    flex-direction: column;
    margin: 2rem 0;
    display: flex
}

@media only screen and (min-width: 50em) {
    .blog-grid {
        grid-gap: 4rem;
        grid-template-columns: 2fr 8fr 3fr;
        grid-template-areas: "tags main aside";
        margin: 6vh 0;
        display: grid
    }

    .blog-main {
        grid-area: main
    }

    .blog-tags {
        grid-area: tags
    }

    .blog-aside {
        grid-area: aside
    }

    .blog-grid.is-header {
        align-items: end
    }
}

.swatch-list {
    grid-gap: 1rem;
    grid-template-columns: repeat(auto-fill, minmax(146px, 1fr));
    margin: 1rem 0;
    padding: 0;
    list-style: none;
    display: grid
}

.swatch {
    background: var(--card-bg);
    flex-direction: column;
    gap: .5rem;
    padding: .5rem;
    display: flex
}

.swatch .color {
    aspect-ratio: 1.618;
    width: 100%;
    display: block
}

.swatch .name {
    font-size: var(--font-size-small);
    font-weight: 600
}

.swatch .color-hex input,
.swatch .color-rbg input,
.swatch .color-hsl input {
    font-size: var(--font-size-small);
    padding: .25rem
}

.logo-list {
    grid-gap: 4rem;
    grid-template-columns: repeat(auto-fill, minmax(200px, 1fr));
    margin: 2rem 0;
    padding: 0;
    list-style: none;
    display: grid
}

.logo-item .logo {
    margin-bottom: 1rem
}

.logo-item .info {
    text-align: center;
    font-size: var(--font-size-small)
}

.logo-item .info .name {
    display: block
}

.campaign-page .cta-form-bullets {
    display: none
}

.campaign-page .cta-form-subheading {
    font-size: var(--font-size-h4)
}

@media only screen and (min-width: 50em) {
    .campaign-page .cta-form-bullets {
        display: flex
    }
}

.cs-aside-list {
    margin: 0;
    padding: 0;
    list-style: none
}

.cs-aside-list>li {
    padding: 2rem 0
}

.cs-aside-list>li:not(:first-child) {
    border-top: 2px solid var(--text-color-alpha-15)
}

.cs-aside-heading {
    font-size: var(--font-size-body);
    margin-top: 0
}

.cs-aside-sublist {
    font-size: var(--font-size-small);
    margin: 0;
    padding: 0;
    list-style: none
}

.cs-aside-sublist li {
    margin: 1rem 0
}

.at-a-glance {
    margin: 3.5rem 0
}

.at-a-glance figcaption {
    text-align: revert
}

.at-a-glance h2 {
    font-weight: 400;
    font-size: var(--font-size-h3);
    margin-top: 0;
    line-height: 1.4
}

.at-a-glance p {
    font-size: var(--font-size-small)
}

.stat-grid {
    grid-gap: 2rem 1rem;
    color: var(--text-color-alpha-80);
    font-size: var(--font-size-body);
    grid-template-columns: repeat(auto-fill, minmax(146px, 1fr));
    margin: 0;
    padding: 0;
    list-style: none;
    display: grid
}

.stat-grid .num {
    font-size: var(--font-size-h3);
    color: var(--text-color);
    font-weight: 600;
    display: block
}

.cta-form-heading {
    font-size: var(--font-size-h2)
}

.cta-form-subheading {
    font-size: var(--font-size-h3)
}

.cta-form-intro {
    justify-self: center
}

@media only screen and (min-width: 50em) {
    .cs-grid {
        grid-gap: 4rem;
        grid-template-columns: 1fr 3fr;
        grid-template-areas: "aside main";
        display: grid
    }

    .cs-main {
        grid-area: main
    }

    .cs-aside {
        grid-area: aside
    }

    .at-a-glance {
        grid-gap: 2rem;
        grid-template-columns: 2fr 3fr;
        display: grid
    }
}

.centered-circle-bg {
    --w: min(90vw, 860px);
    position: relative
}

.centered-circle-bg:before {
    content: "";
    z-index: 1;
    width: var(--w);
    height: var(--w);
    background-image: linear-gradient(to top, #cfd9df00 0%, #e2ebf0 100%);
    opacity: var(--centered-circle-bg-opacity);
    border-radius: 50%;
    position: absolute;
    top: 0;
    left: 50%;
    -webkit-transform: translate(-50%);
    transform: translate(-50%);
}

.heart-icon {
    width: 32px;
    height: 32px
}

@media only screen and (min-width: 50em) {
    .heart-icon {
        width: 54px;
        height: 46px
    }

    .centered-circle-bg:before {
        top: 2rem
    }

    .section-pad-2x .centered-circle-bg:before {
        top: -2rem
    }
}

.os-header .large {
    max-width: 26ch;
    margin: 1rem 0
}

.os-ex-grid {
    gap: 1rem;
    width: 100vw;
    margin-left: -1rem;
    padding: 1rem;
    display: flex;
    overflow: auto
}

.os-ex {
    scroll-snap-align: start;
    flex: 1 0 300px;
    width: min(70vw, 300px)
}

.os-ex-row {
    display: contents
}

@media only screen and (min-width: 50em) {
    .os-ex-grid {
        overflow: unset;
        width: unset;
        margin-left: 0;
        padding: 0;
        display: block
    }

    .os-header {
        align-self: center
    }

    .os-header h2 {
        max-width: 15ch
    }

    .os-header p {
        max-width: 35ch
    }

    .os-ex {
        width: unset;
        flex: 0 calc(25% - 1rem)
    }

    .os-ex-row {
        grid-template-columns: repeat(4, 1fr);
        gap: 1rem;
        display: grid
    }

    .os-ex-grid {
        columns: 2;
        column-gap: 1rem
    }

    .os-ex-grid>* {
        break-inside: avoid;
        margin: 0 0 1rem
    }
}

.os-ex-header {
    justify-content: space-between;
    align-items: baseline;
    gap: .5rem;
    display: flex
}

.os-star {
    font-size: var(--font-size-small);
    flex: none;
    align-items: center;
    gap: .25rem;
    display: inline-flex
}

.os-star:after {
    background-color: var(--brand-color);
    content: "";
    width: 16px;
    height: 16px;
    -webkit-mask-image: url(os-star.36216730.5dcce896685d.svg);
    mask-image: url(os-star.36216730.5dcce896685d.svg);
    -webkit-mask-size: contain;
    mask-size: contain
}

.os-ex-heading {
    font-size: var(--font-size-body);
    margin: 0
}

.os-ex-heading a {
    text-decoration: none
}

.os-contrib {
    color: var(--accent-color);
    font-weight: 600;
    font-size: var(--font-size-small)
}

.logo-grid {
    flex-wrap: wrap;
    justify-content: center;
    align-items: center;
    gap: 1.5rem;
    display: flex
}

.logo-grid.extra-margin {
    margin: 3rem 0 2rem
}

.logo-grid a {
    aspect-ratio: 2;
    width: min(180px, 50% - 1.5rem);
    text-decoration: none;
    display: flex
}

.logo-grid a img {
    object-fit: contain;
    width: 100%;
    height: auto
}

.media-logo {
    margin: 3rem 0 0;
    display: block
}

.giving-grid,
.giving-list {
    flex-direction: column;
    gap: 1rem;
    display: flex
}

.giving-list {
    margin: 0;
    padding: 0;
    list-style: none
}

.giving-item {
    flex-direction: column;
    display: flex
}

.giving-item>:first-child {
    margin: 0 0 auto
}

.subtotal-donated {
    font-size: var(--font-size-h2);
    color: var(--text-color-alpha-40);
    font-weight: 600;
    display: block
}

.giving-item-donated {
    font-size: var(--font-size-h3);
    margin: 1rem 0 0;
    line-height: 1.2
}

@media only screen and (min-width: 50em) {
    .giving-grid {
        grid-template-columns: 2fr 5fr;
        gap: 2rem;
        display: grid
    }

    .giving-list {
        grid-template-columns: 1fr 1fr;
        gap: 1rem;
        display: grid
    }
}

.site-header {
    justify-content: space-between;
    align-items: center;
    gap: 1rem;
    padding-top: 1rem;
    padding-bottom: 1rem;
    display: flex
}

.brand {
    width: 100px;
    display: block
}

.logo-circle {
    fill: var(--brand-color)
}

.logo-socks {
    fill: #fff
}

.logo-text {
    fill: var(--text-color)
}

.color-pref-toggle {
    -webkit-appearance: none;
    appearance: none;
    color: var(--text-color);
    cursor: pointer;
    background-color: transparent;
    border: 0;
    margin: 0;
    padding: 1rem .5rem
}

.color-pref-toggle svg {
    width: 32px;
    height: 32px
}

@media only screen and (min-width: 50em) {
    .brand {
        width: 140px
    }

    .color-pref-toggle {
        padding: .5rem
    }

    .color-pref-toggle svg {
        width: 26px;
        height: 26px
    }
}

.home-header {
    background-blend-mode: multiply, normal, normal;
    background-image: url(/assets/images/195.jpg);
    background-position: bottom -20px right -11px;
    background-repeat: no-repeat;
    background-size: 56vw;
    padding-top: 2rem;
    padding-bottom: 18rem
}

.home-header h1 {
    text-shadow: 0 0 25px var(--body-bg), 0 0 25px var(--body-bg), 0 0 25px var(--body-bg);
}

.home-header--content,
.home-header--content .subheading {
    max-width: 64ch
}

.home-header--content .subheading {
    max-width: 46ch;
    font-size: 1.25rem
}

.help-grid {
    flex-direction: column;
    gap: 3rem;
    display: flex
}

.help-cell {
    text-align: center;
    flex-direction: column;
    gap: 10px;
    display: flex
}

.help-text {
    flex-direction: column;
    gap: 10px;
    display: flex
}

.help-text>* {
    margin: 0
}

.help-cell figure {
    max-width: 100px;
    margin: 0 auto
}

.cta-rule-wrap {
    text-align: center;
    background-image: url(data:image/svg+xml;base64,PHN2ZyBmaWxsPVwibm9uZVwiIHhtbG5zPVwiaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmdcIiB2aWV3Qm94PVwiMCAwIDE5ODMgMlwiPjxwYXRoIGQ9XCJNMSAxaDE5ODFcIiBzdHJva2U9XCIjMjkyOTI5XCIgc3Ryb2tlLXdpZHRoPVwiMlwiIHN0cm9rZS1saW5lY2FwPVwicm91bmRcIiBzdHJva2UtbGluZWpvaW49XCJyb3VuZFwiIHN0cm9rZS1kYXNoYXJyYXk9XCIxIDIwXCIvPjwvc3ZnPg==);
    background-repeat: repeat-x;
    background-size: 1983px 3px;
    margin-top: 6rem
}

.cta-rule-wrap .bg-pad {
    padding: 0 2rem;
    display: inline-flex;
    -webkit-transform: translateY(-2rem);
    transform: translateY(-2rem)
}

.logo-list-wrap {
    flex-direction: column;
    align-items: center;
    gap: 1rem;
    display: flex
}

.logo-list-heading {
    color: var(--accent-color);
    text-align: center;
    text-transform: uppercase;
    flex: 0 auto;
    font-size: 2.25rem;
    font-weight: 900
}

.book-logo-composite {
    justify-content: center;
    align-items: center;
    gap: 3rem;
    display: flex
}

.has-pentagon-bg {
    position: relative
}

.has-pentagon-bg:before {
    z-index: -1;
    content: "";
    background-image: url(data:image/svg+xml;base64,PHN2ZyB4bWxucz1cImh0dHA6Ly93d3cudzMub3JnLzIwMDAvc3ZnXCIgdmlld0JveD1cIjAgMCA3MjAuOTE1IDgxMS4xMlwiPjxwYXRoIGZpbGw9XCIjNzVjZGQ2XCIgb3BhY2l0eT1cIi4zXCIgZD1cIm0wIDU0OS41MSAxOTkuNDEgMjYxLjYxIDUyMS41MDUtMzk3LjUxMVYwTDAgNTQ5LjUxelwiLz48L3N2Zz4=);
    background-position: 100% 0;
    background-repeat: no-repeat;
    background-size: contain;
    width: 94vw;
    height: 94vw;
    position: absolute;
    top: -9vw;
    right: 0
}

.testimonial-wrap {
    flex-direction: column;
    align-items: center;
    gap: 2rem;
    display: flex
}

.typewriter {
    max-width: 180px;
    margin-top: -4rem
}

.book-logo-composite--book {
    max-width: 120px
}

.book-logo-composite--logos {
    flex-direction: column;
    align-items: center;
    gap: 2rem;
    max-width: 100px;
    display: flex
}

@media only screen and (min-width: 50em) {
    .testimonial-wrap {
        flex-direction: row-reverse;
        gap: 2rem;
        display: flex
    }

    .typewriter {
        max-width: 380px;
        margin-top: -7rem;
        margin-bottom: -4rem
    }

    .help-grid {
        grid-template-columns: 1fr 1fr;
        gap: 3rem 4rem;
        margin: 4rem 0 0;
        display: grid
    }

    .help-cell {
        text-align: left;
        flex-direction: row
    }

    .help-cell figure {
        margin: 0
    }

    .logo-list-wrap {
        flex-direction: row;
        gap: 4rem
    }

    .home-header {
        background-image: url(/assets/images/195.jpg);
        background-position: right bottom 60%;
        background-size: 50vw;
        padding-top: 8vh;
        padding-bottom: 15rem;
    }

    .home-pull-up {
        margin-top: -9rem
    }

    .book-logo-composite--book {
        max-width: 260px
    }

    .book-logo-composite--django {
        max-width: 160px
    }

    .book-logo-composite--logos {
        max-width: 240px
    }

    .has-pentagon-bg:before {
        width: 58vw;
        height: 58vw;
        top: -12vw
    }
}

@media only screen and (min-width: 80em) {
    .home-header {
        background-size: 45vw;
    }

    .home-header--content .subheading {
        font-size: var(--font-size-lead)
    }
}



.site-nav-list {
    flex-direction: column;
    margin: 0;
    list-style: none;
    display: none
}

.site-nav-list.is-expanded {
    background-color: var(--body-bg);
    z-index: 10;
    justify-content: center;
    align-items: center;
    padding: 1rem;
    display: flex;
    position: fixed;
    top: 0;
    bottom: 0;
    left: 0;
    right: 0;
    overflow: auto
}

.site-nav-item {
    min-width: 180px
}

.nav-link {
    font-size: var(--font-size-lead);
    margin: .5rem;
    padding: .1rem 0;
    font-weight: 700;
    text-decoration: none;
    display: inline-flex;
    position: relative
}

.nav-link:after {
    content: "";
    background-color: transparent;
    height: 4px;
    transition: background-color .2s linear;
    position: absolute;
    top: auto;
    bottom: 0;
    left: 0;
    right: 0
}

.nav-link:hover,
.nav-link:focus {
    color: var(--text-color)
}

.nav-link:hover:after,
.nav-link:focus:after {
    background-color: var(--text-color-alpha-15)
}

.nav-link[aria-current=page] {
    font-weight: 600
}

.nav-link[aria-current=page]:after,
.nav-link[aria-current=page]:hover:after {
    background-color: var(--brand-color);
    font-weight: 600
}

.nav-link.is-button {
    background: var(--nav-button-bg);
    border: var(--nav-button-border);
    border-radius: var(--global-radius);
    padding: .5rem 1rem;
    transition: background-color .2s linear
}

.nav-link.is-button:hover,
.nav-link.is-button[aria-current=page] {
    color: var(--nav-button-color-hover);
    background: var(--nav-button-bg-hover)
}

.nav-link.is-button:hover:after,
.nav-link.is-button[aria-current=page]:after {
    content: unset
}

.menu-toggle {
    font-size: var(--font-size-body);
    text-transform: uppercase;
    border-bottom: 4px solid transparent;
    padding: .1rem 0;
    font-weight: 600;
    text-decoration: none;
    transition: border-color .2s linear;
    display: inline-flex
}

.menu-toggle:hover,
.menu-toggle:focus {
    border-color: var(--text-color-alpha-15);
    color: var(--text-color)
}

.close-button {
    color: var(--text-color);
    cursor: pointer;
    width: 36px;
    height: 36px;
    text-decoration: none;
    position: fixed;
    top: 1rem;
    right: 1rem
}

.close-button:hover {
    color: var(--accent-color)
}

.mobile-brand {
    position: absolute;
    top: calc(1rem + 2px);
    left: 1rem
}

@media only screen and (min-width: 50em) {
    .mobile-brand {
        display: none
    }

    .site-nav-list,
    .site-nav-list.is-expanded {
        background-color: transparent;
        flex-direction: row;
        align-items: baseline;
        gap: max(2vw, 1rem);
        padding: 0;
        display: flex;
        position: static;
        overflow: visible
    }

    .site-nav-item {
        min-width: unset;
        flex: 1 0 auto
    }

    .menu-toggle,
    .close-button {
        display: none
    }

    .nav-link {
        font-size: var(--font-size-body);
        margin: 0
    }
}

.site-footer {
    background: var(--footer-bg);
    margin-top: auto
}

.site-footer .section-pad {
    padding-bottom: 0
}

.footer-grid {
    flex-direction: column;
    justify-content: space-between;
    align-items: flex-start;
    display: flex
}


.legal {
    font-size: var(--font-size-small);
    color: var(--footer-nav-link-color);
    opacity: .8
}

.footer-social {
    justify-content: flex-end;
    gap: 1rem;
    /* margin: 1rem 0; */
    display: flex;
    flex-direction: column;
    color: var(--footer-nav-link-color);
}

.footer-social h3 {
    margin: 0;
}


.social-link {
    color: var(--footer-nav-link-color);
    opacity: .8;
    width: 2rem;
    height: 2rem;
    display: flex
}

.social-link:hover {
    opacity: 1;
    color: var(--footer-nav-link-color)
}

.social-link svg {
    width: 100%;
    height: 100%
}

.footer-logo-lockup {
    flex-direction: column;
    gap: 1rem;
    margin: 2rem 0 4rem;
    display: flex
}

.footer-logo-lockup .brand {
    width: 160px
}

.footer-logo-lockup .logo-text {
    fill: var(--footer-nav-link-color)
}

.footer-tagline {
    color: var(--footer-nav-link-color);
    font-size: var(--font-size-body);
    opacity: .7;
    letter-spacing: 0;
    max-width: 30ch;
    margin: 0;
    font-weight: 300;
    line-height: 1.65
}

.footer-nav-link {
    color: var(--footer-nav-link-color);
    font-weight: 500;
    text-decoration: none
}

.footer-nav-link:hover {
    color: var(--footer-nav-link-color);
    text-decoration: underline
}

.footer-nav-list {
    padding-left: 0;
}

@media only screen and (min-width: 50em) {

    .footer-grid {
        flex-direction: row;
        justify-content: space-between;
        gap: 2rem
    }

    .footer-nav-list {
        flex-wrap: wrap;
        gap: 2rem;
        margin: 1rem 0;
        padding: 0;
        list-style: none;
        display: flex;
    }



    .footer-nav-link.is-secondary {
        opacity: .7;
        font-weight: 300
    }

    .footer-logo-lockup {
        /* flex-direction: row;
        align-items: flex-end; */
        gap: 2rem;
        margin: 0 0 6rem
    }
}

.clamp-text-width-header h1 {
    max-width: 30ch
}

.clamp-text-width-header p {
    max-width: 44ch
}

.results-card {
    flex-direction: column;
    display: flex
}

.results-card ul li img {
    vertical-align: middle;
}

.results-card-figure {
    margin: calc(-1*var(--font-size-body));
    background: var(--text-color-alpha-65);
    border-radius: var(--large-radius)var(--large-radius)0 0;
    margin-bottom: 0;
    position: relative;
    overflow: hidden
}



.results-card-screenshot {
    filter: blur(5px);
    mix-blend-mode: multiply;
    -webkit-transform: scale(1.3);
    transform: scale(1.3)
}

.results-card-logo {
    z-index: 2;
    object-fit: contain;
    object-position: center;
    -webkit-transform-origin: 50%;
    transform-origin: 50%;
    width: 80%;
    max-width: 260px;
    height: 80px;
    position: absolute;
    top: 50%;
    left: 50%;
    -webkit-transform: translate(-50%, -50%);
    transform: translate(-50%, -50%)
}

.results-card-logo.is-vertical {
    height: 120px
}

.results-card-title {
    font-size: var(--font-size-body);
    font-family: var(--font-family);
    font-weight: 400;
    line-height: 1.65
}

.results-card-body {
    max-width: 45ch
}

.results-card:hover .results-card-figure {
    background-color: var(--card-bg-color)
}

.results-card:hover .results-card-screenshot {
    opacity: 1;
    filter: none;
    -webkit-transform: scale(1);
    transform: scale(1)
}

.results-card:hover .results-card-logo {
    opacity: 0;
    -webkit-transform: scale(2)translate(-25%, -25%);
    transform: scale(2)translate(-25%, -25%)
}

.results-card .results-card-screenshot,
.results-card .results-card-logo,
.results-card-figure {
    transition: all .3s ease-in-out
}

.apppack-bg {
    background: #4d0792
}

.apppack-ribbon-logo {
    width: 140px
}

.apppack-content h3,
.apppack-content p,
.apppack-content a {
    color: #fff
}

.apppack-blockquote {
    margin: 0
}

.apppack-blockquote p {
    font-size: var(--font-size-body);
    color: rgba(255, 255, 255, .7);
    border-color: transparent
}

.apppack-blockquote strong {
    color: #fff
}

.apppack-blockquote cite {
    margin: 0 0 0 calc(12px + 2rem)
}

.apppack-blockquote .blockquote-name {
    margin-bottom: 0
}

.article-list {
    flex-direction: column;
    gap: 4vh;
    display: flex
}

.post-sidebar .article-list {
    gap: 1rem
}

.sidebar-heading {
    font-size: var(--font-size-body)
}

.article-preview {
    background: var(--card-bg);
    border-radius: var(--large-radius);
    flex-direction: column;
    transition: box-shadow .2s linear;
    display: flex;
    position: relative
}

.article-preview:hover {
    box-shadow: var(--brand-shadow-medium)
}

.article-preview-figure {
    aspect-ratio: 2;
    border-radius: var(--large-radius)var(--large-radius)0 0;
    flex-direction: column;
    grid-area: figure;
    justify-content: flex-end;
    margin: 0;
    display: flex;
    overflow: hidden
}


.article-tag-list {
    font-size: var(--font-size-small);
    flex-wrap: wrap;
    gap: .5rem 1rem;
    margin: 0;
    padding: 0;
    list-style: none;
    display: flex
}

.article-tag-list a:before {
    content: "#"
}

.article-tag-list a:after {
    content: "";
    min-height: 36px;
    position: absolute;
    top: auto;
    bottom: 0;
    left: 0;
    right: 0
}

.article-preview:hover .article-preview-img {
    -webkit-transform: scale(1.15);
    transform: scale(1.15)
}

.article-preview-img {
    object-fit: cover;
    width: 100%;
    height: 100%;
    transition: -webkit-transform .2s linear, -webkit-transform .2s linear, transform .2s linear
}

.article-preview-title {
    font-size: var(--font-size-h5);
    margin: 0 0 auto
}

.article-preview-title a:hover {
    color: var(--text-color)
}

.article-preview-title a:after {
    content: "";
    z-index: 1;
    display: block;
    position: absolute;
    top: 0;
    bottom: 0;
    left: 0;
    right: 0
}

.article-preview-body {
    grid-area: body;
    width: 100%;
    padding: 1rem
}

.by-line {
    font-size: var(--font-size-small);
    margin: .5rem 0
}

.article-preview-excerpt {
    display: none
}

@media only screen and (min-width: 50em) {
    .article-preview {
        grid-template: "figure body" 100%/140px 1fr;
        align-content: stretch;
        gap: 1rem;
        display: grid
    }

    .article-preview.no-img {
        padding-left: 1rem;
        display: flex
    }

    .article-preview-title {
        font-size: var(--font-size-h4)
    }

    .article-preview-body {
        flex-direction: column;
        padding: 2rem 2rem 2rem 0;
        display: flex
    }

    .article-preview-figure {
        border-radius: var(--large-radius)0 0 var(--large-radius);
        width: unset;
        aspect-ratio: unset;
        position: static
    }

    .moon-layout-on-large .article-preview-excerpt {
        -webkit-line-clamp: 3;
        -webkit-box-orient: vertical;
        display: -webkit-box;
        overflow: hidden
    }
}

.post-admin-message {
    --stripe-color: rgba(255, 191, 52, .1);
    --stripe-color2: rgba(255, 191, 52, .24);
    background-image: linear-gradient(140deg, var(--stripe-color2)25%, var(--stripe-color)25%, var(--stripe-color)50%, var(--stripe-color2)50%, var(--stripe-color2)75%, var(--stripe-color)75%, var(--stripe-color)100%);
    background-size: 77.79px 65.27px;
    padding: 2rem
}

.breadcrumb {
    justify-content: space-between;
    align-items: center;
    display: flex
}

.breadcrumb-title {
    background: var(--brand-color-alpha-30);
    font-family: var(--heading-font-family);
    text-transform: uppercase;
    padding: .5rem 1rem;
    font-weight: 900
}

.breadcrumb-list {
    font-size: var(--font-size-small);
    margin: 0;
    padding: 0;
    list-style: none;
    display: flex
}

.breadcrumb-list li:after {
    content: ">";
    padding: 0 .5rem;
    display: inline-flex
}

.breadcrumb-list li:last-of-type:after {
    content: unset
}

.card {
    padding: var(--font-size-body);
    background: var(--card-bg);
    border-radius: var(--large-radius);
    position: relative
}

.card-stack {
    flex-direction: column;
    gap: 2rem;
    display: flex
}

.card.small-pad {
    padding: .5rem
}

.card.extra-v-margin {
    margin: 4rem 0
}

.card.has-border {
    border: 1px solid var(--brand-color);
    border-bottom-width: 3px
}

.card.has-shadow {
    box-shadow: var(--brand-shadow)
}

.card.highlight-on-focus:focus-within {
    box-shadow: var(--brand-shadow)
}

.card.has-border>:last-child {
    margin-bottom: 0
}

.card.h-image-card {
    flex-direction: column;
    align-items: center;
    gap: 1rem;
    display: flex
}

.apppack-logo {
    max-width: 200px;
    margin: 2rem auto 0
}

.hpd-book {
    max-width: 120px;
    margin: -30px auto 1rem
}

.shadow-on-hover {
    transition: box-shadow .2s linear
}

.shadow-on-hover:hover {
    box-shadow: var(--brand-shadow-medium)
}

.talk-card {
    flex-direction: column;
    display: flex;
    position: relative
}

.talk-heading {
    margin-bottom: 0
}

.talk-heading a:hover {
    color: var(--text-color)
}

.card.til-card {
    flex-direction: column;
    margin: 2rem 0;
    display: flex
}

.card.til-card svg {
    max-width: 180px;
    margin: 0 0 0 auto
}

.til-card-content {
    padding: var(--font-size-body)var(--font-size-body)0
}

.card.p-0 {
    padding: 0
}

@media only screen and (min-width: 50em) {

    .card.large-pad,
    .card.full-width-pad {
        padding: calc(var(--font-size-body)*2)
    }

    .card.h-image-card {
        flex-direction: row
    }

    .card.h-image-card.reverse-on-large {
        flex-direction: row-reverse
    }

    .apppack-logo {
        margin: 0 40px
    }

    .hpd-book {
        max-width: 160px;
        margin: -30px 20px -48px -7px
    }

    .card.full-width-pad {
        padding: 3rem
    }
}

@media only screen and (min-width: 70em) {
    .card.full-width-pad {
        padding: 3rem 8rem
    }
}

.client-logo-list {
    flex-flow: wrap;
    justify-content: center;
    align-items: center;
    gap: 3rem;
    max-width: 1100px;
    margin: 0 auto;
    padding: 0;
    list-style: none;
    display: flex
}

.client-logo-item {
    text-align: center;
    flex: 1 0 auto
}

@media only screen and (min-width: 50em) {
    .client-logo-list {
        gap: 4.5rem 4rem;
        margin: 3rem auto
    }

    .client-logo-list.tight-gap {
        gap: 2rem
    }
}

.code-snippet {
    margin-left: 0;
    margin-right: 0;
    position: relative
}

.code-snippet .copy-button {
    position: absolute;
    top: 0;
    right: 0
}

.code-snippet .copy-button:not(.success) {
    visibility: hidden
}

.code-snippet:hover .copy-button {
    visibility: visible
}

pre,
code {
    font-family: Menlo, Monaco, monospace
}

pre {
    background: var(--body-bg);
    width: 100%;
    padding: 1rem;
    font-size: .9rem;
    font-weight: 300;
    line-height: 1.4rem;
    overflow: auto
}

pre code {
    display: block
}

code .hll {
    background-color: var(--code-highlight)
}

code {
    background: var(--body-bg);
    color: var(--text-color)
}

code .c {
    color: var(--highlight-comment-color)
}

code .err,
code .g {
    color: var(--highlight-text-color)
}

code .k {
    color: var(--highlight-keyword-color)
}

code .l,
code .n {
    color: var(--highlight-text-color)
}

code .o {
    color: var(--highlight-keyword-color)
}

code .x,
code .p {
    color: var(--highlight-text-color)
}

code .ch,
code .cm {
    color: var(--highlight-comment-color)
}

code .cp {
    color: var(--highlight-keyword-color)
}

code .cpf,
code .c1,
code .cs {
    color: var(--highlight-comment-color)
}

code .gd {
    color: var(--highlight-generic-deleted)
}

code .ge {
    color: var(--highlight-text-color);
    text-decoration: underline
}

code .gr {
    color: var(--highlight-text-color)
}

code .gh,
code .gi {
    color: var(--highlight-text-color);
    font-weight: 700
}

code .go {
    color: var(--highlight-generic-output)
}

code .gp,
code .gs {
    color: var(--highlight-text-color)
}

code .gu {
    color: var(--highlight-text-color);
    font-weight: 700
}

code .gt {
    color: var(--highlight-text-color)
}

code .kc {
    color: var(--highlight-keyword-color)
}

code .kd {
    color: var(--highlight-keyword-declaration);
    font-style: italic
}

code .kn,
code .kp,
code .kr {
    color: var(--highlight-keyword-color)
}

code .kt {
    color: var(--highlight-keyword-declaration)
}

code .ld {
    color: var(--highlight-text-color)
}

code .m {
    color: var(--highlight-literal-number)
}

code .s {
    color: var(--highlight-attribute-color)
}

code .na {
    color: var(--highlight-name-attr)
}

code .nb {
    color: var(--highlight-keyword-declaration);
    font-style: italic
}

code .nc {
    color: var(--highlight-name-attr)
}

code .no,
code .nd,
code .ni,
code .ne {
    color: var(--highlight-text-color)
}

code .nf {
    color: var(--highlight-name-attr)
}

code .nl {
    color: var(--highlight-keyword-declaration);
    font-style: italic
}

code .nn,
code .nx,
code .py {
    color: var(--highlight-text-color)
}

code .nt {
    color: var(--highlight-keyword-color)
}

code .nv {
    color: var(--highlight-keyword-declaration);
    font-style: italic
}

code .ow {
    color: var(--highlight-keyword-color)
}

code .w {
    color: var(--highlight-text-color)
}

code .mb,
code .mf,
code .mh,
code .mi,
code .mo {
    color: var(--highlight-literal-number)
}

code .sa,
code .sb,
code .sc,
code .dl,
code .sd,
code .s2,
code .se,
code .sh,
code .si,
code .sx,
code .sr,
code .s1,
code .ss {
    color: var(--highlight-attribute-color)
}

code .bp {
    color: var(--highlight-text-color);
    font-style: italic
}

code .fm {
    color: var(--highlight-name-attr)
}

code .vc,
code .vg,
code .vi,
code .vm {
    color: var(--highlight-keyword-declaration);
    font-style: italic
}

code .il {
    color: var(--highlight-literal-number)
}

.icon-list {
    grid-template-columns: repeat(auto-fit, minmax(410px, 1fr));
    gap: 3rem;
    margin: 0;
    padding: 0;
    list-style: none;
    display: grid
}

.icon-list li {
    gap: 1.5rem;
    display: flex
}

.icon-list li svg {
    flex: none;
    width: 62px;
    height: 62px
}

.icon-list-heading {
    font-size: var(--font-size-marketing);
    margin: 0;
    font-weight: 600
}

.icon-list-body {
    font-size: var(--font-size-body);
    margin: 0
}

.two-imgs,
.one-img {
    aspect-ratio: 1;
    width: 100%;
    position: relative
}

.two-imgs:after,
.one-img:after {
    aspect-ratio: 1;
    content: "";
    mix-blend-mode: var(--bg-blend-mode);
    opacity: var(--figure-bg-opacity);
    background-image: url(waves.653b8304.54685e368761.svg);
    border-radius: 50%;
    position: absolute;
    top: 0;
    bottom: 0;
    left: 0;
    right: 0
}

.two-imgs .main-img,
.two-imgs .secondary-img,
.one-img .main-img,
.one-img .secondary-img {
    aspect-ratio: 1;
    z-index: 1;
    box-shadow: var(--figure-box-shadow);
    border-radius: 50%;
    width: 75%;
    position: absolute;
    top: 0;
    bottom: auto;
    left: 0;
    right: auto;
    object-fit: cover;
}

.two-imgs .secondary-img {
    z-index: 2;
    width: 50%;
    top: auto;
    bottom: 0;
    left: auto;
    right: 0
}

.one-img:after,
.one-img .main-img {
    width: 85%;
    top: auto;
    bottom: 0;
    left: 0;
    right: auto
}

.one-img .main-img {
    top: 0;
    bottom: auto;
    left: auto;
    right: 0
}

figcaption {
    text-align: center;
    font-size: var(--font-size-small)
}

.pull-right {
    shape-outside: circle(60% at 50% 50%)padding-box;
    width: 70%;
    height: 70%;
    margin: 1rem auto;
    position: relative
}

.pull-right img {
    aspect-ratio: 1;
    object-fit: cover;
    box-shadow: var(--brand-shadow);
    border-radius: 50%;
    width: 100%;
    height: auto
}

.pull-right figcaption {
    box-shadow: var(--brand-shadow);
    background: linear-gradient(314.59deg, #e8fdff 37%, #d1fbff 84.3%);
    border-radius: 50%;
    justify-content: center;
    align-items: center;
    width: 50%;
    height: 50%;
    padding: .5rem;
    display: flex;
    position: absolute;
    top: auto;
    bottom: 0;
    left: auto;
    right: -10%
}




.pull-right [data-open-modal] {
    display: block;
    position: relative
}

.pull-right [data-open-modal]:before,
.pull-right [data-open-modal]:after {
    opacity: .8;
    content: "";
    width: 2.5rem;
    height: 2.5rem;
    display: block;
    position: absolute;
    top: 2.25rem;
    bottom: auto;
    left: auto;
    right: 2.25rem
}

.pull-right [data-open-modal]:hover:before,
.pull-right [data-open-modal]:hover:after {
    opacity: 1
}

.pull-right [data-open-modal]:hover:before {
    background-color: var(--brand-color)
}

.pull-right [data-open-modal]:after {
    background-color: var(--text-color);
    -webkit-mask-image: url(magnifying-glass.1dac9e5a.27b51800ef5a.svg);
    mask-image: url(magnifying-glass.1dac9e5a.27b51800ef5a.svg);
    -webkit-mask-position: 50%;
    mask-position: 50%;
    -webkit-mask-size: 50% 50%;
    mask-size: 50% 50%;
    -webkit-mask-repeat: no-repeat;
    mask-repeat: no-repeat
}

.pull-right [data-open-modal]:before {
    background-color: var(--body-bg);
    box-shadow: var(--brand-shadow);
    border-radius: 50%
}

@media only screen and (min-width: 38em) {
    .pull-right {
        float: right;
        width: 50%;
        height: 50%;
        margin: 2rem
    }

    .pull-right figcaption {
        width: 40%;
        height: 40%;
        top: auto;
        bottom: 0;
        left: auto;
        right: 0
    }
}

@media only screen and (min-width: 84em) {
    .pull-right {
        margin-right: -10%
    }
}

.modal {
    z-index: 100;
    background: var(--card-bg);
    color: var(--text-color);
    border: 0;
    border-radius: 0;
    width: 100%;
    max-width: 75rem;
    height: 100%;
    max-height: 100vh;
    margin: auto;
    padding: 0;
    display: block;
    position: fixed;
    top: 0;
    bottom: 0;
    left: 0;
    right: 0;
    overflow: visible
}

.modal::-webkit-backdrop {
    opacity: .98;
    background: #f0f2f2;
    position: fixed;
    top: 0;
    bottom: 0;
    left: 0;
    right: 0
}

.modal::backdrop {
    opacity: .98;
    background: #f0f2f2;
    position: fixed;
    top: 0;
    bottom: 0;
    left: 0;
    right: 0
}

.modal.has-bg-img {
    background-image: url(modal-bg.d1254cc8.9b48d6631e4d.svg);
    background-position: left -145px bottom -500px;
    background-repeat: no-repeat;
    background-size: 75%
}





.modal:not([open]) {
    display: none
}

.modal-header {
    position: relative
}

.modal-header-inner {
    justify-content: space-between;
    height: 1.5rem;
    margin-top: 1rem;
    padding-left: .75rem;
    display: flex
}

.modal-header .pagination {
    margin: 0
}

.close-button-prefix {
    -webkit-appearance: none;
    appearance: none;
    cursor: pointer;
    color: var(--text-color);
    background: 0 0;
    border: 0;
    gap: 4px;
    font-weight: 700;
    display: flex
}

.close-button-prefix:before {
    content: "×"
}

.modal .scroll-wrap {
    -webkit-overflow-scrolling: touch;
    scrollbar-width: thin;
    z-index: 102;
    height: 100%;
    max-height: calc(100vh - 2.5rem);
    padding: 1rem;
    position: relative;
    overflow: auto
}

.modal .close-button {
    z-index: 101;
    -webkit-appearance: none;
    appearance: none;
    color: var(--text-color);
    background: 0 0;
    border: 0;
    display: flex
}

.modal-figure {
    margin: 0
}

@media only screen and (min-width: 50em) {
    .modal-header-inner {
        margin: 0;
        padding: 0;
        position: absolute;
        top: -32px;
        bottom: auto;
        left: 0;
        right: 0
    }

    .modal {
        height: -webkit-fit-content;
        height: -moz-fit-content;
        height: fit-content;
        max-height: 94vh;
        top: 50%;
        bottom: auto;
        -webkit-transform: translateY(-50%);
        transform: translateY(-50%)
    }

    .modal-figure {
        margin: -2rem 0 -2rem -2rem
    }

    .modal-grid {
        grid-gap: 2rem;
        grid-template-columns: 3fr 2fr;
        display: grid
    }

    .modal .scroll-wrap {
        height: auto;
        max-height: 94vh;
        padding: 2rem
    }
}

.pagination {
    grid-gap: 1rem;
    grid-template-columns: 1fr 1fr;
    grid-template-areas: "prev next";
    align-items: center;
    margin-top: 2rem;
    padding: 0 1rem;
    display: grid
}

.pagination.has-center-circle {
    grid-template-columns: 1fr 1fr 1fr;
    grid-template-areas: "prev label next"
}

.article-list .pagination {
    padding: 0
}

.prev {
    grid-area: prev;
    justify-self: start
}

.next {
    grid-area: next;
    justify-self: end
}

.pagination .label {
    aspect-ratio: 1;
    background: var(--brand-color-alpha-30);
    border-radius: 50%;
    grid-area: label;
    justify-content: center;
    justify-self: center;
    align-items: center;
    gap: .25rem;
    min-height: 80px;
    margin: 0;
    padding: .5rem;
    font-weight: 600;
    display: flex
}

.sep {
    padding-right: 2px;
    font-style: italic;
    font-weight: 400
}

.prev,
.next {
    color: var(--text-color-alpha-40);
    align-items: baseline;
    gap: 4px;
    font-weight: 600;
    text-decoration: none;
    display: flex
}

.prev:hover,
.next:hover {
    color: var(--text-color)
}

.prev:before,
.next:after {
    content: "";
    background-color: currentColor;
    flex: none;
    width: 16px;
    height: 16px;
    display: inline-flex;
    -webkit-transform: translateY(1.5px);
    transform: translateY(1.5px);
    -webkit-mask-image: url(prev-next-arrow.596eabe3.00f196062c1c.svg);
    mask-image: url(prev-next-arrow.596eabe3.00f196062c1c.svg);
    -webkit-mask-size: contain;
    mask-size: contain;
    -webkit-mask-repeat: no-repeat;
    mask-repeat: no-repeat
}

.next {
    text-align: right
}

.next:after {
    -webkit-transform: rotate(180deg)translateY(-1px);
    transform: rotate(180deg)translateY(-1px)
}

.price-heading {
    font-size: var(--font-size-h5);
    font-weight: 700
}

.price {
    flex-direction: column;
    justify-content: flex-end;
    min-height: 130px;
    line-height: 1.4;
    display: flex
}

.price-meta {
    color: var(--text-color-alpha-65)
}

.price-num {
    font-size: var(--font-size-h1);
    font-weight: 600
}

.price-list {
    flex-direction: column;
    gap: 1rem;
    margin: 2rem 0 1rem;
    padding: 0;
    list-style: none;
    display: flex
}

.price-list li {
    padding-left: 1.75rem
}

.price-list li:before {
    content: "";
    background-image: url(data:image/svg+xml;base64,PHN2ZyB3aWR0aD0nMjInIGhlaWdodD0nMjInIHZpZXdCb3g9JzAgMCAyMiAyMicgZmlsbD0nbm9uZScgeG1sbnM9J2h0dHA6Ly93d3cudzMub3JnLzIwMDAvc3ZnJz48cGF0aCBkPSdtNS42NjcgMTIuMDg4IDIuMTc4IDMuMDlhLjkzMy45MzMgMCAwIDAgMS41MTcuMDQ2bDYuOTcyLTguODInIHN0cm9rZT0nI0QzNjUyOScgc3Ryb2tlLXdpZHRoPScxLjgnIHN0cm9rZS1saW5lY2FwPSdyb3VuZCcgc3Ryb2tlLWxpbmVqb2luPSdyb3VuZCcvPjxwYXRoIGQ9J00xIDExYTEwIDEwIDAgMSAwIDIwIDAgMTAgMTAgMCAwIDAtMjAgMHYwWicgc3Ryb2tlPScjRDM2NTI5JyBzdHJva2Utd2lkdGg9JzEuOCcgc3Ryb2tlLWxpbmVjYXA9J3JvdW5kJyBzdHJva2UtbGluZWpvaW49J3JvdW5kJy8+PC9zdmc+);
    background-repeat: no-repeat;
    background-size: contain;
    width: 1.25rem;
    height: 1.25rem;
    margin-left: -1.75rem;
    margin-right: .5rem;
    display: inline-flex;
    -webkit-transform: translateY(4px);
    transform: translateY(4px)
}

.price-list li.strikeout {
    color: var(--text-color-alpha-40)
}

.price-list li.strikeout:before {
    background-image: none
}

.tag-index-heading {
    font-size: var(--font-size-small);
    align-items: center;
    gap: .5rem;
    font-weight: 600;
    display: flex;
    position: relative
}

.tag-index-heading:after {
    content: "";
    background-image: url(select-arrow.7d8f0b0f.b8ad47726f77.svg);
    background-position: 50%;
    background-repeat: no-repeat;
    background-size: 14px 14px;
    width: 14px;
    height: 14px;
    transition: -webkit-transform .2s linear, -webkit-transform .2s linear, transform .2s linear;
    display: flex
}

[data-color-preference=dark] .tag-index-heading:after {
    background-image: url(select-arrow-dark.2f614be1.b8e4981849d6.svg)
}

.tag-index {
    margin: 1rem 0;
    padding: 0;
    list-style: none;
    display: none
}

.tag-index a {
    margin: .25rem 0;
    text-decoration: none;
    display: block
}

.tag-index a[aria-current=page] {
    border-left: 4px solid var(--brand-color);
    margin-left: -10px;
    padding-left: 8px;
    font-weight: 600
}

.tag-index a[aria-current=page]:hover {
    color: var(--text-color);
    text-decoration: none
}

.tag-index a:hover {
    text-decoration: underline
}

.tag-index-checkbox {
    opacity: 0;
    width: 1px;
    height: 1px;
    position: absolute
}

.tag-index-checkbox:checked+.tag-index-heading+.tag-index {
    display: block
}

.tag-index-checkbox:checked+.tag-index-heading:after {
    -webkit-transform: rotate(180deg);
    transform: rotate(180deg)
}

@media only screen and (min-width: 50em) {
    .tag-index {
        display: block
    }

    .tag-index-heading:after {
        content: unset
    }
}

.team-list {
    flex-wrap: wrap;
    justify-content: center;
    align-items: stretch;
    gap: 1rem;
    margin: 0;
    padding: 0;
    list-style: none;
    display: flex
}

.team-item {
    text-align: center;
    background: url(slide-bg.9a727a27.bac7c6f6a808.png) top left no-repeat var(--card-bg);
    aspect-ratio: 1;
    border: 1px solid var(--brand-color-alpha-30);
    z-index: 1;
    background-size: cover;
    border-radius: 12px;
    flex: 100%;
    padding: 4rem;
    transition: all .3s ease-in-out;
    position: relative
}

.team-item:nth-of-type(2) {
    rotate: 7.47deg
}

.team-item:nth-of-type(3) {
    rotate: -.68deg
}

.team-item:nth-of-type(4) {
    rotate: -2.97deg
}

.team-item:nth-of-type(5) {
    rotate: -1.4deg
}

.team-item:nth-of-type(6) {
    rotate: 5.64deg
}

.team-item:nth-of-type(7) {
    rotate: -2.6deg
}

.team-item:nth-of-type(8) {
    rotate: 1deg
}

.team-item:nth-of-type(9) {
    rotate: none
}

.team-item:nth-of-type(10) {
    -webkit-transform: translateY(-10px);
    transform: translateY(-10px)
}

.team-item:nth-of-type(11) {
    rotate: 3.24deg
}

.team-item:nth-of-type(12) {
    rotate: -1deg
}

.team-item:nth-of-type(13) {
    rotate: 6.93deg
}

.team-item:hover {
    z-index: 2;
    rotate: none;
    scale: 1.1;
    box-shadow: 0 20px 25px -5px rgba(0, 0, 0, .1), 0 8px 10px -6px rgba(0, 0, 0, .1)
}

.team-item .avatar {
    object-fit: cover;
    aspect-ratio: 1;
    border-radius: 4px;
    width: 100%
}

.team-item a {
    text-decoration: none
}

.team-item a:hover {
    color: var(--text-color);
    text-decoration: none
}

.team-item .name {
    text-align: center;
    font-family: Delicious Handrawn, cursive;
    font-size: var(--font-size-marketing);
    margin: 0;
    line-height: 1.2;
    position: absolute;
    bottom: 10px;
    left: 0;
    right: 0
}

.team-item .title {
    display: block
}

.team-item .name {
    margin-top: 1rem
}

.full-posts-grid {
    flex-direction: column;
    gap: 1rem;
    display: flex
}

.talk-links {
    gap: 2rem;
    margin: auto 0 0;
    padding-top: 1rem;
    display: flex
}

.talk-links a {
    z-index: 2;
    position: relative
}

.profile-social-nav {
    gap: 1rem;
    display: flex
}

.profile-social-nav .social-link {
    color: var(--text-color-alpha-40)
}

.profile-social-nav .social-link:hover {
    color: var(--accent-color)
}

@media only screen and (min-width: 26em) {
    .team-item {
        flex: 0 calc(50% - 2rem)
    }
}

@media only screen and (min-width: 50em) {
    .team-item {
        flex-basis: 24%
    }

    .full-posts-grid {
        grid-template-columns: repeat(2, 1fr);
        gap: 2rem;
        display: grid;
        container: article-wrapper/inline-size
    }
}

.team-member {
    flex-direction: column;
    align-items: center;
    display: flex
}

.team-member .avatar-wrap {
    flex: 1 0 auto
}

.team-member .headline {
    margin-top: 1rem
}

.team-member .avatar {
    box-shadow: var(--brand-shadow);
    border-radius: 50%;
    width: 120px;
    height: auto;
    display: block
}

.team-member .author-link {
    font-size: var(--font-size-h5)
}

.team-member.avatar-floats-on-mobile {
    display: block
}

.team-member.avatar-floats-on-mobile .avatar-wrap {
    shape-outside: circle(60% at 50% 50%)padding-box;
    float: right;
    width: auto;
    height: auto;
    margin: 1rem 0 1rem 1rem
}

@media only screen and (min-width: 30em) {
    .team-member .avatar {
        width: 200px
    }
}

@media only screen and (min-width: 50em) {
    .team-member {
        flex-direction: row;
        gap: 2rem
    }

    .team-member.avatar-floats-on-mobile {
        margin: 0;
        display: flex
    }

    .team-member.avatar-floats-on-mobile .avatar-wrap {
        margin: 0
    }

    .team-member .headline {
        margin-top: 2rem
    }
}