* {
    margin: 0;
    padding: 0;
}

img,
svg,
video {
    width: 100%;
    height: auto;
}

a {
    text-decoration: none;
}

ul {
    list-style: none;
}

.invisible {
    display: none !important;
}

/* ------------------------------------------------------------------------------------------------ */

/* poppins-300 - latin */
@font-face {
    font-display: swap; /* Check https://developer.mozilla.org/en-US/docs/Web/CSS/@font-face/font-display for other options. */
    font-family: 'Poppins';
    font-style: normal;
    font-weight: 300;
    src: url('../fonts/Poppins/poppins-v20-latin-300.eot'); /* IE9 Compat Modes */
    src: url('../fonts/Poppins/poppins-v20-latin-300.eot?#iefix') format('embedded-opentype'), /* IE6-IE8 */
         url('../fonts/Poppins/poppins-v20-latin-300.woff2') format('woff2'), /* Chrome 36+, Opera 23+, Firefox 39+, Safari 12+, iOS 10+ */
         url('../fonts/Poppins/poppins-v20-latin-300.woff') format('woff'), /* Chrome 5+, Firefox 3.6+, IE 9+, Safari 5.1+, iOS 5+ */
         url('../fonts/Poppins/poppins-v20-latin-300.ttf') format('truetype'), /* Chrome 4+, Firefox 3.5+, IE 9+, Safari 3.1+, iOS 4.2+, Android Browser 2.2+ */
         url('../fonts/Poppins/poppins-v20-latin-300.svg#Poppins') format('svg'); /* Legacy iOS */
  }
  /* poppins-regular - latin */
  @font-face {
    font-display: swap; /* Check https://developer.mozilla.org/en-US/docs/Web/CSS/@font-face/font-display for other options. */
    font-family: 'Poppins';
    font-style: normal;
    font-weight: 400;
    src: url('../fonts/Poppins/poppins-v20-latin-regular.eot'); /* IE9 Compat Modes */
    src: url('../fonts/Poppins/poppins-v20-latin-regular.eot?#iefix') format('embedded-opentype'), /* IE6-IE8 */
         url('../fonts/Poppins/poppins-v20-latin-regular.woff2') format('woff2'), /* Chrome 36+, Opera 23+, Firefox 39+, Safari 12+, iOS 10+ */
         url('../fonts/Poppins/poppins-v20-latin-regular.woff') format('woff'), /* Chrome 5+, Firefox 3.6+, IE 9+, Safari 5.1+, iOS 5+ */
         url('../fonts/Poppins/poppins-v20-latin-regular.ttf') format('truetype'), /* Chrome 4+, Firefox 3.5+, IE 9+, Safari 3.1+, iOS 4.2+, Android Browser 2.2+ */
         url('../fonts/Poppins/poppins-v20-latin-regular.svg#Poppins') format('svg'); /* Legacy iOS */
  }
  /* poppins-600 - latin */
  @font-face {
    font-display: swap; /* Check https://developer.mozilla.org/en-US/docs/Web/CSS/@font-face/font-display for other options. */
    font-family: 'Poppins';
    font-style: normal;
    font-weight: 600;
    src: url('../fonts/Poppins/poppins-v20-latin-600.eot'); /* IE9 Compat Modes */
    src: url('../fonts/Poppins/poppins-v20-latin-600.eot?#iefix') format('embedded-opentype'), /* IE6-IE8 */
         url('../fonts/Poppins/poppins-v20-latin-600.woff2') format('woff2'), /* Chrome 36+, Opera 23+, Firefox 39+, Safari 12+, iOS 10+ */
         url('../fonts/Poppins/poppins-v20-latin-600.woff') format('woff'), /* Chrome 5+, Firefox 3.6+, IE 9+, Safari 5.1+, iOS 5+ */
         url('../fonts/Poppins/poppins-v20-latin-600.ttf') format('truetype'), /* Chrome 4+, Firefox 3.5+, IE 9+, Safari 3.1+, iOS 4.2+, Android Browser 2.2+ */
         url('../fonts/Poppins/poppins-v20-latin-600.svg#Poppins') format('svg'); /* Legacy iOS */
  }
  /* poppins-700 - latin */
  @font-face {
    font-display: swap; /* Check https://developer.mozilla.org/en-US/docs/Web/CSS/@font-face/font-display for other options. */
    font-family: 'Poppins';
    font-style: normal;
    font-weight: 700;
    src: url('../fonts/Poppins/poppins-v20-latin-700.eot'); /* IE9 Compat Modes */
    src: url('../fonts/Poppins/poppins-v20-latin-700.eot?#iefix') format('embedded-opentype'), /* IE6-IE8 */
         url('../fonts/Poppins/poppins-v20-latin-700.woff2') format('woff2'), /* Chrome 36+, Opera 23+, Firefox 39+, Safari 12+, iOS 10+ */
         url('../fonts/Poppins/poppins-v20-latin-700.woff') format('woff'), /* Chrome 5+, Firefox 3.6+, IE 9+, Safari 5.1+, iOS 5+ */
         url('../fonts/Poppins/poppins-v20-latin-700.ttf') format('truetype'), /* Chrome 4+, Firefox 3.5+, IE 9+, Safari 3.1+, iOS 4.2+, Android Browser 2.2+ */
         url('../fonts/Poppins/poppins-v20-latin-700.svg#Poppins') format('svg'); /* Legacy iOS */
  }

/* ------------------------------------------------------------------------------------------------ */

:root {
    --black: #333333;
    --white: #ffffff;
    --grey: #eceff8;
    --lightgrey: #f6f8fc;
    --darkgrey: #aaaaaa;
    --purple: #6161ff;
    --pink: #fb275d;
    --yellow: #ffcc00;
    --green: #00d87e;

    --unit: 40px;

    --font-size: 18px;
    --line-height: 30px;

    --font-size-small: 14px;
    --line-height-small: 26px;

    --font-size-h1: 80px;
    --line-height-h1: 94px;

    --font-size-h2: 40px;
    --line-height-h2: 54px;

    --font-size-h3: 30px;
    --line-height-h3: 44px;

    --font-size-h4: 20px;
    --line-height-h4: 34px;
}

@media only screen and (max-width: 1400px) {
    :root__ {
        --unit: 30px;

        --font-size: 14px;
        --line-height: 26px;
    
        --font-size-small: 14px;
        --line-height-small: 26px;
    
        --font-size-h1: 50px;
        --line-height-h1: 64px;
    
        --font-size-h2: 40px;
        --line-height-h2: 54px;
    
        --font-size-h3: 30px;
        --line-height-h3: 44px;
    
        --font-size-h4: 20px;
        --line-height-h4: 34px;
    }
}

/* ------------------------------------------------------------------------------------------------ */

#GORILLA_NEWSLETTER.disabled {
    pointer-events: none;
}

#GORILLA_NEWSLETTER_SUBSCRIBED {
    display: none;
}

/* ------------------------------------------------------------------------------------------------ */

h1,
h2,
h3 {
    font-weight: 700;
}

h1 {
    font-size: var(--font-size-h1);
    line-height: var(--line-height-h1);
}

h2 {
    font-size: var(--font-size-h2);
    line-height: var(--line-height-h2);
}

h3 {
    font-size: var(--font-size-h3);
    line-height: var(--line-height-h3);
}

h4 {
    font-size: var(--font-size-h4);
    line-height: var(--line-height-h4);
    font-weight: 600;
}

p + h1,
p + h2,
p + h3,
p + h4 {
    margin-top: calc(var(--unit) * 0.5);
}

/* ------------------------------------------------------------------------------------------------ */

small {
    font-size: var(--font-size-small);
    line-height: var(--line-height-small);
    color: var(--darkgrey);
}

/* ------------------------------------------------------------------------------------------------ */

.headline--icon {
    margin-right: calc(var(--unit) * 0.25);
}

/* ------------------------------------------------------------------------------------------------ */

a {
    color: var(--black);
}

/* ------------------------------------------------------------------------------------------------ */

em {
    font-style: normal;
    color: var(--purple);
}

em.pink {
    color: var(--pink);
}

em.yellow {
    color: var(--yellow);
}

em.green {
    color: var(--green);
}

em.white {
    color: var(--white);
}

/* ------------------------------------------------------------------------------------------------ */

strong {
    font-weight: 600;
}

/* ------------------------------------------------------------------------------------------------ */

body {
    background-color: var(--white);

    font-family: 'Poppins', sans-serif;
    font-weight: 400;
    font-size: var(--font-size);
    line-height: var(--line-height);
    color: var(--black);
}

/* ------------------------------------------------------------------------------------------------ */

#header {
    z-index: 1000;
    position: fixed;
    top: 0;
    right: 0;
    left: 0;
    display: flex;
    flex-wrap: nowrap;
    align-items: center;
    padding: 0 calc(var(--unit) * 1);
    width: calc(100% - var(--unit) * 2);
    height: 100px;
    background-color: var(--white);
    box-shadow: 0px 15px 25px rgba(0,0,0,0.05);
    /*border-bottom: 1px solid var(--grey);*/
    transition: transform .2s ease-out, box-shadow .2s ease-out;
}

#header.hidden {
    box-shadow: 0px 25px 50px rgba(0,0,0,0);
    transform: translate3d(0,-100%,0);
}

/* ------------------------------------------------------------------------------------------------ */

.navigation {
    font-size: var(--font-size-small);
    line-height: var(--line-height-small);
}

.navigation:nth-child(n+2) {
    margin-left: calc(var(--unit) * 3);
}

.navigation:nth-child(n+2):first-of-type {
    margin-left: 0;
}

.navigation ul {
    display: flex;
    flex-wrap: nowrap;
    align-items: center;
    height: inherit;
}

.navigation ul:nth-child(n+2) {
    margin-top: calc(var(--unit) * 0.15);
}

.navigation ul li:nth-child(n+2) {
    margin-left: calc(var(--unit) * 0.75);
}

.navigation ul li.active a {
    color: var(--purple);
}

body.green .navigation ul li.active a {
    color: var(--green);
}

.navigation--vertical ul {
    display: block;
}

.navigation--vertical ul li:nth-child(n+2) {
    margin-left: 0;
}

.navigation a {
    color: var(--black);
}

@media (hover: hover) {
    .navigation a {
        transition: color .2s ease-out;
    }

    .navigation a:hover {
        color: var(--purple);
    }

    body.green .navigation a:hover {
        color: var(--green);
    }
}

/* ------------------------------------------------------------------------------------------------ */

#wrapper {
    padding-top: 100px;
}

/* ------------------------------------------------------------------------------------------------ */

#footer {
    
}

#footer .columns,
#footer .columns .column {
    align-items: flex-start;
}

#footer .logo {
    margin-top: 15px;
}

/* ------------------------------------------------------------------------------------------------ */

.background--purple,
.background--pink,
.background--yellow,
.background--green {
    color: var(--white);
}

.background--purple {
    background-color: var(--purple);
}

.background--grey {
    background-color: var(--grey);
}

.background--pink {
    background-color: var(--pink);
}

.background--yellow {
    background-color: var(--yellow);
}

.background--green {
    background-color: var(--green);
}

/* ------------------------------------------------------------------------------------------------ */

.logo {
    display: block;
    margin-right: calc(var(--unit) * 1);
    height: 44px;
}

.logo--large {
    height: 88px;
}

.logo svg {
    width: auto;
    height: 100%;
}

.logo a {
    display: flex;
    flex-wrap: nowrap;
    align-items: center;
    height: inherit;
}

.logo a h4 {
    margin-left: calc(var(--unit) * 0.5);
}

@media (hover: hover) {
    /*
    .logo a svg path {
        transition: fill .2s ease-out;
    }

    .logo a:hover svg path {
        fill: var(--purple);
    }
    */

    .logo a h4 {
        transition: color .2s ease-out;
    }

    .logo a:hover h4 {
        color: var(--purple);
    }

    body.green .logo a:hover h4 {
        color: var(--green);
    }
}

/* ------------------------------------------------------------------------------------------------ */

.section {
    position: relative;
}

/* BANNER */

.section--banner {
    margin: 0;
    padding: calc(var(--unit) * 0.75) calc(var(--unit) * 0.5);
    background-color: var(--purple);

    font-size: var(--font-size-small);
    line-height: var(--line-height-small);
    color: var(--white);
}

.section--banner .content {
    margin-top: 0;
    margin-bottom: 0;
}

.section--banner a {
    border-bottom: 2px solid var(--white);

    color: var(--white);
}

/* COLORS */

.section--pink {
    background-color: var(--pink);
}

.section--yellow {
    background-color: var(--yellow);
}

.section--green {
    background-color: var(--green);
}

.section--pink a, 
.section--yellow a, 
.section--green a {
    color: var(--white);
}

/* ALIGNMENT */

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

/* ------------------------------------------------------------------------------------------------ */

.content {
    position: relative;
    margin: calc(var(--unit) * 3) calc(var(--unit) * 2.5);
    max-width: 1200px;
}

.content--no-margin-top {
    margin-top: 0;
}

.content--no-margin-right {
    margin-right: 0;
}

.content--no-margin-bottom {
    margin-bottom: 0;
}

.content--no-margin-left {
    margin-left: 0;
}

.content--padding-top {
    padding-top: calc(var(--unit) * 3);
}

.content--padding-bottom {
    padding-bottom: calc(var(--unit) * 3);
}

.content--half-margin-top {
    margin-top: calc(var(--unit) * 1.5);
}

.content--half-margin-bottom {
    margin-bottom: calc(var(--unit) * 1.5);
}

@media only screen and (max-width: 1400px) {
    .content {
        margin: 10%;
    }
}

@media only screen and (min-width: 1401px) {
    .content {
        margin-right: auto;
        margin-left: auto;
    }
}

/* ------------------------------------------------------------------------------------------------ */

.breadcrumb {
    padding-bottom: calc(var(--unit) * 1.5);
    border-bottom: 1px solid var(--grey);

    font-size: var(--font-size-small);
    line-height: var(--line-height-small);
}

.breadcrumb ul {
    display: flex;
    flex-wrap: nowrap;
    width: 100%;
}

.breadcrumb ul li:nth-child(n+2) {
    margin-left: calc(var(--unit) * 0.25);
}

.breadcrumb i {
    margin-left: calc(var(--unit) * 0.15);
}

.breadcrumb strong {
    color: var(--purple);
}

body.green .breadcrumb strong {
    color: var(--green);
}

@media (hover: hover) {
    .breadcrumb a {
        transition: color .2s ease-out;
    }

    .breadcrumb a:hover {
        color: var(--purple);
    }

    body.green .breadcrumb a:hover {
        color: var(--green);
    }
}

/* ------------------------------------------------------------------------------------------------ */

.columns {
    display: flex;
    flex-direction: row;
    flex-wrap: wrap;
    align-items: center;
    justify-content: space-between;
    width: 100%;
}

.columns:nth-child(n+2) {
    margin-top: calc(var(--unit) * 1.5);
}

.columns--reverse {
    flex-direction: row-reverse;
}

.column {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    height: 100%;
}

.column--top {
    align-self: flex-start;
}

.column--bottom {
    align-self: flex-end;
}

.column--left {
    justify-content: flex-start;
}

.column--center {
    justify-content: center;
}

.column--right {
    justify-content: flex-end;
}

.columns--5050 .column {
    width: calc(1/2 * 100% - (1 - 1/2) * (var(--unit) * 1.5));
}

.columns--5050-gap .column {
    width: calc(1/2 * 100% - (1 - 1/2) * (var(--unit) * 3));
}

.columns--333333 .column {
    width: calc(1/3 * 100% - (1 - 1/3) * (var(--unit) * 1.5));
}

.columns--25252525 .column {
    width: calc(1/4 * 100% - (1 - 1/4) * (var(--unit) * 1.5));
}

.columns--3366 .column:first-of-type {
    width: calc(1/3 * 100% - (1 - 1/3) * (var(--unit) * 1.5));
}

.columns--3366 .column:last-of-type {
    width: calc(2/3 * 100% - (1 - 2/3) * (var(--unit) * 1.5));
}

.columns--6633 .column:first-of-type {
    width: calc(2/3 * 100% - (1 - 2/3) * (var(--unit) * 1.5));
}

.columns--6633 .column:last-of-type {
    width: calc(1/3 * 100% - (1 - 1/3) * (var(--unit) * 1.5));
}

/* ------------------------------------------------------------------------------------------------ */

.box {
    overflow: hidden;
    padding: calc(var(--unit) * 1.75) calc(var(--unit) * 2);
    width: calc(100% - var(--unit) * 4);
    border-radius: calc(var(--unit) * 0.25);
}

.box:nth-child(n+2) {
    margin-top: calc(var(--unit) * 1);
}

.box--border {
    border: 2px solid var(--white);
}

/* ------------------------------------------------------------------------------------------------ */

.tag {
    padding: 3px 13px;
    background-color: var(--purple);
    border-radius: 5px;

    font-size: var(--font-size-small);
    line-height: var(--line-height-small);
    color: var(--white);
}

.tag.green {
    background-color: var(--green);
}

/* ------------------------------------------------------------------------------------------------ */

.linkslist {
    overflow: hidden;
    border-radius: calc(var(--unit) * 0.25);
    border: 2px solid var(--grey);
}

.linkslist ul li {
    
}

.linkslist ul li:nth-child(n+2) {
    border-top: 2px solid var(--grey);
}

.linkslist ul li a {
    display: flex;
    align-items: center;
    padding: calc(var(--unit) * 0.75) calc(var(--unit) * 1.25) calc(var(--unit) * 0.75) calc(var(--unit) * 1);
}

.linkslist ul li a span {
    display: block;
}

.linkslist ul li a span.index {
    display: flex;
    flex-wrap: nowrap;
    align-items: center;
    justify-content: center;
    margin-right: calc(var(--unit) * 0.75);
    width: calc(var(--unit) * 1.25);
    height: calc(var(--unit) * 1.25);
    border-radius: 100%;
    background-color: var(--purple);

    font-size: var(--font-size);
    line-height: var(--line-height);
    color: var(--white);
}

.linkslist ul li a span.index--green {
    background-color: var(--green);
}

.linkslist ul li a span.info {
    
}

.linkslist ul li a span.icon {
    margin-left: auto;
}

@media (hover: hover) {
    .linkslist a .info strong,
    .linkslist a .icon {
        transition: color .2s ease-out;
    }

    .linkslist a:hover .info strong,
    .linkslist a:hover .icon {
        color: var(--purple);
    }

    .linkslist a:hover .info.info--green strong,
    .linkslist a:hover .icon.icon--green {
        color: var(--green);
    }
}

/* ------------------------------------------------------------------------------------------------ */

form:nth-child(n+2) {
    margin-top: calc(var(--unit) * 0.5);
}

.form--newsletter {
    display: flex;
    flex-wrap: nowrap;
    align-items: center;
    width: 100%;
}

.checkbox {
    display: flex;
    flex-wrap: nowrap;
    align-items: center;
    margin-top: calc(var(--unit) * 0.5);
    width: 100%;

    font-size: var(--font-size-small);
    line-height: var(--line-height-small);
}

label {
    flex: 1 1 auto;
}

label a {
    color: var(--white);
}

input,
button {
    -webkit-appearance: none;
    appearance: none;
    outline: 0;
    border: 0;
    border-radius: 0;
    background: none;
}

input[type=email] {
    flex: 1 1 auto;
    padding: 0 calc(var(--unit) * 0.75);
    height: calc(var(--unit) * 1.5);
    border-radius: calc(var(--unit) * 1.5);
    background-color: var(--white);

    font-family: 'Poppins', sans-serif;
    font-weight: normal;
    font-size: var(--font-size);
    line-height: var(--line-height);
    color: var(--black);
}

input[type=checkbox] {
    cursor: pointer;
    position: relative;
    margin-right: calc(var(--unit) * 0.5);
    width: calc(var(--unit) * 0.75);
    min-width: calc(var(--unit) * 0.75);
    height: calc(var(--unit) * 0.75);
    border-radius: calc(var(--unit) * 0.15);
    border: 2px solid var(--white);

    font-family: 'Poppins', sans-serif;
    font-weight: normal;
    font-size: var(--font-size);
    line-height: var(--line-height);
    color: var(--black);
}

input[type=checkbox]:checked:after {
    content: '';
    position: absolute;
    top: 50%;
    left: 50%;
    display: block;
    width: calc(var(--unit) * 0.25);
    height: calc(var(--unit) * 0.25);
    background-color: var(--white);
    border-radius: calc(var(--unit) * 0.05);
    transform: translate3d(-50%,-50%,0);
}

button[type=submit] {
    cursor: pointer;
    margin-left: calc(var(--unit) * 0.5);
    padding: 0 calc(var(--unit) * 0.75);
    width: calc(var(--unit) * 4);
    height: calc(var(--unit) * 1.5);
    border-radius: calc(var(--unit) * 1.5);
    border: 2px solid var(--white);

    font-family: 'Poppins', sans-serif;
    font-weight: normal;
    font-size: var(--font-size);
    line-height: var(--line-height);
    text-align: center;
    color: var(--white);
}

@media (hover: hover) {
    button[type=submit] {
        transition: width .2s ease-out;
    }

    button[type=submit]:hover {
        width: calc(var(--unit) * 4.5);
    }
}

/* ------------------------------------------------------------------------------------------------ */

.text {
    
}

.text:nth-child(n+2) {
    margin-top: calc(var(--unit) * 1);
}

/* QUICK FOOTER FIX */

.logo + .text:nth-child(n+2) {
    margin-top: 0;
}

.text p:nth-child(n+2),
.text ul:nth-child(n+2),
.text ol:nth-child(n+2) {
    margin-top: calc(var(--unit) * 1);
}

.text h3 + p:nth-child(n+2),
.text h4 + p:nth-child(n+2) {
    margin-top: calc(var(--unit) * 0.5);
}

.text h3 + ol:nth-child(n+2),
.text h4 + ol:nth-child(n+2) {
    margin-top: calc(var(--unit) * 0.5);
}

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

.text--small {
    font-size: var(--font-size-small);
    line-height: var(--line-height-small);
}

.text--small p:nth-child(n+2) {
    margin-top: calc(var(--unit) * 0.15);
}

.text--uppercase p {
    text-transform: uppercase;
}

.text ul {
    list-style: square;
    margin-left: 20px;
}

.text ul.socialmedia {
    list-style: none;
    display: flex;
    flex-wrap: nowrap;
    margin-left: 0;

    font-size: var(--font-size);
    line-height: var(--line-height);
}

.text ul.socialmedia:nth-child(n+2) {
    margin-top: 15px;
}

.text ul.socialmedia li:nth-child(n+2) {
    margin-left: 15px;
}

.text ol {
    margin-left: 20px;
}

.text ol.small {
    font-size: var(--font-size-small);
}

.text ul.margin li:nth-child(n+2) {
    margin-top: 15px;
}

.text ul li::marker {
    color: var(--purple);
}

.text ol li::marker {
    color: var(--purple);
}

body.green .text ol li::marker {
    color: var(--green);
}


.text ul ul:nth-child(n+2) {
    list-style: disc;
    margin-top: 15px;
    margin-left: 40px;
}

.text ul ul:nth-child(n+2) li:nth-child(n+2) {
    margin-top: 0;
}

@media (hover: hover) {
    .text p a:hover em {
        border-bottom: 1px solid var(--purple);
    }

    body.green .text p a:hover em {
        border-bottom: 1px solid var(--green);
    }

    .text ul a:hover em,
    .text ol a:hover em {
        border-bottom: 1px solid var(--purple);
    }

    body.green .text ul a:hover em,
    body.green .text ol a:hover em {
        border-bottom: 1px solid var(--green);
    }

    .text ul.socialmedia a:hover {
        color: var(--purple);
    }

    body.green .text ul.socialmedia a:hover {
        color: var(--green);
    }
}

/* ------------------------------------------------------------------------------------------------ */

.divider {
    margin-top: calc(var(--unit) * 1.5);
    margin-bottom: calc(var(--unit) * 1.5);
    border-bottom: 1px solid var(--grey);

    font-size: 0;
    line-height: 0;
}

/* ------------------------------------------------------------------------------------------------ */

.products {
    display: flex;
    flex-direction: row;
    flex-wrap: wrap;
    align-items: stretch;
    justify-content: space-between;
    width: 100%;
}

.product {
    overflow: hidden;
    display: flex;
    flex-wrap: wrap;
    align-items: flex-start;
    width: calc(1/3 * 100% - (1 - 1/3) * (var(--unit) * 1.5));
    min-height: 530px;
    background-color: var(--white);
    border-radius: calc(var(--unit) * 0.25);
    box-shadow: 0px 10px 30px rgba(0,0,0,0.15);
}

.product:nth-child(n+4) {
    margin-top: calc(var(--unit) * 1.5);
}

.product--blank {
    display: flex;
    flex-direction: row;
    flex-wrap: nowrap;
    align-items: center;
    justify-content: center;
    background-color: var(--lightgrey);
    box-shadow: none;
    border: 1px solid var(--grey);
}

.product--blank svg {
    width: 15%;
}

.product--blank svg path {
    fill: var(--grey);
}

.product .app--card {
    aspect-ratio: auto 1600 / 940;
    background-color: var(--lightgrey);
    line-height: 0;
}

.product .app--meta {
    position: relative;
}

.product .app--meta .app--icon {
    position: absolute;
    top: 0;
    left: 0;
    margin: 0;
    width: calc(var(--unit) * 1.5);
    border-radius: calc(var(--unit) * 0.2);
    border: 3px solid var(--white);
    transform: translate3d(40px,-30%,0);
}

.product .text {
    margin-top: 0 !important;
    padding: 40px;
    padding-top: 70px;
}

.product h2 {
    font-size: var(--font-size-h4);
    line-height: var(--line-height-h4);
}

.product p {
    font-size: var(--font-size-small);
    line-height: var(--line-height-small);
}

.product p:nth-child(n+2) {
    margin-top: calc(var(--unit) * 0.25);
}

.product .columns {
    margin-top: calc(var(--unit) * 0.5);
}

@media (hover: hover) {
    .product:not(.product--blank) {
        transition: transform .2s ease-out, box-shadow .2s ease-out;
    }

    .product:not(.product--blank):hover {
        box-shadow: 0px 30px 40px rgba(0,0,0,0.2);
        transform: translate3d(0,-20px,0);
    }
}

/* ------------------------------------------------------------------------------------------------ */

.faq {
    overflow: hidden;
    border-radius: calc(var(--unit) * 0.25);
    border: 2px solid var(--grey);
}

.faq:nth-child(n+2) {
    margin-top: calc(var(--unit) * 1.5);
}

.item {
    border-top: 2px solid var(--grey);
}

.item.expanded {
    background-color: var(--lightgrey);
}

.item.expanded .answer {
    display: block;
}

.item.expanded .question {
    padding-bottom: calc(var(--unit) * 0.5);

    color: var(--purple);
}

.item.expanded.item--green .question {
    color: var(--green);
}

.item.expanded .question .icon {
    transform: scaleY(-1);
}

.item:first-of-type {
    border-top: 0;
}

.question {
    cursor: pointer;
    display: flex;
    flex-wrap: nowrap;
    align-items: center;
    padding: calc(var(--unit) * 1);
    width: calc(100% - var(--unit) * 2);
}

.question .icon {
    margin-left: auto;

    font-size: var(--font-size-h4);
    line-height: var(--line-height-h4);
}

.answer {
    display: none;
    padding: 0 calc(var(--unit) * 1) calc(var(--unit) * 1) calc(var(--unit) * 1);
}

@media (hover: hover) {
    .item .question {
        transition: color .2s ease-out;
    }

    .item .question:hover {
        color: var(--purple);
    }

    .item.item--green .question:hover {
        color: var(--green);
    }
}

/* ------------------------------------------------------------------------------------------------ */

.list {

}

.list--square {
    list-style: square;
    margin-left: calc(var(--unit) * 0.5);
}

/* ------------------------------------------------------------------------------------------------ */

.buttons {
    display: flex;
    flex-wrap: nowrap;
    align-items: center;
    width: 100%;
}

.buttons--left {
    justify-content: flex-start;
}

.buttons--center {
    justify-content: center;
}

.buttons--right {
    justify-content: flex-end;
}

.buttons:nth-child(n+2) {
    margin-top: calc(var(--unit) * 1);
}

.buttons--monday,
.buttons--monday:nth-child(n+2) {
    margin-top: calc(var(--unit) * 0.75);
}

.button:nth-child(n+2) {
    margin-left: calc(var(--unit) * 0.5);
}

.button a {
    display: flex;
    flex-wrap: nowrap;
    align-items: center;
    justify-content: center;
    width: calc(var(--unit) * 5);
    height: calc(var(--unit) * 1.5);
    border-radius: calc(var(--unit) * 1.5);
    border: 2px solid var(--purple);
}

.button--primary a {
    background-color: var(--purple);

    color: var(--white);
}

.button--secondary a {
    color: var(--purple);
}

.button--small a {
    width: calc(var(--unit) * 4);
    height: calc(var(--unit) * 1);

    font-size: var(--font-size-small);
    line-height: var(--line-height-small);
}

.button--pink.button--primary a {
    border-color: var(--pink);
    background-color: var(--pink);
}

.button--pink.button--secondary a {
    border-color: var(--pink);

    color: var(--pink);
}

.button--white.button--primary a {
    border-color: var(--white);
    background-color: var(--white);

    color: var(--purple);
}

.button--white.button--secondary a {
    border-color: var(--white);

    color: var(--white);
}

.button--yellow.button--primary a {
    border-color: var(--yellow);
    background-color: var(--yellow);
}

.button--yellow.button--secondary a {
    border-color: var(--yellow);

    color: var(--yellow);
}

.button--green.button--primary a {
    border-color: var(--green);
    background-color: var(--green);
}

.button--green.button--secondary a {
    border-color: var(--green);

    color: var(--green);
}

@media (hover: hover) {
    .button a {
        transition: width .2s ease-out;
    }

    .button a:hover {
        width: calc(var(--unit) * 5.5);
    }

    .button--small a:hover {
        width: calc(var(--unit) * 4.5);
    }
}

/* ------------------------------------------------------------------------------------------------ */

.monday-button {
    width: auto;
    height: 42px;

    line-height: 0;
}

.monday-button a {
    display: block;
}

.monday-button:nth-child(n+2) {
    margin-left: calc(var(--unit) * 0.5);
}

.monday-button img {
    width: auto;
    height: 42px;
}

.monday-button--right {
    margin-left: auto;
}

/* ------------------------------------------------------------------------------------------------ */

.screenshot {
    overflow: hidden;
    border-radius: calc(var(--unit) * 0.25);
    box-shadow: 0px 25px 50px rgba(0,0,0,0.2);

    line-height: 0;
}

.screenshot:nth-child(n+2) {
    margin-top: calc(var(--unit) * 1);
}

.screenshot--no-shadow {
    box-shadow: none;
}

.screenshot--no-radius-bottom {
    border-bottom-right-radius: 0;
    border-bottom-left-radius: 0;
}

.screenshot--small-radius {
    border-radius: calc(var(--unit) * 0.1);
    box-shadow: 0px 10px 30px rgba(0,0,0,0.2);
}

/* ------------------------------------------------------------------------------------------------ */

.app--icon {
    overflow: hidden;
    border-radius: calc(var(--unit) * 0.25);
    margin: 0 auto;
    width: calc(var(--unit) * 2);

    line-height: 0;
}

/* ------------------------------------------------------------------------------------------------ */

.compare table {
    overflow-x: scroll;
    width: 100%;
    min-width: 800px;
    border-collapse: collapse;
}

.compare table thead tr td {
    padding: calc(var(--unit) * 0.5) 0;

    font-size: var(--font-size-small);
}

.compare table thead tr td:nth-child(2) {
    border-top: 2px solid var(--grey);
}

.compare table tbody tr td {
    padding: calc(var(--unit) * 0.4) 0;
}

.compare table tr td:nth-child(2) {
    background-color: var(--lightgrey);
}

.compare table tr td {
    border-right: 2px solid var(--grey);
    border-bottom: 2px solid var(--grey);
}

.compare table tr td:nth-child(1) {
    width: 30%;

    font-size: var(--font-size-small);
}

.compare table tr td:nth-child(2),
.compare table tr td:nth-child(3),
.compare table tr td:nth-child(4),
.compare table tr td:nth-child(5) {
    width: 17.5%;
}

.compare table tr:last-of-type td:nth-child(2) {
    border-bottom: 2px solid var(--grey);
}

.compare table tbody tr:last-of-type td {
    border-bottom: 0;
}

.compare table tr td:last-of-type {
    border-right: 0;
}

.compare table tr td:nth-child(n+2) {
    text-align: center;
}