@charset "UTF-8";
/*
 *  Variables and mixins
 *  ---
 *  Our variables first so we can override bootstrap defaults
 *
 */
/*
  Spacer Generator
  ---
  Output a list of spacers with a consistent multiplier
  to standardize spacing of margins, padding, etc.
  -
  Usage
  .selector {
    margin-bottom: spacer(2);
    padding: spacer(1) spacer(3);
  }
*/
/*
  Letter Spacing Converter
  ---
  Allows you to enter letter-spacing values
  as they appear in sketch
  -
  Usage
  .selector {
    @include ls(0.5);
    @include ls(1.5);
  }
*/
/*
 *  Font-smoothing 
 *
 */
/* Build container out of bootstrap includes
 * this allows us to make elements work like containers
 * even inside of media queries
 */
/*
 *  Font-face Based on http://codepen.io/javasteve99/pen/hDxpn
 *
 */
/* mixin for multiline */
/*
  *  External library overrides
  *
  */
/*!
 * Bootstrap v4.6.0 (https://getbootstrap.com/)
 * Copyright 2011-2021 The Bootstrap Authors
 * Copyright 2011-2021 Twitter, Inc.
 * Licensed under MIT (https://github.com/twbs/bootstrap/blob/main/LICENSE)
 */
:root {
    --blue: #007bff;
    --indigo: #6610f2;
    --purple: #6f42c1;
    --pink: #e83e8c;
    --red: #dc3545;
    --orange: #fd7e14;
    --yellow: #ffc107;
    --green: #28a745;
    --teal: #20c997;
    --cyan: #17a2b8;
    --white: #fff;
    --gray: #6c757d;
    --gray-dark: #343a40;
    --primary: #007bff;
    --secondary: #6c757d;
    --success: #28a745;
    --info: #17a2b8;
    --warning: #ffc107;
    --danger: #dc3545;
    --light: #f8f9fa;
    --dark: #343a40;
    --breakpoint-xs: 0;
    --breakpoint-sm: 576px;
    --breakpoint-md: 768px;
    --breakpoint-lg: 992px;
    --breakpoint-xl: 1200px;
    --font-family-sans-serif: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "Helvetica Neue", Arial, "Noto Sans", "Liberation Sans", sans-serif, "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol", "Noto Color Emoji";
    --font-family-monospace: SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace;
}

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

html {
    font-family: sans-serif;
    line-height: 1.15;
    -webkit-text-size-adjust: 100%;
    -webkit-tap-highlight-color: transparent;
}

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

body {
    margin: 0;
    font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "Helvetica Neue", Arial, "Noto Sans", "Liberation Sans", sans-serif, "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol", "Noto Color Emoji";
    font-size: 1rem;
    font-weight: 400;
    line-height: 1.5;
    color: #212529;
    text-align: left;
    background-color: #fff;
}

[tabindex="-1"]:focus:not(:focus-visible) {
    outline: 0 !important;
}

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

h1, h2, h3, h4, h5, h6 {
    margin-top: 0;
    margin-bottom: 0.5rem;
}

p {
    margin-top: 0;
    margin-bottom: 1rem;
}

abbr[title],
abbr[data-original-title] {
    text-decoration: underline;
    text-decoration: underline dotted;
    cursor: help;
    border-bottom: 0;
    text-decoration-skip-ink: none;
}

address {
    margin-bottom: 1rem;
    font-style: normal;
    line-height: inherit;
}

ol,
ul,
dl {
    margin-top: 0;
    margin-bottom: 1rem;
}

    ol ol,
    ul ul,
    ol ul,
    ul ol {
        margin-bottom: 0;
    }

dt {
    font-weight: 700;
}

dd {
    margin-bottom: .5rem;
    margin-left: 0;
}

blockquote {
    margin: 0 0 1rem;
}

b,
strong {
    font-weight: bolder;
}

small {
    font-size: 80%;
}

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

sub {
    bottom: -.25em;
}

sup {
    top: -.5em;
}

a {
    color: #007bff;
    text-decoration: none;
    background-color: transparent;
}

    a:hover {
        color: #0056b3;
        text-decoration: underline;
    }

    a:not([href]):not([class]) {
        color: inherit;
        text-decoration: none;
    }

        a:not([href]):not([class]):hover {
            color: inherit;
            text-decoration: none;
        }

pre,
code,
kbd,
samp {
    font-family: SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace;
    font-size: 1em;
}

pre {
    margin-top: 0;
    margin-bottom: 1rem;
    overflow: auto;
    -ms-overflow-style: scrollbar;
}

figure {
    margin: 0 0 1rem;
}

img {
    vertical-align: middle;
    border-style: none;
}

svg {
    overflow: hidden;
    vertical-align: middle;
}

table {
    border-collapse: collapse;
}

caption {
    padding-top: 0.75rem;
    padding-bottom: 0.75rem;
    color: #6c757d;
    text-align: left;
    caption-side: bottom;
}

th {
    text-align: inherit;
    text-align: -webkit-match-parent;
}

label {
    display: inline-block;
    margin-bottom: 0.5rem;
}

button {
    border-radius: 0;
}

    button:focus:not(:focus-visible) {
        outline: 0;
    }

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

button,
input {
    overflow: visible;
}

button,
select {
    text-transform: none;
}

[role="button"] {
    cursor: pointer;
}

select {
    word-wrap: normal;
}

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

    button:not(:disabled),
    [type="button"]:not(:disabled),
    [type="reset"]:not(:disabled),
    [type="submit"]:not(:disabled) {
        cursor: pointer;
    }

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

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

textarea {
    overflow: auto;
    resize: vertical;
}

fieldset {
    min-width: 0;
    padding: 0;
    margin: 0;
    border: 0;
}

legend {
    display: block;
    width: 100%;
    max-width: 100%;
    padding: 0;
    margin-bottom: .5rem;
    font-size: 1.5rem;
    line-height: inherit;
    color: inherit;
    white-space: normal;
}

progress {
    vertical-align: baseline;
}

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

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

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

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

output {
    display: inline-block;
}

summary {
    display: list-item;
    cursor: pointer;
}

template {
    display: none;
}

[hidden] {
    display: none !important;
}

h1, h2, h3, h4, h5, h6,
.h1, .h2, .h3, .h4, .h5, .h6 {
    margin-bottom: 0.5rem;
    font-weight: 500;
    line-height: 1.2;
}

h1, .h1 {
    font-size: 2.5rem;
}

h2, .h2 {
    font-size: 2rem;
}

h3, .h3 {
    font-size: 1.75rem;
}

h4, .h4 {
    font-size: 1.5rem;
}

h5, .h5 {
    font-size: 1.25rem;
}

h6, .h6 {
    font-size: 1rem;
}

.lead {
    font-size: 1.25rem;
    font-weight: 300;
}

.display-1 {
    font-size: 6rem;
    font-weight: 300;
    line-height: 1.2;
}

.display-2 {
    font-size: 5.5rem;
    font-weight: 300;
    line-height: 1.2;
}

.display-3 {
    font-size: 4.5rem;
    font-weight: 300;
    line-height: 1.2;
}

.display-4 {
    font-size: 3.5rem;
    font-weight: 300;
    line-height: 1.2;
}

hr {
    margin-top: 1rem;
    margin-bottom: 1rem;
    border: 0;
    border-top: 1px solid rgba(0, 0, 0, 0.1);
}

small,
.small {
    font-size: 80%;
    font-weight: 400;
}

mark,
.mark {
    padding: 0.2em;
    background-color: #fcf8e3;
}

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

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

.list-inline-item {
    display: inline-block;
}

    .list-inline-item:not(:last-child) {
        margin-right: 0.5rem;
    }

.initialism {
    font-size: 90%;
    text-transform: uppercase;
}

.blockquote {
    margin-bottom: 1rem;
    font-size: 1.25rem;
}

.blockquote-footer {
    display: block;
    font-size: 80%;
    color: #6c757d;
}

    .blockquote-footer::before {
        content: "\2014\00A0";
    }

.img-fluid, .accordion-content img, .product-gallery-item > img, .carousel-slide-image, .carousel img, .compare-finishes-image {
    max-width: 100%;
    height: auto;
}

.img-thumbnail {
    padding: 0.25rem;
    background-color: #fff;
    border: 1px solid #dee2e6;
    border-radius: 0.25rem;
    max-width: 100%;
    height: auto;
}

.figure {
    display: inline-block;
}

.figure-img {
    margin-bottom: 0.5rem;
    line-height: 1;
}

.figure-caption {
    font-size: 90%;
    color: #6c757d;
}

code {
    font-size: 87.5%;
    color: #e83e8c;
    word-wrap: break-word;
}

a > code {
    color: inherit;
}

kbd {
    padding: 0.2rem 0.4rem;
    font-size: 87.5%;
    color: #fff;
    background-color: #212529;
    border-radius: 0.2rem;
}

    kbd kbd {
        padding: 0;
        font-size: 100%;
        font-weight: 700;
    }

pre {
    display: block;
    font-size: 87.5%;
    color: #212529;
}

    pre code {
        font-size: inherit;
        color: inherit;
        word-break: normal;
    }

.pre-scrollable {
    max-height: 340px;
    overflow-y: scroll;
}

.container, .iframe-container,
.container-fluid,
.container-sm,
.container-md,
.container-lg,
.container-xl {
    width: 100%;
    padding-right: 16px;
    padding-left: 16px;
    margin-right: auto;
    margin-left: auto;
}

@media (min-width: 576px) {
    .container, .iframe-container, .container-sm {
        max-width: 540px;
    }
}

@media (min-width: 768px) {
    .container, .iframe-container, .container-sm, .container-md {
        max-width: 720px;
    }
}

@media (min-width: 992px) {
    .container, .iframe-container, .container-sm, .container-md, .container-lg {
        max-width: 960px;
    }
}

@media (min-width: 1200px) {
    .container, .iframe-container, .container-sm, .container-md, .container-lg, .container-xl {
        max-width: 1140px;
    }
}

.row {
    display: -ms-flexbox;
    display: flex;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
    margin-right: -16px;
    margin-left: -16px;
}

.no-gutters {
    margin-right: 0;
    margin-left: 0;
}

    .no-gutters > .col,
    .no-gutters > [class*="col-"] {
        padding-right: 0;
        padding-left: 0;
    }

.col-1, .col-2, .col-3, .col-4, .col-5, .col-6, .col-7, .col-8, .col-9, .col-10, .col-11, .col-12, .col,
.col-auto, .col-sm-1, .col-sm-2, .col-sm-3, .col-sm-4, .col-sm-5, .col-sm-6, .col-sm-7, .col-sm-8, .col-sm-9, .col-sm-10, .col-sm-11, .col-sm-12, .col-sm,
.col-sm-auto, .col-md-1, .col-md-2, .col-md-3, .col-md-4, .col-md-5, .col-md-6, .col-md-7, .col-md-8, .col-md-9, .col-md-10, .col-md-11, .col-md-12, .col-md,
.col-md-auto, .col-lg-1, .col-lg-2, .col-lg-3, .col-lg-4, .col-lg-5, .col-lg-6, .col-lg-7, .col-lg-8, .col-lg-9, .col-lg-10, .col-lg-11, .col-lg-12, .col-lg,
.col-lg-auto, .col-xl-1, .col-xl-2, .col-xl-3, .col-xl-4, .col-xl-5, .col-xl-6, .col-xl-7, .col-xl-8, .col-xl-9, .col-xl-10, .col-xl-11, .col-xl-12, .col-xl,
.col-xl-auto {
    position: relative;
    width: 100%;
    padding-right: 16px;
    padding-left: 16px;
}

.col {
    -ms-flex-preferred-size: 0;
    flex-basis: 0;
    -ms-flex-positive: 1;
    flex-grow: 1;
    max-width: 100%;
}

.row-cols-1 > * {
    -ms-flex: 0 0 100%;
    flex: 0 0 100%;
    max-width: 100%;
}

.row-cols-2 > * {
    -ms-flex: 0 0 50%;
    flex: 0 0 50%;
    max-width: 50%;
}

.row-cols-3 > * {
    -ms-flex: 0 0 33.33333%;
    flex: 0 0 33.33333%;
    max-width: 33.33333%;
}

.row-cols-4 > * {
    -ms-flex: 0 0 25%;
    flex: 0 0 25%;
    max-width: 25%;
}

.row-cols-5 > * {
    -ms-flex: 0 0 20%;
    flex: 0 0 20%;
    max-width: 20%;
}

.row-cols-6 > * {
    -ms-flex: 0 0 16.66667%;
    flex: 0 0 16.66667%;
    max-width: 16.66667%;
}

.col-auto {
    -ms-flex: 0 0 auto;
    flex: 0 0 auto;
    width: auto;
    max-width: 100%;
}

.col-1 {
    -ms-flex: 0 0 8.33333%;
    flex: 0 0 8.33333%;
    max-width: 8.33333%;
}

.col-2 {
    -ms-flex: 0 0 16.66667%;
    flex: 0 0 16.66667%;
    max-width: 16.66667%;
}

.col-3 {
    -ms-flex: 0 0 25%;
    flex: 0 0 25%;
    max-width: 25%;
}

.col-4 {
    -ms-flex: 0 0 33.33333%;
    flex: 0 0 33.33333%;
    max-width: 33.33333%;
}

.col-5 {
    -ms-flex: 0 0 41.66667%;
    flex: 0 0 41.66667%;
    max-width: 41.66667%;
}

.col-6 {
    -ms-flex: 0 0 50%;
    flex: 0 0 50%;
    max-width: 50%;
}

.col-7 {
    -ms-flex: 0 0 58.33333%;
    flex: 0 0 58.33333%;
    max-width: 58.33333%;
}

.col-8 {
    -ms-flex: 0 0 66.66667%;
    flex: 0 0 66.66667%;
    max-width: 66.66667%;
}

.col-9 {
    -ms-flex: 0 0 75%;
    flex: 0 0 75%;
    max-width: 75%;
}

.col-10 {
    -ms-flex: 0 0 83.33333%;
    flex: 0 0 83.33333%;
    max-width: 83.33333%;
}

.col-11 {
    -ms-flex: 0 0 91.66667%;
    flex: 0 0 91.66667%;
    max-width: 91.66667%;
}

.col-12 {
    -ms-flex: 0 0 100%;
    flex: 0 0 100%;
    max-width: 100%;
}

.order-first {
    -ms-flex-order: -1;
    order: -1;
}

.order-last {
    -ms-flex-order: 13;
    order: 13;
}

.order-0 {
    -ms-flex-order: 0;
    order: 0;
}

.order-1 {
    -ms-flex-order: 1;
    order: 1;
}

.order-2 {
    -ms-flex-order: 2;
    order: 2;
}

.order-3 {
    -ms-flex-order: 3;
    order: 3;
}

.order-4 {
    -ms-flex-order: 4;
    order: 4;
}

.order-5 {
    -ms-flex-order: 5;
    order: 5;
}

.order-6 {
    -ms-flex-order: 6;
    order: 6;
}

.order-7 {
    -ms-flex-order: 7;
    order: 7;
}

.order-8 {
    -ms-flex-order: 8;
    order: 8;
}

.order-9 {
    -ms-flex-order: 9;
    order: 9;
}

.order-10 {
    -ms-flex-order: 10;
    order: 10;
}

.order-11 {
    -ms-flex-order: 11;
    order: 11;
}

.order-12 {
    -ms-flex-order: 12;
    order: 12;
}

.offset-1 {
    margin-left: 8.33333%;
}

.offset-2 {
    margin-left: 16.66667%;
}

.offset-3 {
    margin-left: 25%;
}

.offset-4 {
    margin-left: 33.33333%;
}

.offset-5 {
    margin-left: 41.66667%;
}

.offset-6 {
    margin-left: 50%;
}

.offset-7 {
    margin-left: 58.33333%;
}

.offset-8 {
    margin-left: 66.66667%;
}

.offset-9 {
    margin-left: 75%;
}

.offset-10 {
    margin-left: 83.33333%;
}

.offset-11 {
    margin-left: 91.66667%;
}

@media (min-width: 576px) {
    .col-sm {
        -ms-flex-preferred-size: 0;
        flex-basis: 0;
        -ms-flex-positive: 1;
        flex-grow: 1;
        max-width: 100%;
    }

    .row-cols-sm-1 > * {
        -ms-flex: 0 0 100%;
        flex: 0 0 100%;
        max-width: 100%;
    }

    .row-cols-sm-2 > * {
        -ms-flex: 0 0 50%;
        flex: 0 0 50%;
        max-width: 50%;
    }

    .row-cols-sm-3 > * {
        -ms-flex: 0 0 33.33333%;
        flex: 0 0 33.33333%;
        max-width: 33.33333%;
    }

    .row-cols-sm-4 > * {
        -ms-flex: 0 0 25%;
        flex: 0 0 25%;
        max-width: 25%;
    }

    .row-cols-sm-5 > * {
        -ms-flex: 0 0 20%;
        flex: 0 0 20%;
        max-width: 20%;
    }

    .row-cols-sm-6 > * {
        -ms-flex: 0 0 16.66667%;
        flex: 0 0 16.66667%;
        max-width: 16.66667%;
    }

    .col-sm-auto {
        -ms-flex: 0 0 auto;
        flex: 0 0 auto;
        width: auto;
        max-width: 100%;
    }

    .col-sm-1 {
        -ms-flex: 0 0 8.33333%;
        flex: 0 0 8.33333%;
        max-width: 8.33333%;
    }

    .col-sm-2 {
        -ms-flex: 0 0 16.66667%;
        flex: 0 0 16.66667%;
        max-width: 16.66667%;
    }

    .col-sm-3 {
        -ms-flex: 0 0 25%;
        flex: 0 0 25%;
        max-width: 25%;
    }

    .col-sm-4 {
        -ms-flex: 0 0 33.33333%;
        flex: 0 0 33.33333%;
        max-width: 33.33333%;
    }

    .col-sm-5 {
        -ms-flex: 0 0 41.66667%;
        flex: 0 0 41.66667%;
        max-width: 41.66667%;
    }

    .col-sm-6 {
        -ms-flex: 0 0 50%;
        flex: 0 0 50%;
        max-width: 50%;
    }

    .col-sm-7 {
        -ms-flex: 0 0 58.33333%;
        flex: 0 0 58.33333%;
        max-width: 58.33333%;
    }

    .col-sm-8 {
        -ms-flex: 0 0 66.66667%;
        flex: 0 0 66.66667%;
        max-width: 66.66667%;
    }

    .col-sm-9 {
        -ms-flex: 0 0 75%;
        flex: 0 0 75%;
        max-width: 75%;
    }

    .col-sm-10 {
        -ms-flex: 0 0 83.33333%;
        flex: 0 0 83.33333%;
        max-width: 83.33333%;
    }

    .col-sm-11 {
        -ms-flex: 0 0 91.66667%;
        flex: 0 0 91.66667%;
        max-width: 91.66667%;
    }

    .col-sm-12 {
        -ms-flex: 0 0 100%;
        flex: 0 0 100%;
        max-width: 100%;
    }

    .order-sm-first {
        -ms-flex-order: -1;
        order: -1;
    }

    .order-sm-last {
        -ms-flex-order: 13;
        order: 13;
    }

    .order-sm-0 {
        -ms-flex-order: 0;
        order: 0;
    }

    .order-sm-1 {
        -ms-flex-order: 1;
        order: 1;
    }

    .order-sm-2 {
        -ms-flex-order: 2;
        order: 2;
    }

    .order-sm-3 {
        -ms-flex-order: 3;
        order: 3;
    }

    .order-sm-4 {
        -ms-flex-order: 4;
        order: 4;
    }

    .order-sm-5 {
        -ms-flex-order: 5;
        order: 5;
    }

    .order-sm-6 {
        -ms-flex-order: 6;
        order: 6;
    }

    .order-sm-7 {
        -ms-flex-order: 7;
        order: 7;
    }

    .order-sm-8 {
        -ms-flex-order: 8;
        order: 8;
    }

    .order-sm-9 {
        -ms-flex-order: 9;
        order: 9;
    }

    .order-sm-10 {
        -ms-flex-order: 10;
        order: 10;
    }

    .order-sm-11 {
        -ms-flex-order: 11;
        order: 11;
    }

    .order-sm-12 {
        -ms-flex-order: 12;
        order: 12;
    }

    .offset-sm-0 {
        margin-left: 0;
    }

    .offset-sm-1 {
        margin-left: 8.33333%;
    }

    .offset-sm-2 {
        margin-left: 16.66667%;
    }

    .offset-sm-3 {
        margin-left: 25%;
    }

    .offset-sm-4 {
        margin-left: 33.33333%;
    }

    .offset-sm-5 {
        margin-left: 41.66667%;
    }

    .offset-sm-6 {
        margin-left: 50%;
    }

    .offset-sm-7 {
        margin-left: 58.33333%;
    }

    .offset-sm-8 {
        margin-left: 66.66667%;
    }

    .offset-sm-9 {
        margin-left: 75%;
    }

    .offset-sm-10 {
        margin-left: 83.33333%;
    }

    .offset-sm-11 {
        margin-left: 91.66667%;
    }
}

@media (min-width: 768px) {
    .col-md {
        -ms-flex-preferred-size: 0;
        flex-basis: 0;
        -ms-flex-positive: 1;
        flex-grow: 1;
        max-width: 100%;
    }

    .row-cols-md-1 > * {
        -ms-flex: 0 0 100%;
        flex: 0 0 100%;
        max-width: 100%;
    }

    .row-cols-md-2 > * {
        -ms-flex: 0 0 50%;
        flex: 0 0 50%;
        max-width: 50%;
    }

    .row-cols-md-3 > * {
        -ms-flex: 0 0 33.33333%;
        flex: 0 0 33.33333%;
        max-width: 33.33333%;
    }

    .row-cols-md-4 > * {
        -ms-flex: 0 0 25%;
        flex: 0 0 25%;
        max-width: 25%;
    }

    .row-cols-md-5 > * {
        -ms-flex: 0 0 20%;
        flex: 0 0 20%;
        max-width: 20%;
    }

    .row-cols-md-6 > * {
        -ms-flex: 0 0 16.66667%;
        flex: 0 0 16.66667%;
        max-width: 16.66667%;
    }

    .col-md-auto {
        -ms-flex: 0 0 auto;
        flex: 0 0 auto;
        width: auto;
        max-width: 100%;
    }

    .col-md-1 {
        -ms-flex: 0 0 8.33333%;
        flex: 0 0 8.33333%;
        max-width: 8.33333%;
    }

    .col-md-2 {
        -ms-flex: 0 0 16.66667%;
        flex: 0 0 16.66667%;
        max-width: 16.66667%;
    }

    .col-md-3 {
        -ms-flex: 0 0 25%;
        flex: 0 0 25%;
        max-width: 25%;
    }

    .col-md-4 {
        -ms-flex: 0 0 33.33333%;
        flex: 0 0 33.33333%;
        max-width: 33.33333%;
    }

    .col-md-5 {
        -ms-flex: 0 0 41.66667%;
        flex: 0 0 41.66667%;
        max-width: 41.66667%;
    }

    .col-md-6 {
        -ms-flex: 0 0 50%;
        flex: 0 0 50%;
        max-width: 50%;
    }

    .col-md-7 {
        -ms-flex: 0 0 58.33333%;
        flex: 0 0 58.33333%;
        max-width: 58.33333%;
    }

    .col-md-8 {
        -ms-flex: 0 0 66.66667%;
        flex: 0 0 66.66667%;
        max-width: 66.66667%;
    }

    .col-md-9 {
        -ms-flex: 0 0 75%;
        flex: 0 0 75%;
        max-width: 75%;
    }

    .col-md-10 {
        -ms-flex: 0 0 83.33333%;
        flex: 0 0 83.33333%;
        max-width: 83.33333%;
    }

    .col-md-11 {
        -ms-flex: 0 0 91.66667%;
        flex: 0 0 91.66667%;
        max-width: 91.66667%;
    }

    .col-md-12 {
        -ms-flex: 0 0 100%;
        flex: 0 0 100%;
        max-width: 100%;
    }

    .order-md-first {
        -ms-flex-order: -1;
        order: -1;
    }

    .order-md-last {
        -ms-flex-order: 13;
        order: 13;
    }

    .order-md-0 {
        -ms-flex-order: 0;
        order: 0;
    }

    .order-md-1 {
        -ms-flex-order: 1;
        order: 1;
    }

    .order-md-2 {
        -ms-flex-order: 2;
        order: 2;
    }

    .order-md-3 {
        -ms-flex-order: 3;
        order: 3;
    }

    .order-md-4 {
        -ms-flex-order: 4;
        order: 4;
    }

    .order-md-5 {
        -ms-flex-order: 5;
        order: 5;
    }

    .order-md-6 {
        -ms-flex-order: 6;
        order: 6;
    }

    .order-md-7 {
        -ms-flex-order: 7;
        order: 7;
    }

    .order-md-8 {
        -ms-flex-order: 8;
        order: 8;
    }

    .order-md-9 {
        -ms-flex-order: 9;
        order: 9;
    }

    .order-md-10 {
        -ms-flex-order: 10;
        order: 10;
    }

    .order-md-11 {
        -ms-flex-order: 11;
        order: 11;
    }

    .order-md-12 {
        -ms-flex-order: 12;
        order: 12;
    }

    .offset-md-0 {
        margin-left: 0;
    }

    .offset-md-1 {
        margin-left: 8.33333%;
    }

    .offset-md-2 {
        margin-left: 16.66667%;
    }

    .offset-md-3 {
        margin-left: 25%;
    }

    .offset-md-4 {
        margin-left: 33.33333%;
    }

    .offset-md-5 {
        margin-left: 41.66667%;
    }

    .offset-md-6 {
        margin-left: 50%;
    }

    .offset-md-7 {
        margin-left: 58.33333%;
    }

    .offset-md-8 {
        margin-left: 66.66667%;
    }

    .offset-md-9 {
        margin-left: 75%;
    }

    .offset-md-10 {
        margin-left: 83.33333%;
    }

    .offset-md-11 {
        margin-left: 91.66667%;
    }
}

@media (min-width: 992px) {
    .col-lg {
        -ms-flex-preferred-size: 0;
        flex-basis: 0;
        -ms-flex-positive: 1;
        flex-grow: 1;
        max-width: 100%;
    }

    .row-cols-lg-1 > * {
        -ms-flex: 0 0 100%;
        flex: 0 0 100%;
        max-width: 100%;
    }

    .row-cols-lg-2 > * {
        -ms-flex: 0 0 50%;
        flex: 0 0 50%;
        max-width: 50%;
    }

    .row-cols-lg-3 > * {
        -ms-flex: 0 0 33.33333%;
        flex: 0 0 33.33333%;
        max-width: 33.33333%;
    }

    .row-cols-lg-4 > * {
        -ms-flex: 0 0 25%;
        flex: 0 0 25%;
        max-width: 25%;
    }

    .row-cols-lg-5 > * {
        -ms-flex: 0 0 20%;
        flex: 0 0 20%;
        max-width: 20%;
    }

    .row-cols-lg-6 > * {
        -ms-flex: 0 0 16.66667%;
        flex: 0 0 16.66667%;
        max-width: 16.66667%;
    }

    .col-lg-auto {
        -ms-flex: 0 0 auto;
        flex: 0 0 auto;
        width: auto;
        max-width: 100%;
    }

    .col-lg-1 {
        -ms-flex: 0 0 8.33333%;
        flex: 0 0 8.33333%;
        max-width: 8.33333%;
    }

    .col-lg-2 {
        -ms-flex: 0 0 16.66667%;
        flex: 0 0 16.66667%;
        max-width: 16.66667%;
    }

    .col-lg-3 {
        -ms-flex: 0 0 25%;
        flex: 0 0 25%;
        max-width: 25%;
    }

    .col-lg-4 {
        -ms-flex: 0 0 33.33333%;
        flex: 0 0 33.33333%;
        max-width: 33.33333%;
    }

    .col-lg-5 {
        -ms-flex: 0 0 41.66667%;
        flex: 0 0 41.66667%;
        max-width: 41.66667%;
    }

    .col-lg-6 {
        -ms-flex: 0 0 50%;
        flex: 0 0 50%;
        max-width: 50%;
    }

    .col-lg-7 {
        -ms-flex: 0 0 58.33333%;
        flex: 0 0 58.33333%;
        max-width: 58.33333%;
    }

    .col-lg-8 {
        -ms-flex: 0 0 66.66667%;
        flex: 0 0 66.66667%;
        max-width: 66.66667%;
    }

    .col-lg-9 {
        -ms-flex: 0 0 75%;
        flex: 0 0 75%;
        max-width: 75%;
    }

    .col-lg-10 {
        -ms-flex: 0 0 83.33333%;
        flex: 0 0 83.33333%;
        max-width: 83.33333%;
    }

    .col-lg-11 {
        -ms-flex: 0 0 91.66667%;
        flex: 0 0 91.66667%;
        max-width: 91.66667%;
    }

    .col-lg-12 {
        -ms-flex: 0 0 100%;
        flex: 0 0 100%;
        max-width: 100%;
    }

    .order-lg-first {
        -ms-flex-order: -1;
        order: -1;
    }

    .order-lg-last {
        -ms-flex-order: 13;
        order: 13;
    }

    .order-lg-0 {
        -ms-flex-order: 0;
        order: 0;
    }

    .order-lg-1 {
        -ms-flex-order: 1;
        order: 1;
    }

    .order-lg-2 {
        -ms-flex-order: 2;
        order: 2;
    }

    .order-lg-3 {
        -ms-flex-order: 3;
        order: 3;
    }

    .order-lg-4 {
        -ms-flex-order: 4;
        order: 4;
    }

    .order-lg-5 {
        -ms-flex-order: 5;
        order: 5;
    }

    .order-lg-6 {
        -ms-flex-order: 6;
        order: 6;
    }

    .order-lg-7 {
        -ms-flex-order: 7;
        order: 7;
    }

    .order-lg-8 {
        -ms-flex-order: 8;
        order: 8;
    }

    .order-lg-9 {
        -ms-flex-order: 9;
        order: 9;
    }

    .order-lg-10 {
        -ms-flex-order: 10;
        order: 10;
    }

    .order-lg-11 {
        -ms-flex-order: 11;
        order: 11;
    }

    .order-lg-12 {
        -ms-flex-order: 12;
        order: 12;
    }

    .offset-lg-0 {
        margin-left: 0;
    }

    .offset-lg-1 {
        margin-left: 8.33333%;
    }

    .offset-lg-2 {
        margin-left: 16.66667%;
    }

    .offset-lg-3 {
        margin-left: 25%;
    }

    .offset-lg-4 {
        margin-left: 33.33333%;
    }

    .offset-lg-5 {
        margin-left: 41.66667%;
    }

    .offset-lg-6 {
        margin-left: 50%;
    }

    .offset-lg-7 {
        margin-left: 58.33333%;
    }

    .offset-lg-8 {
        margin-left: 66.66667%;
    }

    .offset-lg-9 {
        margin-left: 75%;
    }

    .offset-lg-10 {
        margin-left: 83.33333%;
    }

    .offset-lg-11 {
        margin-left: 91.66667%;
    }
}

@media (min-width: 1200px) {
    .col-xl {
        -ms-flex-preferred-size: 0;
        flex-basis: 0;
        -ms-flex-positive: 1;
        flex-grow: 1;
        max-width: 100%;
    }

    .row-cols-xl-1 > * {
        -ms-flex: 0 0 100%;
        flex: 0 0 100%;
        max-width: 100%;
    }

    .row-cols-xl-2 > * {
        -ms-flex: 0 0 50%;
        flex: 0 0 50%;
        max-width: 50%;
    }

    .row-cols-xl-3 > * {
        -ms-flex: 0 0 33.33333%;
        flex: 0 0 33.33333%;
        max-width: 33.33333%;
    }

    .row-cols-xl-4 > * {
        -ms-flex: 0 0 25%;
        flex: 0 0 25%;
        max-width: 25%;
    }

    .row-cols-xl-5 > * {
        -ms-flex: 0 0 20%;
        flex: 0 0 20%;
        max-width: 20%;
    }

    .row-cols-xl-6 > * {
        -ms-flex: 0 0 16.66667%;
        flex: 0 0 16.66667%;
        max-width: 16.66667%;
    }

    .col-xl-auto {
        -ms-flex: 0 0 auto;
        flex: 0 0 auto;
        width: auto;
        max-width: 100%;
    }

    .col-xl-1 {
        -ms-flex: 0 0 8.33333%;
        flex: 0 0 8.33333%;
        max-width: 8.33333%;
    }

    .col-xl-2 {
        -ms-flex: 0 0 16.66667%;
        flex: 0 0 16.66667%;
        max-width: 16.66667%;
    }

    .col-xl-3 {
        -ms-flex: 0 0 25%;
        flex: 0 0 25%;
        max-width: 25%;
    }

    .col-xl-4 {
        -ms-flex: 0 0 33.33333%;
        flex: 0 0 33.33333%;
        max-width: 33.33333%;
    }

    .col-xl-5 {
        -ms-flex: 0 0 41.66667%;
        flex: 0 0 41.66667%;
        max-width: 41.66667%;
    }

    .col-xl-6 {
        -ms-flex: 0 0 50%;
        flex: 0 0 50%;
        max-width: 50%;
    }

    .col-xl-7 {
        -ms-flex: 0 0 58.33333%;
        flex: 0 0 58.33333%;
        max-width: 58.33333%;
    }

    .col-xl-8 {
        -ms-flex: 0 0 66.66667%;
        flex: 0 0 66.66667%;
        max-width: 66.66667%;
    }

    .col-xl-9 {
        -ms-flex: 0 0 75%;
        flex: 0 0 75%;
        max-width: 75%;
    }

    .col-xl-10 {
        -ms-flex: 0 0 83.33333%;
        flex: 0 0 83.33333%;
        max-width: 83.33333%;
    }

    .col-xl-11 {
        -ms-flex: 0 0 91.66667%;
        flex: 0 0 91.66667%;
        max-width: 91.66667%;
    }

    .col-xl-12 {
        -ms-flex: 0 0 100%;
        flex: 0 0 100%;
        max-width: 100%;
    }

    .order-xl-first {
        -ms-flex-order: -1;
        order: -1;
    }

    .order-xl-last {
        -ms-flex-order: 13;
        order: 13;
    }

    .order-xl-0 {
        -ms-flex-order: 0;
        order: 0;
    }

    .order-xl-1 {
        -ms-flex-order: 1;
        order: 1;
    }

    .order-xl-2 {
        -ms-flex-order: 2;
        order: 2;
    }

    .order-xl-3 {
        -ms-flex-order: 3;
        order: 3;
    }

    .order-xl-4 {
        -ms-flex-order: 4;
        order: 4;
    }

    .order-xl-5 {
        -ms-flex-order: 5;
        order: 5;
    }

    .order-xl-6 {
        -ms-flex-order: 6;
        order: 6;
    }

    .order-xl-7 {
        -ms-flex-order: 7;
        order: 7;
    }

    .order-xl-8 {
        -ms-flex-order: 8;
        order: 8;
    }

    .order-xl-9 {
        -ms-flex-order: 9;
        order: 9;
    }

    .order-xl-10 {
        -ms-flex-order: 10;
        order: 10;
    }

    .order-xl-11 {
        -ms-flex-order: 11;
        order: 11;
    }

    .order-xl-12 {
        -ms-flex-order: 12;
        order: 12;
    }

    .offset-xl-0 {
        margin-left: 0;
    }

    .offset-xl-1 {
        margin-left: 8.33333%;
    }

    .offset-xl-2 {
        margin-left: 16.66667%;
    }

    .offset-xl-3 {
        margin-left: 25%;
    }

    .offset-xl-4 {
        margin-left: 33.33333%;
    }

    .offset-xl-5 {
        margin-left: 41.66667%;
    }

    .offset-xl-6 {
        margin-left: 50%;
    }

    .offset-xl-7 {
        margin-left: 58.33333%;
    }

    .offset-xl-8 {
        margin-left: 66.66667%;
    }

    .offset-xl-9 {
        margin-left: 75%;
    }

    .offset-xl-10 {
        margin-left: 83.33333%;
    }

    .offset-xl-11 {
        margin-left: 91.66667%;
    }
}

.table {
    width: 100%;
    margin-bottom: 1rem;
    color: #212529;
}

    .table th,
    .table td {
        padding: 0.75rem;
        vertical-align: top;
        border-top: 1px solid #dee2e6;
    }

    .table thead th {
        vertical-align: bottom;
        border-bottom: 2px solid #dee2e6;
    }

    .table tbody + tbody {
        border-top: 2px solid #dee2e6;
    }

.table-sm th,
.table-sm td {
    padding: 0.3rem;
}

.table-bordered {
    border: 1px solid #dee2e6;
}

    .table-bordered th,
    .table-bordered td {
        border: 1px solid #dee2e6;
    }

    .table-bordered thead th,
    .table-bordered thead td {
        border-bottom-width: 2px;
    }

.table-borderless th,
.table-borderless td,
.table-borderless thead th,
.table-borderless tbody + tbody {
    border: 0;
}

.table-striped tbody tr:nth-of-type(odd) {
    background-color: rgba(0, 0, 0, 0.05);
}

.table-hover tbody tr:hover {
    color: #212529;
    background-color: rgba(0, 0, 0, 0.075);
}

.table-primary,
.table-primary > th,
.table-primary > td {
    background-color: #b8daff;
}

    .table-primary th,
    .table-primary td,
    .table-primary thead th,
    .table-primary tbody + tbody {
        border-color: #7abaff;
    }

.table-hover .table-primary:hover {
    background-color: #9fcdff;
}

    .table-hover .table-primary:hover > td,
    .table-hover .table-primary:hover > th {
        background-color: #9fcdff;
    }

.table-secondary,
.table-secondary > th,
.table-secondary > td {
    background-color: #d6d8db;
}

    .table-secondary th,
    .table-secondary td,
    .table-secondary thead th,
    .table-secondary tbody + tbody {
        border-color: #b3b7bb;
    }

.table-hover .table-secondary:hover {
    background-color: #c8cbcf;
}

    .table-hover .table-secondary:hover > td,
    .table-hover .table-secondary:hover > th {
        background-color: #c8cbcf;
    }

.table-success,
.table-success > th,
.table-success > td {
    background-color: #c3e6cb;
}

    .table-success th,
    .table-success td,
    .table-success thead th,
    .table-success tbody + tbody {
        border-color: #8fd19e;
    }

.table-hover .table-success:hover {
    background-color: #b1dfbb;
}

    .table-hover .table-success:hover > td,
    .table-hover .table-success:hover > th {
        background-color: #b1dfbb;
    }

.table-info,
.table-info > th,
.table-info > td {
    background-color: #bee5eb;
}

    .table-info th,
    .table-info td,
    .table-info thead th,
    .table-info tbody + tbody {
        border-color: #86cfda;
    }

.table-hover .table-info:hover {
    background-color: #abdde5;
}

    .table-hover .table-info:hover > td,
    .table-hover .table-info:hover > th {
        background-color: #abdde5;
    }

.table-warning,
.table-warning > th,
.table-warning > td {
    background-color: #ffeeba;
}

    .table-warning th,
    .table-warning td,
    .table-warning thead th,
    .table-warning tbody + tbody {
        border-color: #ffdf7e;
    }

.table-hover .table-warning:hover {
    background-color: #ffe8a1;
}

    .table-hover .table-warning:hover > td,
    .table-hover .table-warning:hover > th {
        background-color: #ffe8a1;
    }

.table-danger,
.table-danger > th,
.table-danger > td {
    background-color: #f5c6cb;
}

    .table-danger th,
    .table-danger td,
    .table-danger thead th,
    .table-danger tbody + tbody {
        border-color: #ed969e;
    }

.table-hover .table-danger:hover {
    background-color: #f1b0b7;
}

    .table-hover .table-danger:hover > td,
    .table-hover .table-danger:hover > th {
        background-color: #f1b0b7;
    }

.table-light,
.table-light > th,
.table-light > td {
    background-color: #fdfdfe;
}

    .table-light th,
    .table-light td,
    .table-light thead th,
    .table-light tbody + tbody {
        border-color: #fbfcfc;
    }

.table-hover .table-light:hover {
    background-color: #ececf6;
}

    .table-hover .table-light:hover > td,
    .table-hover .table-light:hover > th {
        background-color: #ececf6;
    }

.table-dark,
.table-dark > th,
.table-dark > td {
    background-color: #c6c8ca;
}

    .table-dark th,
    .table-dark td,
    .table-dark thead th,
    .table-dark tbody + tbody {
        border-color: #95999c;
    }

.table-hover .table-dark:hover {
    background-color: #b9bbbe;
}

    .table-hover .table-dark:hover > td,
    .table-hover .table-dark:hover > th {
        background-color: #b9bbbe;
    }

.table-active,
.table-active > th,
.table-active > td {
    background-color: rgba(0, 0, 0, 0.075);
}

.table-hover .table-active:hover {
    background-color: rgba(0, 0, 0, 0.075);
}

    .table-hover .table-active:hover > td,
    .table-hover .table-active:hover > th {
        background-color: rgba(0, 0, 0, 0.075);
    }

.table .thead-dark th {
    color: #fff;
    background-color: #343a40;
    border-color: #454d55;
}

.table .thead-light th {
    color: #495057;
    background-color: #e9ecef;
    border-color: #dee2e6;
}

.table-dark {
    color: #fff;
    background-color: #343a40;
}

    .table-dark th,
    .table-dark td,
    .table-dark thead th {
        border-color: #454d55;
    }

    .table-dark.table-bordered {
        border: 0;
    }

    .table-dark.table-striped tbody tr:nth-of-type(odd) {
        background-color: rgba(255, 255, 255, 0.05);
    }

    .table-dark.table-hover tbody tr:hover {
        color: #fff;
        background-color: rgba(255, 255, 255, 0.075);
    }

@media (max-width: 575.98px) {
    .table-responsive-sm {
        display: block;
        width: 100%;
        overflow-x: auto;
        -webkit-overflow-scrolling: touch;
    }

        .table-responsive-sm > .table-bordered {
            border: 0;
        }
}

@media (max-width: 767.98px) {
    .table-responsive-md {
        display: block;
        width: 100%;
        overflow-x: auto;
        -webkit-overflow-scrolling: touch;
    }

        .table-responsive-md > .table-bordered {
            border: 0;
        }
}

@media (max-width: 991.98px) {
    .table-responsive-lg {
        display: block;
        width: 100%;
        overflow-x: auto;
        -webkit-overflow-scrolling: touch;
    }

        .table-responsive-lg > .table-bordered {
            border: 0;
        }
}

@media (max-width: 1199.98px) {
    .table-responsive-xl {
        display: block;
        width: 100%;
        overflow-x: auto;
        -webkit-overflow-scrolling: touch;
    }

        .table-responsive-xl > .table-bordered {
            border: 0;
        }
}

.table-responsive {
    display: block;
    width: 100%;
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
}

    .table-responsive > .table-bordered {
        border: 0;
    }

.form-control {
    display: block;
    width: 100%;
    height: calc(1.5em + 0.75rem + 2px);
    padding: 0.375rem 0.75rem;
    font-size: 1rem;
    font-weight: 400;
    line-height: 1.5;
    color: #495057;
    background-color: #fff;
    background-clip: padding-box;
    border: 1px solid #ced4da;
    border-radius: 0.25rem;
    transition: border-color 0.15s ease-in-out, box-shadow 0.15s ease-in-out;
}

@media (prefers-reduced-motion: reduce) {
    .form-control {
        transition: none;
    }
}

.form-control::-ms-expand {
    background-color: transparent;
    border: 0;
}

.form-control:-moz-focusring {
    color: transparent;
    text-shadow: 0 0 0 #495057;
}

.form-control:focus {
    color: #495057;
    background-color: #fff;
    border-color: #80bdff;
    outline: 0;
    box-shadow: 0 0 0 0.2rem rgba(0, 123, 255, 0.25);
}

.form-control:-ms-input-placeholder {
    color: #6c757d;
    opacity: 1;
}

.form-control::placeholder {
    color: #6c757d;
    opacity: 1;
}

.form-control:disabled, .form-control[readonly] {
    background-color: #e9ecef;
    opacity: 1;
}

input[type="date"].form-control,
input[type="time"].form-control,
input[type="datetime-local"].form-control,
input[type="month"].form-control {
    -webkit-appearance: none;
    -moz-appearance: none;
    appearance: none;
}

select.form-control:focus::-ms-value {
    color: #495057;
    background-color: #fff;
}

.form-control-file,
.form-control-range {
    display: block;
    width: 100%;
}

.col-form-label {
    padding-top: calc(0.375rem + 1px);
    padding-bottom: calc(0.375rem + 1px);
    margin-bottom: 0;
    font-size: inherit;
    line-height: 1.5;
}

.col-form-label-lg {
    padding-top: calc(0.5rem + 1px);
    padding-bottom: calc(0.5rem + 1px);
    font-size: 1.25rem;
    line-height: 1.5;
}

.col-form-label-sm {
    padding-top: calc(0.25rem + 1px);
    padding-bottom: calc(0.25rem + 1px);
    font-size: 0.875rem;
    line-height: 1.5;
}

.form-control-plaintext {
    display: block;
    width: 100%;
    padding: 0.375rem 0;
    margin-bottom: 0;
    font-size: 1rem;
    line-height: 1.5;
    color: #212529;
    background-color: transparent;
    border: solid transparent;
    border-width: 1px 0;
}

    .form-control-plaintext.form-control-sm, .form-control-plaintext.form-control-lg {
        padding-right: 0;
        padding-left: 0;
    }

.form-control-sm {
    height: calc(1.5em + 0.5rem + 2px);
    padding: 0.25rem 0.5rem;
    font-size: 0.875rem;
    line-height: 1.5;
    border-radius: 0.2rem;
}

.form-control-lg {
    height: calc(1.5em + 1rem + 2px);
    padding: 0.5rem 1rem;
    font-size: 1.25rem;
    line-height: 1.5;
    border-radius: 0.3rem;
}

select.form-control[size], select.form-control[multiple] {
    height: auto;
}

textarea.form-control {
    height: auto;
}

.form-group {
    margin-bottom: 1rem;
}

.form-text {
    display: block;
    margin-top: 0.25rem;
}

.form-row {
    display: -ms-flexbox;
    display: flex;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
    margin-right: -5px;
    margin-left: -5px;
}

    .form-row > .col,
    .form-row > [class*="col-"] {
        padding-right: 5px;
        padding-left: 5px;
    }

.form-check {
    position: relative;
    display: block;
    padding-left: 1.25rem;
}

.form-check-input {
    position: absolute;
    margin-top: 0.3rem;
    margin-left: -1.25rem;
}

    .form-check-input[disabled] ~ .form-check-label,
    .form-check-input:disabled ~ .form-check-label {
        color: #6c757d;
    }

.form-check-label {
    margin-bottom: 0;
}

.form-check-inline {
    display: -ms-inline-flexbox;
    display: inline-flex;
    -ms-flex-align: center;
    align-items: center;
    padding-left: 0;
    margin-right: 0.75rem;
}

    .form-check-inline .form-check-input {
        position: static;
        margin-top: 0;
        margin-right: 0.3125rem;
        margin-left: 0;
    }

.valid-feedback {
    display: none;
    width: 100%;
    margin-top: 0.25rem;
    font-size: 80%;
    color: #28a745;
}

.valid-tooltip {
    position: absolute;
    top: 100%;
    left: 0;
    z-index: 5;
    display: none;
    max-width: 100%;
    padding: 0.25rem 0.5rem;
    margin-top: .1rem;
    font-size: 0.875rem;
    line-height: 1.5;
    color: #fff;
    background-color: rgba(40, 167, 69, 0.9);
    border-radius: 0.25rem;
}

.form-row > .col > .valid-tooltip,
.form-row > [class*="col-"] > .valid-tooltip {
    left: 5px;
}

.was-validated :valid ~ .valid-feedback,
.was-validated :valid ~ .valid-tooltip,
.is-valid ~ .valid-feedback,
.is-valid ~ .valid-tooltip {
    display: block;
}

.form-control .was-validated :valid,
.form-control .is-valid {
    border-color: #28a745;
    padding-right: calc(1.5em + 0.75rem);
    background-image: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' width='8' height='8' viewBox='0 0 8 8'%3e%3cpath fill='%2328a745' d='M2.3 6.73L.6 4.53c-.4-1.04.46-1.4 1.1-.8l1.1 1.4 3.4-3.8c.6-.63 1.6-.27 1.2.7l-4 4.6c-.43.5-.8.4-1.1.1z'/%3e%3c/svg%3e");
    background-repeat: no-repeat;
    background-position: right calc(0.375em + 0.1875rem) center;
    background-size: calc(0.75em + 0.375rem) calc(0.75em + 0.375rem);
}

    .form-control .was-validated :valid:focus,
    .form-control .is-valid:focus {
        border-color: #28a745;
        box-shadow: 0 0 0 0.2rem rgba(40, 167, 69, 0.25);
    }

textarea.form-control .was-validated :valid,
textarea.form-control .is-valid {
    padding-right: calc(1.5em + 0.75rem);
    background-position: top calc(0.375em + 0.1875rem) right calc(0.375em + 0.1875rem);
}

.custom-select .was-validated :valid,
.custom-select .is-valid {
    border-color: #28a745;
    padding-right: calc(0.75em + 2.3125rem);
    background: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' width='4' height='5' viewBox='0 0 4 5'%3e%3cpath fill='%23343a40' d='M2 0L0 2h4zm0 5L0 3h4z'/%3e%3c/svg%3e") right 0.75rem center/8px 10px no-repeat, #fff url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' width='8' height='8' viewBox='0 0 8 8'%3e%3cpath fill='%2328a745' d='M2.3 6.73L.6 4.53c-.4-1.04.46-1.4 1.1-.8l1.1 1.4 3.4-3.8c.6-.63 1.6-.27 1.2.7l-4 4.6c-.43.5-.8.4-1.1.1z'/%3e%3c/svg%3e") center right 1.75rem/calc(0.75em + 0.375rem) calc(0.75em + 0.375rem) no-repeat;
}

    .custom-select .was-validated :valid:focus,
    .custom-select .is-valid:focus {
        border-color: #28a745;
        box-shadow: 0 0 0 0.2rem rgba(40, 167, 69, 0.25);
    }

.form-check-input .was-validated :valid ~ .form-check-label,
.form-check-input .is-valid ~ .form-check-label {
    color: #28a745;
}

.form-check-input .was-validated :valid ~ .valid-feedback,
.form-check-input .was-validated :valid ~ .valid-tooltip,
.form-check-input .is-valid ~ .valid-feedback,
.form-check-input .is-valid ~ .valid-tooltip {
    display: block;
}

.custom-control-input .was-validated :valid ~ .custom-control-label,
.custom-control-input .is-valid ~ .custom-control-label {
    color: #28a745;
}

    .custom-control-input .was-validated :valid ~ .custom-control-label::before,
    .custom-control-input .is-valid ~ .custom-control-label::before {
        border-color: #28a745;
    }

.custom-control-input .was-validated :valid:checked ~ .custom-control-label::before,
.custom-control-input .is-valid:checked ~ .custom-control-label::before {
    border-color: #34ce57;
    background-color: #34ce57;
}

.custom-control-input .was-validated :valid:focus ~ .custom-control-label::before,
.custom-control-input .is-valid:focus ~ .custom-control-label::before {
    box-shadow: 0 0 0 0.2rem rgba(40, 167, 69, 0.25);
}

.custom-control-input .was-validated :valid:focus:not(:checked) ~ .custom-control-label::before,
.custom-control-input .is-valid:focus:not(:checked) ~ .custom-control-label::before {
    border-color: #28a745;
}

.custom-file-input .was-validated :valid ~ .custom-file-label,
.custom-file-input .is-valid ~ .custom-file-label {
    border-color: #28a745;
}

.custom-file-input .was-validated :valid:focus ~ .custom-file-label,
.custom-file-input .is-valid:focus ~ .custom-file-label {
    border-color: #28a745;
    box-shadow: 0 0 0 0.2rem rgba(40, 167, 69, 0.25);
}

.invalid-feedback {
    display: none;
    width: 100%;
    margin-top: 0.25rem;
    font-size: 80%;
    color: #dc3545;
}

.invalid-tooltip {
    position: absolute;
    top: 100%;
    left: 0;
    z-index: 5;
    display: none;
    max-width: 100%;
    padding: 0.25rem 0.5rem;
    margin-top: .1rem;
    font-size: 0.875rem;
    line-height: 1.5;
    color: #fff;
    background-color: rgba(220, 53, 69, 0.9);
    border-radius: 0.25rem;
}

.form-row > .col > .invalid-tooltip,
.form-row > [class*="col-"] > .invalid-tooltip {
    left: 5px;
}

.was-validated :invalid ~ .invalid-feedback,
.was-validated :invalid ~ .invalid-tooltip,
.is-invalid ~ .invalid-feedback,
.is-invalid ~ .invalid-tooltip {
    display: block;
}

.form-control .was-validated :invalid,
.form-control .is-invalid {
    border-color: #dc3545;
    padding-right: calc(1.5em + 0.75rem);
    background-image: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' fill='none' stroke='%23dc3545' viewBox='0 0 12 12'%3e%3ccircle cx='6' cy='6' r='4.5'/%3e%3cpath stroke-linejoin='round' d='M5.8 3.6h.4L6 6.5z'/%3e%3ccircle cx='6' cy='8.2' r='.6' fill='%23dc3545' stroke='none'/%3e%3c/svg%3e");
    background-repeat: no-repeat;
    background-position: right calc(0.375em + 0.1875rem) center;
    background-size: calc(0.75em + 0.375rem) calc(0.75em + 0.375rem);
}

    .form-control .was-validated :invalid:focus,
    .form-control .is-invalid:focus {
        border-color: #dc3545;
        box-shadow: 0 0 0 0.2rem rgba(220, 53, 69, 0.25);
    }

textarea.form-control .was-validated :invalid,
textarea.form-control .is-invalid {
    padding-right: calc(1.5em + 0.75rem);
    background-position: top calc(0.375em + 0.1875rem) right calc(0.375em + 0.1875rem);
}

.custom-select .was-validated :invalid,
.custom-select .is-invalid {
    border-color: #dc3545;
    padding-right: calc(0.75em + 2.3125rem);
    background: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' width='4' height='5' viewBox='0 0 4 5'%3e%3cpath fill='%23343a40' d='M2 0L0 2h4zm0 5L0 3h4z'/%3e%3c/svg%3e") right 0.75rem center/8px 10px no-repeat, #fff url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' fill='none' stroke='%23dc3545' viewBox='0 0 12 12'%3e%3ccircle cx='6' cy='6' r='4.5'/%3e%3cpath stroke-linejoin='round' d='M5.8 3.6h.4L6 6.5z'/%3e%3ccircle cx='6' cy='8.2' r='.6' fill='%23dc3545' stroke='none'/%3e%3c/svg%3e") center right 1.75rem/calc(0.75em + 0.375rem) calc(0.75em + 0.375rem) no-repeat;
}

    .custom-select .was-validated :invalid:focus,
    .custom-select .is-invalid:focus {
        border-color: #dc3545;
        box-shadow: 0 0 0 0.2rem rgba(220, 53, 69, 0.25);
    }

.form-check-input .was-validated :invalid ~ .form-check-label,
.form-check-input .is-invalid ~ .form-check-label {
    color: #dc3545;
}

.form-check-input .was-validated :invalid ~ .invalid-feedback,
.form-check-input .was-validated :invalid ~ .invalid-tooltip,
.form-check-input .is-invalid ~ .invalid-feedback,
.form-check-input .is-invalid ~ .invalid-tooltip {
    display: block;
}

.custom-control-input .was-validated :invalid ~ .custom-control-label,
.custom-control-input .is-invalid ~ .custom-control-label {
    color: #dc3545;
}

    .custom-control-input .was-validated :invalid ~ .custom-control-label::before,
    .custom-control-input .is-invalid ~ .custom-control-label::before {
        border-color: #dc3545;
    }

.custom-control-input .was-validated :invalid:checked ~ .custom-control-label::before,
.custom-control-input .is-invalid:checked ~ .custom-control-label::before {
    border-color: #e4606d;
    background-color: #e4606d;
}

.custom-control-input .was-validated :invalid:focus ~ .custom-control-label::before,
.custom-control-input .is-invalid:focus ~ .custom-control-label::before {
    box-shadow: 0 0 0 0.2rem rgba(220, 53, 69, 0.25);
}

.custom-control-input .was-validated :invalid:focus:not(:checked) ~ .custom-control-label::before,
.custom-control-input .is-invalid:focus:not(:checked) ~ .custom-control-label::before {
    border-color: #dc3545;
}

.custom-file-input .was-validated :invalid ~ .custom-file-label,
.custom-file-input .is-invalid ~ .custom-file-label {
    border-color: #dc3545;
}

.custom-file-input .was-validated :invalid:focus ~ .custom-file-label,
.custom-file-input .is-invalid:focus ~ .custom-file-label {
    border-color: #dc3545;
    box-shadow: 0 0 0 0.2rem rgba(220, 53, 69, 0.25);
}

.form-inline {
    display: -ms-flexbox;
    display: flex;
    -ms-flex-flow: row wrap;
    flex-flow: row wrap;
    -ms-flex-align: center;
    align-items: center;
}

    .form-inline .form-check {
        width: 100%;
    }

@media (min-width: 576px) {
    .form-inline label {
        display: -ms-flexbox;
        display: flex;
        -ms-flex-align: center;
        align-items: center;
        -ms-flex-pack: center;
        justify-content: center;
        margin-bottom: 0;
    }

    .form-inline .form-group {
        display: -ms-flexbox;
        display: flex;
        -ms-flex: 0 0 auto;
        flex: 0 0 auto;
        -ms-flex-flow: row wrap;
        flex-flow: row wrap;
        -ms-flex-align: center;
        align-items: center;
        margin-bottom: 0;
    }

    .form-inline .form-control {
        display: inline-block;
        width: auto;
        vertical-align: middle;
    }

    .form-inline .form-control-plaintext {
        display: inline-block;
    }

    .form-inline .input-group,
    .form-inline .custom-select {
        width: auto;
    }

    .form-inline .form-check {
        display: -ms-flexbox;
        display: flex;
        -ms-flex-align: center;
        align-items: center;
        -ms-flex-pack: center;
        justify-content: center;
        width: auto;
        padding-left: 0;
    }

    .form-inline .form-check-input {
        position: relative;
        -ms-flex-negative: 0;
        flex-shrink: 0;
        margin-top: 0;
        margin-right: 0.25rem;
        margin-left: 0;
    }

    .form-inline .custom-control {
        -ms-flex-align: center;
        align-items: center;
        -ms-flex-pack: center;
        justify-content: center;
    }

    .form-inline .custom-control-label {
        margin-bottom: 0;
    }
}

.btn, .cart-total-cta, .checkout form [type="submit"], .cookie-policy-cta {
    display: inline-block;
    font-weight: 400;
    color: #212529;
    text-align: center;
    vertical-align: middle;
    -webkit-user-select: none;
    -moz-user-select: none;
    -ms-user-select: none;
    user-select: none;
    background-color: transparent;
    border: 1px solid transparent;
    padding: 0.375rem 0.75rem;
    font-size: 1rem;
    line-height: 1.5;
    border-radius: 0.25rem;
    transition: color 0.15s ease-in-out, background-color 0.15s ease-in-out, border-color 0.15s ease-in-out, box-shadow 0.15s ease-in-out;
}

@media (prefers-reduced-motion: reduce) {
    .btn, .cart-total-cta, .checkout form [type="submit"], .cookie-policy-cta {
        transition: none;
    }
}

.btn:hover, .cart-total-cta:hover, .checkout form [type="submit"]:hover, .cookie-policy-cta:hover {
    color: #212529;
    text-decoration: none;
}

.btn:focus, .cart-total-cta:focus, .checkout form [type="submit"]:focus, .cookie-policy-cta:focus, .btn.focus, .focus.cart-total-cta, .checkout form .focus[type="submit"], .focus.cookie-policy-cta {
    outline: 0;
    box-shadow: 0 0 0 0.2rem rgba(0, 123, 255, 0.25);
}

.btn.disabled, .disabled.cart-total-cta, .checkout form .disabled[type="submit"], .disabled.cookie-policy-cta, .btn:disabled, .cart-total-cta:disabled, .checkout form [type="submit"]:disabled, .cookie-policy-cta:disabled {
    opacity: 0.65;
}

.btn:not(:disabled):not(.disabled), .cart-total-cta:not(:disabled):not(.disabled), .checkout form [type="submit"]:not(:disabled):not(.disabled), .cookie-policy-cta:not(:disabled):not(.disabled) {
    cursor: pointer;
}

a.btn.disabled, a.disabled.cart-total-cta, .checkout form a.disabled[type="submit"], a.disabled.cookie-policy-cta,
fieldset:disabled a.btn,
fieldset:disabled a.cart-total-cta,
fieldset:disabled .checkout form a[type="submit"], .checkout form
fieldset:disabled a[type="submit"],
fieldset:disabled a.cookie-policy-cta {
    pointer-events: none;
}

.btn-primary {
    color: #fff;
    background-color: #007bff;
    border-color: #007bff;
}

    .btn-primary:hover {
        color: #fff;
        background-color: #0069d9;
        border-color: #0062cc;
    }

    .btn-primary:focus, .btn-primary.focus {
        color: #fff;
        background-color: #0069d9;
        border-color: #0062cc;
        box-shadow: 0 0 0 0.2rem rgba(38, 143, 255, 0.5);
    }

    .btn-primary.disabled, .btn-primary:disabled {
        color: #fff;
        background-color: #007bff;
        border-color: #007bff;
    }

    .btn-primary:not(:disabled):not(.disabled):active, .btn-primary:not(:disabled):not(.disabled).active,
    .show > .btn-primary.dropdown-toggle {
        color: #fff;
        background-color: #0062cc;
        border-color: #005cbf;
    }

        .btn-primary:not(:disabled):not(.disabled):active:focus, .btn-primary:not(:disabled):not(.disabled).active:focus,
        .show > .btn-primary.dropdown-toggle:focus {
            box-shadow: 0 0 0 0.2rem rgba(38, 143, 255, 0.5);
        }

.btn-secondary {
    color: #fff;
    background-color: #6c757d;
    border-color: #6c757d;
}

    .btn-secondary:hover {
        color: #fff;
        background-color: #5a6268;
        border-color: #545b62;
    }

    .btn-secondary:focus, .btn-secondary.focus {
        color: #fff;
        background-color: #5a6268;
        border-color: #545b62;
        box-shadow: 0 0 0 0.2rem rgba(130, 138, 145, 0.5);
    }

    .btn-secondary.disabled, .btn-secondary:disabled {
        color: #fff;
        background-color: #6c757d;
        border-color: #6c757d;
    }

    .btn-secondary:not(:disabled):not(.disabled):active, .btn-secondary:not(:disabled):not(.disabled).active,
    .show > .btn-secondary.dropdown-toggle {
        color: #fff;
        background-color: #545b62;
        border-color: #4e555b;
    }

        .btn-secondary:not(:disabled):not(.disabled):active:focus, .btn-secondary:not(:disabled):not(.disabled).active:focus,
        .show > .btn-secondary.dropdown-toggle:focus {
            box-shadow: 0 0 0 0.2rem rgba(130, 138, 145, 0.5);
        }

.btn-success {
    color: #fff;
    background-color: #28a745;
    border-color: #28a745;
}

    .btn-success:hover {
        color: #fff;
        background-color: #218838;
        border-color: #1e7e34;
    }

    .btn-success:focus, .btn-success.focus {
        color: #fff;
        background-color: #218838;
        border-color: #1e7e34;
        box-shadow: 0 0 0 0.2rem rgba(72, 180, 97, 0.5);
    }

    .btn-success.disabled, .btn-success:disabled {
        color: #fff;
        background-color: #28a745;
        border-color: #28a745;
    }

    .btn-success:not(:disabled):not(.disabled):active, .btn-success:not(:disabled):not(.disabled).active,
    .show > .btn-success.dropdown-toggle {
        color: #fff;
        background-color: #1e7e34;
        border-color: #1c7430;
    }

        .btn-success:not(:disabled):not(.disabled):active:focus, .btn-success:not(:disabled):not(.disabled).active:focus,
        .show > .btn-success.dropdown-toggle:focus {
            box-shadow: 0 0 0 0.2rem rgba(72, 180, 97, 0.5);
        }

.btn-info {
    color: #fff;
    background-color: #17a2b8;
    border-color: #17a2b8;
}

    .btn-info:hover {
        color: #fff;
        background-color: #138496;
        border-color: #117a8b;
    }

    .btn-info:focus, .btn-info.focus {
        color: #fff;
        background-color: #138496;
        border-color: #117a8b;
        box-shadow: 0 0 0 0.2rem rgba(58, 176, 195, 0.5);
    }

    .btn-info.disabled, .btn-info:disabled {
        color: #fff;
        background-color: #17a2b8;
        border-color: #17a2b8;
    }

    .btn-info:not(:disabled):not(.disabled):active, .btn-info:not(:disabled):not(.disabled).active,
    .show > .btn-info.dropdown-toggle {
        color: #fff;
        background-color: #117a8b;
        border-color: #10707f;
    }

        .btn-info:not(:disabled):not(.disabled):active:focus, .btn-info:not(:disabled):not(.disabled).active:focus,
        .show > .btn-info.dropdown-toggle:focus {
            box-shadow: 0 0 0 0.2rem rgba(58, 176, 195, 0.5);
        }

.btn-warning {
    color: #212529;
    background-color: #ffc107;
    border-color: #ffc107;
}

    .btn-warning:hover {
        color: #212529;
        background-color: #e0a800;
        border-color: #d39e00;
    }

    .btn-warning:focus, .btn-warning.focus {
        color: #212529;
        background-color: #e0a800;
        border-color: #d39e00;
        box-shadow: 0 0 0 0.2rem rgba(222, 170, 12, 0.5);
    }

    .btn-warning.disabled, .btn-warning:disabled {
        color: #212529;
        background-color: #ffc107;
        border-color: #ffc107;
    }

    .btn-warning:not(:disabled):not(.disabled):active, .btn-warning:not(:disabled):not(.disabled).active,
    .show > .btn-warning.dropdown-toggle {
        color: #212529;
        background-color: #d39e00;
        border-color: #c69500;
    }

        .btn-warning:not(:disabled):not(.disabled):active:focus, .btn-warning:not(:disabled):not(.disabled).active:focus,
        .show > .btn-warning.dropdown-toggle:focus {
            box-shadow: 0 0 0 0.2rem rgba(222, 170, 12, 0.5);
        }

.btn-danger {
    color: #fff;
    background-color: #dc3545;
    border-color: #dc3545;
}

    .btn-danger:hover {
        color: #fff;
        background-color: #c82333;
        border-color: #bd2130;
    }

    .btn-danger:focus, .btn-danger.focus {
        color: #fff;
        background-color: #c82333;
        border-color: #bd2130;
        box-shadow: 0 0 0 0.2rem rgba(225, 83, 97, 0.5);
    }

    .btn-danger.disabled, .btn-danger:disabled {
        color: #fff;
        background-color: #dc3545;
        border-color: #dc3545;
    }

    .btn-danger:not(:disabled):not(.disabled):active, .btn-danger:not(:disabled):not(.disabled).active,
    .show > .btn-danger.dropdown-toggle {
        color: #fff;
        background-color: #bd2130;
        border-color: #b21f2d;
    }

        .btn-danger:not(:disabled):not(.disabled):active:focus, .btn-danger:not(:disabled):not(.disabled).active:focus,
        .show > .btn-danger.dropdown-toggle:focus {
            box-shadow: 0 0 0 0.2rem rgba(225, 83, 97, 0.5);
        }

.btn-light {
    color: #212529;
    background-color: #f8f9fa;
    border-color: #f8f9fa;
}

    .btn-light:hover {
        color: #212529;
        background-color: #e2e6ea;
        border-color: #dae0e5;
    }

    .btn-light:focus, .btn-light.focus {
        color: #212529;
        background-color: #e2e6ea;
        border-color: #dae0e5;
        box-shadow: 0 0 0 0.2rem rgba(216, 217, 219, 0.5);
    }

    .btn-light.disabled, .btn-light:disabled {
        color: #212529;
        background-color: #f8f9fa;
        border-color: #f8f9fa;
    }

    .btn-light:not(:disabled):not(.disabled):active, .btn-light:not(:disabled):not(.disabled).active,
    .show > .btn-light.dropdown-toggle {
        color: #212529;
        background-color: #dae0e5;
        border-color: #d3d9df;
    }

        .btn-light:not(:disabled):not(.disabled):active:focus, .btn-light:not(:disabled):not(.disabled).active:focus,
        .show > .btn-light.dropdown-toggle:focus {
            box-shadow: 0 0 0 0.2rem rgba(216, 217, 219, 0.5);
        }

.btn-dark {
    color: #fff;
    background-color: #343a40;
    border-color: #343a40;
}

    .btn-dark:hover {
        color: #fff;
        background-color: #23272b;
        border-color: #1d2124;
    }

    .btn-dark:focus, .btn-dark.focus {
        color: #fff;
        background-color: #23272b;
        border-color: #1d2124;
        box-shadow: 0 0 0 0.2rem rgba(82, 88, 93, 0.5);
    }

    .btn-dark.disabled, .btn-dark:disabled {
        color: #fff;
        background-color: #343a40;
        border-color: #343a40;
    }

    .btn-dark:not(:disabled):not(.disabled):active, .btn-dark:not(:disabled):not(.disabled).active,
    .show > .btn-dark.dropdown-toggle {
        color: #fff;
        background-color: #1d2124;
        border-color: #171a1d;
    }

        .btn-dark:not(:disabled):not(.disabled):active:focus, .btn-dark:not(:disabled):not(.disabled).active:focus,
        .show > .btn-dark.dropdown-toggle:focus {
            box-shadow: 0 0 0 0.2rem rgba(82, 88, 93, 0.5);
        }

.btn-outline-primary {
    color: #007bff;
    border-color: #007bff;
}

    .btn-outline-primary:hover {
        color: #fff;
        background-color: #007bff;
        border-color: #007bff;
    }

    .btn-outline-primary:focus, .btn-outline-primary.focus {
        box-shadow: 0 0 0 0.2rem rgba(0, 123, 255, 0.5);
    }

    .btn-outline-primary.disabled, .btn-outline-primary:disabled {
        color: #007bff;
        background-color: transparent;
    }

    .btn-outline-primary:not(:disabled):not(.disabled):active, .btn-outline-primary:not(:disabled):not(.disabled).active,
    .show > .btn-outline-primary.dropdown-toggle {
        color: #fff;
        background-color: #007bff;
        border-color: #007bff;
    }

        .btn-outline-primary:not(:disabled):not(.disabled):active:focus, .btn-outline-primary:not(:disabled):not(.disabled).active:focus,
        .show > .btn-outline-primary.dropdown-toggle:focus {
            box-shadow: 0 0 0 0.2rem rgba(0, 123, 255, 0.5);
        }

.btn-outline-secondary {
    color: #6c757d;
    border-color: #6c757d;
}

    .btn-outline-secondary:hover {
        color: #fff;
        background-color: #6c757d;
        border-color: #6c757d;
    }

    .btn-outline-secondary:focus, .btn-outline-secondary.focus {
        box-shadow: 0 0 0 0.2rem rgba(108, 117, 125, 0.5);
    }

    .btn-outline-secondary.disabled, .btn-outline-secondary:disabled {
        color: #6c757d;
        background-color: transparent;
    }

    .btn-outline-secondary:not(:disabled):not(.disabled):active, .btn-outline-secondary:not(:disabled):not(.disabled).active,
    .show > .btn-outline-secondary.dropdown-toggle {
        color: #fff;
        background-color: #6c757d;
        border-color: #6c757d;
    }

        .btn-outline-secondary:not(:disabled):not(.disabled):active:focus, .btn-outline-secondary:not(:disabled):not(.disabled).active:focus,
        .show > .btn-outline-secondary.dropdown-toggle:focus {
            box-shadow: 0 0 0 0.2rem rgba(108, 117, 125, 0.5);
        }

.btn-outline-success {
    color: #28a745;
    border-color: #28a745;
}

    .btn-outline-success:hover {
        color: #fff;
        background-color: #28a745;
        border-color: #28a745;
    }

    .btn-outline-success:focus, .btn-outline-success.focus {
        box-shadow: 0 0 0 0.2rem rgba(40, 167, 69, 0.5);
    }

    .btn-outline-success.disabled, .btn-outline-success:disabled {
        color: #28a745;
        background-color: transparent;
    }

    .btn-outline-success:not(:disabled):not(.disabled):active, .btn-outline-success:not(:disabled):not(.disabled).active,
    .show > .btn-outline-success.dropdown-toggle {
        color: #fff;
        background-color: #28a745;
        border-color: #28a745;
    }

        .btn-outline-success:not(:disabled):not(.disabled):active:focus, .btn-outline-success:not(:disabled):not(.disabled).active:focus,
        .show > .btn-outline-success.dropdown-toggle:focus {
            box-shadow: 0 0 0 0.2rem rgba(40, 167, 69, 0.5);
        }

.btn-outline-info {
    color: #17a2b8;
    border-color: #17a2b8;
}

    .btn-outline-info:hover {
        color: #fff;
        background-color: #17a2b8;
        border-color: #17a2b8;
    }

    .btn-outline-info:focus, .btn-outline-info.focus {
        box-shadow: 0 0 0 0.2rem rgba(23, 162, 184, 0.5);
    }

    .btn-outline-info.disabled, .btn-outline-info:disabled {
        color: #17a2b8;
        background-color: transparent;
    }

    .btn-outline-info:not(:disabled):not(.disabled):active, .btn-outline-info:not(:disabled):not(.disabled).active,
    .show > .btn-outline-info.dropdown-toggle {
        color: #fff;
        background-color: #17a2b8;
        border-color: #17a2b8;
    }

        .btn-outline-info:not(:disabled):not(.disabled):active:focus, .btn-outline-info:not(:disabled):not(.disabled).active:focus,
        .show > .btn-outline-info.dropdown-toggle:focus {
            box-shadow: 0 0 0 0.2rem rgba(23, 162, 184, 0.5);
        }

.btn-outline-warning {
    color: #ffc107;
    border-color: #ffc107;
}

    .btn-outline-warning:hover {
        color: #212529;
        background-color: #ffc107;
        border-color: #ffc107;
    }

    .btn-outline-warning:focus, .btn-outline-warning.focus {
        box-shadow: 0 0 0 0.2rem rgba(255, 193, 7, 0.5);
    }

    .btn-outline-warning.disabled, .btn-outline-warning:disabled {
        color: #ffc107;
        background-color: transparent;
    }

    .btn-outline-warning:not(:disabled):not(.disabled):active, .btn-outline-warning:not(:disabled):not(.disabled).active,
    .show > .btn-outline-warning.dropdown-toggle {
        color: #212529;
        background-color: #ffc107;
        border-color: #ffc107;
    }

        .btn-outline-warning:not(:disabled):not(.disabled):active:focus, .btn-outline-warning:not(:disabled):not(.disabled).active:focus,
        .show > .btn-outline-warning.dropdown-toggle:focus {
            box-shadow: 0 0 0 0.2rem rgba(255, 193, 7, 0.5);
        }

.btn-outline-danger {
    color: #dc3545;
    border-color: #dc3545;
}

    .btn-outline-danger:hover {
        color: #fff;
        background-color: #dc3545;
        border-color: #dc3545;
    }

    .btn-outline-danger:focus, .btn-outline-danger.focus {
        box-shadow: 0 0 0 0.2rem rgba(220, 53, 69, 0.5);
    }

    .btn-outline-danger.disabled, .btn-outline-danger:disabled {
        color: #dc3545;
        background-color: transparent;
    }

    .btn-outline-danger:not(:disabled):not(.disabled):active, .btn-outline-danger:not(:disabled):not(.disabled).active,
    .show > .btn-outline-danger.dropdown-toggle {
        color: #fff;
        background-color: #dc3545;
        border-color: #dc3545;
    }

        .btn-outline-danger:not(:disabled):not(.disabled):active:focus, .btn-outline-danger:not(:disabled):not(.disabled).active:focus,
        .show > .btn-outline-danger.dropdown-toggle:focus {
            box-shadow: 0 0 0 0.2rem rgba(220, 53, 69, 0.5);
        }

.btn-outline-light {
    color: #f8f9fa;
    border-color: #f8f9fa;
}

    .btn-outline-light:hover {
        color: #212529;
        background-color: #f8f9fa;
        border-color: #f8f9fa;
    }

    .btn-outline-light:focus, .btn-outline-light.focus {
        box-shadow: 0 0 0 0.2rem rgba(248, 249, 250, 0.5);
    }

    .btn-outline-light.disabled, .btn-outline-light:disabled {
        color: #f8f9fa;
        background-color: transparent;
    }

    .btn-outline-light:not(:disabled):not(.disabled):active, .btn-outline-light:not(:disabled):not(.disabled).active,
    .show > .btn-outline-light.dropdown-toggle {
        color: #212529;
        background-color: #f8f9fa;
        border-color: #f8f9fa;
    }

        .btn-outline-light:not(:disabled):not(.disabled):active:focus, .btn-outline-light:not(:disabled):not(.disabled).active:focus,
        .show > .btn-outline-light.dropdown-toggle:focus {
            box-shadow: 0 0 0 0.2rem rgba(248, 249, 250, 0.5);
        }

.btn-outline-dark {
    color: #343a40;
    border-color: #343a40;
}

    .btn-outline-dark:hover {
        color: #fff;
        background-color: #343a40;
        border-color: #343a40;
    }

    .btn-outline-dark:focus, .btn-outline-dark.focus {
        box-shadow: 0 0 0 0.2rem rgba(52, 58, 64, 0.5);
    }

    .btn-outline-dark.disabled, .btn-outline-dark:disabled {
        color: #343a40;
        background-color: transparent;
    }

    .btn-outline-dark:not(:disabled):not(.disabled):active, .btn-outline-dark:not(:disabled):not(.disabled).active,
    .show > .btn-outline-dark.dropdown-toggle {
        color: #fff;
        background-color: #343a40;
        border-color: #343a40;
    }

        .btn-outline-dark:not(:disabled):not(.disabled):active:focus, .btn-outline-dark:not(:disabled):not(.disabled).active:focus,
        .show > .btn-outline-dark.dropdown-toggle:focus {
            box-shadow: 0 0 0 0.2rem rgba(52, 58, 64, 0.5);
        }

.btn-link, .checkout-step-edit {
    font-weight: 400;
    color: #007bff;
    text-decoration: none;
}

    .btn-link:hover, .checkout-step-edit:hover {
        color: #0056b3;
        text-decoration: underline;
    }

    .btn-link:focus, .checkout-step-edit:focus, .btn-link.focus, .focus.checkout-step-edit {
        text-decoration: underline;
    }

    .btn-link:disabled, .checkout-step-edit:disabled, .btn-link.disabled, .disabled.checkout-step-edit {
        color: #6c757d;
        pointer-events: none;
    }

.btn-lg, .btn-group-lg > .btn, .btn-group-lg > .cart-total-cta, .checkout form .btn-group-lg > [type="submit"], .btn-group-lg > .cookie-policy-cta {
    padding: 0.5rem 1rem;
    font-size: 1.25rem;
    line-height: 1.5;
    border-radius: 0.3rem;
}

.btn-sm, .btn-group-sm > .btn, .btn-group-sm > .cart-total-cta, .checkout form .btn-group-sm > [type="submit"], .btn-group-sm > .cookie-policy-cta {
    padding: 0.25rem 0.5rem;
    font-size: 0.875rem;
    line-height: 1.5;
    border-radius: 0.2rem;
}

.btn-block {
    display: block;
    width: 100%;
}

    .btn-block + .btn-block {
        margin-top: 0.5rem;
    }

input[type="submit"].btn-block,
input[type="reset"].btn-block,
input[type="button"].btn-block {
    width: 100%;
}

.fade {
    transition: opacity 0.15s linear;
}

@media (prefers-reduced-motion: reduce) {
    .fade {
        transition: none;
    }
}

.fade:not(.show) {
    opacity: 0;
}

.collapse:not(.show) {
    display: none;
}

.collapsing {
    position: relative;
    height: 0;
    overflow: hidden;
    transition: height 0.35s ease;
}

@media (prefers-reduced-motion: reduce) {
    .collapsing {
        transition: none;
    }
}

.dropup,
.dropright,
.dropdown,
.dropleft {
    position: relative;
}

.dropdown-toggle {
    white-space: nowrap;
}

    .dropdown-toggle::after {
        display: inline-block;
        margin-left: 0.255em;
        vertical-align: 0.255em;
        content: "";
        border-top: 0.3em solid;
        border-right: 0.3em solid transparent;
        border-bottom: 0;
        border-left: 0.3em solid transparent;
    }

    .dropdown-toggle:empty::after {
        margin-left: 0;
    }

.dropdown-menu {
    position: absolute;
    top: 100%;
    left: 0;
    z-index: 1000;
    display: none;
    float: left;
    min-width: 10rem;
    padding: 0.5rem 0;
    margin: 0.125rem 0 0;
    font-size: 1rem;
    color: #212529;
    text-align: left;
    list-style: none;
    background-color: #fff;
    background-clip: padding-box;
    border: 1px solid rgba(0, 0, 0, 0.15);
    border-radius: 0.25rem;
}

.dropdown-menu-left {
    right: auto;
    left: 0;
}

.dropdown-menu-right {
    right: 0;
    left: auto;
}

@media (min-width: 576px) {
    .dropdown-menu-sm-left {
        right: auto;
        left: 0;
    }

    .dropdown-menu-sm-right {
        right: 0;
        left: auto;
    }
}

@media (min-width: 768px) {
    .dropdown-menu-md-left {
        right: auto;
        left: 0;
    }

    .dropdown-menu-md-right {
        right: 0;
        left: auto;
    }
}

@media (min-width: 992px) {
    .dropdown-menu-lg-left {
        right: auto;
        left: 0;
    }

    .dropdown-menu-lg-right {
        right: 0;
        left: auto;
    }
}

@media (min-width: 1200px) {
    .dropdown-menu-xl-left {
        right: auto;
        left: 0;
    }

    .dropdown-menu-xl-right {
        right: 0;
        left: auto;
    }
}

.dropup .dropdown-menu {
    top: auto;
    bottom: 100%;
    margin-top: 0;
    margin-bottom: 0.125rem;
}

.dropup .dropdown-toggle::after {
    display: inline-block;
    margin-left: 0.255em;
    vertical-align: 0.255em;
    content: "";
    border-top: 0;
    border-right: 0.3em solid transparent;
    border-bottom: 0.3em solid;
    border-left: 0.3em solid transparent;
}

.dropup .dropdown-toggle:empty::after {
    margin-left: 0;
}

.dropright .dropdown-menu {
    top: 0;
    right: auto;
    left: 100%;
    margin-top: 0;
    margin-left: 0.125rem;
}

.dropright .dropdown-toggle::after {
    display: inline-block;
    margin-left: 0.255em;
    vertical-align: 0.255em;
    content: "";
    border-top: 0.3em solid transparent;
    border-right: 0;
    border-bottom: 0.3em solid transparent;
    border-left: 0.3em solid;
}

.dropright .dropdown-toggle:empty::after {
    margin-left: 0;
}

.dropright .dropdown-toggle::after {
    vertical-align: 0;
}

.dropleft .dropdown-menu {
    top: 0;
    right: 100%;
    left: auto;
    margin-top: 0;
    margin-right: 0.125rem;
}

.dropleft .dropdown-toggle::after {
    display: inline-block;
    margin-left: 0.255em;
    vertical-align: 0.255em;
    content: "";
}

.dropleft .dropdown-toggle::after {
    display: none;
}

.dropleft .dropdown-toggle::before {
    display: inline-block;
    margin-right: 0.255em;
    vertical-align: 0.255em;
    content: "";
    border-top: 0.3em solid transparent;
    border-right: 0.3em solid;
    border-bottom: 0.3em solid transparent;
}

.dropleft .dropdown-toggle:empty::after {
    margin-left: 0;
}

.dropleft .dropdown-toggle::before {
    vertical-align: 0;
}

.dropdown-menu[x-placement^="top"], .dropdown-menu[x-placement^="right"], .dropdown-menu[x-placement^="bottom"], .dropdown-menu[x-placement^="left"] {
    right: auto;
    bottom: auto;
}

.dropdown-divider {
    height: 0;
    margin: 0.5rem 0;
    overflow: hidden;
    border-top: 1px solid #e9ecef;
}

.dropdown-item {
    display: block;
    width: 100%;
    padding: 0.25rem 1.5rem;
    clear: both;
    font-weight: 400;
    color: #212529;
    text-align: inherit;
    white-space: nowrap;
    background-color: transparent;
    border: 0;
}

    .dropdown-item:hover, .dropdown-item:focus {
        color: #16181b;
        text-decoration: none;
        background-color: #e9ecef;
    }

    .dropdown-item.active, .dropdown-item:active {
        color: #fff;
        text-decoration: none;
        background-color: #007bff;
    }

    .dropdown-item.disabled, .dropdown-item:disabled {
        color: #adb5bd;
        pointer-events: none;
        background-color: transparent;
    }

.dropdown-menu.show {
    display: block;
}

.dropdown-header {
    display: block;
    padding: 0.5rem 1.5rem;
    margin-bottom: 0;
    font-size: 0.875rem;
    color: #6c757d;
    white-space: nowrap;
}

.dropdown-item-text {
    display: block;
    padding: 0.25rem 1.5rem;
    color: #212529;
}

.btn-group,
.btn-group-vertical {
    position: relative;
    display: -ms-inline-flexbox;
    display: inline-flex;
    vertical-align: middle;
}

    .btn-group > .btn, .btn-group > .cart-total-cta, .checkout form .btn-group > [type="submit"], .btn-group > .cookie-policy-cta,
    .btn-group-vertical > .btn,
    .btn-group-vertical > .cart-total-cta, .checkout form
    .btn-group-vertical > [type="submit"],
    .btn-group-vertical > .cookie-policy-cta {
        position: relative;
        -ms-flex: 1 1 auto;
        flex: 1 1 auto;
    }

        .btn-group > .btn:hover, .btn-group > .cart-total-cta:hover, .checkout form .btn-group > [type="submit"]:hover, .btn-group > .cookie-policy-cta:hover,
        .btn-group-vertical > .btn:hover,
        .btn-group-vertical > .cart-total-cta:hover, .checkout form
        .btn-group-vertical > [type="submit"]:hover,
        .btn-group-vertical > .cookie-policy-cta:hover {
            z-index: 1;
        }

        .btn-group > .btn:focus, .btn-group > .cart-total-cta:focus, .checkout form .btn-group > [type="submit"]:focus, .btn-group > .cookie-policy-cta:focus, .btn-group > .btn:active, .btn-group > .cart-total-cta:active, .checkout form .btn-group > [type="submit"]:active, .btn-group > .cookie-policy-cta:active, .btn-group > .btn.active, .btn-group > .active.cart-total-cta, .checkout form .btn-group > .active[type="submit"], .btn-group > .active.cookie-policy-cta,
        .btn-group-vertical > .btn:focus,
        .btn-group-vertical > .cart-total-cta:focus, .checkout form
        .btn-group-vertical > [type="submit"]:focus,
        .btn-group-vertical > .cookie-policy-cta:focus,
        .btn-group-vertical > .btn:active,
        .btn-group-vertical > .cart-total-cta:active, .checkout form
        .btn-group-vertical > [type="submit"]:active,
        .btn-group-vertical > .cookie-policy-cta:active,
        .btn-group-vertical > .btn.active,
        .btn-group-vertical > .active.cart-total-cta, .checkout form
        .btn-group-vertical > .active[type="submit"],
        .btn-group-vertical > .active.cookie-policy-cta {
            z-index: 1;
        }

.btn-toolbar {
    display: -ms-flexbox;
    display: flex;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
    -ms-flex-pack: start;
    justify-content: flex-start;
}

    .btn-toolbar .input-group {
        width: auto;
    }

.btn-group > .btn:not(:first-child), .btn-group > .cart-total-cta:not(:first-child), .checkout form .btn-group > [type="submit"]:not(:first-child), .btn-group > .cookie-policy-cta:not(:first-child),
.btn-group > .btn-group:not(:first-child) {
    margin-left: -1px;
}

.btn-group > .btn:not(:last-child):not(.dropdown-toggle), .btn-group > .cart-total-cta:not(:last-child):not(.dropdown-toggle), .checkout form .btn-group > [type="submit"]:not(:last-child):not(.dropdown-toggle), .btn-group > .cookie-policy-cta:not(:last-child):not(.dropdown-toggle),
.btn-group > .btn-group:not(:last-child) > .btn,
.btn-group > .btn-group:not(:last-child) > .cart-total-cta, .checkout form
.btn-group > .btn-group:not(:last-child) > [type="submit"],
.btn-group > .btn-group:not(:last-child) > .cookie-policy-cta {
    border-top-right-radius: 0;
    border-bottom-right-radius: 0;
}

.btn-group > .btn:not(:first-child), .btn-group > .cart-total-cta:not(:first-child), .checkout form .btn-group > [type="submit"]:not(:first-child), .btn-group > .cookie-policy-cta:not(:first-child),
.btn-group > .btn-group:not(:first-child) > .btn,
.btn-group > .btn-group:not(:first-child) > .cart-total-cta, .checkout form
.btn-group > .btn-group:not(:first-child) > [type="submit"],
.btn-group > .btn-group:not(:first-child) > .cookie-policy-cta {
    border-top-left-radius: 0;
    border-bottom-left-radius: 0;
}

.dropdown-toggle-split {
    padding-right: 0.5625rem;
    padding-left: 0.5625rem;
}

    .dropdown-toggle-split::after,
    .dropup .dropdown-toggle-split::after,
    .dropright .dropdown-toggle-split::after {
        margin-left: 0;
    }

.dropleft .dropdown-toggle-split::before {
    margin-right: 0;
}

.btn-sm + .dropdown-toggle-split, .btn-group-sm > .btn + .dropdown-toggle-split, .btn-group-sm > .cart-total-cta + .dropdown-toggle-split, .checkout form .btn-group-sm > [type="submit"] + .dropdown-toggle-split, .btn-group-sm > .cookie-policy-cta + .dropdown-toggle-split {
    padding-right: 0.375rem;
    padding-left: 0.375rem;
}

.btn-lg + .dropdown-toggle-split, .btn-group-lg > .btn + .dropdown-toggle-split, .btn-group-lg > .cart-total-cta + .dropdown-toggle-split, .checkout form .btn-group-lg > [type="submit"] + .dropdown-toggle-split, .btn-group-lg > .cookie-policy-cta + .dropdown-toggle-split {
    padding-right: 0.75rem;
    padding-left: 0.75rem;
}

.btn-group-vertical {
    -ms-flex-direction: column;
    flex-direction: column;
    -ms-flex-align: start;
    align-items: flex-start;
    -ms-flex-pack: center;
    justify-content: center;
}

    .btn-group-vertical > .btn, .btn-group-vertical > .cart-total-cta, .checkout form .btn-group-vertical > [type="submit"], .btn-group-vertical > .cookie-policy-cta,
    .btn-group-vertical > .btn-group {
        width: 100%;
    }

        .btn-group-vertical > .btn:not(:first-child), .btn-group-vertical > .cart-total-cta:not(:first-child), .checkout form .btn-group-vertical > [type="submit"]:not(:first-child), .btn-group-vertical > .cookie-policy-cta:not(:first-child),
        .btn-group-vertical > .btn-group:not(:first-child) {
            margin-top: -1px;
        }

        .btn-group-vertical > .btn:not(:last-child):not(.dropdown-toggle), .btn-group-vertical > .cart-total-cta:not(:last-child):not(.dropdown-toggle), .checkout form .btn-group-vertical > [type="submit"]:not(:last-child):not(.dropdown-toggle), .btn-group-vertical > .cookie-policy-cta:not(:last-child):not(.dropdown-toggle),
        .btn-group-vertical > .btn-group:not(:last-child) > .btn,
        .btn-group-vertical > .btn-group:not(:last-child) > .cart-total-cta, .checkout form
        .btn-group-vertical > .btn-group:not(:last-child) > [type="submit"],
        .btn-group-vertical > .btn-group:not(:last-child) > .cookie-policy-cta {
            border-bottom-right-radius: 0;
            border-bottom-left-radius: 0;
        }

        .btn-group-vertical > .btn:not(:first-child), .btn-group-vertical > .cart-total-cta:not(:first-child), .checkout form .btn-group-vertical > [type="submit"]:not(:first-child), .btn-group-vertical > .cookie-policy-cta:not(:first-child),
        .btn-group-vertical > .btn-group:not(:first-child) > .btn,
        .btn-group-vertical > .btn-group:not(:first-child) > .cart-total-cta, .checkout form
        .btn-group-vertical > .btn-group:not(:first-child) > [type="submit"],
        .btn-group-vertical > .btn-group:not(:first-child) > .cookie-policy-cta {
            border-top-left-radius: 0;
            border-top-right-radius: 0;
        }

.btn-group-toggle > .btn, .btn-group-toggle > .cart-total-cta, .checkout form .btn-group-toggle > [type="submit"], .btn-group-toggle > .cookie-policy-cta,
.btn-group-toggle > .btn-group > .btn,
.btn-group-toggle > .btn-group > .cart-total-cta, .checkout form
.btn-group-toggle > .btn-group > [type="submit"],
.btn-group-toggle > .btn-group > .cookie-policy-cta {
    margin-bottom: 0;
}

    .btn-group-toggle > .btn input[type="radio"], .btn-group-toggle > .cart-total-cta input[type="radio"], .checkout form .btn-group-toggle > [type="submit"] input[type="radio"], .btn-group-toggle > .cookie-policy-cta input[type="radio"],
    .btn-group-toggle > .btn input[type="checkbox"],
    .btn-group-toggle > .cart-total-cta input[type="checkbox"], .checkout form
    .btn-group-toggle > [type="submit"] input[type="checkbox"],
    .btn-group-toggle > .cookie-policy-cta input[type="checkbox"],
    .btn-group-toggle > .btn-group > .btn input[type="radio"],
    .btn-group-toggle > .btn-group > .cart-total-cta input[type="radio"], .checkout form
    .btn-group-toggle > .btn-group > [type="submit"] input[type="radio"],
    .btn-group-toggle > .btn-group > .cookie-policy-cta input[type="radio"],
    .btn-group-toggle > .btn-group > .btn input[type="checkbox"],
    .btn-group-toggle > .btn-group > .cart-total-cta input[type="checkbox"], .checkout form
    .btn-group-toggle > .btn-group > [type="submit"] input[type="checkbox"],
    .btn-group-toggle > .btn-group > .cookie-policy-cta input[type="checkbox"] {
        position: absolute;
        clip: rect(0, 0, 0, 0);
        pointer-events: none;
    }

.input-group {
    position: relative;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
    -ms-flex-align: stretch;
    align-items: stretch;
    width: 100%;
}

    .input-group > .form-control,
    .input-group > .form-control-plaintext,
    .input-group > .custom-select,
    .input-group > .custom-file {
        position: relative;
        -ms-flex: 1 1 auto;
        flex: 1 1 auto;
        width: 1%;
        min-width: 0;
        margin-bottom: 0;
    }

        .input-group > .form-control + .form-control,
        .input-group > .form-control + .custom-select,
        .input-group > .form-control + .custom-file,
        .input-group > .form-control-plaintext + .form-control,
        .input-group > .form-control-plaintext + .custom-select,
        .input-group > .form-control-plaintext + .custom-file,
        .input-group > .custom-select + .form-control,
        .input-group > .custom-select + .custom-select,
        .input-group > .custom-select + .custom-file,
        .input-group > .custom-file + .form-control,
        .input-group > .custom-file + .custom-select,
        .input-group > .custom-file + .custom-file {
            margin-left: -1px;
        }

        .input-group > .form-control:focus,
        .input-group > .custom-select:focus,
        .input-group > .custom-file .custom-file-input:focus ~ .custom-file-label {
            z-index: 3;
        }

        .input-group > .custom-file .custom-file-input:focus {
            z-index: 4;
        }

        .input-group > .form-control:not(:first-child),
        .input-group > .custom-select:not(:first-child) {
            border-top-left-radius: 0;
            border-bottom-left-radius: 0;
        }

    .input-group > .custom-file {
        display: -ms-flexbox;
        display: flex;
        -ms-flex-align: center;
        align-items: center;
    }

        .input-group > .custom-file:not(:last-child) .custom-file-label,
        .input-group > .custom-file:not(:first-child) .custom-file-label {
            border-top-left-radius: 0;
            border-bottom-left-radius: 0;
        }

    .input-group:not(.has-validation) > .form-control:not(:last-child),
    .input-group:not(.has-validation) > .custom-select:not(:last-child),
    .input-group:not(.has-validation) > .custom-file:not(:last-child) .custom-file-label::after {
        border-top-right-radius: 0;
        border-bottom-right-radius: 0;
    }

    .input-group.has-validation > .form-control:nth-last-child(n + 3),
    .input-group.has-validation > .custom-select:nth-last-child(n + 3),
    .input-group.has-validation > .custom-file:nth-last-child(n + 3) .custom-file-label::after {
        border-top-right-radius: 0;
        border-bottom-right-radius: 0;
    }

.input-group-prepend,
.input-group-append {
    display: -ms-flexbox;
    display: flex;
}

    .input-group-prepend .btn, .input-group-prepend .cart-total-cta, .input-group-prepend .checkout form [type="submit"], .checkout form .input-group-prepend [type="submit"], .input-group-prepend .cookie-policy-cta,
    .input-group-append .btn,
    .input-group-append .cart-total-cta,
    .input-group-append .checkout form [type="submit"], .checkout form
    .input-group-append [type="submit"],
    .input-group-append .cookie-policy-cta {
        position: relative;
        z-index: 2;
    }

        .input-group-prepend .btn:focus, .input-group-prepend .cart-total-cta:focus, .input-group-prepend .checkout form [type="submit"]:focus, .checkout form .input-group-prepend [type="submit"]:focus, .input-group-prepend .cookie-policy-cta:focus,
        .input-group-append .btn:focus,
        .input-group-append .cart-total-cta:focus,
        .input-group-append .checkout form [type="submit"]:focus, .checkout form
        .input-group-append [type="submit"]:focus,
        .input-group-append .cookie-policy-cta:focus {
            z-index: 3;
        }

        .input-group-prepend .btn + .btn, .input-group-prepend .cart-total-cta + .btn, .input-group-prepend .checkout form [type="submit"] + .btn, .checkout form .input-group-prepend [type="submit"] + .btn, .input-group-prepend .cookie-policy-cta + .btn, .input-group-prepend .btn + .cart-total-cta, .input-group-prepend .cart-total-cta + .cart-total-cta, .input-group-prepend .checkout form [type="submit"] + .cart-total-cta, .checkout form .input-group-prepend [type="submit"] + .cart-total-cta, .input-group-prepend .cookie-policy-cta + .cart-total-cta, .input-group-prepend .checkout form .btn + [type="submit"], .checkout form .input-group-prepend .btn + [type="submit"], .input-group-prepend .checkout form .cart-total-cta + [type="submit"], .checkout form .input-group-prepend .cart-total-cta + [type="submit"], .input-group-prepend .checkout form [type="submit"] + [type="submit"], .checkout form .input-group-prepend [type="submit"] + [type="submit"], .input-group-prepend .checkout form .cookie-policy-cta + [type="submit"], .checkout form .input-group-prepend .cookie-policy-cta + [type="submit"], .input-group-prepend .btn + .cookie-policy-cta, .input-group-prepend .cart-total-cta + .cookie-policy-cta, .input-group-prepend .checkout form [type="submit"] + .cookie-policy-cta, .checkout form .input-group-prepend [type="submit"] + .cookie-policy-cta, .input-group-prepend .cookie-policy-cta + .cookie-policy-cta,
        .input-group-prepend .btn + .input-group-text,
        .input-group-prepend .cart-total-cta + .input-group-text,
        .input-group-prepend .checkout form [type="submit"] + .input-group-text, .checkout form
        .input-group-prepend [type="submit"] + .input-group-text,
        .input-group-prepend .cookie-policy-cta + .input-group-text,
        .input-group-prepend .input-group-text + .input-group-text,
        .input-group-prepend .input-group-text + .btn,
        .input-group-prepend .input-group-text + .cart-total-cta,
        .input-group-prepend .checkout form .input-group-text + [type="submit"], .checkout form
        .input-group-prepend .input-group-text + [type="submit"],
        .input-group-prepend .input-group-text + .cookie-policy-cta,
        .input-group-append .btn + .btn,
        .input-group-append .cart-total-cta + .btn,
        .input-group-append .checkout form [type="submit"] + .btn, .checkout form
        .input-group-append [type="submit"] + .btn,
        .input-group-append .cookie-policy-cta + .btn,
        .input-group-append .btn + .cart-total-cta,
        .input-group-append .cart-total-cta + .cart-total-cta,
        .input-group-append .checkout form [type="submit"] + .cart-total-cta, .checkout form
        .input-group-append [type="submit"] + .cart-total-cta,
        .input-group-append .cookie-policy-cta + .cart-total-cta,
        .input-group-append .checkout form .btn + [type="submit"], .checkout form
        .input-group-append .btn + [type="submit"],
        .input-group-append .checkout form .cart-total-cta + [type="submit"], .checkout form
        .input-group-append .cart-total-cta + [type="submit"],
        .input-group-append .checkout form [type="submit"] + [type="submit"], .checkout form
        .input-group-append [type="submit"] + [type="submit"],
        .input-group-append .checkout form .cookie-policy-cta + [type="submit"], .checkout form
        .input-group-append .cookie-policy-cta + [type="submit"],
        .input-group-append .btn + .cookie-policy-cta,
        .input-group-append .cart-total-cta + .cookie-policy-cta,
        .input-group-append .checkout form [type="submit"] + .cookie-policy-cta, .checkout form
        .input-group-append [type="submit"] + .cookie-policy-cta,
        .input-group-append .cookie-policy-cta + .cookie-policy-cta,
        .input-group-append .btn + .input-group-text,
        .input-group-append .cart-total-cta + .input-group-text,
        .input-group-append .checkout form [type="submit"] + .input-group-text, .checkout form
        .input-group-append [type="submit"] + .input-group-text,
        .input-group-append .cookie-policy-cta + .input-group-text,
        .input-group-append .input-group-text + .input-group-text,
        .input-group-append .input-group-text + .btn,
        .input-group-append .input-group-text + .cart-total-cta,
        .input-group-append .checkout form .input-group-text + [type="submit"], .checkout form
        .input-group-append .input-group-text + [type="submit"],
        .input-group-append .input-group-text + .cookie-policy-cta {
            margin-left: -1px;
        }

.input-group-prepend {
    margin-right: -1px;
}

.input-group-append {
    margin-left: -1px;
}

.input-group-text {
    display: -ms-flexbox;
    display: flex;
    -ms-flex-align: center;
    align-items: center;
    padding: 0.375rem 0.75rem;
    margin-bottom: 0;
    font-size: 1rem;
    font-weight: 400;
    line-height: 1.5;
    color: #495057;
    text-align: center;
    white-space: nowrap;
    background-color: #e9ecef;
    border: 1px solid #ced4da;
    border-radius: 0.25rem;
}

    .input-group-text input[type="radio"],
    .input-group-text input[type="checkbox"] {
        margin-top: 0;
    }

.input-group-lg > .form-control:not(textarea),
.input-group-lg > .custom-select {
    height: calc(1.5em + 1rem + 2px);
}

.input-group-lg > .form-control,
.input-group-lg > .custom-select,
.input-group-lg > .input-group-prepend > .input-group-text,
.input-group-lg > .input-group-append > .input-group-text,
.input-group-lg > .input-group-prepend > .btn,
.input-group-lg > .input-group-prepend > .cart-total-cta, .checkout form
.input-group-lg > .input-group-prepend > [type="submit"],
.input-group-lg > .input-group-prepend > .cookie-policy-cta,
.input-group-lg > .input-group-append > .btn,
.input-group-lg > .input-group-append > .cart-total-cta, .checkout form
.input-group-lg > .input-group-append > [type="submit"],
.input-group-lg > .input-group-append > .cookie-policy-cta {
    padding: 0.5rem 1rem;
    font-size: 1.25rem;
    line-height: 1.5;
    border-radius: 0.3rem;
}

.input-group-sm > .form-control:not(textarea),
.input-group-sm > .custom-select {
    height: calc(1.5em + 0.5rem + 2px);
}

.input-group-sm > .form-control,
.input-group-sm > .custom-select,
.input-group-sm > .input-group-prepend > .input-group-text,
.input-group-sm > .input-group-append > .input-group-text,
.input-group-sm > .input-group-prepend > .btn,
.input-group-sm > .input-group-prepend > .cart-total-cta, .checkout form
.input-group-sm > .input-group-prepend > [type="submit"],
.input-group-sm > .input-group-prepend > .cookie-policy-cta,
.input-group-sm > .input-group-append > .btn,
.input-group-sm > .input-group-append > .cart-total-cta, .checkout form
.input-group-sm > .input-group-append > [type="submit"],
.input-group-sm > .input-group-append > .cookie-policy-cta {
    padding: 0.25rem 0.5rem;
    font-size: 0.875rem;
    line-height: 1.5;
    border-radius: 0.2rem;
}

.input-group-lg > .custom-select,
.input-group-sm > .custom-select {
    padding-right: 1.75rem;
}

.input-group > .input-group-prepend > .btn, .input-group > .input-group-prepend > .cart-total-cta, .checkout form .input-group > .input-group-prepend > [type="submit"], .input-group > .input-group-prepend > .cookie-policy-cta,
.input-group > .input-group-prepend > .input-group-text,
.input-group:not(.has-validation) > .input-group-append:not(:last-child) > .btn,
.input-group:not(.has-validation) > .input-group-append:not(:last-child) > .cart-total-cta, .checkout form
.input-group:not(.has-validation) > .input-group-append:not(:last-child) > [type="submit"],
.input-group:not(.has-validation) > .input-group-append:not(:last-child) > .cookie-policy-cta,
.input-group:not(.has-validation) > .input-group-append:not(:last-child) > .input-group-text,
.input-group.has-validation > .input-group-append:nth-last-child(n + 3) > .btn,
.input-group.has-validation > .input-group-append:nth-last-child(n + 3) > .cart-total-cta, .checkout form
.input-group.has-validation > .input-group-append:nth-last-child(n + 3) > [type="submit"],
.input-group.has-validation > .input-group-append:nth-last-child(n + 3) > .cookie-policy-cta,
.input-group.has-validation > .input-group-append:nth-last-child(n + 3) > .input-group-text,
.input-group > .input-group-append:last-child > .btn:not(:last-child):not(.dropdown-toggle),
.input-group > .input-group-append:last-child > .cart-total-cta:not(:last-child):not(.dropdown-toggle), .checkout form
.input-group > .input-group-append:last-child > [type="submit"]:not(:last-child):not(.dropdown-toggle),
.input-group > .input-group-append:last-child > .cookie-policy-cta:not(:last-child):not(.dropdown-toggle),
.input-group > .input-group-append:last-child > .input-group-text:not(:last-child) {
    border-top-right-radius: 0;
    border-bottom-right-radius: 0;
}

.input-group > .input-group-append > .btn, .input-group > .input-group-append > .cart-total-cta, .checkout form .input-group > .input-group-append > [type="submit"], .input-group > .input-group-append > .cookie-policy-cta,
.input-group > .input-group-append > .input-group-text,
.input-group > .input-group-prepend:not(:first-child) > .btn,
.input-group > .input-group-prepend:not(:first-child) > .cart-total-cta, .checkout form
.input-group > .input-group-prepend:not(:first-child) > [type="submit"],
.input-group > .input-group-prepend:not(:first-child) > .cookie-policy-cta,
.input-group > .input-group-prepend:not(:first-child) > .input-group-text,
.input-group > .input-group-prepend:first-child > .btn:not(:first-child),
.input-group > .input-group-prepend:first-child > .cart-total-cta:not(:first-child), .checkout form
.input-group > .input-group-prepend:first-child > [type="submit"]:not(:first-child),
.input-group > .input-group-prepend:first-child > .cookie-policy-cta:not(:first-child),
.input-group > .input-group-prepend:first-child > .input-group-text:not(:first-child) {
    border-top-left-radius: 0;
    border-bottom-left-radius: 0;
}

.custom-control {
    position: relative;
    z-index: 1;
    display: block;
    min-height: 1.5rem;
    padding-left: 1.5rem;
    color-adjust: exact;
}

.custom-control-inline {
    display: -ms-inline-flexbox;
    display: inline-flex;
    margin-right: 1rem;
}

.custom-control-input {
    position: absolute;
    left: 0;
    z-index: -1;
    width: 1rem;
    height: 1.25rem;
    opacity: 0;
}

    .custom-control-input:checked ~ .custom-control-label::before {
        color: #fff;
        border-color: #007bff;
        background-color: #007bff;
    }

    .custom-control-input:focus ~ .custom-control-label::before {
        box-shadow: 0 0 0 0.2rem rgba(0, 123, 255, 0.25);
    }

    .custom-control-input:focus:not(:checked) ~ .custom-control-label::before {
        border-color: #80bdff;
    }

    .custom-control-input:not(:disabled):active ~ .custom-control-label::before {
        color: #fff;
        background-color: #b3d7ff;
        border-color: #b3d7ff;
    }

    .custom-control-input[disabled] ~ .custom-control-label, .custom-control-input:disabled ~ .custom-control-label {
        color: #6c757d;
    }

        .custom-control-input[disabled] ~ .custom-control-label::before, .custom-control-input:disabled ~ .custom-control-label::before {
            background-color: #e9ecef;
        }

.custom-control-label {
    position: relative;
    margin-bottom: 0;
    vertical-align: top;
}

    .custom-control-label::before {
        position: absolute;
        top: 0.25rem;
        left: -1.5rem;
        display: block;
        width: 1rem;
        height: 1rem;
        pointer-events: none;
        content: "";
        background-color: #fff;
        border: #adb5bd solid 1px;
    }

    .custom-control-label::after {
        position: absolute;
        top: 0.25rem;
        left: -1.5rem;
        display: block;
        width: 1rem;
        height: 1rem;
        content: "";
        background: 50% / 50% 50% no-repeat;
    }

.custom-checkbox .custom-control-label::before {
    border-radius: 0.25rem;
}

.custom-checkbox .custom-control-input:checked ~ .custom-control-label::after {
    background-image: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' width='8' height='8' viewBox='0 0 8 8'%3e%3cpath fill='%23fff' d='M6.564.75l-3.59 3.612-1.538-1.55L0 4.26l2.974 2.99L8 2.193z'/%3e%3c/svg%3e");
}

.custom-checkbox .custom-control-input:indeterminate ~ .custom-control-label::before {
    border-color: #007bff;
    background-color: #007bff;
}

.custom-checkbox .custom-control-input:indeterminate ~ .custom-control-label::after {
    background-image: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' width='4' height='4' viewBox='0 0 4 4'%3e%3cpath stroke='%23fff' d='M0 2h4'/%3e%3c/svg%3e");
}

.custom-checkbox .custom-control-input:disabled:checked ~ .custom-control-label::before {
    background-color: rgba(0, 123, 255, 0.5);
}

.custom-checkbox .custom-control-input:disabled:indeterminate ~ .custom-control-label::before {
    background-color: rgba(0, 123, 255, 0.5);
}

.custom-radio .custom-control-label::before {
    border-radius: 50%;
}

.custom-radio .custom-control-input:checked ~ .custom-control-label::after {
    background-image: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='-4 -4 8 8'%3e%3ccircle r='3' fill='%23fff'/%3e%3c/svg%3e");
}

.custom-radio .custom-control-input:disabled:checked ~ .custom-control-label::before {
    background-color: rgba(0, 123, 255, 0.5);
}

.custom-switch {
    padding-left: 2.25rem;
}

    .custom-switch .custom-control-label::before {
        left: -2.25rem;
        width: 1.75rem;
        pointer-events: all;
        border-radius: 0.5rem;
    }

    .custom-switch .custom-control-label::after {
        top: calc(0.25rem + 2px);
        left: calc(-2.25rem + 2px);
        width: calc(1rem - 4px);
        height: calc(1rem - 4px);
        background-color: #adb5bd;
        border-radius: 0.5rem;
        transition: transform 0.15s ease-in-out, background-color 0.15s ease-in-out, border-color 0.15s ease-in-out, box-shadow 0.15s ease-in-out;
    }

@media (prefers-reduced-motion: reduce) {
    .custom-switch .custom-control-label::after {
        transition: none;
    }
}

.custom-switch .custom-control-input:checked ~ .custom-control-label::after {
    background-color: #fff;
    -ms-transform: translateX(0.75rem);
    transform: translateX(0.75rem);
}

.custom-switch .custom-control-input:disabled:checked ~ .custom-control-label::before {
    background-color: rgba(0, 123, 255, 0.5);
}

.custom-select {
    display: inline-block;
    width: 100%;
    height: calc(1.5em + 0.75rem + 2px);
    padding: 0.375rem 1.75rem 0.375rem 0.75rem;
    font-size: 1rem;
    font-weight: 400;
    line-height: 1.5;
    color: #495057;
    vertical-align: middle;
    background: #fff url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' width='4' height='5' viewBox='0 0 4 5'%3e%3cpath fill='%23343a40' d='M2 0L0 2h4zm0 5L0 3h4z'/%3e%3c/svg%3e") right 0.75rem center/8px 10px no-repeat;
    border: 1px solid #ced4da;
    border-radius: 0.25rem;
    -webkit-appearance: none;
    -moz-appearance: none;
    appearance: none;
}

    .custom-select:focus {
        border-color: #80bdff;
        outline: 0;
        box-shadow: 0 0 0 0.2rem rgba(0, 123, 255, 0.25);
    }

        .custom-select:focus::-ms-value {
            color: #495057;
            background-color: #fff;
        }

    .custom-select[multiple], .custom-select[size]:not([size="1"]) {
        height: auto;
        padding-right: 0.75rem;
        background-image: none;
    }

    .custom-select:disabled {
        color: #6c757d;
        background-color: #e9ecef;
    }

    .custom-select::-ms-expand {
        display: none;
    }

    .custom-select:-moz-focusring {
        color: transparent;
        text-shadow: 0 0 0 #495057;
    }

.custom-select-sm {
    height: calc(1.5em + 0.5rem + 2px);
    padding-top: 0.25rem;
    padding-bottom: 0.25rem;
    padding-left: 0.5rem;
    font-size: 0.875rem;
}

.custom-select-lg {
    height: calc(1.5em + 1rem + 2px);
    padding-top: 0.5rem;
    padding-bottom: 0.5rem;
    padding-left: 1rem;
    font-size: 1.25rem;
}

.custom-file {
    position: relative;
    display: inline-block;
    width: 100%;
    height: calc(1.5em + 0.75rem + 2px);
    margin-bottom: 0;
}

.custom-file-input {
    position: relative;
    z-index: 2;
    width: 100%;
    height: calc(1.5em + 0.75rem + 2px);
    margin: 0;
    overflow: hidden;
    opacity: 0;
}

    .custom-file-input:focus ~ .custom-file-label {
        border-color: #80bdff;
        box-shadow: 0 0 0 0.2rem rgba(0, 123, 255, 0.25);
    }

    .custom-file-input[disabled] ~ .custom-file-label,
    .custom-file-input:disabled ~ .custom-file-label {
        background-color: #e9ecef;
    }

    .custom-file-input:lang(en) ~ .custom-file-label::after {
        content: "Browse";
    }

    .custom-file-input ~ .custom-file-label[data-browse]::after {
        content: attr(data-browse);
    }

.custom-file-label {
    position: absolute;
    top: 0;
    right: 0;
    left: 0;
    z-index: 1;
    height: calc(1.5em + 0.75rem + 2px);
    padding: 0.375rem 0.75rem;
    overflow: hidden;
    font-weight: 400;
    line-height: 1.5;
    color: #495057;
    background-color: #fff;
    border: 1px solid #ced4da;
    border-radius: 0.25rem;
}

    .custom-file-label::after {
        position: absolute;
        top: 0;
        right: 0;
        bottom: 0;
        z-index: 3;
        display: block;
        height: calc(1.5em + 0.75rem);
        padding: 0.375rem 0.75rem;
        line-height: 1.5;
        color: #495057;
        content: "Browse";
        background-color: #e9ecef;
        border-left: inherit;
        border-radius: 0 0.25rem 0.25rem 0;
    }

.custom-range {
    width: 100%;
    height: 1.4rem;
    padding: 0;
    background-color: transparent;
    -webkit-appearance: none;
    -moz-appearance: none;
    appearance: none;
}

    .custom-range:focus {
        outline: 0;
    }

        .custom-range:focus::-webkit-slider-thumb {
            box-shadow: 0 0 0 1px #fff, 0 0 0 0.2rem rgba(0, 123, 255, 0.25);
        }

        .custom-range:focus::-moz-range-thumb {
            box-shadow: 0 0 0 1px #fff, 0 0 0 0.2rem rgba(0, 123, 255, 0.25);
        }

        .custom-range:focus::-ms-thumb {
            box-shadow: 0 0 0 1px #fff, 0 0 0 0.2rem rgba(0, 123, 255, 0.25);
        }

    .custom-range::-moz-focus-outer {
        border: 0;
    }

    .custom-range::-webkit-slider-thumb {
        width: 1rem;
        height: 1rem;
        margin-top: -0.25rem;
        background-color: #007bff;
        border: 0;
        border-radius: 1rem;
        transition: background-color 0.15s ease-in-out, border-color 0.15s ease-in-out, box-shadow 0.15s ease-in-out;
        -webkit-appearance: none;
        appearance: none;
    }

@media (prefers-reduced-motion: reduce) {
    .custom-range::-webkit-slider-thumb {
        transition: none;
    }
}

.custom-range::-webkit-slider-thumb:active {
    background-color: #b3d7ff;
}

.custom-range::-webkit-slider-runnable-track {
    width: 100%;
    height: 0.5rem;
    color: transparent;
    cursor: pointer;
    background-color: #dee2e6;
    border-color: transparent;
    border-radius: 1rem;
}

.custom-range::-moz-range-thumb {
    width: 1rem;
    height: 1rem;
    background-color: #007bff;
    border: 0;
    border-radius: 1rem;
    transition: background-color 0.15s ease-in-out, border-color 0.15s ease-in-out, box-shadow 0.15s ease-in-out;
    -moz-appearance: none;
    appearance: none;
}

@media (prefers-reduced-motion: reduce) {
    .custom-range::-moz-range-thumb {
        transition: none;
    }
}

.custom-range::-moz-range-thumb:active {
    background-color: #b3d7ff;
}

.custom-range::-moz-range-track {
    width: 100%;
    height: 0.5rem;
    color: transparent;
    cursor: pointer;
    background-color: #dee2e6;
    border-color: transparent;
    border-radius: 1rem;
}

.custom-range::-ms-thumb {
    width: 1rem;
    height: 1rem;
    margin-top: 0;
    margin-right: 0.2rem;
    margin-left: 0.2rem;
    background-color: #007bff;
    border: 0;
    border-radius: 1rem;
    transition: background-color 0.15s ease-in-out, border-color 0.15s ease-in-out, box-shadow 0.15s ease-in-out;
    appearance: none;
}

@media (prefers-reduced-motion: reduce) {
    .custom-range::-ms-thumb {
        transition: none;
    }
}

.custom-range::-ms-thumb:active {
    background-color: #b3d7ff;
}

.custom-range::-ms-track {
    width: 100%;
    height: 0.5rem;
    color: transparent;
    cursor: pointer;
    background-color: transparent;
    border-color: transparent;
    border-width: 0.5rem;
}

.custom-range::-ms-fill-lower {
    background-color: #dee2e6;
    border-radius: 1rem;
}

.custom-range::-ms-fill-upper {
    margin-right: 15px;
    background-color: #dee2e6;
    border-radius: 1rem;
}

.custom-range:disabled::-webkit-slider-thumb {
    background-color: #adb5bd;
}

.custom-range:disabled::-webkit-slider-runnable-track {
    cursor: default;
}

.custom-range:disabled::-moz-range-thumb {
    background-color: #adb5bd;
}

.custom-range:disabled::-moz-range-track {
    cursor: default;
}

.custom-range:disabled::-ms-thumb {
    background-color: #adb5bd;
}

.custom-control-label::before,
.custom-file-label,
.custom-select {
    transition: background-color 0.15s ease-in-out, border-color 0.15s ease-in-out, box-shadow 0.15s ease-in-out;
}

@media (prefers-reduced-motion: reduce) {
    .custom-control-label::before,
    .custom-file-label,
    .custom-select {
        transition: none;
    }
}

.nav {
    display: -ms-flexbox;
    display: flex;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
    padding-left: 0;
    margin-bottom: 0;
    list-style: none;
}

.nav-link {
    display: block;
    padding: 0.5rem 1rem;
}

    .nav-link:hover, .nav-link:focus {
        text-decoration: none;
    }

    .nav-link.disabled {
        color: #6c757d;
        pointer-events: none;
        cursor: default;
    }

.nav-tabs {
    border-bottom: 1px solid #dee2e6;
}

    .nav-tabs .nav-link {
        margin-bottom: -1px;
        border: 1px solid transparent;
        border-top-left-radius: 0.25rem;
        border-top-right-radius: 0.25rem;
    }

        .nav-tabs .nav-link:hover, .nav-tabs .nav-link:focus {
            border-color: #e9ecef #e9ecef #dee2e6;
        }

        .nav-tabs .nav-link.disabled {
            color: #6c757d;
            background-color: transparent;
            border-color: transparent;
        }

        .nav-tabs .nav-link.active,
        .nav-tabs .nav-item.show .nav-link {
            color: #495057;
            background-color: #fff;
            border-color: #dee2e6 #dee2e6 #fff;
        }

    .nav-tabs .dropdown-menu {
        margin-top: -1px;
        border-top-left-radius: 0;
        border-top-right-radius: 0;
    }

.nav-pills .nav-link {
    border-radius: 0.25rem;
}

    .nav-pills .nav-link.active,
    .nav-pills .show > .nav-link {
        color: #fff;
        background-color: #007bff;
    }

.nav-fill > .nav-link,
.nav-fill .nav-item {
    -ms-flex: 1 1 auto;
    flex: 1 1 auto;
    text-align: center;
}

.nav-justified > .nav-link,
.nav-justified .nav-item {
    -ms-flex-preferred-size: 0;
    flex-basis: 0;
    -ms-flex-positive: 1;
    flex-grow: 1;
    text-align: center;
}

.tab-content > .tab-pane {
    display: none;
}

.tab-content > .active {
    display: block;
}

.navbar {
    position: relative;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
    -ms-flex-align: center;
    align-items: center;
    -ms-flex-pack: justify;
    justify-content: space-between;
    padding: 0.5rem 1rem;
}

    .navbar .container, .navbar .iframe-container, .navbar .container-fluid, .navbar .container-sm, .navbar .container-md, .navbar .container-lg, .navbar .container-xl {
        display: -ms-flexbox;
        display: flex;
        -ms-flex-wrap: wrap;
        flex-wrap: wrap;
        -ms-flex-align: center;
        align-items: center;
        -ms-flex-pack: justify;
        justify-content: space-between;
    }

.navbar-brand {
    display: inline-block;
    padding-top: 0.3125rem;
    padding-bottom: 0.3125rem;
    margin-right: 1rem;
    font-size: 1.25rem;
    line-height: inherit;
    white-space: nowrap;
}

    .navbar-brand:hover, .navbar-brand:focus {
        text-decoration: none;
    }

.navbar-nav {
    display: -ms-flexbox;
    display: flex;
    -ms-flex-direction: column;
    flex-direction: column;
    padding-left: 0;
    margin-bottom: 0;
    list-style: none;
}

    .navbar-nav .nav-link {
        padding-right: 0;
        padding-left: 0;
    }

    .navbar-nav .dropdown-menu {
        position: static;
        float: none;
    }

.navbar-text {
    display: inline-block;
    padding-top: 0.5rem;
    padding-bottom: 0.5rem;
}

.navbar-collapse {
    -ms-flex-preferred-size: 100%;
    flex-basis: 100%;
    -ms-flex-positive: 1;
    flex-grow: 1;
    -ms-flex-align: center;
    align-items: center;
}

.navbar-toggler {
    padding: 0.25rem 0.75rem;
    font-size: 1.25rem;
    line-height: 1;
    background-color: transparent;
    border: 1px solid transparent;
    border-radius: 0.25rem;
}

    .navbar-toggler:hover, .navbar-toggler:focus {
        text-decoration: none;
    }

.navbar-toggler-icon {
    display: inline-block;
    width: 1.5em;
    height: 1.5em;
    vertical-align: middle;
    content: "";
    background: 50% / 100% 100% no-repeat;
}

.navbar-nav-scroll {
    max-height: 75vh;
    overflow-y: auto;
}

@media (max-width: 575.98px) {
    .navbar-expand-sm > .container, .navbar-expand-sm > .iframe-container,
    .navbar-expand-sm > .container-fluid,
    .navbar-expand-sm > .container-sm,
    .navbar-expand-sm > .container-md,
    .navbar-expand-sm > .container-lg,
    .navbar-expand-sm > .container-xl {
        padding-right: 0;
        padding-left: 0;
    }
}

@media (min-width: 576px) {
    .navbar-expand-sm {
        -ms-flex-flow: row nowrap;
        flex-flow: row nowrap;
        -ms-flex-pack: start;
        justify-content: flex-start;
    }

        .navbar-expand-sm .navbar-nav {
            -ms-flex-direction: row;
            flex-direction: row;
        }

            .navbar-expand-sm .navbar-nav .dropdown-menu {
                position: absolute;
            }

            .navbar-expand-sm .navbar-nav .nav-link {
                padding-right: 0.5rem;
                padding-left: 0.5rem;
            }

        .navbar-expand-sm > .container, .navbar-expand-sm > .iframe-container,
        .navbar-expand-sm > .container-fluid,
        .navbar-expand-sm > .container-sm,
        .navbar-expand-sm > .container-md,
        .navbar-expand-sm > .container-lg,
        .navbar-expand-sm > .container-xl {
            -ms-flex-wrap: nowrap;
            flex-wrap: nowrap;
        }

        .navbar-expand-sm .navbar-nav-scroll {
            overflow: visible;
        }

        .navbar-expand-sm .navbar-collapse {
            display: -ms-flexbox !important;
            display: flex !important;
            -ms-flex-preferred-size: auto;
            flex-basis: auto;
        }

        .navbar-expand-sm .navbar-toggler {
            display: none;
        }
}

@media (max-width: 767.98px) {
    .navbar-expand-md > .container, .navbar-expand-md > .iframe-container,
    .navbar-expand-md > .container-fluid,
    .navbar-expand-md > .container-sm,
    .navbar-expand-md > .container-md,
    .navbar-expand-md > .container-lg,
    .navbar-expand-md > .container-xl {
        padding-right: 0;
        padding-left: 0;
    }
}

@media (min-width: 768px) {
    .navbar-expand-md {
        -ms-flex-flow: row nowrap;
        flex-flow: row nowrap;
        -ms-flex-pack: start;
        justify-content: flex-start;
    }

        .navbar-expand-md .navbar-nav {
            -ms-flex-direction: row;
            flex-direction: row;
        }

            .navbar-expand-md .navbar-nav .dropdown-menu {
                position: absolute;
            }

            .navbar-expand-md .navbar-nav .nav-link {
                padding-right: 0.5rem;
                padding-left: 0.5rem;
            }

        .navbar-expand-md > .container, .navbar-expand-md > .iframe-container,
        .navbar-expand-md > .container-fluid,
        .navbar-expand-md > .container-sm,
        .navbar-expand-md > .container-md,
        .navbar-expand-md > .container-lg,
        .navbar-expand-md > .container-xl {
            -ms-flex-wrap: nowrap;
            flex-wrap: nowrap;
        }

        .navbar-expand-md .navbar-nav-scroll {
            overflow: visible;
        }

        .navbar-expand-md .navbar-collapse {
            display: -ms-flexbox !important;
            display: flex !important;
            -ms-flex-preferred-size: auto;
            flex-basis: auto;
        }

        .navbar-expand-md .navbar-toggler {
            display: none;
        }
}

@media (max-width: 991.98px) {
    .navbar-expand-lg > .container, .navbar-expand-lg > .iframe-container,
    .navbar-expand-lg > .container-fluid,
    .navbar-expand-lg > .container-sm,
    .navbar-expand-lg > .container-md,
    .navbar-expand-lg > .container-lg,
    .navbar-expand-lg > .container-xl {
        padding-right: 0;
        padding-left: 0;
    }
}

@media (min-width: 992px) {
    .navbar-expand-lg {
        -ms-flex-flow: row nowrap;
        flex-flow: row nowrap;
        -ms-flex-pack: start;
        justify-content: flex-start;
    }

        .navbar-expand-lg .navbar-nav {
            -ms-flex-direction: row;
            flex-direction: row;
        }

            .navbar-expand-lg .navbar-nav .dropdown-menu {
                position: absolute;
            }

            .navbar-expand-lg .navbar-nav .nav-link {
                padding-right: 0.5rem;
                padding-left: 0.5rem;
            }

        .navbar-expand-lg > .container, .navbar-expand-lg > .iframe-container,
        .navbar-expand-lg > .container-fluid,
        .navbar-expand-lg > .container-sm,
        .navbar-expand-lg > .container-md,
        .navbar-expand-lg > .container-lg,
        .navbar-expand-lg > .container-xl {
            -ms-flex-wrap: nowrap;
            flex-wrap: nowrap;
        }

        .navbar-expand-lg .navbar-nav-scroll {
            overflow: visible;
        }

        .navbar-expand-lg .navbar-collapse {
            display: -ms-flexbox !important;
            display: flex !important;
            -ms-flex-preferred-size: auto;
            flex-basis: auto;
        }

        .navbar-expand-lg .navbar-toggler {
            display: none;
        }
}

@media (max-width: 1199.98px) {
    .navbar-expand-xl > .container, .navbar-expand-xl > .iframe-container,
    .navbar-expand-xl > .container-fluid,
    .navbar-expand-xl > .container-sm,
    .navbar-expand-xl > .container-md,
    .navbar-expand-xl > .container-lg,
    .navbar-expand-xl > .container-xl {
        padding-right: 0;
        padding-left: 0;
    }
}

@media (min-width: 1200px) {
    .navbar-expand-xl {
        -ms-flex-flow: row nowrap;
        flex-flow: row nowrap;
        -ms-flex-pack: start;
        justify-content: flex-start;
    }

        .navbar-expand-xl .navbar-nav {
            -ms-flex-direction: row;
            flex-direction: row;
        }

            .navbar-expand-xl .navbar-nav .dropdown-menu {
                position: absolute;
            }

            .navbar-expand-xl .navbar-nav .nav-link {
                padding-right: 0.5rem;
                padding-left: 0.5rem;
            }

        .navbar-expand-xl > .container, .navbar-expand-xl > .iframe-container,
        .navbar-expand-xl > .container-fluid,
        .navbar-expand-xl > .container-sm,
        .navbar-expand-xl > .container-md,
        .navbar-expand-xl > .container-lg,
        .navbar-expand-xl > .container-xl {
            -ms-flex-wrap: nowrap;
            flex-wrap: nowrap;
        }

        .navbar-expand-xl .navbar-nav-scroll {
            overflow: visible;
        }

        .navbar-expand-xl .navbar-collapse {
            display: -ms-flexbox !important;
            display: flex !important;
            -ms-flex-preferred-size: auto;
            flex-basis: auto;
        }

        .navbar-expand-xl .navbar-toggler {
            display: none;
        }
}

.navbar-expand {
    -ms-flex-flow: row nowrap;
    flex-flow: row nowrap;
    -ms-flex-pack: start;
    justify-content: flex-start;
}

    .navbar-expand > .container, .navbar-expand > .iframe-container,
    .navbar-expand > .container-fluid,
    .navbar-expand > .container-sm,
    .navbar-expand > .container-md,
    .navbar-expand > .container-lg,
    .navbar-expand > .container-xl {
        padding-right: 0;
        padding-left: 0;
    }

    .navbar-expand .navbar-nav {
        -ms-flex-direction: row;
        flex-direction: row;
    }

        .navbar-expand .navbar-nav .dropdown-menu {
            position: absolute;
        }

        .navbar-expand .navbar-nav .nav-link {
            padding-right: 0.5rem;
            padding-left: 0.5rem;
        }

    .navbar-expand > .container, .navbar-expand > .iframe-container,
    .navbar-expand > .container-fluid,
    .navbar-expand > .container-sm,
    .navbar-expand > .container-md,
    .navbar-expand > .container-lg,
    .navbar-expand > .container-xl {
        -ms-flex-wrap: nowrap;
        flex-wrap: nowrap;
    }

    .navbar-expand .navbar-nav-scroll {
        overflow: visible;
    }

    .navbar-expand .navbar-collapse {
        display: -ms-flexbox !important;
        display: flex !important;
        -ms-flex-preferred-size: auto;
        flex-basis: auto;
    }

    .navbar-expand .navbar-toggler {
        display: none;
    }

.navbar-light .navbar-brand {
    color: rgba(0, 0, 0, 0.9);
}

    .navbar-light .navbar-brand:hover, .navbar-light .navbar-brand:focus {
        color: rgba(0, 0, 0, 0.9);
    }

.navbar-light .navbar-nav .nav-link {
    color: rgba(0, 0, 0, 0.5);
}

    .navbar-light .navbar-nav .nav-link:hover, .navbar-light .navbar-nav .nav-link:focus {
        color: rgba(0, 0, 0, 0.7);
    }

    .navbar-light .navbar-nav .nav-link.disabled {
        color: rgba(0, 0, 0, 0.3);
    }

    .navbar-light .navbar-nav .show > .nav-link,
    .navbar-light .navbar-nav .active > .nav-link,
    .navbar-light .navbar-nav .nav-link.show,
    .navbar-light .navbar-nav .nav-link.active {
        color: rgba(0, 0, 0, 0.9);
    }

.navbar-light .navbar-toggler {
    color: rgba(0, 0, 0, 0.5);
    border-color: rgba(0, 0, 0, 0.1);
}

.navbar-light .navbar-toggler-icon {
    background-image: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' width='30' height='30' viewBox='0 0 30 30'%3e%3cpath stroke='rgba%280, 0, 0, 0.5%29' stroke-linecap='round' stroke-miterlimit='10' stroke-width='2' d='M4 7h22M4 15h22M4 23h22'/%3e%3c/svg%3e");
}

.navbar-light .navbar-text {
    color: rgba(0, 0, 0, 0.5);
}

    .navbar-light .navbar-text a {
        color: rgba(0, 0, 0, 0.9);
    }

        .navbar-light .navbar-text a:hover, .navbar-light .navbar-text a:focus {
            color: rgba(0, 0, 0, 0.9);
        }

.navbar-dark .navbar-brand {
    color: #fff;
}

    .navbar-dark .navbar-brand:hover, .navbar-dark .navbar-brand:focus {
        color: #fff;
    }

.navbar-dark .navbar-nav .nav-link {
    color: rgba(255, 255, 255, 0.5);
}

    .navbar-dark .navbar-nav .nav-link:hover, .navbar-dark .navbar-nav .nav-link:focus {
        color: rgba(255, 255, 255, 0.75);
    }

    .navbar-dark .navbar-nav .nav-link.disabled {
        color: rgba(255, 255, 255, 0.25);
    }

    .navbar-dark .navbar-nav .show > .nav-link,
    .navbar-dark .navbar-nav .active > .nav-link,
    .navbar-dark .navbar-nav .nav-link.show,
    .navbar-dark .navbar-nav .nav-link.active {
        color: #fff;
    }

.navbar-dark .navbar-toggler {
    color: rgba(255, 255, 255, 0.5);
    border-color: rgba(255, 255, 255, 0.1);
}

.navbar-dark .navbar-toggler-icon {
    background-image: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' width='30' height='30' viewBox='0 0 30 30'%3e%3cpath stroke='rgba%28255, 255, 255, 0.5%29' stroke-linecap='round' stroke-miterlimit='10' stroke-width='2' d='M4 7h22M4 15h22M4 23h22'/%3e%3c/svg%3e");
}

.navbar-dark .navbar-text {
    color: rgba(255, 255, 255, 0.5);
}

    .navbar-dark .navbar-text a {
        color: #fff;
    }

        .navbar-dark .navbar-text a:hover, .navbar-dark .navbar-text a:focus {
            color: #fff;
        }

.card, .newsletter-signup {
    position: relative;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-direction: column;
    flex-direction: column;
    min-width: 0;
    word-wrap: break-word;
    background-color: #fff;
    background-clip: border-box;
    border: 1px solid rgba(0, 0, 0, 0.125);
    border-radius: 0.25rem;
}

    .card > hr, .newsletter-signup > hr {
        margin-right: 0;
        margin-left: 0;
    }

    .card > .list-group, .newsletter-signup > .list-group {
        border-top: inherit;
        border-bottom: inherit;
    }

        .card > .list-group:first-child, .newsletter-signup > .list-group:first-child {
            border-top-width: 0;
            border-top-left-radius: calc(0.25rem - 1px);
            border-top-right-radius: calc(0.25rem - 1px);
        }

        .card > .list-group:last-child, .newsletter-signup > .list-group:last-child {
            border-bottom-width: 0;
            border-bottom-right-radius: calc(0.25rem - 1px);
            border-bottom-left-radius: calc(0.25rem - 1px);
        }

        .card > .card-header + .list-group, .newsletter-signup > .card-header + .list-group,
        .card > .list-group + .card-footer, .newsletter-signup > .list-group + .card-footer {
            border-top: 0;
        }

.card-body {
    -ms-flex: 1 1 auto;
    flex: 1 1 auto;
    min-height: 1px;
    padding: 1.25rem;
}

.card-title {
    margin-bottom: 0.75rem;
}

.card-subtitle {
    margin-top: -0.375rem;
    margin-bottom: 0;
}

.card-text:last-child {
    margin-bottom: 0;
}

.card-link:hover {
    text-decoration: none;
}

.card-link + .card-link {
    margin-left: 1.25rem;
}

.card-header {
    padding: 0.75rem 1.25rem;
    margin-bottom: 0;
    background-color: rgba(0, 0, 0, 0.03);
    border-bottom: 1px solid rgba(0, 0, 0, 0.125);
}

    .card-header:first-child {
        border-radius: calc(0.25rem - 1px) calc(0.25rem - 1px) 0 0;
    }

.card-footer {
    padding: 0.75rem 1.25rem;
    background-color: rgba(0, 0, 0, 0.03);
    border-top: 1px solid rgba(0, 0, 0, 0.125);
}

    .card-footer:last-child {
        border-radius: 0 0 calc(0.25rem - 1px) calc(0.25rem - 1px);
    }

.card-header-tabs {
    margin-right: -0.625rem;
    margin-bottom: -0.75rem;
    margin-left: -0.625rem;
    border-bottom: 0;
}

.card-header-pills {
    margin-right: -0.625rem;
    margin-left: -0.625rem;
}

.card-img-overlay {
    position: absolute;
    top: 0;
    right: 0;
    bottom: 0;
    left: 0;
    padding: 1.25rem;
    border-radius: calc(0.25rem - 1px);
}

.card-img,
.card-img-top,
.card-img-bottom {
    -ms-flex-negative: 0;
    flex-shrink: 0;
    width: 100%;
}

.card-img,
.card-img-top {
    border-top-left-radius: calc(0.25rem - 1px);
    border-top-right-radius: calc(0.25rem - 1px);
}

.card-img,
.card-img-bottom {
    border-bottom-right-radius: calc(0.25rem - 1px);
    border-bottom-left-radius: calc(0.25rem - 1px);
}

.card-deck .card, .card-deck .newsletter-signup {
    margin-bottom: 16px;
}

@media (min-width: 576px) {
    .card-deck {
        display: -ms-flexbox;
        display: flex;
        -ms-flex-flow: row wrap;
        flex-flow: row wrap;
        margin-right: -16px;
        margin-left: -16px;
    }

        .card-deck .card, .card-deck .newsletter-signup {
            -ms-flex: 1 0 0%;
            flex: 1 0 0%;
            margin-right: 16px;
            margin-bottom: 0;
            margin-left: 16px;
        }
}

.card-group > .card, .card-group > .newsletter-signup {
    margin-bottom: 16px;
}

@media (min-width: 576px) {
    .card-group {
        display: -ms-flexbox;
        display: flex;
        -ms-flex-flow: row wrap;
        flex-flow: row wrap;
    }

        .card-group > .card, .card-group > .newsletter-signup {
            -ms-flex: 1 0 0%;
            flex: 1 0 0%;
            margin-bottom: 0;
        }

            .card-group > .card + .card, .card-group > .newsletter-signup + .card, .card-group > .card + .newsletter-signup, .card-group > .newsletter-signup + .newsletter-signup {
                margin-left: 0;
                border-left: 0;
            }

            .card-group > .card:not(:last-child), .card-group > .newsletter-signup:not(:last-child) {
                border-top-right-radius: 0;
                border-bottom-right-radius: 0;
            }

                .card-group > .card:not(:last-child) .card-img-top, .card-group > .newsletter-signup:not(:last-child) .card-img-top,
                .card-group > .card:not(:last-child) .card-header,
                .card-group > .newsletter-signup:not(:last-child) .card-header {
                    border-top-right-radius: 0;
                }

                .card-group > .card:not(:last-child) .card-img-bottom, .card-group > .newsletter-signup:not(:last-child) .card-img-bottom,
                .card-group > .card:not(:last-child) .card-footer,
                .card-group > .newsletter-signup:not(:last-child) .card-footer {
                    border-bottom-right-radius: 0;
                }

            .card-group > .card:not(:first-child), .card-group > .newsletter-signup:not(:first-child) {
                border-top-left-radius: 0;
                border-bottom-left-radius: 0;
            }

                .card-group > .card:not(:first-child) .card-img-top, .card-group > .newsletter-signup:not(:first-child) .card-img-top,
                .card-group > .card:not(:first-child) .card-header,
                .card-group > .newsletter-signup:not(:first-child) .card-header {
                    border-top-left-radius: 0;
                }

                .card-group > .card:not(:first-child) .card-img-bottom, .card-group > .newsletter-signup:not(:first-child) .card-img-bottom,
                .card-group > .card:not(:first-child) .card-footer,
                .card-group > .newsletter-signup:not(:first-child) .card-footer {
                    border-bottom-left-radius: 0;
                }
}

.card-columns .card, .card-columns .newsletter-signup {
    margin-bottom: 0.75rem;
}

@media (min-width: 576px) {
    .card-columns {
        column-count: 3;
        column-gap: 1.25rem;
        orphans: 1;
        widows: 1;
    }

        .card-columns .card, .card-columns .newsletter-signup {
            display: inline-block;
            width: 100%;
        }
}

.accordion {
    overflow-anchor: none;
}

    .accordion > .card, .accordion > .newsletter-signup {
        overflow: hidden;
    }

        .accordion > .card:not(:last-of-type), .accordion > .newsletter-signup:not(:last-of-type) {
            border-bottom: 0;
            border-bottom-right-radius: 0;
            border-bottom-left-radius: 0;
        }

        .accordion > .card:not(:first-of-type), .accordion > .newsletter-signup:not(:first-of-type) {
            border-top-left-radius: 0;
            border-top-right-radius: 0;
        }

        .accordion > .card > .card-header, .accordion > .newsletter-signup > .card-header {
            border-radius: 0;
            margin-bottom: -1px;
        }

.breadcrumb {
    display: -ms-flexbox;
    display: flex;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
    padding: 0.75rem 1rem;
    margin-bottom: 1rem;
    list-style: none;
    background-color: #e9ecef;
    border-radius: 0.25rem;
}

.breadcrumb-item + .breadcrumb-item {
    padding-left: 0.5rem;
}

    .breadcrumb-item + .breadcrumb-item::before {
        float: left;
        padding-right: 0.5rem;
        color: #6c757d;
        content: "/";
    }

    .breadcrumb-item + .breadcrumb-item:hover::before {
        text-decoration: underline;
    }

    .breadcrumb-item + .breadcrumb-item:hover::before {
        text-decoration: none;
    }

.breadcrumb-item.active {
    color: #6c757d;
}

.pagination {
    display: -ms-flexbox;
    display: flex;
    padding-left: 0;
    list-style: none;
    border-radius: 0.25rem;
}

.page-link {
    position: relative;
    display: block;
    padding: 0.5rem 0.75rem;
    margin-left: -1px;
    line-height: 1.25;
    color: #007bff;
    background-color: #fff;
    border: 1px solid #dee2e6;
}

    .page-link:hover {
        z-index: 2;
        color: #0056b3;
        text-decoration: none;
        background-color: #e9ecef;
        border-color: #dee2e6;
    }

    .page-link:focus {
        z-index: 3;
        outline: 0;
        box-shadow: 0 0 0 0.2rem rgba(0, 123, 255, 0.25);
    }

.page-item:first-child .page-link {
    margin-left: 0;
    border-top-left-radius: 0.25rem;
    border-bottom-left-radius: 0.25rem;
}

.page-item:last-child .page-link {
    border-top-right-radius: 0.25rem;
    border-bottom-right-radius: 0.25rem;
}

.page-item.active .page-link {
    z-index: 3;
    color: #fff;
    background-color: #007bff;
    border-color: #007bff;
}

.page-item.disabled .page-link {
    color: #6c757d;
    pointer-events: none;
    cursor: auto;
    background-color: #fff;
    border-color: #dee2e6;
}

.pagination-lg .page-link {
    padding: 0.75rem 1.5rem;
    font-size: 1.25rem;
    line-height: 1.5;
}

.pagination-lg .page-item:first-child .page-link {
    border-top-left-radius: 0.3rem;
    border-bottom-left-radius: 0.3rem;
}

.pagination-lg .page-item:last-child .page-link {
    border-top-right-radius: 0.3rem;
    border-bottom-right-radius: 0.3rem;
}

.pagination-sm .page-link {
    padding: 0.25rem 0.5rem;
    font-size: 0.875rem;
    line-height: 1.5;
}

.pagination-sm .page-item:first-child .page-link {
    border-top-left-radius: 0.2rem;
    border-bottom-left-radius: 0.2rem;
}

.pagination-sm .page-item:last-child .page-link {
    border-top-right-radius: 0.2rem;
    border-bottom-right-radius: 0.2rem;
}

.badge {
    display: inline-block;
    padding: 0.25em 0.4em;
    font-size: 75%;
    font-weight: 700;
    line-height: 1;
    text-align: center;
    white-space: nowrap;
    vertical-align: baseline;
    border-radius: 0.25rem;
    transition: color 0.15s ease-in-out, background-color 0.15s ease-in-out, border-color 0.15s ease-in-out, box-shadow 0.15s ease-in-out;
}

@media (prefers-reduced-motion: reduce) {
    .badge {
        transition: none;
    }
}

a.badge:hover, a.badge:focus {
    text-decoration: none;
}

.badge:empty {
    display: none;
}

.btn .badge, .cart-total-cta .badge, .checkout form [type="submit"] .badge, .cookie-policy-cta .badge {
    position: relative;
    top: -1px;
}

.badge-pill {
    padding-right: 0.6em;
    padding-left: 0.6em;
    border-radius: 10rem;
}

.badge-primary {
    color: #fff;
    background-color: #007bff;
}

a.badge-primary:hover, a.badge-primary:focus {
    color: #fff;
    background-color: #0062cc;
}

a.badge-primary:focus, a.badge-primary.focus {
    outline: 0;
    box-shadow: 0 0 0 0.2rem rgba(0, 123, 255, 0.5);
}

.badge-secondary {
    color: #fff;
    background-color: #6c757d;
}

a.badge-secondary:hover, a.badge-secondary:focus {
    color: #fff;
    background-color: #545b62;
}

a.badge-secondary:focus, a.badge-secondary.focus {
    outline: 0;
    box-shadow: 0 0 0 0.2rem rgba(108, 117, 125, 0.5);
}

.badge-success {
    color: #fff;
    background-color: #28a745;
}

a.badge-success:hover, a.badge-success:focus {
    color: #fff;
    background-color: #1e7e34;
}

a.badge-success:focus, a.badge-success.focus {
    outline: 0;
    box-shadow: 0 0 0 0.2rem rgba(40, 167, 69, 0.5);
}

.badge-info {
    color: #fff;
    background-color: #17a2b8;
}

a.badge-info:hover, a.badge-info:focus {
    color: #fff;
    background-color: #117a8b;
}

a.badge-info:focus, a.badge-info.focus {
    outline: 0;
    box-shadow: 0 0 0 0.2rem rgba(23, 162, 184, 0.5);
}

.badge-warning {
    color: #212529;
    background-color: #ffc107;
}

a.badge-warning:hover, a.badge-warning:focus {
    color: #212529;
    background-color: #d39e00;
}

a.badge-warning:focus, a.badge-warning.focus {
    outline: 0;
    box-shadow: 0 0 0 0.2rem rgba(255, 193, 7, 0.5);
}

.badge-danger {
    color: #fff;
    background-color: #dc3545;
}

a.badge-danger:hover, a.badge-danger:focus {
    color: #fff;
    background-color: #bd2130;
}

a.badge-danger:focus, a.badge-danger.focus {
    outline: 0;
    box-shadow: 0 0 0 0.2rem rgba(220, 53, 69, 0.5);
}

.badge-light {
    color: #212529;
    background-color: #f8f9fa;
}

a.badge-light:hover, a.badge-light:focus {
    color: #212529;
    background-color: #dae0e5;
}

a.badge-light:focus, a.badge-light.focus {
    outline: 0;
    box-shadow: 0 0 0 0.2rem rgba(248, 249, 250, 0.5);
}

.badge-dark {
    color: #fff;
    background-color: #343a40;
}

a.badge-dark:hover, a.badge-dark:focus {
    color: #fff;
    background-color: #1d2124;
}

a.badge-dark:focus, a.badge-dark.focus {
    outline: 0;
    box-shadow: 0 0 0 0.2rem rgba(52, 58, 64, 0.5);
}

.jumbotron {
    padding: 2rem 1rem;
    margin-bottom: 2rem;
    background-color: #e9ecef;
    border-radius: 0.3rem;
}

@media (min-width: 576px) {
    .jumbotron {
        padding: 4rem 2rem;
    }
}

.jumbotron-fluid {
    padding-right: 0;
    padding-left: 0;
    border-radius: 0;
}

.alert {
    position: relative;
    padding: 0.75rem 1.25rem;
    margin-bottom: 1rem;
    border: 1px solid transparent;
    border-radius: 0.25rem;
}

.alert-heading {
    color: inherit;
}

.alert-link {
    font-weight: 700;
}

.alert-dismissible {
    padding-right: 4rem;
}

    .alert-dismissible .close {
        position: absolute;
        top: 0;
        right: 0;
        z-index: 2;
        padding: 0.75rem 1.25rem;
        color: inherit;
    }

.alert-primary {
    color: #004085;
    background-color: #cce5ff;
    border-color: #b8daff;
}

    .alert-primary hr {
        border-top-color: #9fcdff;
    }

    .alert-primary .alert-link {
        color: #002752;
    }

.alert-secondary {
    color: #383d41;
    background-color: #e2e3e5;
    border-color: #d6d8db;
}

    .alert-secondary hr {
        border-top-color: #c8cbcf;
    }

    .alert-secondary .alert-link {
        color: #202326;
    }

.alert-success {
    color: #155724;
    background-color: #d4edda;
    border-color: #c3e6cb;
}

    .alert-success hr {
        border-top-color: #b1dfbb;
    }

    .alert-success .alert-link {
        color: #0b2e13;
    }

.alert-info {
    color: #0c5460;
    background-color: #d1ecf1;
    border-color: #bee5eb;
}

    .alert-info hr {
        border-top-color: #abdde5;
    }

    .alert-info .alert-link {
        color: #062c33;
    }

.alert-warning {
    color: #856404;
    background-color: #fff3cd;
    border-color: #ffeeba;
}

    .alert-warning hr {
        border-top-color: #ffe8a1;
    }

    .alert-warning .alert-link {
        color: #533f03;
    }

.alert-danger {
    color: #721c24;
    background-color: #f8d7da;
    border-color: #f5c6cb;
}

    .alert-danger hr {
        border-top-color: #f1b0b7;
    }

    .alert-danger .alert-link {
        color: #491217;
    }

.alert-light {
    color: #818182;
    background-color: #fefefe;
    border-color: #fdfdfe;
}

    .alert-light hr {
        border-top-color: #ececf6;
    }

    .alert-light .alert-link {
        color: #686868;
    }

.alert-dark {
    color: #1b1e21;
    background-color: #d6d8d9;
    border-color: #c6c8ca;
}

    .alert-dark hr {
        border-top-color: #b9bbbe;
    }

    .alert-dark .alert-link {
        color: #040505;
    }

@keyframes progress-bar-stripes {
    from {
        background-position: 1rem 0;
    }

    to {
        background-position: 0 0;
    }
}

.progress {
    display: -ms-flexbox;
    display: flex;
    height: 1rem;
    overflow: hidden;
    line-height: 0;
    font-size: 0.75rem;
    background-color: #e9ecef;
    border-radius: 0.25rem;
}

.progress-bar {
    display: -ms-flexbox;
    display: flex;
    -ms-flex-direction: column;
    flex-direction: column;
    -ms-flex-pack: center;
    justify-content: center;
    overflow: hidden;
    color: #fff;
    text-align: center;
    white-space: nowrap;
    background-color: #007bff;
    transition: width 0.6s ease;
}

@media (prefers-reduced-motion: reduce) {
    .progress-bar {
        transition: none;
    }
}

.progress-bar-striped {
    background-image: linear-gradient(45deg, rgba(255, 255, 255, 0.15) 25%, transparent 25%, transparent 50%, rgba(255, 255, 255, 0.15) 50%, rgba(255, 255, 255, 0.15) 75%, transparent 75%, transparent);
    background-size: 1rem 1rem;
}

.progress-bar-animated {
    animation: 1s linear infinite progress-bar-stripes;
}

@media (prefers-reduced-motion: reduce) {
    .progress-bar-animated {
        animation: none;
    }
}

.media {
    display: -ms-flexbox;
    display: flex;
    -ms-flex-align: start;
    align-items: flex-start;
}

.media-body {
    -ms-flex: 1;
    flex: 1;
}

.list-group {
    display: -ms-flexbox;
    display: flex;
    -ms-flex-direction: column;
    flex-direction: column;
    padding-left: 0;
    margin-bottom: 0;
    border-radius: 0.25rem;
}

.list-group-item-action {
    width: 100%;
    color: #495057;
    text-align: inherit;
}

    .list-group-item-action:hover, .list-group-item-action:focus {
        z-index: 1;
        color: #495057;
        text-decoration: none;
        background-color: #f8f9fa;
    }

    .list-group-item-action:active {
        color: #212529;
        background-color: #e9ecef;
    }

.list-group-item {
    position: relative;
    display: block;
    padding: 0.75rem 1.25rem;
    background-color: #fff;
    border: 1px solid rgba(0, 0, 0, 0.125);
}

    .list-group-item:first-child {
        border-top-left-radius: inherit;
        border-top-right-radius: inherit;
    }

    .list-group-item:last-child {
        border-bottom-right-radius: inherit;
        border-bottom-left-radius: inherit;
    }

    .list-group-item.disabled, .list-group-item:disabled {
        color: #6c757d;
        pointer-events: none;
        background-color: #fff;
    }

    .list-group-item.active {
        z-index: 2;
        color: #fff;
        background-color: #007bff;
        border-color: #007bff;
    }

    .list-group-item + .list-group-item {
        border-top-width: 0;
    }

        .list-group-item + .list-group-item.active {
            margin-top: -1px;
            border-top-width: 1px;
        }

.list-group-horizontal {
    -ms-flex-direction: row;
    flex-direction: row;
}

    .list-group-horizontal > .list-group-item:first-child {
        border-bottom-left-radius: 0.25rem;
        border-top-right-radius: 0;
    }

    .list-group-horizontal > .list-group-item:last-child {
        border-top-right-radius: 0.25rem;
        border-bottom-left-radius: 0;
    }

    .list-group-horizontal > .list-group-item.active {
        margin-top: 0;
    }

    .list-group-horizontal > .list-group-item + .list-group-item {
        border-top-width: 1px;
        border-left-width: 0;
    }

        .list-group-horizontal > .list-group-item + .list-group-item.active {
            margin-left: -1px;
            border-left-width: 1px;
        }

@media (min-width: 576px) {
    .list-group-horizontal-sm {
        -ms-flex-direction: row;
        flex-direction: row;
    }

        .list-group-horizontal-sm > .list-group-item:first-child {
            border-bottom-left-radius: 0.25rem;
            border-top-right-radius: 0;
        }

        .list-group-horizontal-sm > .list-group-item:last-child {
            border-top-right-radius: 0.25rem;
            border-bottom-left-radius: 0;
        }

        .list-group-horizontal-sm > .list-group-item.active {
            margin-top: 0;
        }

        .list-group-horizontal-sm > .list-group-item + .list-group-item {
            border-top-width: 1px;
            border-left-width: 0;
        }

            .list-group-horizontal-sm > .list-group-item + .list-group-item.active {
                margin-left: -1px;
                border-left-width: 1px;
            }
}

@media (min-width: 768px) {
    .list-group-horizontal-md {
        -ms-flex-direction: row;
        flex-direction: row;
    }

        .list-group-horizontal-md > .list-group-item:first-child {
            border-bottom-left-radius: 0.25rem;
            border-top-right-radius: 0;
        }

        .list-group-horizontal-md > .list-group-item:last-child {
            border-top-right-radius: 0.25rem;
            border-bottom-left-radius: 0;
        }

        .list-group-horizontal-md > .list-group-item.active {
            margin-top: 0;
        }

        .list-group-horizontal-md > .list-group-item + .list-group-item {
            border-top-width: 1px;
            border-left-width: 0;
        }

            .list-group-horizontal-md > .list-group-item + .list-group-item.active {
                margin-left: -1px;
                border-left-width: 1px;
            }
}

@media (min-width: 992px) {
    .list-group-horizontal-lg {
        -ms-flex-direction: row;
        flex-direction: row;
    }

        .list-group-horizontal-lg > .list-group-item:first-child {
            border-bottom-left-radius: 0.25rem;
            border-top-right-radius: 0;
        }

        .list-group-horizontal-lg > .list-group-item:last-child {
            border-top-right-radius: 0.25rem;
            border-bottom-left-radius: 0;
        }

        .list-group-horizontal-lg > .list-group-item.active {
            margin-top: 0;
        }

        .list-group-horizontal-lg > .list-group-item + .list-group-item {
            border-top-width: 1px;
            border-left-width: 0;
        }

            .list-group-horizontal-lg > .list-group-item + .list-group-item.active {
                margin-left: -1px;
                border-left-width: 1px;
            }
}

@media (min-width: 1200px) {
    .list-group-horizontal-xl {
        -ms-flex-direction: row;
        flex-direction: row;
    }

        .list-group-horizontal-xl > .list-group-item:first-child {
            border-bottom-left-radius: 0.25rem;
            border-top-right-radius: 0;
        }

        .list-group-horizontal-xl > .list-group-item:last-child {
            border-top-right-radius: 0.25rem;
            border-bottom-left-radius: 0;
        }

        .list-group-horizontal-xl > .list-group-item.active {
            margin-top: 0;
        }

        .list-group-horizontal-xl > .list-group-item + .list-group-item {
            border-top-width: 1px;
            border-left-width: 0;
        }

            .list-group-horizontal-xl > .list-group-item + .list-group-item.active {
                margin-left: -1px;
                border-left-width: 1px;
            }
}

.list-group-flush {
    border-radius: 0;
}

    .list-group-flush > .list-group-item {
        border-width: 0 0 1px;
    }

        .list-group-flush > .list-group-item:last-child {
            border-bottom-width: 0;
        }

.list-group-item-primary {
    color: #004085;
    background-color: #b8daff;
}

    .list-group-item-primary.list-group-item-action:hover, .list-group-item-primary.list-group-item-action:focus {
        color: #004085;
        background-color: #9fcdff;
    }

    .list-group-item-primary.list-group-item-action.active {
        color: #fff;
        background-color: #004085;
        border-color: #004085;
    }

.list-group-item-secondary {
    color: #383d41;
    background-color: #d6d8db;
}

    .list-group-item-secondary.list-group-item-action:hover, .list-group-item-secondary.list-group-item-action:focus {
        color: #383d41;
        background-color: #c8cbcf;
    }

    .list-group-item-secondary.list-group-item-action.active {
        color: #fff;
        background-color: #383d41;
        border-color: #383d41;
    }

.list-group-item-success {
    color: #155724;
    background-color: #c3e6cb;
}

    .list-group-item-success.list-group-item-action:hover, .list-group-item-success.list-group-item-action:focus {
        color: #155724;
        background-color: #b1dfbb;
    }

    .list-group-item-success.list-group-item-action.active {
        color: #fff;
        background-color: #155724;
        border-color: #155724;
    }

.list-group-item-info {
    color: #0c5460;
    background-color: #bee5eb;
}

    .list-group-item-info.list-group-item-action:hover, .list-group-item-info.list-group-item-action:focus {
        color: #0c5460;
        background-color: #abdde5;
    }

    .list-group-item-info.list-group-item-action.active {
        color: #fff;
        background-color: #0c5460;
        border-color: #0c5460;
    }

.list-group-item-warning {
    color: #856404;
    background-color: #ffeeba;
}

    .list-group-item-warning.list-group-item-action:hover, .list-group-item-warning.list-group-item-action:focus {
        color: #856404;
        background-color: #ffe8a1;
    }

    .list-group-item-warning.list-group-item-action.active {
        color: #fff;
        background-color: #856404;
        border-color: #856404;
    }

.list-group-item-danger {
    color: #721c24;
    background-color: #f5c6cb;
}

    .list-group-item-danger.list-group-item-action:hover, .list-group-item-danger.list-group-item-action:focus {
        color: #721c24;
        background-color: #f1b0b7;
    }

    .list-group-item-danger.list-group-item-action.active {
        color: #fff;
        background-color: #721c24;
        border-color: #721c24;
    }

.list-group-item-light {
    color: #818182;
    background-color: #fdfdfe;
}

    .list-group-item-light.list-group-item-action:hover, .list-group-item-light.list-group-item-action:focus {
        color: #818182;
        background-color: #ececf6;
    }

    .list-group-item-light.list-group-item-action.active {
        color: #fff;
        background-color: #818182;
        border-color: #818182;
    }

.list-group-item-dark {
    color: #1b1e21;
    background-color: #c6c8ca;
}

    .list-group-item-dark.list-group-item-action:hover, .list-group-item-dark.list-group-item-action:focus {
        color: #1b1e21;
        background-color: #b9bbbe;
    }

    .list-group-item-dark.list-group-item-action.active {
        color: #fff;
        background-color: #1b1e21;
        border-color: #1b1e21;
    }

.close {
    float: right;
    font-size: 1.5rem;
    font-weight: 700;
    line-height: 1;
    color: #000;
    text-shadow: 0 1px 0 #fff;
    opacity: .5;
}

    .close:hover {
        color: #000;
        text-decoration: none;
    }

    .close:not(:disabled):not(.disabled):hover, .close:not(:disabled):not(.disabled):focus {
        opacity: .75;
    }

button.close {
    padding: 0;
    background-color: transparent;
    border: 0;
}

a.close.disabled {
    pointer-events: none;
}

.toast {
    -ms-flex-preferred-size: 350px;
    flex-basis: 350px;
    max-width: 350px;
    font-size: 0.875rem;
    background-color: rgba(255, 255, 255, 0.85);
    background-clip: padding-box;
    border: 1px solid rgba(0, 0, 0, 0.1);
    box-shadow: 0 0.25rem 0.75rem rgba(0, 0, 0, 0.1);
    opacity: 0;
    border-radius: 0.25rem;
}

    .toast:not(:last-child) {
        margin-bottom: 0.75rem;
    }

    .toast.showing {
        opacity: 1;
    }

    .toast.show {
        display: block;
        opacity: 1;
    }

    .toast.hide {
        display: none;
    }

.toast-header {
    display: -ms-flexbox;
    display: flex;
    -ms-flex-align: center;
    align-items: center;
    padding: 0.25rem 0.75rem;
    color: #6c757d;
    background-color: rgba(255, 255, 255, 0.85);
    background-clip: padding-box;
    border-bottom: 1px solid rgba(0, 0, 0, 0.05);
    border-top-left-radius: calc(0.25rem - 1px);
    border-top-right-radius: calc(0.25rem - 1px);
}

.toast-body {
    padding: 0.75rem;
}

.modal-open {
    overflow: hidden;
}

    .modal-open .modal {
        overflow-x: hidden;
        overflow-y: auto;
    }

.modal {
    position: fixed;
    top: 0;
    left: 0;
    z-index: 1050;
    display: none;
    width: 100%;
    height: 100%;
    overflow: hidden;
    outline: 0;
}

.modal-dialog {
    position: relative;
    width: auto;
    margin: 0.5rem;
    pointer-events: none;
}

.modal.fade .modal-dialog {
    transition: transform 0.3s ease-out;
    -ms-transform: translate(0, -50px);
    transform: translate(0, -50px);
}

@media (prefers-reduced-motion: reduce) {
    .modal.fade .modal-dialog {
        transition: none;
    }
}

.modal.show .modal-dialog {
    -ms-transform: none;
    transform: none;
}

.modal.modal-static .modal-dialog {
    -ms-transform: scale(1.02);
    transform: scale(1.02);
}

.modal-dialog-scrollable {
    display: -ms-flexbox;
    display: flex;
    max-height: calc(100% - 1rem);
}

    .modal-dialog-scrollable .modal-content {
        max-height: calc(100vh - 1rem);
        overflow: hidden;
    }

    .modal-dialog-scrollable .modal-header,
    .modal-dialog-scrollable .modal-footer {
        -ms-flex-negative: 0;
        flex-shrink: 0;
    }

    .modal-dialog-scrollable .modal-body {
        overflow-y: auto;
    }

.modal-dialog-centered {
    display: -ms-flexbox;
    display: flex;
    -ms-flex-align: center;
    align-items: center;
    min-height: calc(100% - 1rem);
}

    .modal-dialog-centered::before {
        display: block;
        height: calc(100vh - 1rem);
        height: -webkit-min-content;
        height: -moz-min-content;
        height: min-content;
        content: "";
    }

    .modal-dialog-centered.modal-dialog-scrollable {
        -ms-flex-direction: column;
        flex-direction: column;
        -ms-flex-pack: center;
        justify-content: center;
        height: 100%;
    }

        .modal-dialog-centered.modal-dialog-scrollable .modal-content {
            max-height: none;
        }

        .modal-dialog-centered.modal-dialog-scrollable::before {
            content: none;
        }

.modal-content {
    position: relative;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-direction: column;
    flex-direction: column;
    width: 100%;
    pointer-events: auto;
    background-color: #fff;
    background-clip: padding-box;
    border: 1px solid rgba(0, 0, 0, 0.2);
    border-radius: 0.3rem;
    outline: 0;
}

.modal-backdrop {
    position: fixed;
    top: 0;
    left: 0;
    z-index: 1040;
    width: 100vw;
    height: 100vh;
    background-color: #000;
}

    .modal-backdrop.fade {
        opacity: 0;
    }

    .modal-backdrop.show {
        opacity: 0.5;
    }

.modal-header {
    display: -ms-flexbox;
    display: flex;
    -ms-flex-align: start;
    align-items: flex-start;
    -ms-flex-pack: justify;
    justify-content: space-between;
    padding: 1rem 1rem;
    border-bottom: 1px solid #dee2e6;
    border-top-left-radius: calc(0.3rem - 1px);
    border-top-right-radius: calc(0.3rem - 1px);
}

    .modal-header .close {
        padding: 1rem 1rem;
        margin: -1rem -1rem -1rem auto;
    }

.modal-title {
    margin-bottom: 0;
    line-height: 1.5;
}

.modal-body {
    position: relative;
    -ms-flex: 1 1 auto;
    flex: 1 1 auto;
    padding: 1rem;
}

.modal-footer {
    display: -ms-flexbox;
    display: flex;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
    -ms-flex-align: center;
    align-items: center;
    -ms-flex-pack: end;
    justify-content: flex-end;
    padding: 0.75rem;
    border-top: 1px solid #dee2e6;
    border-bottom-right-radius: calc(0.3rem - 1px);
    border-bottom-left-radius: calc(0.3rem - 1px);
}

    .modal-footer > * {
        margin: 0.25rem;
    }

.modal-scrollbar-measure {
    position: absolute;
    top: -9999px;
    width: 50px;
    height: 50px;
    overflow: scroll;
}

@media (min-width: 576px) {
    .modal-dialog {
        max-width: 500px;
        margin: 1.75rem auto;
    }

    .modal-dialog-scrollable {
        max-height: calc(100% - 3.5rem);
    }

        .modal-dialog-scrollable .modal-content {
            max-height: calc(100vh - 3.5rem);
        }

    .modal-dialog-centered {
        min-height: calc(100% - 3.5rem);
    }

        .modal-dialog-centered::before {
            height: calc(100vh - 3.5rem);
            height: -webkit-min-content;
            height: -moz-min-content;
            height: min-content;
        }

    .modal-sm {
        max-width: 300px;
    }
}

@media (min-width: 992px) {
    .modal-lg,
    .modal-xl {
        max-width: 800px;
    }
}

@media (min-width: 1200px) {
    .modal-xl {
        max-width: 1140px;
    }
}

.tooltip {
    position: absolute;
    z-index: 1070;
    display: block;
    margin: 0;
    font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "Helvetica Neue", Arial, "Noto Sans", "Liberation Sans", sans-serif, "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol", "Noto Color Emoji";
    font-style: normal;
    font-weight: 400;
    line-height: 1.5;
    text-align: left;
    text-align: start;
    text-decoration: none;
    text-shadow: none;
    text-transform: none;
    letter-spacing: normal;
    word-break: normal;
    word-spacing: normal;
    white-space: normal;
    line-break: auto;
    font-size: 0.875rem;
    word-wrap: break-word;
    opacity: 0;
}

    .tooltip.show {
        opacity: 0.9;
    }

    .tooltip .arrow {
        position: absolute;
        display: block;
        width: 0.8rem;
        height: 0.4rem;
    }

        .tooltip .arrow::before {
            position: absolute;
            content: "";
            border-color: transparent;
            border-style: solid;
        }

.bs-tooltip-top, .bs-tooltip-auto[x-placement^="top"] {
    padding: 0.4rem 0;
}

    .bs-tooltip-top .arrow, .bs-tooltip-auto[x-placement^="top"] .arrow {
        bottom: 0;
    }

        .bs-tooltip-top .arrow::before, .bs-tooltip-auto[x-placement^="top"] .arrow::before {
            top: 0;
            border-width: 0.4rem 0.4rem 0;
            border-top-color: #000;
        }

.bs-tooltip-right, .bs-tooltip-auto[x-placement^="right"] {
    padding: 0 0.4rem;
}

    .bs-tooltip-right .arrow, .bs-tooltip-auto[x-placement^="right"] .arrow {
        left: 0;
        width: 0.4rem;
        height: 0.8rem;
    }

        .bs-tooltip-right .arrow::before, .bs-tooltip-auto[x-placement^="right"] .arrow::before {
            right: 0;
            border-width: 0.4rem 0.4rem 0.4rem 0;
            border-right-color: #000;
        }

.bs-tooltip-bottom, .bs-tooltip-auto[x-placement^="bottom"] {
    padding: 0.4rem 0;
}

    .bs-tooltip-bottom .arrow, .bs-tooltip-auto[x-placement^="bottom"] .arrow {
        top: 0;
    }

        .bs-tooltip-bottom .arrow::before, .bs-tooltip-auto[x-placement^="bottom"] .arrow::before {
            bottom: 0;
            border-width: 0 0.4rem 0.4rem;
            border-bottom-color: #000;
        }

.bs-tooltip-left, .bs-tooltip-auto[x-placement^="left"] {
    padding: 0 0.4rem;
}

    .bs-tooltip-left .arrow, .bs-tooltip-auto[x-placement^="left"] .arrow {
        right: 0;
        width: 0.4rem;
        height: 0.8rem;
    }

        .bs-tooltip-left .arrow::before, .bs-tooltip-auto[x-placement^="left"] .arrow::before {
            left: 0;
            border-width: 0.4rem 0 0.4rem 0.4rem;
            border-left-color: #000;
        }

.tooltip-inner {
    max-width: 200px;
    padding: 0.25rem 0.5rem;
    color: #fff;
    text-align: center;
    background-color: #000;
    border-radius: 0.25rem;
}

.popover {
    position: absolute;
    top: 0;
    left: 0;
    z-index: 1060;
    display: block;
    max-width: 276px;
    font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "Helvetica Neue", Arial, "Noto Sans", "Liberation Sans", sans-serif, "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol", "Noto Color Emoji";
    font-style: normal;
    font-weight: 400;
    line-height: 1.5;
    text-align: left;
    text-align: start;
    text-decoration: none;
    text-shadow: none;
    text-transform: none;
    letter-spacing: normal;
    word-break: normal;
    word-spacing: normal;
    white-space: normal;
    line-break: auto;
    font-size: 0.875rem;
    word-wrap: break-word;
    background-color: #fff;
    background-clip: padding-box;
    border: 1px solid rgba(0, 0, 0, 0.2);
    border-radius: 0.3rem;
}

    .popover .arrow {
        position: absolute;
        display: block;
        width: 1rem;
        height: 0.5rem;
        margin: 0 0.3rem;
    }

        .popover .arrow::before, .popover .arrow::after {
            position: absolute;
            display: block;
            content: "";
            border-color: transparent;
            border-style: solid;
        }

.bs-popover-top, .bs-popover-auto[x-placement^="top"] {
    margin-bottom: 0.5rem;
}

    .bs-popover-top > .arrow, .bs-popover-auto[x-placement^="top"] > .arrow {
        bottom: calc(-0.5rem - 1px);
    }

        .bs-popover-top > .arrow::before, .bs-popover-auto[x-placement^="top"] > .arrow::before {
            bottom: 0;
            border-width: 0.5rem 0.5rem 0;
            border-top-color: rgba(0, 0, 0, 0.25);
        }

        .bs-popover-top > .arrow::after, .bs-popover-auto[x-placement^="top"] > .arrow::after {
            bottom: 1px;
            border-width: 0.5rem 0.5rem 0;
            border-top-color: #fff;
        }

.bs-popover-right, .bs-popover-auto[x-placement^="right"] {
    margin-left: 0.5rem;
}

    .bs-popover-right > .arrow, .bs-popover-auto[x-placement^="right"] > .arrow {
        left: calc(-0.5rem - 1px);
        width: 0.5rem;
        height: 1rem;
        margin: 0.3rem 0;
    }

        .bs-popover-right > .arrow::before, .bs-popover-auto[x-placement^="right"] > .arrow::before {
            left: 0;
            border-width: 0.5rem 0.5rem 0.5rem 0;
            border-right-color: rgba(0, 0, 0, 0.25);
        }

        .bs-popover-right > .arrow::after, .bs-popover-auto[x-placement^="right"] > .arrow::after {
            left: 1px;
            border-width: 0.5rem 0.5rem 0.5rem 0;
            border-right-color: #fff;
        }

.bs-popover-bottom, .bs-popover-auto[x-placement^="bottom"] {
    margin-top: 0.5rem;
}

    .bs-popover-bottom > .arrow, .bs-popover-auto[x-placement^="bottom"] > .arrow {
        top: calc(-0.5rem - 1px);
    }

        .bs-popover-bottom > .arrow::before, .bs-popover-auto[x-placement^="bottom"] > .arrow::before {
            top: 0;
            border-width: 0 0.5rem 0.5rem 0.5rem;
            border-bottom-color: rgba(0, 0, 0, 0.25);
        }

        .bs-popover-bottom > .arrow::after, .bs-popover-auto[x-placement^="bottom"] > .arrow::after {
            top: 1px;
            border-width: 0 0.5rem 0.5rem 0.5rem;
            border-bottom-color: #fff;
        }

    .bs-popover-bottom .popover-header::before, .bs-popover-auto[x-placement^="bottom"] .popover-header::before {
        position: absolute;
        top: 0;
        left: 50%;
        display: block;
        width: 1rem;
        margin-left: -0.5rem;
        content: "";
        border-bottom: 1px solid #f7f7f7;
    }

.bs-popover-left, .bs-popover-auto[x-placement^="left"] {
    margin-right: 0.5rem;
}

    .bs-popover-left > .arrow, .bs-popover-auto[x-placement^="left"] > .arrow {
        right: calc(-0.5rem - 1px);
        width: 0.5rem;
        height: 1rem;
        margin: 0.3rem 0;
    }

        .bs-popover-left > .arrow::before, .bs-popover-auto[x-placement^="left"] > .arrow::before {
            right: 0;
            border-width: 0.5rem 0 0.5rem 0.5rem;
            border-left-color: rgba(0, 0, 0, 0.25);
        }

        .bs-popover-left > .arrow::after, .bs-popover-auto[x-placement^="left"] > .arrow::after {
            right: 1px;
            border-width: 0.5rem 0 0.5rem 0.5rem;
            border-left-color: #fff;
        }

.popover-header {
    padding: 0.5rem 0.75rem;
    margin-bottom: 0;
    font-size: 1rem;
    background-color: #f7f7f7;
    border-bottom: 1px solid #ebebeb;
    border-top-left-radius: calc(0.3rem - 1px);
    border-top-right-radius: calc(0.3rem - 1px);
}

    .popover-header:empty {
        display: none;
    }

.popover-body {
    padding: 0.5rem 0.75rem;
    color: #212529;
}

.carousel {
    position: relative;
}

    .carousel.pointer-event {
        -ms-touch-action: pan-y;
        touch-action: pan-y;
    }

.carousel-inner {
    position: relative;
    width: 100%;
    overflow: hidden;
}

    .carousel-inner::after {
        display: block;
        clear: both;
        content: "";
    }

.carousel-item {
    position: relative;
    display: none;
    float: left;
    width: 100%;
    margin-right: -100%;
    -webkit-backface-visibility: hidden;
    backface-visibility: hidden;
    transition: transform 0.6s ease-in-out;
}

@media (prefers-reduced-motion: reduce) {
    .carousel-item {
        transition: none;
    }
}

.carousel-item.active,
.carousel-item-next,
.carousel-item-prev {
    display: block;
}

    .carousel-item-next:not(.carousel-item-left),
    .active.carousel-item-right {
        -ms-transform: translateX(100%);
        transform: translateX(100%);
    }

    .carousel-item-prev:not(.carousel-item-right),
    .active.carousel-item-left {
        -ms-transform: translateX(-100%);
        transform: translateX(-100%);
    }

.carousel-fade .carousel-item {
    opacity: 0;
    transition-property: opacity;
    -ms-transform: none;
    transform: none;
}

    .carousel-fade .carousel-item.active,
    .carousel-fade .carousel-item-next.carousel-item-left,
    .carousel-fade .carousel-item-prev.carousel-item-right {
        z-index: 1;
        opacity: 1;
    }

.carousel-fade .active.carousel-item-left,
.carousel-fade .active.carousel-item-right {
    z-index: 0;
    opacity: 0;
    transition: opacity 0s 0.6s;
}

@media (prefers-reduced-motion: reduce) {
    .carousel-fade .active.carousel-item-left,
    .carousel-fade .active.carousel-item-right {
        transition: none;
    }
}

.carousel-control-prev,
.carousel-control-next {
    position: absolute;
    top: 0;
    bottom: 0;
    z-index: 1;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-align: center;
    align-items: center;
    -ms-flex-pack: center;
    justify-content: center;
    width: 15%;
    color: #fff;
    text-align: center;
    opacity: 0.5;
    transition: opacity 0.15s ease;
}

@media (prefers-reduced-motion: reduce) {
    .carousel-control-prev,
    .carousel-control-next {
        transition: none;
    }
}

.carousel-control-prev:hover, .carousel-control-prev:focus,
.carousel-control-next:hover,
.carousel-control-next:focus {
    color: #fff;
    text-decoration: none;
    outline: 0;
    opacity: 0.9;
}

.carousel-control-prev {
    left: 0;
}

.carousel-control-next {
    right: 0;
}

.carousel-control-prev-icon,
.carousel-control-next-icon {
    display: inline-block;
    width: 20px;
    height: 20px;
    background: 50% / 100% 100% no-repeat;
}

.carousel-control-prev-icon {
    background-image: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' fill='%23fff' width='8' height='8' viewBox='0 0 8 8'%3e%3cpath d='M5.25 0l-4 4 4 4 1.5-1.5L4.25 4l2.5-2.5L5.25 0z'/%3e%3c/svg%3e");
}

.carousel-control-next-icon {
    background-image: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' fill='%23fff' width='8' height='8' viewBox='0 0 8 8'%3e%3cpath d='M2.75 0l-1.5 1.5L3.75 4l-2.5 2.5L2.75 8l4-4-4-4z'/%3e%3c/svg%3e");
}

.carousel-indicators {
    position: absolute;
    right: 0;
    bottom: 0;
    left: 0;
    z-index: 15;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-pack: center;
    justify-content: center;
    padding-left: 0;
    margin-right: 15%;
    margin-left: 15%;
    list-style: none;
}

    .carousel-indicators li {
        box-sizing: content-box;
        -ms-flex: 0 1 auto;
        flex: 0 1 auto;
        width: 30px;
        height: 3px;
        margin-right: 3px;
        margin-left: 3px;
        text-indent: -999px;
        cursor: pointer;
        background-color: #fff;
        background-clip: padding-box;
        border-top: 10px solid transparent;
        border-bottom: 10px solid transparent;
        opacity: .5;
        transition: opacity 0.6s ease;
    }

@media (prefers-reduced-motion: reduce) {
    .carousel-indicators li {
        transition: none;
    }
}

.carousel-indicators .active {
    opacity: 1;
}

.carousel-caption {
    position: absolute;
    right: 15%;
    bottom: 20px;
    left: 15%;
    z-index: 10;
    padding-top: 20px;
    padding-bottom: 20px;
    color: #fff;
    text-align: center;
}

@keyframes spinner-border {
    to {
        transform: rotate(360deg);
    }
}

.spinner-border {
    display: inline-block;
    width: 2rem;
    height: 2rem;
    vertical-align: text-bottom;
    border: 0.25em solid currentColor;
    border-right-color: transparent;
    border-radius: 50%;
    animation: .75s linear infinite spinner-border;
}

.spinner-border-sm {
    width: 1rem;
    height: 1rem;
    border-width: 0.2em;
}

@keyframes spinner-grow {
    0% {
        transform: scale(0);
    }

    50% {
        opacity: 1;
        transform: none;
    }
}

.spinner-grow {
    display: inline-block;
    width: 2rem;
    height: 2rem;
    vertical-align: text-bottom;
    background-color: currentColor;
    border-radius: 50%;
    opacity: 0;
    animation: .75s linear infinite spinner-grow;
}

.spinner-grow-sm {
    width: 1rem;
    height: 1rem;
}

@media (prefers-reduced-motion: reduce) {
    .spinner-border,
    .spinner-grow {
        animation-duration: 1.5s;
    }
}

.align-baseline {
    vertical-align: baseline !important;
}

.align-top {
    vertical-align: top !important;
}

.align-middle {
    vertical-align: middle !important;
}

.align-bottom {
    vertical-align: bottom !important;
}

.align-text-bottom {
    vertical-align: text-bottom !important;
}

.align-text-top {
    vertical-align: text-top !important;
}

.bg-primary {
    background-color: #007bff !important;
}

a.bg-primary:hover, a.bg-primary:focus,
button.bg-primary:hover,
button.bg-primary:focus {
    background-color: #0062cc !important;
}

.bg-secondary {
    background-color: #6c757d !important;
}

a.bg-secondary:hover, a.bg-secondary:focus,
button.bg-secondary:hover,
button.bg-secondary:focus {
    background-color: #545b62 !important;
}

.bg-success {
    background-color: #28a745 !important;
}

a.bg-success:hover, a.bg-success:focus,
button.bg-success:hover,
button.bg-success:focus {
    background-color: #1e7e34 !important;
}

.bg-info {
    background-color: #17a2b8 !important;
}

a.bg-info:hover, a.bg-info:focus,
button.bg-info:hover,
button.bg-info:focus {
    background-color: #117a8b !important;
}

.bg-warning {
    background-color: #ffc107 !important;
}

a.bg-warning:hover, a.bg-warning:focus,
button.bg-warning:hover,
button.bg-warning:focus {
    background-color: #d39e00 !important;
}

.bg-danger {
    background-color: #dc3545 !important;
}

a.bg-danger:hover, a.bg-danger:focus,
button.bg-danger:hover,
button.bg-danger:focus {
    background-color: #bd2130 !important;
}

.bg-light {
    background-color: #f8f9fa !important;
}

a.bg-light:hover, a.bg-light:focus,
button.bg-light:hover,
button.bg-light:focus {
    background-color: #dae0e5 !important;
}

.bg-dark {
    background-color: #343a40 !important;
}

a.bg-dark:hover, a.bg-dark:focus,
button.bg-dark:hover,
button.bg-dark:focus {
    background-color: #1d2124 !important;
}

.bg-white {
    background-color: #fff !important;
}

.bg-transparent {
    background-color: transparent !important;
}

.border {
    border: 1px solid #dee2e6 !important;
}

.border-top {
    border-top: 1px solid #dee2e6 !important;
}

.border-right {
    border-right: 1px solid #dee2e6 !important;
}

.border-bottom {
    border-bottom: 1px solid #dee2e6 !important;
}

.border-left {
    border-left: 1px solid #dee2e6 !important;
}

.border-0 {
    border: 0 !important;
}

.border-top-0 {
    border-top: 0 !important;
}

.border-right-0 {
    border-right: 0 !important;
}

.border-bottom-0 {
    border-bottom: 0 !important;
}

.border-left-0 {
    border-left: 0 !important;
}

.border-primary {
    border-color: #007bff !important;
}

.border-secondary {
    border-color: #6c757d !important;
}

.border-success {
    border-color: #28a745 !important;
}

.border-info {
    border-color: #17a2b8 !important;
}

.border-warning {
    border-color: #ffc107 !important;
}

.border-danger {
    border-color: #dc3545 !important;
}

.border-light {
    border-color: #f8f9fa !important;
}

.border-dark {
    border-color: #343a40 !important;
}

.border-white {
    border-color: #fff !important;
}

.rounded-sm {
    border-radius: 0.2rem !important;
}

.rounded {
    border-radius: 0.25rem !important;
}

.rounded-top {
    border-top-left-radius: 0.25rem !important;
    border-top-right-radius: 0.25rem !important;
}

.rounded-right {
    border-top-right-radius: 0.25rem !important;
    border-bottom-right-radius: 0.25rem !important;
}

.rounded-bottom {
    border-bottom-right-radius: 0.25rem !important;
    border-bottom-left-radius: 0.25rem !important;
}

.rounded-left {
    border-top-left-radius: 0.25rem !important;
    border-bottom-left-radius: 0.25rem !important;
}

.rounded-lg {
    border-radius: 0.3rem !important;
}

.rounded-circle {
    border-radius: 50% !important;
}

.rounded-pill {
    border-radius: 50rem !important;
}

.rounded-0 {
    border-radius: 0 !important;
}

.clearfix::after {
    display: block;
    clear: both;
    content: "";
}

.d-none {
    display: none !important;
}

.d-inline {
    display: inline !important;
}

.d-inline-block {
    display: inline-block !important;
}

.d-block {
    display: block !important;
}

.d-table {
    display: table !important;
}

.d-table-row {
    display: table-row !important;
}

.d-table-cell {
    display: table-cell !important;
}

.d-flex {
    display: -ms-flexbox !important;
    display: flex !important;
}

.d-inline-flex {
    display: -ms-inline-flexbox !important;
    display: inline-flex !important;
}

@media (min-width: 576px) {
    .d-sm-none {
        display: none !important;
    }

    .d-sm-inline {
        display: inline !important;
    }

    .d-sm-inline-block {
        display: inline-block !important;
    }

    .d-sm-block {
        display: block !important;
    }

    .d-sm-table {
        display: table !important;
    }

    .d-sm-table-row {
        display: table-row !important;
    }

    .d-sm-table-cell {
        display: table-cell !important;
    }

    .d-sm-flex {
        display: -ms-flexbox !important;
        display: flex !important;
    }

    .d-sm-inline-flex {
        display: -ms-inline-flexbox !important;
        display: inline-flex !important;
    }
}

@media (min-width: 768px) {
    .d-md-none {
        display: none !important;
    }

    .d-md-inline {
        display: inline !important;
    }

    .d-md-inline-block {
        display: inline-block !important;
    }

    .d-md-block {
        display: block !important;
    }

    .d-md-table {
        display: table !important;
    }

    .d-md-table-row {
        display: table-row !important;
    }

    .d-md-table-cell {
        display: table-cell !important;
    }

    .d-md-flex {
        display: -ms-flexbox !important;
        display: flex !important;
    }

    .d-md-inline-flex {
        display: -ms-inline-flexbox !important;
        display: inline-flex !important;
    }
}

@media (min-width: 992px) {
    .d-lg-none {
        display: none !important;
    }

    .d-lg-inline {
        display: inline !important;
    }

    .d-lg-inline-block {
        display: inline-block !important;
    }

    .d-lg-block {
        display: block !important;
    }

    .d-lg-table {
        display: table !important;
    }

    .d-lg-table-row {
        display: table-row !important;
    }

    .d-lg-table-cell {
        display: table-cell !important;
    }

    .d-lg-flex {
        display: -ms-flexbox !important;
        display: flex !important;
    }

    .d-lg-inline-flex {
        display: -ms-inline-flexbox !important;
        display: inline-flex !important;
    }
}

@media (min-width: 1200px) {
    .d-xl-none {
        display: none !important;
    }

    .d-xl-inline {
        display: inline !important;
    }

    .d-xl-inline-block {
        display: inline-block !important;
    }

    .d-xl-block {
        display: block !important;
    }

    .d-xl-table {
        display: table !important;
    }

    .d-xl-table-row {
        display: table-row !important;
    }

    .d-xl-table-cell {
        display: table-cell !important;
    }

    .d-xl-flex {
        display: -ms-flexbox !important;
        display: flex !important;
    }

    .d-xl-inline-flex {
        display: -ms-inline-flexbox !important;
        display: inline-flex !important;
    }
}

@media print {
    .d-print-none {
        display: none !important;
    }

    .d-print-inline {
        display: inline !important;
    }

    .d-print-inline-block {
        display: inline-block !important;
    }

    .d-print-block {
        display: block !important;
    }

    .d-print-table {
        display: table !important;
    }

    .d-print-table-row {
        display: table-row !important;
    }

    .d-print-table-cell {
        display: table-cell !important;
    }

    .d-print-flex {
        display: -ms-flexbox !important;
        display: flex !important;
    }

    .d-print-inline-flex {
        display: -ms-inline-flexbox !important;
        display: inline-flex !important;
    }
}

.embed-responsive {
    position: relative;
    display: block;
    width: 100%;
    padding: 0;
    overflow: hidden;
}

    .embed-responsive::before {
        display: block;
        content: "";
    }

    .embed-responsive .embed-responsive-item,
    .embed-responsive iframe,
    .embed-responsive embed,
    .embed-responsive object,
    .embed-responsive video {
        position: absolute;
        top: 0;
        bottom: 0;
        left: 0;
        width: 100%;
        height: 100%;
        border: 0;
    }

.embed-responsive-21by9::before {
    padding-top: 42.85714%;
}

.embed-responsive-16by9::before {
    padding-top: 56.25%;
}

.embed-responsive-4by3::before {
    padding-top: 75%;
}

.embed-responsive-1by1::before {
    padding-top: 100%;
}

.flex-row {
    -ms-flex-direction: row !important;
    flex-direction: row !important;
}

.flex-column {
    -ms-flex-direction: column !important;
    flex-direction: column !important;
}

.flex-row-reverse {
    -ms-flex-direction: row-reverse !important;
    flex-direction: row-reverse !important;
}

.flex-column-reverse {
    -ms-flex-direction: column-reverse !important;
    flex-direction: column-reverse !important;
}

.flex-wrap {
    -ms-flex-wrap: wrap !important;
    flex-wrap: wrap !important;
}

.flex-nowrap {
    -ms-flex-wrap: nowrap !important;
    flex-wrap: nowrap !important;
}

.flex-wrap-reverse {
    -ms-flex-wrap: wrap-reverse !important;
    flex-wrap: wrap-reverse !important;
}

.flex-fill {
    -ms-flex: 1 1 auto !important;
    flex: 1 1 auto !important;
}

.flex-grow-0 {
    -ms-flex-positive: 0 !important;
    flex-grow: 0 !important;
}

.flex-grow-1 {
    -ms-flex-positive: 1 !important;
    flex-grow: 1 !important;
}

.flex-shrink-0 {
    -ms-flex-negative: 0 !important;
    flex-shrink: 0 !important;
}

.flex-shrink-1 {
    -ms-flex-negative: 1 !important;
    flex-shrink: 1 !important;
}

.justify-content-start {
    -ms-flex-pack: start !important;
    justify-content: flex-start !important;
}

.justify-content-end {
    -ms-flex-pack: end !important;
    justify-content: flex-end !important;
}

.justify-content-center {
    -ms-flex-pack: center !important;
    justify-content: center !important;
}

.justify-content-between {
    -ms-flex-pack: justify !important;
    justify-content: space-between !important;
}

.justify-content-around {
    -ms-flex-pack: distribute !important;
    justify-content: space-around !important;
}

.align-items-start {
    -ms-flex-align: start !important;
    align-items: flex-start !important;
}

.align-items-end {
    -ms-flex-align: end !important;
    align-items: flex-end !important;
}

.align-items-center {
    -ms-flex-align: center !important;
    align-items: center !important;
}

.align-items-baseline {
    -ms-flex-align: baseline !important;
    align-items: baseline !important;
}

.align-items-stretch {
    -ms-flex-align: stretch !important;
    align-items: stretch !important;
}

.align-content-start {
    -ms-flex-line-pack: start !important;
    align-content: flex-start !important;
}

.align-content-end {
    -ms-flex-line-pack: end !important;
    align-content: flex-end !important;
}

.align-content-center {
    -ms-flex-line-pack: center !important;
    align-content: center !important;
}

.align-content-between {
    -ms-flex-line-pack: justify !important;
    align-content: space-between !important;
}

.align-content-around {
    -ms-flex-line-pack: distribute !important;
    align-content: space-around !important;
}

.align-content-stretch {
    -ms-flex-line-pack: stretch !important;
    align-content: stretch !important;
}

.align-self-auto {
    -ms-flex-item-align: auto !important;
    -ms-grid-row-align: auto !important;
    align-self: auto !important;
}

.align-self-start {
    -ms-flex-item-align: start !important;
    align-self: flex-start !important;
}

.align-self-end {
    -ms-flex-item-align: end !important;
    align-self: flex-end !important;
}

.align-self-center {
    -ms-flex-item-align: center !important;
    -ms-grid-row-align: center !important;
    align-self: center !important;
}

.align-self-baseline {
    -ms-flex-item-align: baseline !important;
    align-self: baseline !important;
}

.align-self-stretch {
    -ms-flex-item-align: stretch !important;
    -ms-grid-row-align: stretch !important;
    align-self: stretch !important;
}

@media (min-width: 576px) {
    .flex-sm-row {
        -ms-flex-direction: row !important;
        flex-direction: row !important;
    }

    .flex-sm-column {
        -ms-flex-direction: column !important;
        flex-direction: column !important;
    }

    .flex-sm-row-reverse {
        -ms-flex-direction: row-reverse !important;
        flex-direction: row-reverse !important;
    }

    .flex-sm-column-reverse {
        -ms-flex-direction: column-reverse !important;
        flex-direction: column-reverse !important;
    }

    .flex-sm-wrap {
        -ms-flex-wrap: wrap !important;
        flex-wrap: wrap !important;
    }

    .flex-sm-nowrap {
        -ms-flex-wrap: nowrap !important;
        flex-wrap: nowrap !important;
    }

    .flex-sm-wrap-reverse {
        -ms-flex-wrap: wrap-reverse !important;
        flex-wrap: wrap-reverse !important;
    }

    .flex-sm-fill {
        -ms-flex: 1 1 auto !important;
        flex: 1 1 auto !important;
    }

    .flex-sm-grow-0 {
        -ms-flex-positive: 0 !important;
        flex-grow: 0 !important;
    }

    .flex-sm-grow-1 {
        -ms-flex-positive: 1 !important;
        flex-grow: 1 !important;
    }

    .flex-sm-shrink-0 {
        -ms-flex-negative: 0 !important;
        flex-shrink: 0 !important;
    }

    .flex-sm-shrink-1 {
        -ms-flex-negative: 1 !important;
        flex-shrink: 1 !important;
    }

    .justify-content-sm-start {
        -ms-flex-pack: start !important;
        justify-content: flex-start !important;
    }

    .justify-content-sm-end {
        -ms-flex-pack: end !important;
        justify-content: flex-end !important;
    }

    .justify-content-sm-center {
        -ms-flex-pack: center !important;
        justify-content: center !important;
    }

    .justify-content-sm-between {
        -ms-flex-pack: justify !important;
        justify-content: space-between !important;
    }

    .justify-content-sm-around {
        -ms-flex-pack: distribute !important;
        justify-content: space-around !important;
    }

    .align-items-sm-start {
        -ms-flex-align: start !important;
        align-items: flex-start !important;
    }

    .align-items-sm-end {
        -ms-flex-align: end !important;
        align-items: flex-end !important;
    }

    .align-items-sm-center {
        -ms-flex-align: center !important;
        align-items: center !important;
    }

    .align-items-sm-baseline {
        -ms-flex-align: baseline !important;
        align-items: baseline !important;
    }

    .align-items-sm-stretch {
        -ms-flex-align: stretch !important;
        align-items: stretch !important;
    }

    .align-content-sm-start {
        -ms-flex-line-pack: start !important;
        align-content: flex-start !important;
    }

    .align-content-sm-end {
        -ms-flex-line-pack: end !important;
        align-content: flex-end !important;
    }

    .align-content-sm-center {
        -ms-flex-line-pack: center !important;
        align-content: center !important;
    }

    .align-content-sm-between {
        -ms-flex-line-pack: justify !important;
        align-content: space-between !important;
    }

    .align-content-sm-around {
        -ms-flex-line-pack: distribute !important;
        align-content: space-around !important;
    }

    .align-content-sm-stretch {
        -ms-flex-line-pack: stretch !important;
        align-content: stretch !important;
    }

    .align-self-sm-auto {
        -ms-flex-item-align: auto !important;
        -ms-grid-row-align: auto !important;
        align-self: auto !important;
    }

    .align-self-sm-start {
        -ms-flex-item-align: start !important;
        align-self: flex-start !important;
    }

    .align-self-sm-end {
        -ms-flex-item-align: end !important;
        align-self: flex-end !important;
    }

    .align-self-sm-center {
        -ms-flex-item-align: center !important;
        -ms-grid-row-align: center !important;
        align-self: center !important;
    }

    .align-self-sm-baseline {
        -ms-flex-item-align: baseline !important;
        align-self: baseline !important;
    }

    .align-self-sm-stretch {
        -ms-flex-item-align: stretch !important;
        -ms-grid-row-align: stretch !important;
        align-self: stretch !important;
    }
}

@media (min-width: 768px) {
    .flex-md-row {
        -ms-flex-direction: row !important;
        flex-direction: row !important;
    }

    .flex-md-column {
        -ms-flex-direction: column !important;
        flex-direction: column !important;
    }

    .flex-md-row-reverse {
        -ms-flex-direction: row-reverse !important;
        flex-direction: row-reverse !important;
    }

    .flex-md-column-reverse {
        -ms-flex-direction: column-reverse !important;
        flex-direction: column-reverse !important;
    }

    .flex-md-wrap {
        -ms-flex-wrap: wrap !important;
        flex-wrap: wrap !important;
    }

    .flex-md-nowrap {
        -ms-flex-wrap: nowrap !important;
        flex-wrap: nowrap !important;
    }

    .flex-md-wrap-reverse {
        -ms-flex-wrap: wrap-reverse !important;
        flex-wrap: wrap-reverse !important;
    }

    .flex-md-fill {
        -ms-flex: 1 1 auto !important;
        flex: 1 1 auto !important;
    }

    .flex-md-grow-0 {
        -ms-flex-positive: 0 !important;
        flex-grow: 0 !important;
    }

    .flex-md-grow-1 {
        -ms-flex-positive: 1 !important;
        flex-grow: 1 !important;
    }

    .flex-md-shrink-0 {
        -ms-flex-negative: 0 !important;
        flex-shrink: 0 !important;
    }

    .flex-md-shrink-1 {
        -ms-flex-negative: 1 !important;
        flex-shrink: 1 !important;
    }

    .justify-content-md-start {
        -ms-flex-pack: start !important;
        justify-content: flex-start !important;
    }

    .justify-content-md-end {
        -ms-flex-pack: end !important;
        justify-content: flex-end !important;
    }

    .justify-content-md-center {
        -ms-flex-pack: center !important;
        justify-content: center !important;
    }

    .justify-content-md-between {
        -ms-flex-pack: justify !important;
        justify-content: space-between !important;
    }

    .justify-content-md-around {
        -ms-flex-pack: distribute !important;
        justify-content: space-around !important;
    }

    .align-items-md-start {
        -ms-flex-align: start !important;
        align-items: flex-start !important;
    }

    .align-items-md-end {
        -ms-flex-align: end !important;
        align-items: flex-end !important;
    }

    .align-items-md-center {
        -ms-flex-align: center !important;
        align-items: center !important;
    }

    .align-items-md-baseline {
        -ms-flex-align: baseline !important;
        align-items: baseline !important;
    }

    .align-items-md-stretch {
        -ms-flex-align: stretch !important;
        align-items: stretch !important;
    }

    .align-content-md-start {
        -ms-flex-line-pack: start !important;
        align-content: flex-start !important;
    }

    .align-content-md-end {
        -ms-flex-line-pack: end !important;
        align-content: flex-end !important;
    }

    .align-content-md-center {
        -ms-flex-line-pack: center !important;
        align-content: center !important;
    }

    .align-content-md-between {
        -ms-flex-line-pack: justify !important;
        align-content: space-between !important;
    }

    .align-content-md-around {
        -ms-flex-line-pack: distribute !important;
        align-content: space-around !important;
    }

    .align-content-md-stretch {
        -ms-flex-line-pack: stretch !important;
        align-content: stretch !important;
    }

    .align-self-md-auto {
        -ms-flex-item-align: auto !important;
        -ms-grid-row-align: auto !important;
        align-self: auto !important;
    }

    .align-self-md-start {
        -ms-flex-item-align: start !important;
        align-self: flex-start !important;
    }

    .align-self-md-end {
        -ms-flex-item-align: end !important;
        align-self: flex-end !important;
    }

    .align-self-md-center {
        -ms-flex-item-align: center !important;
        -ms-grid-row-align: center !important;
        align-self: center !important;
    }

    .align-self-md-baseline {
        -ms-flex-item-align: baseline !important;
        align-self: baseline !important;
    }

    .align-self-md-stretch {
        -ms-flex-item-align: stretch !important;
        -ms-grid-row-align: stretch !important;
        align-self: stretch !important;
    }
}

@media (min-width: 992px) {
    .flex-lg-row {
        -ms-flex-direction: row !important;
        flex-direction: row !important;
    }

    .flex-lg-column {
        -ms-flex-direction: column !important;
        flex-direction: column !important;
    }

    .flex-lg-row-reverse {
        -ms-flex-direction: row-reverse !important;
        flex-direction: row-reverse !important;
    }

    .flex-lg-column-reverse {
        -ms-flex-direction: column-reverse !important;
        flex-direction: column-reverse !important;
    }

    .flex-lg-wrap {
        -ms-flex-wrap: wrap !important;
        flex-wrap: wrap !important;
    }

    .flex-lg-nowrap {
        -ms-flex-wrap: nowrap !important;
        flex-wrap: nowrap !important;
    }

    .flex-lg-wrap-reverse {
        -ms-flex-wrap: wrap-reverse !important;
        flex-wrap: wrap-reverse !important;
    }

    .flex-lg-fill {
        -ms-flex: 1 1 auto !important;
        flex: 1 1 auto !important;
    }

    .flex-lg-grow-0 {
        -ms-flex-positive: 0 !important;
        flex-grow: 0 !important;
    }

    .flex-lg-grow-1 {
        -ms-flex-positive: 1 !important;
        flex-grow: 1 !important;
    }

    .flex-lg-shrink-0 {
        -ms-flex-negative: 0 !important;
        flex-shrink: 0 !important;
    }

    .flex-lg-shrink-1 {
        -ms-flex-negative: 1 !important;
        flex-shrink: 1 !important;
    }

    .justify-content-lg-start {
        -ms-flex-pack: start !important;
        justify-content: flex-start !important;
    }

    .justify-content-lg-end {
        -ms-flex-pack: end !important;
        justify-content: flex-end !important;
    }

    .justify-content-lg-center {
        -ms-flex-pack: center !important;
        justify-content: center !important;
    }

    .justify-content-lg-between {
        -ms-flex-pack: justify !important;
        justify-content: space-between !important;
    }

    .justify-content-lg-around {
        -ms-flex-pack: distribute !important;
        justify-content: space-around !important;
    }

    .align-items-lg-start {
        -ms-flex-align: start !important;
        align-items: flex-start !important;
    }

    .align-items-lg-end {
        -ms-flex-align: end !important;
        align-items: flex-end !important;
    }

    .align-items-lg-center {
        -ms-flex-align: center !important;
        align-items: center !important;
    }

    .align-items-lg-baseline {
        -ms-flex-align: baseline !important;
        align-items: baseline !important;
    }

    .align-items-lg-stretch {
        -ms-flex-align: stretch !important;
        align-items: stretch !important;
    }

    .align-content-lg-start {
        -ms-flex-line-pack: start !important;
        align-content: flex-start !important;
    }

    .align-content-lg-end {
        -ms-flex-line-pack: end !important;
        align-content: flex-end !important;
    }

    .align-content-lg-center {
        -ms-flex-line-pack: center !important;
        align-content: center !important;
    }

    .align-content-lg-between {
        -ms-flex-line-pack: justify !important;
        align-content: space-between !important;
    }

    .align-content-lg-around {
        -ms-flex-line-pack: distribute !important;
        align-content: space-around !important;
    }

    .align-content-lg-stretch {
        -ms-flex-line-pack: stretch !important;
        align-content: stretch !important;
    }

    .align-self-lg-auto {
        -ms-flex-item-align: auto !important;
        -ms-grid-row-align: auto !important;
        align-self: auto !important;
    }

    .align-self-lg-start {
        -ms-flex-item-align: start !important;
        align-self: flex-start !important;
    }

    .align-self-lg-end {
        -ms-flex-item-align: end !important;
        align-self: flex-end !important;
    }

    .align-self-lg-center {
        -ms-flex-item-align: center !important;
        -ms-grid-row-align: center !important;
        align-self: center !important;
    }

    .align-self-lg-baseline {
        -ms-flex-item-align: baseline !important;
        align-self: baseline !important;
    }

    .align-self-lg-stretch {
        -ms-flex-item-align: stretch !important;
        -ms-grid-row-align: stretch !important;
        align-self: stretch !important;
    }
}

@media (min-width: 1200px) {
    .flex-xl-row {
        -ms-flex-direction: row !important;
        flex-direction: row !important;
    }

    .flex-xl-column {
        -ms-flex-direction: column !important;
        flex-direction: column !important;
    }

    .flex-xl-row-reverse {
        -ms-flex-direction: row-reverse !important;
        flex-direction: row-reverse !important;
    }

    .flex-xl-column-reverse {
        -ms-flex-direction: column-reverse !important;
        flex-direction: column-reverse !important;
    }

    .flex-xl-wrap {
        -ms-flex-wrap: wrap !important;
        flex-wrap: wrap !important;
    }

    .flex-xl-nowrap {
        -ms-flex-wrap: nowrap !important;
        flex-wrap: nowrap !important;
    }

    .flex-xl-wrap-reverse {
        -ms-flex-wrap: wrap-reverse !important;
        flex-wrap: wrap-reverse !important;
    }

    .flex-xl-fill {
        -ms-flex: 1 1 auto !important;
        flex: 1 1 auto !important;
    }

    .flex-xl-grow-0 {
        -ms-flex-positive: 0 !important;
        flex-grow: 0 !important;
    }

    .flex-xl-grow-1 {
        -ms-flex-positive: 1 !important;
        flex-grow: 1 !important;
    }

    .flex-xl-shrink-0 {
        -ms-flex-negative: 0 !important;
        flex-shrink: 0 !important;
    }

    .flex-xl-shrink-1 {
        -ms-flex-negative: 1 !important;
        flex-shrink: 1 !important;
    }

    .justify-content-xl-start {
        -ms-flex-pack: start !important;
        justify-content: flex-start !important;
    }

    .justify-content-xl-end {
        -ms-flex-pack: end !important;
        justify-content: flex-end !important;
    }

    .justify-content-xl-center {
        -ms-flex-pack: center !important;
        justify-content: center !important;
    }

    .justify-content-xl-between {
        -ms-flex-pack: justify !important;
        justify-content: space-between !important;
    }

    .justify-content-xl-around {
        -ms-flex-pack: distribute !important;
        justify-content: space-around !important;
    }

    .align-items-xl-start {
        -ms-flex-align: start !important;
        align-items: flex-start !important;
    }

    .align-items-xl-end {
        -ms-flex-align: end !important;
        align-items: flex-end !important;
    }

    .align-items-xl-center {
        -ms-flex-align: center !important;
        align-items: center !important;
    }

    .align-items-xl-baseline {
        -ms-flex-align: baseline !important;
        align-items: baseline !important;
    }

    .align-items-xl-stretch {
        -ms-flex-align: stretch !important;
        align-items: stretch !important;
    }

    .align-content-xl-start {
        -ms-flex-line-pack: start !important;
        align-content: flex-start !important;
    }

    .align-content-xl-end {
        -ms-flex-line-pack: end !important;
        align-content: flex-end !important;
    }

    .align-content-xl-center {
        -ms-flex-line-pack: center !important;
        align-content: center !important;
    }

    .align-content-xl-between {
        -ms-flex-line-pack: justify !important;
        align-content: space-between !important;
    }

    .align-content-xl-around {
        -ms-flex-line-pack: distribute !important;
        align-content: space-around !important;
    }

    .align-content-xl-stretch {
        -ms-flex-line-pack: stretch !important;
        align-content: stretch !important;
    }

    .align-self-xl-auto {
        -ms-flex-item-align: auto !important;
        -ms-grid-row-align: auto !important;
        align-self: auto !important;
    }

    .align-self-xl-start {
        -ms-flex-item-align: start !important;
        align-self: flex-start !important;
    }

    .align-self-xl-end {
        -ms-flex-item-align: end !important;
        align-self: flex-end !important;
    }

    .align-self-xl-center {
        -ms-flex-item-align: center !important;
        -ms-grid-row-align: center !important;
        align-self: center !important;
    }

    .align-self-xl-baseline {
        -ms-flex-item-align: baseline !important;
        align-self: baseline !important;
    }

    .align-self-xl-stretch {
        -ms-flex-item-align: stretch !important;
        -ms-grid-row-align: stretch !important;
        align-self: stretch !important;
    }
}

.float-left {
    float: left !important;
}

.float-right {
    float: right !important;
}

.float-none {
    float: none !important;
}

@media (min-width: 576px) {
    .float-sm-left {
        float: left !important;
    }

    .float-sm-right {
        float: right !important;
    }

    .float-sm-none {
        float: none !important;
    }
}

@media (min-width: 768px) {
    .float-md-left {
        float: left !important;
    }

    .float-md-right {
        float: right !important;
    }

    .float-md-none {
        float: none !important;
    }
}

@media (min-width: 992px) {
    .float-lg-left {
        float: left !important;
    }

    .float-lg-right {
        float: right !important;
    }

    .float-lg-none {
        float: none !important;
    }
}

@media (min-width: 1200px) {
    .float-xl-left {
        float: left !important;
    }

    .float-xl-right {
        float: right !important;
    }

    .float-xl-none {
        float: none !important;
    }
}

.user-select-all {
    -webkit-user-select: all !important;
    -moz-user-select: all !important;
    -ms-user-select: all !important;
    user-select: all !important;
}

.user-select-auto {
    -webkit-user-select: auto !important;
    -moz-user-select: auto !important;
    -ms-user-select: auto !important;
    user-select: auto !important;
}

.user-select-none {
    -webkit-user-select: none !important;
    -moz-user-select: none !important;
    -ms-user-select: none !important;
    user-select: none !important;
}

.overflow-auto {
    overflow: auto !important;
}

.overflow-hidden {
    overflow: hidden !important;
}

.position-static {
    position: static !important;
}

.position-relative {
    position: relative !important;
}

.position-absolute {
    position: absolute !important;
}

.position-fixed {
    position: fixed !important;
}

.position-sticky {
    position: -webkit-sticky !important;
    position: sticky !important;
}

.fixed-top {
    position: fixed;
    top: 0;
    right: 0;
    left: 0;
    z-index: 1030;
}

.fixed-bottom {
    position: fixed;
    right: 0;
    bottom: 0;
    left: 0;
    z-index: 1030;
}

@supports ((position: -webkit-sticky) or (position: sticky)) {
    .sticky-top {
        position: -webkit-sticky;
        position: sticky;
        top: 0;
        z-index: 1020;
    }
}

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

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

.shadow-sm {
    box-shadow: 0 0.125rem 0.25rem rgba(0, 0, 0, 0.075) !important;
}

.shadow {
    box-shadow: 0 0.5rem 1rem rgba(0, 0, 0, 0.15) !important;
}

.shadow-lg {
    box-shadow: 0 1rem 3rem rgba(0, 0, 0, 0.175) !important;
}

.shadow-none {
    box-shadow: none !important;
}

.w-25 {
    width: 25% !important;
}

.w-50 {
    width: 50% !important;
}

.w-75 {
    width: 75% !important;
}

.w-100 {
    width: 100% !important;
}

.w-auto {
    width: auto !important;
}

.h-25 {
    height: 25% !important;
}

.h-50 {
    height: 50% !important;
}

.h-75 {
    height: 75% !important;
}

.h-100 {
    height: 100% !important;
}

.h-auto {
    height: auto !important;
}

.mw-100 {
    max-width: 100% !important;
}

.mh-100 {
    max-height: 100% !important;
}

.min-vw-100 {
    min-width: 100vw !important;
}

.min-vh-100 {
    min-height: 100vh !important;
}

.vw-100 {
    width: 100vw !important;
}

.vh-100 {
    height: 100vh !important;
}

.m-0 {
    margin: 0 !important;
}

.mt-0,
.my-0 {
    margin-top: 0 !important;
}

.mr-0,
.mx-0 {
    margin-right: 0 !important;
}

.mb-0,
.my-0 {
    margin-bottom: 0 !important;
}

.ml-0,
.mx-0 {
    margin-left: 0 !important;
}

.m-1 {
    margin: 0.25rem !important;
}

.mt-1,
.my-1 {
    margin-top: 0.25rem !important;
}

.mr-1,
.mx-1 {
    margin-right: 0.25rem !important;
}

.mb-1,
.my-1 {
    margin-bottom: 0.25rem !important;
}

.ml-1,
.mx-1 {
    margin-left: 0.25rem !important;
}

.m-2 {
    margin: 0.5rem !important;
}

.mt-2,
.my-2 {
    margin-top: 0.5rem !important;
}

.mr-2,
.mx-2 {
    margin-right: 0.5rem !important;
}

.mb-2,
.my-2 {
    margin-bottom: 0.5rem !important;
}

.ml-2,
.mx-2 {
    margin-left: 0.5rem !important;
}

.m-3 {
    margin: 1rem !important;
}

.mt-3,
.my-3 {
    margin-top: 1rem !important;
}

.mr-3,
.mx-3 {
    margin-right: 1rem !important;
}

.mb-3,
.my-3 {
    margin-bottom: 1rem !important;
}

.ml-3,
.mx-3 {
    margin-left: 1rem !important;
}

.m-4 {
    margin: 1.5rem !important;
}

.mt-4,
.my-4 {
    margin-top: 1.5rem !important;
}

.mr-4,
.mx-4 {
    margin-right: 1.5rem !important;
}

.mb-4,
.my-4 {
    margin-bottom: 1.5rem !important;
}

.ml-4,
.mx-4 {
    margin-left: 1.5rem !important;
}

.m-5 {
    margin: 3rem !important;
}

.mt-5,
.my-5 {
    margin-top: 3rem !important;
}

.mr-5,
.mx-5 {
    margin-right: 3rem !important;
}

.mb-5,
.my-5 {
    margin-bottom: 3rem !important;
}

.ml-5,
.mx-5 {
    margin-left: 3rem !important;
}

.p-0 {
    padding: 0 !important;
}

.pt-0,
.py-0 {
    padding-top: 0 !important;
}

.pr-0,
.px-0 {
    padding-right: 0 !important;
}

.pb-0,
.py-0 {
    padding-bottom: 0 !important;
}

.pl-0,
.px-0 {
    padding-left: 0 !important;
}

.p-1 {
    padding: 0.25rem !important;
}

.pt-1,
.py-1 {
    padding-top: 0.25rem !important;
}

.pr-1,
.px-1 {
    padding-right: 0.25rem !important;
}

.pb-1,
.py-1 {
    padding-bottom: 0.25rem !important;
}

.pl-1,
.px-1 {
    padding-left: 0.25rem !important;
}

.p-2 {
    padding: 0.5rem !important;
}

.pt-2,
.py-2 {
    padding-top: 0.5rem !important;
}

.pr-2,
.px-2 {
    padding-right: 0.5rem !important;
}

.pb-2,
.py-2 {
    padding-bottom: 0.5rem !important;
}

.pl-2,
.px-2 {
    padding-left: 0.5rem !important;
}

.p-3 {
    padding: 1rem !important;
}

.pt-3,
.py-3 {
    padding-top: 1rem !important;
}

.pr-3,
.px-3 {
    padding-right: 1rem !important;
}

.pb-3,
.py-3 {
    padding-bottom: 1rem !important;
}

.pl-3,
.px-3 {
    padding-left: 1rem !important;
}

.p-4 {
    padding: 1.5rem !important;
}

.pt-4,
.py-4 {
    padding-top: 1.5rem !important;
}

.pr-4,
.px-4 {
    padding-right: 1.5rem !important;
}

.pb-4,
.py-4 {
    padding-bottom: 1.5rem !important;
}

.pl-4,
.px-4 {
    padding-left: 1.5rem !important;
}

.p-5 {
    padding: 3rem !important;
}

.pt-5,
.py-5 {
    padding-top: 3rem !important;
}

.pr-5,
.px-5 {
    padding-right: 3rem !important;
}

.pb-5,
.py-5 {
    padding-bottom: 3rem !important;
}

.pl-5,
.px-5 {
    padding-left: 3rem !important;
}

.m-n1 {
    margin: -0.25rem !important;
}

.mt-n1,
.my-n1 {
    margin-top: -0.25rem !important;
}

.mr-n1,
.mx-n1 {
    margin-right: -0.25rem !important;
}

.mb-n1,
.my-n1 {
    margin-bottom: -0.25rem !important;
}

.ml-n1,
.mx-n1 {
    margin-left: -0.25rem !important;
}

.m-n2 {
    margin: -0.5rem !important;
}

.mt-n2,
.my-n2 {
    margin-top: -0.5rem !important;
}

.mr-n2,
.mx-n2 {
    margin-right: -0.5rem !important;
}

.mb-n2,
.my-n2 {
    margin-bottom: -0.5rem !important;
}

.ml-n2,
.mx-n2 {
    margin-left: -0.5rem !important;
}

.m-n3 {
    margin: -1rem !important;
}

.mt-n3,
.my-n3 {
    margin-top: -1rem !important;
}

.mr-n3,
.mx-n3 {
    margin-right: -1rem !important;
}

.mb-n3,
.my-n3 {
    margin-bottom: -1rem !important;
}

.ml-n3,
.mx-n3 {
    margin-left: -1rem !important;
}

.m-n4 {
    margin: -1.5rem !important;
}

.mt-n4,
.my-n4 {
    margin-top: -1.5rem !important;
}

.mr-n4,
.mx-n4 {
    margin-right: -1.5rem !important;
}

.mb-n4,
.my-n4 {
    margin-bottom: -1.5rem !important;
}

.ml-n4,
.mx-n4 {
    margin-left: -1.5rem !important;
}

.m-n5 {
    margin: -3rem !important;
}

.mt-n5,
.my-n5 {
    margin-top: -3rem !important;
}

.mr-n5,
.mx-n5 {
    margin-right: -3rem !important;
}

.mb-n5,
.my-n5 {
    margin-bottom: -3rem !important;
}

.ml-n5,
.mx-n5 {
    margin-left: -3rem !important;
}

.m-auto {
    margin: auto !important;
}

.mt-auto,
.my-auto {
    margin-top: auto !important;
}

.mr-auto,
.mx-auto {
    margin-right: auto !important;
}

.mb-auto,
.my-auto {
    margin-bottom: auto !important;
}

.ml-auto,
.mx-auto {
    margin-left: auto !important;
}

@media (min-width: 576px) {
    .m-sm-0 {
        margin: 0 !important;
    }

    .mt-sm-0,
    .my-sm-0 {
        margin-top: 0 !important;
    }

    .mr-sm-0,
    .mx-sm-0 {
        margin-right: 0 !important;
    }

    .mb-sm-0,
    .my-sm-0 {
        margin-bottom: 0 !important;
    }

    .ml-sm-0,
    .mx-sm-0 {
        margin-left: 0 !important;
    }

    .m-sm-1 {
        margin: 0.25rem !important;
    }

    .mt-sm-1,
    .my-sm-1 {
        margin-top: 0.25rem !important;
    }

    .mr-sm-1,
    .mx-sm-1 {
        margin-right: 0.25rem !important;
    }

    .mb-sm-1,
    .my-sm-1 {
        margin-bottom: 0.25rem !important;
    }

    .ml-sm-1,
    .mx-sm-1 {
        margin-left: 0.25rem !important;
    }

    .m-sm-2 {
        margin: 0.5rem !important;
    }

    .mt-sm-2,
    .my-sm-2 {
        margin-top: 0.5rem !important;
    }

    .mr-sm-2,
    .mx-sm-2 {
        margin-right: 0.5rem !important;
    }

    .mb-sm-2,
    .my-sm-2 {
        margin-bottom: 0.5rem !important;
    }

    .ml-sm-2,
    .mx-sm-2 {
        margin-left: 0.5rem !important;
    }

    .m-sm-3 {
        margin: 1rem !important;
    }

    .mt-sm-3,
    .my-sm-3 {
        margin-top: 1rem !important;
    }

    .mr-sm-3,
    .mx-sm-3 {
        margin-right: 1rem !important;
    }

    .mb-sm-3,
    .my-sm-3 {
        margin-bottom: 1rem !important;
    }

    .ml-sm-3,
    .mx-sm-3 {
        margin-left: 1rem !important;
    }

    .m-sm-4 {
        margin: 1.5rem !important;
    }

    .mt-sm-4,
    .my-sm-4 {
        margin-top: 1.5rem !important;
    }

    .mr-sm-4,
    .mx-sm-4 {
        margin-right: 1.5rem !important;
    }

    .mb-sm-4,
    .my-sm-4 {
        margin-bottom: 1.5rem !important;
    }

    .ml-sm-4,
    .mx-sm-4 {
        margin-left: 1.5rem !important;
    }

    .m-sm-5 {
        margin: 3rem !important;
    }

    .mt-sm-5,
    .my-sm-5 {
        margin-top: 3rem !important;
    }

    .mr-sm-5,
    .mx-sm-5 {
        margin-right: 3rem !important;
    }

    .mb-sm-5,
    .my-sm-5 {
        margin-bottom: 3rem !important;
    }

    .ml-sm-5,
    .mx-sm-5 {
        margin-left: 3rem !important;
    }

    .p-sm-0 {
        padding: 0 !important;
    }

    .pt-sm-0,
    .py-sm-0 {
        padding-top: 0 !important;
    }

    .pr-sm-0,
    .px-sm-0 {
        padding-right: 0 !important;
    }

    .pb-sm-0,
    .py-sm-0 {
        padding-bottom: 0 !important;
    }

    .pl-sm-0,
    .px-sm-0 {
        padding-left: 0 !important;
    }

    .p-sm-1 {
        padding: 0.25rem !important;
    }

    .pt-sm-1,
    .py-sm-1 {
        padding-top: 0.25rem !important;
    }

    .pr-sm-1,
    .px-sm-1 {
        padding-right: 0.25rem !important;
    }

    .pb-sm-1,
    .py-sm-1 {
        padding-bottom: 0.25rem !important;
    }

    .pl-sm-1,
    .px-sm-1 {
        padding-left: 0.25rem !important;
    }

    .p-sm-2 {
        padding: 0.5rem !important;
    }

    .pt-sm-2,
    .py-sm-2 {
        padding-top: 0.5rem !important;
    }

    .pr-sm-2,
    .px-sm-2 {
        padding-right: 0.5rem !important;
    }

    .pb-sm-2,
    .py-sm-2 {
        padding-bottom: 0.5rem !important;
    }

    .pl-sm-2,
    .px-sm-2 {
        padding-left: 0.5rem !important;
    }

    .p-sm-3 {
        padding: 1rem !important;
    }

    .pt-sm-3,
    .py-sm-3 {
        padding-top: 1rem !important;
    }

    .pr-sm-3,
    .px-sm-3 {
        padding-right: 1rem !important;
    }

    .pb-sm-3,
    .py-sm-3 {
        padding-bottom: 1rem !important;
    }

    .pl-sm-3,
    .px-sm-3 {
        padding-left: 1rem !important;
    }

    .p-sm-4 {
        padding: 1.5rem !important;
    }

    .pt-sm-4,
    .py-sm-4 {
        padding-top: 1.5rem !important;
    }

    .pr-sm-4,
    .px-sm-4 {
        padding-right: 1.5rem !important;
    }

    .pb-sm-4,
    .py-sm-4 {
        padding-bottom: 1.5rem !important;
    }

    .pl-sm-4,
    .px-sm-4 {
        padding-left: 1.5rem !important;
    }

    .p-sm-5 {
        padding: 3rem !important;
    }

    .pt-sm-5,
    .py-sm-5 {
        padding-top: 3rem !important;
    }

    .pr-sm-5,
    .px-sm-5 {
        padding-right: 3rem !important;
    }

    .pb-sm-5,
    .py-sm-5 {
        padding-bottom: 3rem !important;
    }

    .pl-sm-5,
    .px-sm-5 {
        padding-left: 3rem !important;
    }

    .m-sm-n1 {
        margin: -0.25rem !important;
    }

    .mt-sm-n1,
    .my-sm-n1 {
        margin-top: -0.25rem !important;
    }

    .mr-sm-n1,
    .mx-sm-n1 {
        margin-right: -0.25rem !important;
    }

    .mb-sm-n1,
    .my-sm-n1 {
        margin-bottom: -0.25rem !important;
    }

    .ml-sm-n1,
    .mx-sm-n1 {
        margin-left: -0.25rem !important;
    }

    .m-sm-n2 {
        margin: -0.5rem !important;
    }

    .mt-sm-n2,
    .my-sm-n2 {
        margin-top: -0.5rem !important;
    }

    .mr-sm-n2,
    .mx-sm-n2 {
        margin-right: -0.5rem !important;
    }

    .mb-sm-n2,
    .my-sm-n2 {
        margin-bottom: -0.5rem !important;
    }

    .ml-sm-n2,
    .mx-sm-n2 {
        margin-left: -0.5rem !important;
    }

    .m-sm-n3 {
        margin: -1rem !important;
    }

    .mt-sm-n3,
    .my-sm-n3 {
        margin-top: -1rem !important;
    }

    .mr-sm-n3,
    .mx-sm-n3 {
        margin-right: -1rem !important;
    }

    .mb-sm-n3,
    .my-sm-n3 {
        margin-bottom: -1rem !important;
    }

    .ml-sm-n3,
    .mx-sm-n3 {
        margin-left: -1rem !important;
    }

    .m-sm-n4 {
        margin: -1.5rem !important;
    }

    .mt-sm-n4,
    .my-sm-n4 {
        margin-top: -1.5rem !important;
    }

    .mr-sm-n4,
    .mx-sm-n4 {
        margin-right: -1.5rem !important;
    }

    .mb-sm-n4,
    .my-sm-n4 {
        margin-bottom: -1.5rem !important;
    }

    .ml-sm-n4,
    .mx-sm-n4 {
        margin-left: -1.5rem !important;
    }

    .m-sm-n5 {
        margin: -3rem !important;
    }

    .mt-sm-n5,
    .my-sm-n5 {
        margin-top: -3rem !important;
    }

    .mr-sm-n5,
    .mx-sm-n5 {
        margin-right: -3rem !important;
    }

    .mb-sm-n5,
    .my-sm-n5 {
        margin-bottom: -3rem !important;
    }

    .ml-sm-n5,
    .mx-sm-n5 {
        margin-left: -3rem !important;
    }

    .m-sm-auto {
        margin: auto !important;
    }

    .mt-sm-auto,
    .my-sm-auto {
        margin-top: auto !important;
    }

    .mr-sm-auto,
    .mx-sm-auto {
        margin-right: auto !important;
    }

    .mb-sm-auto,
    .my-sm-auto {
        margin-bottom: auto !important;
    }

    .ml-sm-auto,
    .mx-sm-auto {
        margin-left: auto !important;
    }
}

@media (min-width: 768px) {
    .m-md-0 {
        margin: 0 !important;
    }

    .mt-md-0,
    .my-md-0 {
        margin-top: 0 !important;
    }

    .mr-md-0,
    .mx-md-0 {
        margin-right: 0 !important;
    }

    .mb-md-0,
    .my-md-0 {
        margin-bottom: 0 !important;
    }

    .ml-md-0,
    .mx-md-0 {
        margin-left: 0 !important;
    }

    .m-md-1 {
        margin: 0.25rem !important;
    }

    .mt-md-1,
    .my-md-1 {
        margin-top: 0.25rem !important;
    }

    .mr-md-1,
    .mx-md-1 {
        margin-right: 0.25rem !important;
    }

    .mb-md-1,
    .my-md-1 {
        margin-bottom: 0.25rem !important;
    }

    .ml-md-1,
    .mx-md-1 {
        margin-left: 0.25rem !important;
    }

    .m-md-2 {
        margin: 0.5rem !important;
    }

    .mt-md-2,
    .my-md-2 {
        margin-top: 0.5rem !important;
    }

    .mr-md-2,
    .mx-md-2 {
        margin-right: 0.5rem !important;
    }

    .mb-md-2,
    .my-md-2 {
        margin-bottom: 0.5rem !important;
    }

    .ml-md-2,
    .mx-md-2 {
        margin-left: 0.5rem !important;
    }

    .m-md-3 {
        margin: 1rem !important;
    }

    .mt-md-3,
    .my-md-3 {
        margin-top: 1rem !important;
    }

    .mr-md-3,
    .mx-md-3 {
        margin-right: 1rem !important;
    }

    .mb-md-3,
    .my-md-3 {
        margin-bottom: 1rem !important;
    }

    .ml-md-3,
    .mx-md-3 {
        margin-left: 1rem !important;
    }

    .m-md-4 {
        margin: 1.5rem !important;
    }

    .mt-md-4,
    .my-md-4 {
        margin-top: 1.5rem !important;
    }

    .mr-md-4,
    .mx-md-4 {
        margin-right: 1.5rem !important;
    }

    .mb-md-4,
    .my-md-4 {
        margin-bottom: 1.5rem !important;
    }

    .ml-md-4,
    .mx-md-4 {
        margin-left: 1.5rem !important;
    }

    .m-md-5 {
        margin: 3rem !important;
    }

    .mt-md-5,
    .my-md-5 {
        margin-top: 3rem !important;
    }

    .mr-md-5,
    .mx-md-5 {
        margin-right: 3rem !important;
    }

    .mb-md-5,
    .my-md-5 {
        margin-bottom: 3rem !important;
    }

    .ml-md-5,
    .mx-md-5 {
        margin-left: 3rem !important;
    }

    .p-md-0 {
        padding: 0 !important;
    }

    .pt-md-0,
    .py-md-0 {
        padding-top: 0 !important;
    }

    .pr-md-0,
    .px-md-0 {
        padding-right: 0 !important;
    }

    .pb-md-0,
    .py-md-0 {
        padding-bottom: 0 !important;
    }

    .pl-md-0,
    .px-md-0 {
        padding-left: 0 !important;
    }

    .p-md-1 {
        padding: 0.25rem !important;
    }

    .pt-md-1,
    .py-md-1 {
        padding-top: 0.25rem !important;
    }

    .pr-md-1,
    .px-md-1 {
        padding-right: 0.25rem !important;
    }

    .pb-md-1,
    .py-md-1 {
        padding-bottom: 0.25rem !important;
    }

    .pl-md-1,
    .px-md-1 {
        padding-left: 0.25rem !important;
    }

    .p-md-2 {
        padding: 0.5rem !important;
    }

    .pt-md-2,
    .py-md-2 {
        padding-top: 0.5rem !important;
    }

    .pr-md-2,
    .px-md-2 {
        padding-right: 0.5rem !important;
    }

    .pb-md-2,
    .py-md-2 {
        padding-bottom: 0.5rem !important;
    }

    .pl-md-2,
    .px-md-2 {
        padding-left: 0.5rem !important;
    }

    .p-md-3 {
        padding: 1rem !important;
    }

    .pt-md-3,
    .py-md-3 {
        padding-top: 1rem !important;
    }

    .pr-md-3,
    .px-md-3 {
        padding-right: 1rem !important;
    }

    .pb-md-3,
    .py-md-3 {
        padding-bottom: 1rem !important;
    }

    .pl-md-3,
    .px-md-3 {
        padding-left: 1rem !important;
    }

    .p-md-4 {
        padding: 1.5rem !important;
    }

    .pt-md-4,
    .py-md-4 {
        padding-top: 1.5rem !important;
    }

    .pr-md-4,
    .px-md-4 {
        padding-right: 1.5rem !important;
    }

    .pb-md-4,
    .py-md-4 {
        padding-bottom: 1.5rem !important;
    }

    .pl-md-4,
    .px-md-4 {
        padding-left: 1.5rem !important;
    }

    .p-md-5 {
        padding: 3rem !important;
    }

    .pt-md-5,
    .py-md-5 {
        padding-top: 3rem !important;
    }

    .pr-md-5,
    .px-md-5 {
        padding-right: 3rem !important;
    }

    .pb-md-5,
    .py-md-5 {
        padding-bottom: 3rem !important;
    }

    .pl-md-5,
    .px-md-5 {
        padding-left: 3rem !important;
    }

    .m-md-n1 {
        margin: -0.25rem !important;
    }

    .mt-md-n1,
    .my-md-n1 {
        margin-top: -0.25rem !important;
    }

    .mr-md-n1,
    .mx-md-n1 {
        margin-right: -0.25rem !important;
    }

    .mb-md-n1,
    .my-md-n1 {
        margin-bottom: -0.25rem !important;
    }

    .ml-md-n1,
    .mx-md-n1 {
        margin-left: -0.25rem !important;
    }

    .m-md-n2 {
        margin: -0.5rem !important;
    }

    .mt-md-n2,
    .my-md-n2 {
        margin-top: -0.5rem !important;
    }

    .mr-md-n2,
    .mx-md-n2 {
        margin-right: -0.5rem !important;
    }

    .mb-md-n2,
    .my-md-n2 {
        margin-bottom: -0.5rem !important;
    }

    .ml-md-n2,
    .mx-md-n2 {
        margin-left: -0.5rem !important;
    }

    .m-md-n3 {
        margin: -1rem !important;
    }

    .mt-md-n3,
    .my-md-n3 {
        margin-top: -1rem !important;
    }

    .mr-md-n3,
    .mx-md-n3 {
        margin-right: -1rem !important;
    }

    .mb-md-n3,
    .my-md-n3 {
        margin-bottom: -1rem !important;
    }

    .ml-md-n3,
    .mx-md-n3 {
        margin-left: -1rem !important;
    }

    .m-md-n4 {
        margin: -1.5rem !important;
    }

    .mt-md-n4,
    .my-md-n4 {
        margin-top: -1.5rem !important;
    }

    .mr-md-n4,
    .mx-md-n4 {
        margin-right: -1.5rem !important;
    }

    .mb-md-n4,
    .my-md-n4 {
        margin-bottom: -1.5rem !important;
    }

    .ml-md-n4,
    .mx-md-n4 {
        margin-left: -1.5rem !important;
    }

    .m-md-n5 {
        margin: -3rem !important;
    }

    .mt-md-n5,
    .my-md-n5 {
        margin-top: -3rem !important;
    }

    .mr-md-n5,
    .mx-md-n5 {
        margin-right: -3rem !important;
    }

    .mb-md-n5,
    .my-md-n5 {
        margin-bottom: -3rem !important;
    }

    .ml-md-n5,
    .mx-md-n5 {
        margin-left: -3rem !important;
    }

    .m-md-auto {
        margin: auto !important;
    }

    .mt-md-auto,
    .my-md-auto {
        margin-top: auto !important;
    }

    .mr-md-auto,
    .mx-md-auto {
        margin-right: auto !important;
    }

    .mb-md-auto,
    .my-md-auto {
        margin-bottom: auto !important;
    }

    .ml-md-auto,
    .mx-md-auto {
        margin-left: auto !important;
    }
}

@media (min-width: 992px) {
    .m-lg-0 {
        margin: 0 !important;
    }

    .mt-lg-0,
    .my-lg-0 {
        margin-top: 0 !important;
    }

    .mr-lg-0,
    .mx-lg-0 {
        margin-right: 0 !important;
    }

    .mb-lg-0,
    .my-lg-0 {
        margin-bottom: 0 !important;
    }

    .ml-lg-0,
    .mx-lg-0 {
        margin-left: 0 !important;
    }

    .m-lg-1 {
        margin: 0.25rem !important;
    }

    .mt-lg-1,
    .my-lg-1 {
        margin-top: 0.25rem !important;
    }

    .mr-lg-1,
    .mx-lg-1 {
        margin-right: 0.25rem !important;
    }

    .mb-lg-1,
    .my-lg-1 {
        margin-bottom: 0.25rem !important;
    }

    .ml-lg-1,
    .mx-lg-1 {
        margin-left: 0.25rem !important;
    }

    .m-lg-2 {
        margin: 0.5rem !important;
    }

    .mt-lg-2,
    .my-lg-2 {
        margin-top: 0.5rem !important;
    }

    .mr-lg-2,
    .mx-lg-2 {
        margin-right: 0.5rem !important;
    }

    .mb-lg-2,
    .my-lg-2 {
        margin-bottom: 0.5rem !important;
    }

    .ml-lg-2,
    .mx-lg-2 {
        margin-left: 0.5rem !important;
    }

    .m-lg-3 {
        margin: 1rem !important;
    }

    .mt-lg-3,
    .my-lg-3 {
        margin-top: 1rem !important;
    }

    .mr-lg-3,
    .mx-lg-3 {
        margin-right: 1rem !important;
    }

    .mb-lg-3,
    .my-lg-3 {
        margin-bottom: 1rem !important;
    }

    .ml-lg-3,
    .mx-lg-3 {
        margin-left: 1rem !important;
    }

    .m-lg-4 {
        margin: 1.5rem !important;
    }

    .mt-lg-4,
    .my-lg-4 {
        margin-top: 1.5rem !important;
    }

    .mr-lg-4,
    .mx-lg-4 {
        margin-right: 1.5rem !important;
    }

    .mb-lg-4,
    .my-lg-4 {
        margin-bottom: 1.5rem !important;
    }

    .ml-lg-4,
    .mx-lg-4 {
        margin-left: 1.5rem !important;
    }

    .m-lg-5 {
        margin: 3rem !important;
    }

    .mt-lg-5,
    .my-lg-5 {
        margin-top: 3rem !important;
    }

    .mr-lg-5,
    .mx-lg-5 {
        margin-right: 3rem !important;
    }

    .mb-lg-5,
    .my-lg-5 {
        margin-bottom: 3rem !important;
    }

    .ml-lg-5,
    .mx-lg-5 {
        margin-left: 3rem !important;
    }

    .p-lg-0 {
        padding: 0 !important;
    }

    .pt-lg-0,
    .py-lg-0 {
        padding-top: 0 !important;
    }

    .pr-lg-0,
    .px-lg-0 {
        padding-right: 0 !important;
    }

    .pb-lg-0,
    .py-lg-0 {
        padding-bottom: 0 !important;
    }

    .pl-lg-0,
    .px-lg-0 {
        padding-left: 0 !important;
    }

    .p-lg-1 {
        padding: 0.25rem !important;
    }

    .pt-lg-1,
    .py-lg-1 {
        padding-top: 0.25rem !important;
    }

    .pr-lg-1,
    .px-lg-1 {
        padding-right: 0.25rem !important;
    }

    .pb-lg-1,
    .py-lg-1 {
        padding-bottom: 0.25rem !important;
    }

    .pl-lg-1,
    .px-lg-1 {
        padding-left: 0.25rem !important;
    }

    .p-lg-2 {
        padding: 0.5rem !important;
    }

    .pt-lg-2,
    .py-lg-2 {
        padding-top: 0.5rem !important;
    }

    .pr-lg-2,
    .px-lg-2 {
        padding-right: 0.5rem !important;
    }

    .pb-lg-2,
    .py-lg-2 {
        padding-bottom: 0.5rem !important;
    }

    .pl-lg-2,
    .px-lg-2 {
        padding-left: 0.5rem !important;
    }

    .p-lg-3 {
        padding: 1rem !important;
    }

    .pt-lg-3,
    .py-lg-3 {
        padding-top: 1rem !important;
    }

    .pr-lg-3,
    .px-lg-3 {
        padding-right: 1rem !important;
    }

    .pb-lg-3,
    .py-lg-3 {
        padding-bottom: 1rem !important;
    }

    .pl-lg-3,
    .px-lg-3 {
        padding-left: 1rem !important;
    }

    .p-lg-4 {
        padding: 1.5rem !important;
    }

    .pt-lg-4,
    .py-lg-4 {
        padding-top: 1.5rem !important;
    }

    .pr-lg-4,
    .px-lg-4 {
        padding-right: 1.5rem !important;
    }

    .pb-lg-4,
    .py-lg-4 {
        padding-bottom: 1.5rem !important;
    }

    .pl-lg-4,
    .px-lg-4 {
        padding-left: 1.5rem !important;
    }

    .p-lg-5 {
        padding: 3rem !important;
    }

    .pt-lg-5,
    .py-lg-5 {
        padding-top: 3rem !important;
    }

    .pr-lg-5,
    .px-lg-5 {
        padding-right: 3rem !important;
    }

    .pb-lg-5,
    .py-lg-5 {
        padding-bottom: 3rem !important;
    }

    .pl-lg-5,
    .px-lg-5 {
        padding-left: 3rem !important;
    }

    .m-lg-n1 {
        margin: -0.25rem !important;
    }

    .mt-lg-n1,
    .my-lg-n1 {
        margin-top: -0.25rem !important;
    }

    .mr-lg-n1,
    .mx-lg-n1 {
        margin-right: -0.25rem !important;
    }

    .mb-lg-n1,
    .my-lg-n1 {
        margin-bottom: -0.25rem !important;
    }

    .ml-lg-n1,
    .mx-lg-n1 {
        margin-left: -0.25rem !important;
    }

    .m-lg-n2 {
        margin: -0.5rem !important;
    }

    .mt-lg-n2,
    .my-lg-n2 {
        margin-top: -0.5rem !important;
    }

    .mr-lg-n2,
    .mx-lg-n2 {
        margin-right: -0.5rem !important;
    }

    .mb-lg-n2,
    .my-lg-n2 {
        margin-bottom: -0.5rem !important;
    }

    .ml-lg-n2,
    .mx-lg-n2 {
        margin-left: -0.5rem !important;
    }

    .m-lg-n3 {
        margin: -1rem !important;
    }

    .mt-lg-n3,
    .my-lg-n3 {
        margin-top: -1rem !important;
    }

    .mr-lg-n3,
    .mx-lg-n3 {
        margin-right: -1rem !important;
    }

    .mb-lg-n3,
    .my-lg-n3 {
        margin-bottom: -1rem !important;
    }

    .ml-lg-n3,
    .mx-lg-n3 {
        margin-left: -1rem !important;
    }

    .m-lg-n4 {
        margin: -1.5rem !important;
    }

    .mt-lg-n4,
    .my-lg-n4 {
        margin-top: -1.5rem !important;
    }

    .mr-lg-n4,
    .mx-lg-n4 {
        margin-right: -1.5rem !important;
    }

    .mb-lg-n4,
    .my-lg-n4 {
        margin-bottom: -1.5rem !important;
    }

    .ml-lg-n4,
    .mx-lg-n4 {
        margin-left: -1.5rem !important;
    }

    .m-lg-n5 {
        margin: -3rem !important;
    }

    .mt-lg-n5,
    .my-lg-n5 {
        margin-top: -3rem !important;
    }

    .mr-lg-n5,
    .mx-lg-n5 {
        margin-right: -3rem !important;
    }

    .mb-lg-n5,
    .my-lg-n5 {
        margin-bottom: -3rem !important;
    }

    .ml-lg-n5,
    .mx-lg-n5 {
        margin-left: -3rem !important;
    }

    .m-lg-auto {
        margin: auto !important;
    }

    .mt-lg-auto,
    .my-lg-auto {
        margin-top: auto !important;
    }

    .mr-lg-auto,
    .mx-lg-auto {
        margin-right: auto !important;
    }

    .mb-lg-auto,
    .my-lg-auto {
        margin-bottom: auto !important;
    }

    .ml-lg-auto,
    .mx-lg-auto {
        margin-left: auto !important;
    }
}

@media (min-width: 1200px) {
    .m-xl-0 {
        margin: 0 !important;
    }

    .mt-xl-0,
    .my-xl-0 {
        margin-top: 0 !important;
    }

    .mr-xl-0,
    .mx-xl-0 {
        margin-right: 0 !important;
    }

    .mb-xl-0,
    .my-xl-0 {
        margin-bottom: 0 !important;
    }

    .ml-xl-0,
    .mx-xl-0 {
        margin-left: 0 !important;
    }

    .m-xl-1 {
        margin: 0.25rem !important;
    }

    .mt-xl-1,
    .my-xl-1 {
        margin-top: 0.25rem !important;
    }

    .mr-xl-1,
    .mx-xl-1 {
        margin-right: 0.25rem !important;
    }

    .mb-xl-1,
    .my-xl-1 {
        margin-bottom: 0.25rem !important;
    }

    .ml-xl-1,
    .mx-xl-1 {
        margin-left: 0.25rem !important;
    }

    .m-xl-2 {
        margin: 0.5rem !important;
    }

    .mt-xl-2,
    .my-xl-2 {
        margin-top: 0.5rem !important;
    }

    .mr-xl-2,
    .mx-xl-2 {
        margin-right: 0.5rem !important;
    }

    .mb-xl-2,
    .my-xl-2 {
        margin-bottom: 0.5rem !important;
    }

    .ml-xl-2,
    .mx-xl-2 {
        margin-left: 0.5rem !important;
    }

    .m-xl-3 {
        margin: 1rem !important;
    }

    .mt-xl-3,
    .my-xl-3 {
        margin-top: 1rem !important;
    }

    .mr-xl-3,
    .mx-xl-3 {
        margin-right: 1rem !important;
    }

    .mb-xl-3,
    .my-xl-3 {
        margin-bottom: 1rem !important;
    }

    .ml-xl-3,
    .mx-xl-3 {
        margin-left: 1rem !important;
    }

    .m-xl-4 {
        margin: 1.5rem !important;
    }

    .mt-xl-4,
    .my-xl-4 {
        margin-top: 1.5rem !important;
    }

    .mr-xl-4,
    .mx-xl-4 {
        margin-right: 1.5rem !important;
    }

    .mb-xl-4,
    .my-xl-4 {
        margin-bottom: 1.5rem !important;
    }

    .ml-xl-4,
    .mx-xl-4 {
        margin-left: 1.5rem !important;
    }

    .m-xl-5 {
        margin: 3rem !important;
    }

    .mt-xl-5,
    .my-xl-5 {
        margin-top: 3rem !important;
    }

    .mr-xl-5,
    .mx-xl-5 {
        margin-right: 3rem !important;
    }

    .mb-xl-5,
    .my-xl-5 {
        margin-bottom: 3rem !important;
    }

    .ml-xl-5,
    .mx-xl-5 {
        margin-left: 3rem !important;
    }

    .p-xl-0 {
        padding: 0 !important;
    }

    .pt-xl-0,
    .py-xl-0 {
        padding-top: 0 !important;
    }

    .pr-xl-0,
    .px-xl-0 {
        padding-right: 0 !important;
    }

    .pb-xl-0,
    .py-xl-0 {
        padding-bottom: 0 !important;
    }

    .pl-xl-0,
    .px-xl-0 {
        padding-left: 0 !important;
    }

    .p-xl-1 {
        padding: 0.25rem !important;
    }

    .pt-xl-1,
    .py-xl-1 {
        padding-top: 0.25rem !important;
    }

    .pr-xl-1,
    .px-xl-1 {
        padding-right: 0.25rem !important;
    }

    .pb-xl-1,
    .py-xl-1 {
        padding-bottom: 0.25rem !important;
    }

    .pl-xl-1,
    .px-xl-1 {
        padding-left: 0.25rem !important;
    }

    .p-xl-2 {
        padding: 0.5rem !important;
    }

    .pt-xl-2,
    .py-xl-2 {
        padding-top: 0.5rem !important;
    }

    .pr-xl-2,
    .px-xl-2 {
        padding-right: 0.5rem !important;
    }

    .pb-xl-2,
    .py-xl-2 {
        padding-bottom: 0.5rem !important;
    }

    .pl-xl-2,
    .px-xl-2 {
        padding-left: 0.5rem !important;
    }

    .p-xl-3 {
        padding: 1rem !important;
    }

    .pt-xl-3,
    .py-xl-3 {
        padding-top: 1rem !important;
    }

    .pr-xl-3,
    .px-xl-3 {
        padding-right: 1rem !important;
    }

    .pb-xl-3,
    .py-xl-3 {
        padding-bottom: 1rem !important;
    }

    .pl-xl-3,
    .px-xl-3 {
        padding-left: 1rem !important;
    }

    .p-xl-4 {
        padding: 1.5rem !important;
    }

    .pt-xl-4,
    .py-xl-4 {
        padding-top: 1.5rem !important;
    }

    .pr-xl-4,
    .px-xl-4 {
        padding-right: 1.5rem !important;
    }

    .pb-xl-4,
    .py-xl-4 {
        padding-bottom: 1.5rem !important;
    }

    .pl-xl-4,
    .px-xl-4 {
        padding-left: 1.5rem !important;
    }

    .p-xl-5 {
        padding: 3rem !important;
    }

    .pt-xl-5,
    .py-xl-5 {
        padding-top: 3rem !important;
    }

    .pr-xl-5,
    .px-xl-5 {
        padding-right: 3rem !important;
    }

    .pb-xl-5,
    .py-xl-5 {
        padding-bottom: 3rem !important;
    }

    .pl-xl-5,
    .px-xl-5 {
        padding-left: 3rem !important;
    }

    .m-xl-n1 {
        margin: -0.25rem !important;
    }

    .mt-xl-n1,
    .my-xl-n1 {
        margin-top: -0.25rem !important;
    }

    .mr-xl-n1,
    .mx-xl-n1 {
        margin-right: -0.25rem !important;
    }

    .mb-xl-n1,
    .my-xl-n1 {
        margin-bottom: -0.25rem !important;
    }

    .ml-xl-n1,
    .mx-xl-n1 {
        margin-left: -0.25rem !important;
    }

    .m-xl-n2 {
        margin: -0.5rem !important;
    }

    .mt-xl-n2,
    .my-xl-n2 {
        margin-top: -0.5rem !important;
    }

    .mr-xl-n2,
    .mx-xl-n2 {
        margin-right: -0.5rem !important;
    }

    .mb-xl-n2,
    .my-xl-n2 {
        margin-bottom: -0.5rem !important;
    }

    .ml-xl-n2,
    .mx-xl-n2 {
        margin-left: -0.5rem !important;
    }

    .m-xl-n3 {
        margin: -1rem !important;
    }

    .mt-xl-n3,
    .my-xl-n3 {
        margin-top: -1rem !important;
    }

    .mr-xl-n3,
    .mx-xl-n3 {
        margin-right: -1rem !important;
    }

    .mb-xl-n3,
    .my-xl-n3 {
        margin-bottom: -1rem !important;
    }

    .ml-xl-n3,
    .mx-xl-n3 {
        margin-left: -1rem !important;
    }

    .m-xl-n4 {
        margin: -1.5rem !important;
    }

    .mt-xl-n4,
    .my-xl-n4 {
        margin-top: -1.5rem !important;
    }

    .mr-xl-n4,
    .mx-xl-n4 {
        margin-right: -1.5rem !important;
    }

    .mb-xl-n4,
    .my-xl-n4 {
        margin-bottom: -1.5rem !important;
    }

    .ml-xl-n4,
    .mx-xl-n4 {
        margin-left: -1.5rem !important;
    }

    .m-xl-n5 {
        margin: -3rem !important;
    }

    .mt-xl-n5,
    .my-xl-n5 {
        margin-top: -3rem !important;
    }

    .mr-xl-n5,
    .mx-xl-n5 {
        margin-right: -3rem !important;
    }

    .mb-xl-n5,
    .my-xl-n5 {
        margin-bottom: -3rem !important;
    }

    .ml-xl-n5,
    .mx-xl-n5 {
        margin-left: -3rem !important;
    }

    .m-xl-auto {
        margin: auto !important;
    }

    .mt-xl-auto,
    .my-xl-auto {
        margin-top: auto !important;
    }

    .mr-xl-auto,
    .mx-xl-auto {
        margin-right: auto !important;
    }

    .mb-xl-auto,
    .my-xl-auto {
        margin-bottom: auto !important;
    }

    .ml-xl-auto,
    .mx-xl-auto {
        margin-left: auto !important;
    }
}

.stretched-link::after {
    position: absolute;
    top: 0;
    right: 0;
    bottom: 0;
    left: 0;
    z-index: 1;
    pointer-events: auto;
    content: "";
    background-color: transparent;
}

.text-monospace {
    font-family: SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace !important;
}

.text-justify {
    text-align: justify !important;
}

.text-wrap {
    white-space: normal !important;
}

.text-nowrap {
    white-space: nowrap !important;
}

.text-truncate {
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

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

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

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

@media (min-width: 576px) {
    .text-sm-left {
        text-align: left !important;
    }

    .text-sm-right {
        text-align: right !important;
    }

    .text-sm-center {
        text-align: center !important;
    }
}

@media (min-width: 768px) {
    .text-md-left {
        text-align: left !important;
    }

    .text-md-right {
        text-align: right !important;
    }

    .text-md-center {
        text-align: center !important;
    }
}

@media (min-width: 992px) {
    .text-lg-left {
        text-align: left !important;
    }

    .text-lg-right {
        text-align: right !important;
    }

    .text-lg-center {
        text-align: center !important;
    }
}

@media (min-width: 1200px) {
    .text-xl-left {
        text-align: left !important;
    }

    .text-xl-right {
        text-align: right !important;
    }

    .text-xl-center {
        text-align: center !important;
    }
}

.text-lowercase {
    text-transform: lowercase !important;
}

.text-uppercase {
    text-transform: uppercase !important;
}

.text-capitalize {
    text-transform: capitalize !important;
}

.font-weight-light {
    font-weight: 300 !important;
}

.font-weight-lighter {
    font-weight: lighter !important;
}

.font-weight-normal {
    font-weight: 400 !important;
}

.font-weight-bold {
    font-weight: 700 !important;
}

.font-weight-bolder {
    font-weight: bolder !important;
}

.font-italic {
    font-style: italic !important;
}

.text-white {
    color: #fff !important;
}

.text-primary {
    color: #007bff !important;
}

a.text-primary:hover, a.text-primary:focus {
    color: #0056b3 !important;
}

.text-secondary {
    color: #6c757d !important;
}

a.text-secondary:hover, a.text-secondary:focus {
    color: #494f54 !important;
}

.text-success {
    color: #28a745 !important;
}

a.text-success:hover, a.text-success:focus {
    color: #19692c !important;
}

.text-info {
    color: #17a2b8 !important;
}

a.text-info:hover, a.text-info:focus {
    color: #0f6674 !important;
}

.text-warning {
    color: #ffc107 !important;
}

a.text-warning:hover, a.text-warning:focus {
    color: #ba8b00 !important;
}

.text-danger {
    color: #dc3545 !important;
}

a.text-danger:hover, a.text-danger:focus {
    color: #a71d2a !important;
}

.text-light {
    color: #f8f9fa !important;
}

a.text-light:hover, a.text-light:focus {
    color: #cbd3da !important;
}

.text-dark {
    color: #343a40 !important;
}

a.text-dark:hover, a.text-dark:focus {
    color: #121416 !important;
}

.text-body {
    color: #212529 !important;
}

.text-muted {
    color: #6c757d !important;
}

.text-black-50 {
    color: rgba(0, 0, 0, 0.5) !important;
}

.text-white-50 {
    color: rgba(255, 255, 255, 0.5) !important;
}

.text-hide {
    font: 0/0 a;
    color: transparent;
    text-shadow: none;
    background-color: transparent;
    border: 0;
}

.text-decoration-none {
    text-decoration: none !important;
}

.text-break {
    word-break: break-word !important;
    word-wrap: break-word !important;
}

.text-reset {
    color: inherit !important;
}

.visible {
    visibility: visible !important;
}

.invisible {
    visibility: hidden !important;
}

@media print {
    *,
    *::before,
    *::after {
        text-shadow: none !important;
        box-shadow: none !important;
    }

    a:not(.btn):not(.cart-total-cta):not(.checkout form [type="submit"]):not(.cookie-policy-cta) {
        text-decoration: underline;
    }

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

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

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

    thead {
        display: table-header-group;
    }

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

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

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

    @page {
        size: a3;
    }

    body {
        min-width: 992px !important;
    }

    .container, .iframe-container {
        min-width: 992px !important;
    }

    .navbar {
        display: none;
    }

    .badge {
        border: 1px solid #000;
    }

    .table {
        border-collapse: collapse !important;
    }

        .table td,
        .table th {
            background-color: #fff !important;
        }

    .table-bordered th,
    .table-bordered td {
        border: 1px solid #dee2e6 !important;
    }

    .table-dark {
        color: inherit;
    }

        .table-dark th,
        .table-dark td,
        .table-dark thead th,
        .table-dark tbody + tbody {
            border-color: #dee2e6;
        }

    .table .thead-dark th {
        color: inherit;
        border-color: #dee2e6;
    }
}

/* Slider */
.slick-slider {
    position: relative;
    display: block;
    box-sizing: border-box;
    -webkit-touch-callout: none;
    -webkit-user-select: none;
    -moz-user-select: none;
    -ms-user-select: none;
    user-select: none;
    -ms-touch-action: pan-y;
    touch-action: pan-y;
    -webkit-tap-highlight-color: transparent;
}

.slick-list {
    position: relative;
    overflow: hidden;
    display: block;
    margin: 0;
    padding: 0;
}

    .slick-list:focus {
        outline: none;
    }

    .slick-list.dragging {
        cursor: pointer;
        cursor: hand;
    }

.slick-slider .slick-track,
.slick-slider .slick-list {
    -ms-transform: translate3d(0, 0, 0);
    transform: translate3d(0, 0, 0);
}

.slick-track {
    position: relative;
    left: 0;
    top: 0;
    display: block;
    margin-left: auto;
    margin-right: auto;
}

    .slick-track:before, .slick-track:after {
        content: "";
        display: table;
    }

    .slick-track:after {
        clear: both;
    }

.slick-loading .slick-track {
    visibility: hidden;
}

.slick-slide {
    float: left;
    height: 100%;
    min-height: 1px;
    display: none;
}

[dir="rtl"] .slick-slide {
    float: right;
}

.slick-slide img {
    display: block;
}

.slick-slide.slick-loading img {
    display: none;
}

.slick-slide.dragging img {
    pointer-events: none;
}

.slick-initialized .slick-slide {
    display: block;
}

.slick-loading .slick-slide {
    visibility: hidden;
}

.slick-vertical .slick-slide {
    display: block;
    height: auto;
    border: 1px solid transparent;
}

.slick-arrow.slick-hidden {
    display: none;
}

/* Slider */
.slick-loading .slick-list {
    background: #fff url("./../images/ajax-loader.gif") center center no-repeat;
}

/* Icons */
@font-face {
    font-family: "slick";
    src: url("../fonts/slick.eot");
    src: url("../fonts/slick.eot?#iefix") format("embedded-opentype"), url("../fonts/slick.woff") format("woff"), url("../fonts/slick.ttf") format("truetype"), url("../fonts/slick.svg#slick") format("svg");
    font-weight: normal;
    font-style: normal;
}

/* Arrows */
.slick-prev,
.slick-next {
    position: absolute;
    display: block;
    height: 20px;
    width: 20px;
    line-height: 0px;
    font-size: 0px;
    cursor: pointer;
    background: transparent;
    color: transparent;
    top: 50%;
    margin-top: -10px\9;
    /*lte IE 8*/
    -ms-transform: translate(0, -50%);
    transform: translate(0, -50%);
    padding: 0;
    border: none;
    outline: none;
}

    .slick-prev:hover, .slick-prev:focus,
    .slick-next:hover,
    .slick-next:focus {
        outline: none;
        background: transparent;
        color: transparent;
    }

        .slick-prev:hover:before, .slick-prev:focus:before,
        .slick-next:hover:before,
        .slick-next:focus:before {
            opacity: 1;
        }

    .slick-prev.slick-disabled:before,
    .slick-next.slick-disabled:before {
        opacity: 0.25;
    }

    .slick-prev:before, .slick-next:before {
        font-family: "slick";
        font-size: 20px;
        line-height: 1;
        color: white;
        opacity: 0.75;
        -webkit-font-smoothing: antialiased;
        -moz-osx-font-smoothing: grayscale;
    }

.slick-prev {
    left: -25px;
}

[dir="rtl"] .slick-prev {
    left: auto;
    right: -25px;
}

.slick-prev:before {
    content: "←";
}

[dir="rtl"] .slick-prev:before {
    content: "→";
}

.slick-next {
    right: -25px;
}

[dir="rtl"] .slick-next {
    left: -25px;
    right: auto;
}

.slick-next:before {
    content: "→";
}

[dir="rtl"] .slick-next:before {
    content: "←";
}

/* Dots */
.slick-slider {
    margin-bottom: 30px;
}

.slick-dots {
    position: absolute;
    bottom: -45px;
    list-style: none;
    display: block;
    text-align: center;
    padding: 0;
    width: 100%;
}

    .slick-dots li {
        position: relative;
        display: inline-block;
        height: 20px;
        width: 20px;
        margin: 0 5px;
        padding: 0;
        cursor: pointer;
    }

        .slick-dots li button {
            border: 0;
            background: transparent;
            display: block;
            height: 20px;
            width: 20px;
            outline: none;
            line-height: 0px;
            font-size: 0px;
            color: transparent;
            padding: 5px;
            cursor: pointer;
        }

            .slick-dots li button:hover, .slick-dots li button:focus {
                outline: none;
            }

                .slick-dots li button:hover:before, .slick-dots li button:focus:before {
                    opacity: 1;
                }

            .slick-dots li button:before {
                position: absolute;
                top: 0;
                left: 0;
                content: "•";
                width: 20px;
                height: 20px;
                font-family: "slick";
                font-size: 6px;
                line-height: 20px;
                text-align: center;
                color: black;
                opacity: 0.25;
                -webkit-font-smoothing: antialiased;
                -moz-osx-font-smoothing: grayscale;
            }

        .slick-dots li.slick-active button:before {
            color: black;
            opacity: 0.75;
        }

/*
  *  Elements
  *
  */
@font-face {
    font-family: font-icons;
    src: url("../fonts/font-icons.eot");
    src: url("../fonts/font-icons.eot?#iefix") format("embedded-opentype"), url("../fonts/font-icons.woff") format("woff"), url("../fonts/font-icons.ttf") format("truetype"), url("../fonts/font-icons.svg#font-icons") format("svg");
    font-weight: normal;
    font-style: normal;
}

.icon:before {
    -moz-osx-font-smoothing: grayscale;
    -webkit-font-smoothing: antialiased;
    content: "";
    font-family: "font-icons";
    font-style: normal;
    font-variant: normal;
    font-weight: normal;
    line-height: 1;
    speak: none;
    text-transform: none;
}

.icon-facebook:before {
    content: "";
}

.icon-instagram:before {
    content: "";
}

.icon-twitter:before {
    content: "";
}

.icon-arrow-right:before {
    content: "";
}

.icon-desktop-nav-arrow:before {
    content: "";
}

.icon-menu:before {
    content: "";
}

.icon-accordion-arrow:before {
    content: "";
}

.icon-architizer:before {
    content: "";
}

.icon-arrow-nav-down:before {
    content: "";
}

.icon-back-arrow:before {
    content: "";
}

.icon-cart-full:before {
    content: "";
}

.icon-cart:before {
    content: "";
}

.icon-chevron-left:before {
    content: "";
}

.icon-chevron-right:before {
    content: "";
}

.icon-close:before {
    content: "";
}

.icon-download:before {
    content: "";
}

.icon-external-link:before {
    content: "";
}

.icon-full-screen:before {
    content: "";
}

.icon-location:before {
    content: "";
}

.icon-modal-close:before {
    content: "";
}

.icon-pdf:before {
    content: "";
}

.icon-search:before {
    content: "";
}

.icon-settings:before {
    content: "";
}

.icon-target:before {
    content: "";
}

.icon-video:before {
    content: "";
}

.body-1 {
    font-family: 'Helvetica Neue LT W05_45 Light', Helvetica, sans-serif;
    font-weight: 300;
    font-size: 16px;
    line-height: 24px;
    margin-bottom: 32px;
}

@media screen and (min-width: 1200px) {
    .body-1 {
        font-size: 20px;
        line-height: 36px;
        margin-bottom: 56px;
    }
}

.body-2 {
    font-family: 'Helvetica Neue LT W05_45 Light', Helvetica, sans-serif;
    font-weight: 300;
    font-size: 14px;
    line-height: 22px;
    margin-bottom: 24px;
}

@media screen and (min-width: 1200px) {
    .body-2 {
        font-size: 18px;
        line-height: 32px;
        margin-bottom: 32px;
    }
}

.body-3 {
    font-family: 'Helvetica Neue LT W05_45 Light', Helvetica, sans-serif;
    font-weight: 300;
    font-size: 12px;
    line-height: 20px;
}

@media screen and (min-width: 768px) {
    .body-3 {
        font-size: 14px;
        line-height: 22px;
    }
}

@media screen and (min-width: 1200px) {
    .body-3 {
        font-size: 16px;
        line-height: 24px;
    }
}

.body-4 {
    font-family: 'Helvetica Neue LT W05_45 Light', Helvetica, sans-serif;
    font-weight: 300;
    font-size: 12px;
    line-height: 20px;
    margin-bottom: 32px;
}

@media screen and (min-width: 1200px) {
    .body-4 {
        font-size: 14px;
        line-height: 24px;
    }
}

p, .p {
    font-family: 'Helvetica Neue LT W05_45 Light', Helvetica, sans-serif;
    font-weight: 300;
    font-size: 16px;
    line-height: 24px;
    margin-bottom: 32px;
}

@media screen and (min-width: 1200px) {
    p, .p {
        font-size: 20px;
        line-height: 36px;
        margin-bottom: 56px;
    }
}

h1, .h1 {
    font-family: Georgia, serif;
    font-size: 29.96px;
    color: #333333;
    line-height: 34px;
    margin-bottom: 48px;
}

@media screen and (min-width: 768px) {
    h1, .h1 {
        font-size: 53.5px;
        line-height: 58px;
    }
}

h2, .h2 {
    font-family: Georgia, serif;
    font-size: 27.82px;
    line-height: 32px;
    color: #333333;
    text-align: left;
    margin-bottom: 32px;
}

@media screen and (min-width: 768px) {
    h2, .h2 {
        font-size: 38.52px;
        line-height: 44px;
    }
}

h3, .h3 {
    font-family: Georgia, serif;
    font-size: 25.68px;
    line-height: 30px;
    margin-bottom: 32px;
}

@media screen and (min-width: 768px) {
    h3, .h3 {
        font-size: 34.24px;
        line-height: 40px;
    }
}

h4, .h4 {
    font-family: Georgia, serif;
    font-size: 23.54px;
    line-height: 28px;
    color: #333333;
}

@media screen and (min-width: 768px) {
    h4, .h4 {
        font-size: 29.96px;
        line-height: 34px;
    }
}

h5, .h5 {
    font-family: Georgia, serif;
    font-size: 21.4px;
    line-height: 26px;
    color: #333333;
}

@media screen and (min-width: 768px) {
    h5, .h5 {
        font-size: 23.54px;
        line-height: 28px;
    }
}

@media screen and (min-width: 992px) {
    h5, .h5 {
        font-size: 21.4px;
        line-height: 26px;
    }
}

@media screen and (min-width: 1200px) {
    h5, .h5 {
        font-size: 25.68px;
        line-height: 30px;
    }
}

.body-1 {
    font-family: 'Helvetica Neue LT W05_45 Light', Helvetica, sans-serif;
    font-weight: 300;
    font-size: 16px;
    line-height: 24px;
    margin-bottom: 32px;
}

@media screen and (min-width: 1200px) {
    .body-1 {
        font-size: 20px;
        line-height: 36px;
        margin-bottom: 56px;
    }
}

.body-2 {
    font-family: 'Helvetica Neue LT W05_45 Light', Helvetica, sans-serif;
    font-weight: 300;
    font-size: 14px;
    line-height: 22px;
    margin-bottom: 24px;
}

@media screen and (min-width: 1200px) {
    .body-2 {
        font-size: 18px;
        line-height: 32px;
        margin-bottom: 32px;
    }
}

.body-3 {
    font-family: 'Helvetica Neue LT W05_45 Light', Helvetica, sans-serif;
    font-weight: 300;
    font-size: 12px;
    line-height: 20px;
}

@media screen and (min-width: 768px) {
    .body-3 {
        font-size: 14px;
        line-height: 22px;
    }
}

@media screen and (min-width: 1200px) {
    .body-3 {
        font-size: 16px;
        line-height: 24px;
    }
}

.body-4 {
    font-family: 'Helvetica Neue LT W05_45 Light', Helvetica, sans-serif;
    font-weight: 300;
    font-size: 12px;
    line-height: 20px;
    margin-bottom: 32px;
}

@media screen and (min-width: 1200px) {
    .body-4 {
        font-size: 14px;
        line-height: 24px;
    }
}

.fw-l {
    font-family: 'Helvetica Neue LT W05_45 Light', Helvetica, sans-serif;
    font-weight: 300;
}

.fw-r {
    font-family: 'Helvetica Neue LT W05_45 Light', Helvetica, sans-serif;
    font-weight: 300;
    font-family: 'Helvetica Neue LT W05_55 Roman', Helvetica, sans-serif;
    font-weight: 400;
}

.fw-m {
    font-family: 'Helvetica Neue LT W05_45 Light', Helvetica, sans-serif;
    font-weight: 300;
    font-family: 'Helvetica Neue LT W05_65 Medium', Helvetica, sans-serif;
    font-weight: 600;
}

.fw-b {
    font-family: 'Helvetica Neue LT W05_45 Light', Helvetica, sans-serif;
    font-weight: 300;
    font-family: 'Helvetica Neue LT W05_75 Bold', Helvetica, sans-serif;
    font-weight: 700;
}

/*
  <div class="section-label || section-label-inline-block">
    <h3>Section Label</h3>
  </div>
*/
.section-label > *,
.section-label-inline-block > * {
    font-family: 'Helvetica Neue LT W05_45 Light', Helvetica, sans-serif;
    font-weight: 300;
    font-family: 'Helvetica Neue LT W05_75 Bold', Helvetica, sans-serif;
    font-weight: 700;
    font-size: 14px;
    text-transform: uppercase;
    color: #333333;
    letter-spacing: 0.04875rem;
    padding: 8px 0;
    margin-bottom: 24px;
    border-bottom: 1px solid #979797;
    display: inline-block;
}

@media screen and (min-width: 1200px) {
    .section-label > *,
    .section-label-inline-block > * {
        font-size: 18px;
        letter-spacing: 0.0625rem;
    }
}

@media screen and (min-width: 992px) {
    .section-label > * {
        display: block;
    }

    .section-label-inline-block > {
        display: inline-block;
    }
}

.page-title {
    padding-bottom: 32px;
    margin-bottom: 24px;
    border-bottom: 1px solid rgba(186, 186, 186, 0.5);
}

@media screen and (min-width: 992px) {
    .page-title {
        padding-bottom: 56px;
        margin-bottom: 48px;
    }
}

.page-title.no-border {
    border-bottom: none;
    padding-bottom: 0;
}

@media screen and (min-width: 992px) {
    .page-title.no-border {
        padding-bottom: 0;
    }
}

.hero--copy__card p {
    font-weight: 500 !important;
}

/*
  *  Layout
  *
  */
html,
body {
    height: 100%;
    min-height: 100%;
    overflow-x: hidden;
}

html {
    font-size: 62.5%;
}

body {
    -moz-osx-font-smoothing: grayscale;
    -webkit-font-smoothing: antialiased;
    font-size: 14px;
    font-size: 1.4rem;
    font-family: 'Helvetica Neue LT W05_45 Light', Helvetica, sans-serif;
    font-weight: 300;
    background-color: #f9f7f6;
    color: #333;
}

    body.menu-open {
        overflow: hidden;
    }

section {
    margin-bottom: 48px;
}

@media screen and (min-width: 1200px) {
    section {
        margin-bottom: 72px;
    }
}

a {
    color: #2272CE;
    text-decoration: none;
}

    a.underline {
        text-decoration: underline;
    }

hr {
    border-color: rgba(151, 151, 151, 0.5);
}

    hr.hr-large {
        margin-top: 56px;
        margin-bottom: 40px;
    }

@media screen and (min-width: 1200px) {
    hr.hr-large {
        margin-top: 96px;
        margin-bottom: 80px;
    }
}

.pdf-size {
    font-family: 'Helvetica Neue LT W05_45 Light', Helvetica, sans-serif;
    font-weight: 300;
}

strong {
    font-family: 'Helvetica Neue LT W05_45 Light', Helvetica, sans-serif;
    font-weight: 300;
    font-family: 'Helvetica Neue LT W05_75 Bold', Helvetica, sans-serif;
    font-weight: 700;
    -webkit-font-smoothing: subpixel-antialiased;
}

em {
    font-style: normal;
    font-family: 'Helvetica Neue LT W05_45 Light', Helvetica, sans-serif;
    font-weight: 300;
    font-family: 'Helvetica Neue LT W05_56 Italic', Helvetica, sans-serif;
    font-style: italic;
}

sup {
    top: -0.5em;
}

h1 strong,
h2 strong,
h3 strong,
h4 strong,
h5 strong,
h6 strong {
    font-family: Georgia, serif;
    font-family: Georgia, serif;
    font-weight: bold;
}

li em {
    font-family: 'Helvetica Neue LT W05_45 Light', Helvetica, sans-serif;
    font-weight: 300;
}

.rich-text--large {
    font-size: inherit;
    line-height: inherit;
}

    .rich-text--large p {
        font-size: 20px;
        line-height: 36px;
    }

    .rich-text--large h2 {
        font-size: 36px;
        line-height: 44px;
    }

    .rich-text--large strong {
        font-size: inherit;
        line-height: inherit;
    }

    .rich-text--large ul,
    .rich-text--large ol {
        padding-left: 16px;
        margin-bottom: 56px;
    }

        .rich-text--large ul li,
        .rich-text--large ol li {
            font-size: 20px;
            line-height: 36px;
            margin-bottom: 8px;
        }

.rich-text--small {
    font-size: 18px;
    line-height: 32px;
}

    .rich-text--small p {
        font-size: inherit;
        line-height: inherit;
    }

    .rich-text--small h2 {
        font-size: 32px;
        line-height: 40px;
    }

    .rich-text--small strong {
        font-size: inherit;
        line-height: inherit;
        display: block;
        padding-bottom: 15px;
    }

    .rich-text--small ul,
    .rich-text--small ol {
        padding-left: 16px;
        margin-bottom: 56px;
    }

        .rich-text--small ul li,
        .rich-text--small ol li {
            font-size: 18px;
            line-height: 32px;
            margin-bottom: 10px;
        }

.read-more {
    color: #333;
    font-family: 'Helvetica Neue LT W05_45 Light', Helvetica, sans-serif;
    font-weight: 300;
    font-family: 'Helvetica Neue LT W05_65 Medium', Helvetica, sans-serif;
    font-weight: 600;
    display: inline-block;
    -ms-flex-align: center;
    align-items: center;
    text-decoration: none;
    position: relative;
    padding-right: 25px;
}

    .read-more.icon-cart:before {
        content: "";
    }

    .read-more:after {
        content: "";
        display: block;
        width: 18px;
        height: 12px;
        transform: translate3d(6px, 0, 0);
        transition: transform 0.35s ease-out;
        position: absolute;
        top: 8px;
        right: 0;
        margin: 0;
        font-family: "font-icons";
        color: #333;
        font-size: 13px;
        -ms-transform: rotate(180deg);
        transform: rotate(180deg);
    }

    .read-more:hover {
        text-decoration: none;
        color: inherit;
    }

        .read-more:hover:after {
            transform: translate3d(10px, 0, 0) rotate(180deg);
            transition: transform 0.25s ease-out;
        }

.sticky-nav .read-more:after {
    top: 15px !important;
}

.icon-modal-close {
    height: 60px;
    width: 60px;
    font-size: 60px;
    line-height: 1em;
    display: block;
}

.modal .close .icon-modal-close {
    height: 60px;
    width: 60px;
    font-size: 60px;
    line-height: 1em;
    display: block;
}

.back, .back-border {
    display: -ms-flexbox;
    display: flex;
    -ms-flex-align: center;
    align-items: center;
    margin: 24px 0 32px;
    padding: 16px 0;
    font-size: 14px;
    color: #333;
    font-family: 'Helvetica Neue LT W05_45 Light', Helvetica, sans-serif;
    font-weight: 300;
    font-family: 'Helvetica Neue LT W05_65 Medium', Helvetica, sans-serif;
    font-weight: 600;
    text-decoration: none;
    position: relative;
    padding-left: 35px;
}

    .back:before, .back-border:before {
        content: "";
        display: block;
        width: 18px;
        height: 20px;
        transform: translate3d(8px, 1px, 0);
        transition: transform 0.35s;
        margin-right: 8px;
        position: absolute;
        font-family: "font-icons";
        top: 15px;
        left: 0;
        content: "";
    }

    .back:hover, .back-border:hover {
        text-decoration: none;
        color: #333;
    }

        .back:hover:before, .back-border:hover:before {
            transform: translate3d(0, 1px, 0);
            transition: transform 0.35s;
        }

.back-border {
    padding-bottom: 32px;
    margin-bottom: 32px;
    border-bottom: 1px solid #979797;
}

@media screen and (min-width: 1200px) {
    .back-border {
        padding-bottom: 40px;
        margin-bottom: 48px;
    }
}

.link-ext > i {
    text-decoration: none;
    color: #333;
    font-size: 80%;
    margin-left: 8px;
}

.where-to-buy {
    background: transparent;
    display: block;
    -ms-flex-align: center;
    align-items: center;
    -ms-flex-pack: center;
    justify-content: center;
    width: 100%;
    border-color: #333333;
    padding: 12px;
}

    .where-to-buy span {
        position: relative;
    }

        .where-to-buy span:before {
            content: "";
            display: block;
            margin-right: 8px;
            width: 24px;
            height: 24px;
            position: absolute;
            top: -4px;
            left: -26px;
            color: #333;
            font-family: "font-icons";
            font-size: 23px;
            line-height: 1em;
        }

.request-quote {
    background: transparent;
    display: block;
    -ms-flex-align: center;
    align-items: center;
    -ms-flex-pack: center;
    justify-content: center;
    width: 100%;
    border-color: #333333;
    padding: 12px;
}

    .request-quote span {
        position: relative;
    }

.site-content {
    margin-top: 50px;
    padding: 32px 0 48px;
    overflow: hidden;
}

    .site-content > .hero:first-child {
        margin-top: -32px;
    }

    .site-content > .buy-form:first-child {
        margin-top: -32px;
        margin-bottom: -48px;
    }

@media screen and (min-width: 992px) {
    .site-content {
        margin-top: 60px;
    }
}

@media screen and (min-width: 1200px) {
    .site-content {
        margin-top: 84px;
    }
}

.btn, .cart-total-cta, .checkout form [type="submit"], .cookie-policy-cta {
    padding: 7px 12px 8px;
    border: 1px solid rgba(186, 186, 186, 0.5);
    font-size: 12px;
    text-decoration: none;
    font-family: 'Helvetica Neue LT W05_45 Light', Helvetica, sans-serif;
    font-weight: 300;
    font-family: 'Helvetica Neue LT W05_75 Bold', Helvetica, sans-serif;
    font-weight: 700;
    color: #333333;
    border-radius: 8px;
    line-height: 15px;
}

.btn-large, .featured-article-card .btn, .featured-article-card .cart-total-cta, .featured-article-card .cookie-policy-cta, .cart-total-cta, .checkout form [type="submit"] {
    padding: 16px 32px;
}

.btn-blue, .cart-total-cta, .checkout form [type="submit"] {
    background: #2275d3;
    transition: background-color 0.35s;
    color: #fff;
    border: none;
}

    .btn-blue:hover, .cart-total-cta:hover, .checkout form [type="submit"]:hover {
        color: #fff;
        background: #1b5da7;
        transition: background-color 0.35s;
    }

.btn-dark-gray, .cookie-policy-cta {
    background: #545454;
    color: #ffffff;
    border: none;
}

    .btn-dark-gray:hover, .cookie-policy-cta:hover {
        color: #ffffff;
        background: #333333;
        transition: background-color 0.35s;
    }

.btn-link, .checkout-step-edit {
    background: none;
    padding: 0;
    border: none;
    color: #2272CE;
    text-decoration: underline;
    font-family: 'Helvetica Neue LT W05_45 Light', Helvetica, sans-serif;
    font-weight: 300;
    font-family: 'Helvetica Neue LT W05_55 Roman', Helvetica, sans-serif;
    font-weight: 400;
}

.close {
    opacity: 1;
}

.badge-new {
    width: 25px;
    padding: 4px;
    font-family: 'Helvetica Neue LT W05_45 Light', Helvetica, sans-serif;
    font-weight: 300;
    font-family: 'Helvetica Neue LT W05_75 Bold', Helvetica, sans-serif;
    font-weight: 700;
    font-size: 9px;
    line-height: 11px;
    color: #fff;
    text-transform: uppercase;
    background: linear-gradient(225deg, #3023ae 0%, #c86dd7 100%);
}

.badge-discontinued {
    font-family: 'Helvetica Neue LT W05_45 Light', Helvetica, sans-serif;
    font-weight: 300;
    font-family: 'Helvetica Neue LT W05_75 Bold', Helvetica, sans-serif;
    font-weight: 700;
    font-size: 9px;
    line-height: 11px;
    text-transform: uppercase;
    color: #b30000;
}

.card, .newsletter-signup {
    padding: 32px 24px;
    background: #fff;
    box-shadow: 0 0 30px 0 rgba(151, 151, 151, 0.2);
}

@media screen and (min-width: 992px) {
    .card, .newsletter-signup {
        padding: 48px 96px;
    }
}

.order-sample:before, .decor-order-sample:before, .swatch-overlay-mask:before, #payment-form:before, #cart-container:before, .checkout #reviewitems:before {
    content: "";
    opacity: 0;
    display: block;
    width: 50px;
    height: 50px;
    position: absolute;
    top: 50%;
    left: 50%;
    -ms-transform: translate(-50%, -50%);
    transform: translate(-50%, -50%);
    border-radius: 100%;
    border: 4px solid #979797;
    border-left-color: #333;
    animation: overlayLoadingRotate 0.75s linear infinite;
    -ms-transform-origin: 0 0;
    transform-origin: 0 0;
    transition: opacity 0.25s;
    z-index: 9;
}

.loading.order-sample:before, .loading.decor-order-sample:before, .loading.swatch-overlay-mask:before, .loading#payment-form:before, .loading#cart-container:before, .checkout .loading#reviewitems:before {
    opacity: 1;
    transition: opacity 0.25s;
}

.IE-container {
    display: none;
    position: absolute;
    top: 85px;
    left: 50%;
    -ms-transform: translateX(-50%);
    transform: translateX(-50%);
}

.cookie-content {
    margin-top: 130px;
}

.withoutbanner .cookie-container {
    top: 160px;
}

.cookie-container {
    position: absolute;
    top: 90px;
    left: 50%;
    -ms-transform: translateX(-50%);
    transform: translateX(-50%);
    z-index: 111;
}

    .cookie-container p {
        color: #da3931;
        margin: 0;
        font-size: 12px;
        font-family: 'Helvetica Neue LT W05_45 Light', Helvetica, sans-serif;
        font-weight: 300;
        font-family: 'Helvetica Neue LT W05_65 Medium', Helvetica, sans-serif;
        font-weight: 600;
        line-height: 16px;
    }

.onlyIE {
    color: #da3931;
    display: block;
    position: relative;
    z-index: 111;
    padding: 5px 0;
    margin: 0 auto;
    width: 100%;
    top: 0;
}

    .onlyIE p {
        margin: 0;
        font-size: 12px;
        font-family: 'Helvetica Neue LT W05_45 Light', Helvetica, sans-serif;
        font-weight: 300;
        font-family: 'Helvetica Neue LT W05_65 Medium', Helvetica, sans-serif;
        font-weight: 600;
        line-height: 16px;
    }

    .onlyIE .close {
        display: none;
    }

        .onlyIE .close:focus {
            outline: none;
        }

        .onlyIE .close .icon-modal-close {
            height: 50px;
            width: 50px;
            font-size: 50px;
            line-height: 1em;
            display: block;
            color: #da3931;
        }

@media screen and (-ms-high-contrast: active), (-ms-high-contrast: none) {
    body {
        position: relative;
        overflow-x: hidden;
    }

    .site-content,
    .cookie-content {
        margin-top: 150px;
    }

    .IE-container {
        display: block;
        z-index: 999;
    }

    .cookie-container {
        top: 110px;
    }

    .withoutbanner .IE-container {
        top: 160px;
    }

    .withoutbanner .cookie-container {
        top: 185px;
    }
}

@media screen and (max-width: 1200px) {
    .cookie-container {
        top: 60px;
    }
}

.logo-fenix-inner {
    display: block;
    margin-bottom: 32px;
}

    .logo-fenix-inner img {
        max-height: 42px;
    }

html body.sc-edit-mode {
    overflow: initial;
}

.m0 {
    margin: 0px;
}

.mt0 {
    margin-top: 0px;
}

.mr0 {
    margin-right: 0px;
}

.mb0 {
    margin-bottom: 0px;
}

.ml0 {
    margin-left: 0px;
}

.p0 {
    margin: 0px;
}

.pt0 {
    margin-top: 0px;
}

.pr0 {
    margin-right: 0px;
}

.pb0 {
    margin-bottom: 0px;
}

.pl0 {
    margin-left: 0px;
}

.m1 {
    margin: 8px;
}

.mt1 {
    margin-top: 8px;
}

.mr1 {
    margin-right: 8px;
}

.mb1 {
    margin-bottom: 8px;
}

.ml1 {
    margin-left: 8px;
}

.p1 {
    margin: 8px;
}

.pt1 {
    margin-top: 8px;
}

.pr1 {
    margin-right: 8px;
}

.pb1 {
    margin-bottom: 8px;
}

.pl1 {
    margin-left: 8px;
}

.m2 {
    margin: 16px;
}

.mt2 {
    margin-top: 16px;
}

.mr2 {
    margin-right: 16px;
}

.mb2 {
    margin-bottom: 16px;
}

.ml2 {
    margin-left: 16px;
}

.p2 {
    margin: 16px;
}

.pt2 {
    margin-top: 16px;
}

.pr2 {
    margin-right: 16px;
}

.pb2 {
    margin-bottom: 16px;
}

.pl2 {
    margin-left: 16px;
}

.m3 {
    margin: 24px;
}

.mt3 {
    margin-top: 24px;
}

.mr3 {
    margin-right: 24px;
}

.mb3 {
    margin-bottom: 24px;
}

.ml3 {
    margin-left: 24px;
}

.p3 {
    margin: 24px;
}

.pt3 {
    margin-top: 24px;
}

.pr3 {
    margin-right: 24px;
}

.pb3 {
    margin-bottom: 24px;
}

.pl3 {
    margin-left: 24px;
}

.m4 {
    margin: 32px;
}

.mt4 {
    margin-top: 32px;
}

.mr4 {
    margin-right: 32px;
}

.mb4 {
    margin-bottom: 32px;
}

.ml4 {
    margin-left: 32px;
}

.p4 {
    margin: 32px;
}

.pt4 {
    margin-top: 32px;
}

.pr4 {
    margin-right: 32px;
}

.pb4 {
    margin-bottom: 32px;
}

.pl4 {
    margin-left: 32px;
}

.m5 {
    margin: 40px;
}

.mt5 {
    margin-top: 40px;
}

.mr5 {
    margin-right: 40px;
}

.mb5 {
    margin-bottom: 40px;
}

.ml5 {
    margin-left: 40px;
}

.p5 {
    margin: 40px;
}

.pt5 {
    margin-top: 40px;
}

.pr5 {
    margin-right: 40px;
}

.pb5 {
    margin-bottom: 40px;
}

.pl5 {
    margin-left: 40px;
}

.m6 {
    margin: 48px;
}

.mt6 {
    margin-top: 48px;
}

.mr6 {
    margin-right: 48px;
}

.mb6 {
    margin-bottom: 48px;
}

.ml6 {
    margin-left: 48px;
}

.p6 {
    margin: 48px;
}

.pt6 {
    margin-top: 48px;
}

.pr6 {
    margin-right: 48px;
}

.pb6 {
    margin-bottom: 48px;
}

.pl6 {
    margin-left: 48px;
}

.m7 {
    margin: 56px;
}

.mt7 {
    margin-top: 56px;
}

.mr7 {
    margin-right: 56px;
}

.mb7 {
    margin-bottom: 56px;
}

.ml7 {
    margin-left: 56px;
}

.p7 {
    margin: 56px;
}

.pt7 {
    margin-top: 56px;
}

.pr7 {
    margin-right: 56px;
}

.pb7 {
    margin-bottom: 56px;
}

.pl7 {
    margin-left: 56px;
}

.m8 {
    margin: 64px;
}

.mt8 {
    margin-top: 64px;
}

.mr8 {
    margin-right: 64px;
}

.mb8 {
    margin-bottom: 64px;
}

.ml8 {
    margin-left: 64px;
}

.p8 {
    margin: 64px;
}

.pt8 {
    margin-top: 64px;
}

.pr8 {
    margin-right: 64px;
}

.pb8 {
    margin-bottom: 64px;
}

.pl8 {
    margin-left: 64px;
}

.m9 {
    margin: 72px;
}

.mt9 {
    margin-top: 72px;
}

.mr9 {
    margin-right: 72px;
}

.mb9 {
    margin-bottom: 72px;
}

.ml9 {
    margin-left: 72px;
}

.p9 {
    margin: 72px;
}

.pt9 {
    margin-top: 72px;
}

.pr9 {
    margin-right: 72px;
}

.pb9 {
    margin-bottom: 72px;
}

.pl9 {
    margin-left: 72px;
}

.m10 {
    margin: 80px;
}

.mt10 {
    margin-top: 80px;
}

.mr10 {
    margin-right: 80px;
}

.mb10 {
    margin-bottom: 80px;
}

.ml10 {
    margin-left: 80px;
}

.p10 {
    margin: 80px;
}

.pt10 {
    margin-top: 80px;
}

.pr10 {
    margin-right: 80px;
}

.pb10 {
    margin-bottom: 80px;
}

.pl10 {
    margin-left: 80px;
}

.m11 {
    margin: 88px;
}

.mt11 {
    margin-top: 88px;
}

.mr11 {
    margin-right: 88px;
}

.mb11 {
    margin-bottom: 88px;
}

.ml11 {
    margin-left: 88px;
}

.p11 {
    margin: 88px;
}

.pt11 {
    margin-top: 88px;
}

.pr11 {
    margin-right: 88px;
}

.pb11 {
    margin-bottom: 88px;
}

.pl11 {
    margin-left: 88px;
}

.m12 {
    margin: 96px;
}

.mt12 {
    margin-top: 96px;
}

.mr12 {
    margin-right: 96px;
}

.mb12 {
    margin-bottom: 96px;
}

.ml12 {
    margin-left: 96px;
}

.p12 {
    margin: 96px;
}

.pt12 {
    margin-top: 96px;
}

.pr12 {
    margin-right: 96px;
}

.pb12 {
    margin-bottom: 96px;
}

.pl12 {
    margin-left: 96px;
}

@keyframes snake {
    0% {
        transform-origin: 100% 50%;
        transform: scaleX(1);
    }

    33% {
        transform-origin: 100% 50%;
        transform: scaleX(0);
    }

    66% {
        transform-origin: 0% 50%;
        transform: scaleX(0);
    }

    100% {
        transform-origin: 0% 50%;
        transform: scaleX(1);
    }
}

form .error {
    color: #da3931;
}

    form .error * {
        border-color: #da3931 !important;
    }

    form .error:focus {
        box-shadow: inset 0 0 4px #da3931 !important;
    }

form label.error {
    -ms-flex-order: 1;
    order: 1;
}

.form-group {
    margin-bottom: 24px;
}

input[type="text"],
input[type="phone"],
input[type="email"],
textarea {
    font-size: 12px;
    line-height: 14px;
    padding: 12px 8px;
    border-radius: 8px;
    border: 1px solid #333333;
    background: transparent;
}

    input[type="text"]:focus,
    input[type="phone"]:focus,
    input[type="email"]:focus,
    textarea:focus {
        outline: none;
        border-color: #2272CE;
        box-shadow: inset 0 0 4px #2272CE;
    }

    input[type="text"].input-validation-error,
    input[type="phone"].input-validation-error,
    input[type="email"].input-validation-error,
    textarea.input-validation-error {
        border-color: #da3931;
        color: #da3931;
    }

textarea {
    min-height: 130px;
}

select {
    padding: 12px 20px 12px 8px;
    min-width: 165px;
    font-size: 12px;
    font-family: 'Helvetica Neue LT W05_45 Light', Helvetica, sans-serif;
    font-weight: 300;
    font-family: 'Helvetica Neue LT W05_55 Roman', Helvetica, sans-serif;
    font-weight: 400;
    border: 1px solid #595959;
    border-radius: 8px;
    background: transparent url("../images/arrow-nav-down.svg") calc(100% - 8px) 50% no-repeat !important;
    -webkit-appearance: none;
    -moz-appearance: none;
    appearance: none;
    outline: none;
}

    select:focus {
        outline: none;
        border-color: #2272CE;
        box-shadow: inset 0 0 4px #2272CE;
    }

    select:not(:last-child) {
        margin-right: 16px;
    }

    select[disabled] {
        color: #979797;
        border-color: #979797;
        padding-right: 4px;
    }

.radio-wrap {
    position: relative;
    display: block;
    margin: 0;
    padding-bottom: 10px;
}

    .radio-wrap.indent-level1 {
        margin-left: 29px;
    }

    .radio-wrap + .radio {
        margin-top: 0;
    }

    .radio-wrap input[type="radio"] {
        cursor: pointer;
        position: absolute;
        top: 0px;
        left: 0;
        opacity: 0 !important;
        outline: 0;
        width: 21px;
        height: 21px;
        margin: 0;
        padding: 0;
    }

        .radio-wrap input[type="radio"]:checked + label:after {
            opacity: 1;
        }

    .radio-wrap label {
        cursor: pointer;
        -webkit-user-select: none;
        -moz-user-select: none;
        -ms-user-select: none;
        user-select: none;
        position: relative;
        display: block;
        padding: 0 0 0 25px !important;
        padding-left: 25px;
        outline: 0;
        font-family: 'Helvetica Neue LT W05_45 Light', Helvetica, sans-serif;
        font-weight: 300;
        font-family: 'Helvetica Neue LT W05_65 Medium', Helvetica, sans-serif;
        font-weight: 600;
        font-size: 14px;
        line-height: 24px;
    }

        .radio-wrap label:before {
            position: absolute;
            top: 4px;
            left: 0;
            width: 16px;
            height: 16px;
            content: '';
            background: #fff;
            border: 1px solid #5F5F5F;
            border-radius: 50%;
        }

        .radio-wrap label:after {
            content: "";
            position: absolute;
            top: 7px;
            left: 3px;
            line-height: 10px;
            width: 10px;
            height: 10px;
            text-align: center;
            opacity: 0;
            background: #2070CA;
            border-radius: 50%;
        }

.inputbox {
    border: 1px solid #595959;
    border-radius: 8px;
    height: 44px;
    font-size: 12px;
    line-height: 14px;
    color: #595959;
    margin-bottom: 3px;
}

    .inputbox:focus {
        border: 1px solid #595959;
        box-shadow: none;
        outline: 0;
    }

    .inputbox.input-validation-error {
        border-color: #DA3931;
    }

.btn-dark-gray.large-btn, .large-btn.cookie-policy-cta {
    padding: 15px 30px 15px;
}

.checkboxes label {
    width: 100%;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-align: center;
    align-items: center;
}

    .checkboxes label input {
        width: auto;
        margin-right: 8px;
    }

.checkboxes.error {
    color: #da3931;
}

.label-required {
    display: block;
    font-family: 'Helvetica Neue LT W05_45 Light', Helvetica, sans-serif;
    font-weight: 300;
}

.required {
    font-family: 'Helvetica Neue LT W05_45 Light', Helvetica, sans-serif;
    font-weight: 300;
}

    .required label {
        display: block;
    }

        .required label ~ label {
            font-family: 'Helvetica Neue LT W05_45 Light', Helvetica, sans-serif;
            font-weight: 300;
        }

        .required label:after {
            content: '*';
        }

    .required input,
    .required select,
    .required textarea {
        font-family: 'Helvetica Neue LT W05_45 Light', Helvetica, sans-serif;
        font-weight: 300;
    }

    .required.error input,
    .required.error select,
    .required.error textarea {
        color: #da3931;
    }

    .required .field-validation-error {
        display: block;
        width: 100%;
        font-family: 'Helvetica Neue LT W05_45 Light', Helvetica, sans-serif;
        font-weight: 300;
        font-size: 12px;
        color: #da3931;
    }

input[type="submit"][disabled],
button[type="submit"][disabled] {
    cursor: not-allowed;
}

#payment-form .required label:after {
    content: '*';
}

#payment-form .StripeElement {
    font-size: 12px;
    line-height: 14px;
    padding: 12px 8px;
    border-radius: 8px;
    border: 1px solid #333333;
    background: transparent;
}

#payment-form #card-errors {
    color: #da3931;
    font-family: 'Helvetica Neue LT W05_45 Light', Helvetica, sans-serif;
    font-weight: 300;
    font-family: 'Helvetica Neue LT W05_65 Medium', Helvetica, sans-serif;
    font-weight: 600;
}

#payment-form .form-row {
    -ms-flex-pack: distribute;
    justify-content: space-around;
}

#payment-form label {
    font-family: 'Helvetica Neue LT W05_45 Light', Helvetica, sans-serif;
    font-weight: 300;
    font-family: 'Helvetica Neue LT W05_65 Medium', Helvetica, sans-serif;
    font-weight: 600;
}

#payment-form .form-group {
    width: calc(50% - 15px);
}

    #payment-form .form-group input {
        width: 100%;
    }

#payment-form .formsubmit {
    background: #545454;
    display: block;
    text-decoration: none;
    color: #ffffff;
    padding: 15px 30px;
    line-height: 1em;
    min-width: 160px;
    border-radius: 8px;
    font-family: 'Helvetica Neue LT W05_45 Light', Helvetica, sans-serif;
    font-weight: 300;
    font-family: 'Helvetica Neue LT W05_75 Bold', Helvetica, sans-serif;
    font-weight: 700;
    transition: background 0.35s, opacity 0.5s;
    width: 100%;
    outline: 0;
    margin-top: 25px;
}

    #payment-form .formsubmit:hover {
        color: #ffffff;
        background: #333333;
        text-decoration: none;
    }

@media screen and (max-width: 768px) {
    #payment-form .form-group {
        width: 100%;
    }

    #payment-form .form-row {
        margin-left: 0;
        margin-right: 0;
    }
}

/*
 *  remove blue background on ie10/ie11 when selected
 *
 */
select::-ms-value {
    background: none;
    color: inherit;
}

select::-ms-expand {
    display: none;
}

@media all and (-ms-high-contrast: none) and (min-width: 768px) {
    .product-info,
    .product-info-header {
        position: relative;
        left: 70px;
    }
}

.sc-edit-mode .header {
    position: relative;
}

.sc-edit-mode #component-country-selector div.scLooseFrameZone {
    overflow-x: hidden;
}

.sc-edit-mode .scEmptyPlaceholder {
    width: 100%;
}

.sc-edit-mode .site-content {
    margin-top: 0;
    padding-top: 0;
}

.sc-edit-mode .sticky-nav .sticky-nav-right .read-more {
    width: 300px;
}

.sc-edit-mode .secondary-nav,
.sc-edit-mode .sticky-nav {
    position: static;
    margin-bottom: 50px;
}

.sc-edit-mode .padding20 {
    padding-top: 20px;
    padding-bottom: 20px;
}

.sc-edit-mode .category-bar {
    position: static;
}

.sc-edit-mode .site-content {
    margin-top: 0;
}

@media screen and (min-width: 992px) {
    .sc-edit-mode .site-content {
        margin-top: 0;
    }
}

@media screen and (min-width: 1200px) {
    .sc-edit-mode .site-content {
        margin-top: 0;
    }
}

.sc-edit-mode .product-feature .product__card__outer {
    width: 730px;
    margin: 0 auto;
    bottom: 0;
    right: 0;
}

/*
  *  Components
  *
  */
.accordion {
    border-top: 1px solid rgba(186, 186, 186, 0.5);
    border-bottom: 1px solid rgba(186, 186, 186, 0.5);
    margin-bottom: -1px;
}

.accordion-container {
    margin-bottom: 32px;
}

.accordion-toggle {
    position: relative;
    display: block;
    padding: 16px 32px 16px 16px;
    cursor: pointer;
    font-family: Georgia, serif;
    font-size: 25.68px;
    line-height: 30px;
}

    .accordion-toggle:after {
        content: "";
        position: absolute;
        width: 14px;
        height: 7px;
        top: 50%;
        right: 10px;
        margin-top: -12px;
        transition: transform 0.35s ease-in-out;
        font-family: "font-icons";
        color: #333;
        font-size: 7px;
    }

.accordion-content {
    display: none;
    padding: 0px 16px 24px;
    font-family: 'Helvetica Neue LT W05_45 Light', Helvetica, sans-serif;
    font-weight: 300;
    font-size: 12px;
    line-height: 20px;
    margin-bottom: 32px;
    margin-bottom: 0;
}

@media screen and (min-width: 1200px) {
    .accordion-content {
        font-size: 14px;
        line-height: 24px;
    }
}

.accordion-content p {
    font-family: 'Helvetica Neue LT W05_45 Light', Helvetica, sans-serif;
    font-weight: 300;
    font-size: 12px;
    line-height: 20px;
    margin-bottom: 32px;
}

@media screen and (min-width: 1200px) {
    .accordion-content p {
        font-size: 14px;
        line-height: 24px;
    }
}

.accordion-content p:last-child {
    margin-bottom: 0;
}

.accordion.active {
    background: #fff;
}

    .accordion.active .accordion-toggle:after {
        -ms-transform: rotate(180deg);
        transform: rotate(180deg);
        transition: transform 0.35s ease-in-out;
        margin-top: 8px;
        right: 13px;
    }

.pro-resources .accordion .accordion-toggle {
    padding: 24px 32px 24px 16px;
}

.pro-resources .accordion .accordion-content {
    padding: 8px 16px 40px;
}

.header {
    position: fixed;
    top: 0;
    left: 0;
    right: 0;
    background: #fff;
    z-index: 200;
}

.header-branding {
    display: -ms-flexbox;
    display: flex;
    -ms-flex-pack: justify;
    justify-content: space-between;
    -ms-flex-align: center;
    align-items: center;
    padding: 12px 16px;
    box-shadow: 0 0 30px 0 rgba(151, 151, 151, 0.2);
}

.header .icon-cart {
    font-size: 22px;
    color: #333333;
    top: 3px;
    position: relative;
}

@media screen and (min-width: 768px) {
    .header {
        height: 60px;
    }

    .header-branding {
        padding-left: 40px;
        padding-right: 40px;
    }
}

@media screen and (min-width: 1200px) {
    .header {
        height: 84px;
        box-shadow: 0 0 30px 0 rgba(151, 151, 151, 0.2);
    }

    .header-container {
        width: 100%;
        padding-right: 16px;
        padding-left: 16px;
        margin-right: auto;
        margin-left: auto;
        display: -ms-flexbox;
        display: flex;
        -ms-flex-direction: row;
        flex-direction: row;
    }
}

@media screen and (min-width: 1200px) and (min-width: 576px) {
    .header-container {
        max-width: 540px;
    }
}

@media screen and (min-width: 1200px) and (min-width: 768px) {
    .header-container {
        max-width: 720px;
    }
}

@media screen and (min-width: 1200px) and (min-width: 992px) {
    .header-container {
        max-width: 960px;
    }
}

@media screen and (min-width: 1200px) and (min-width: 1200px) {
    .header-container {
        max-width: 1140px;
    }
}

@media screen and (min-width: 1200px) {
    .header-branding {
        box-shadow: none;
        padding: 0;
        margin-right: 40px;
    }
}

.header-utility-nav {
    -ms-flex-align: center;
    align-items: center;
}

.header-utility-nav-toggles {
    display: none;
}

    .header-utility-nav-toggles a:hover {
        text-decoration: none;
    }

    .header-utility-nav-toggles .icon-search {
        font-size: 22px;
        color: #333333;
        top: 4px;
        position: relative;
    }

    .header-utility-nav-toggles .icon-cart {
        font-size: 22px;
        color: #333333;
        top: 3px;
        position: relative;
    }

    .header-utility-nav-toggles .icon-close {
        font-size: 18px;
        color: #333333;
        top: 3px;
        position: relative;
    }

.navigation-utility-toggles a:hover {
    text-decoration: none;
}

.navigation-utility-toggles .icon-search {
    font-size: 22px;
    color: #333333;
    top: 4px;
    position: relative;
}

.navigation-utility-toggles .icon-close {
    font-size: 18px;
    color: #333333;
    top: 6px;
    position: relative;
}

@media screen and (min-width: 1200px) {
    .header-utility-nav {
        display: -ms-flexbox;
        display: flex;
    }

    .header-utility-nav-toggles {
        display: -ms-flexbox;
        display: flex;
        -ms-flex-align: center;
        align-items: center;
        height: 100%;
        padding-right: 8px;
        border-right: 1px solid rgba(186, 186, 186, 0.5);
    }

        .header-utility-nav-toggles > a {
            display: block;
            margin: 0 12px;
        }
}

.country-selector {
    visibility: hidden;
    position: fixed;
    left: -15px;
    right: -15px;
    bottom: 0;
    height: 0;
    margin: 0 16px;
    background: #fff;
    border-top: 1px solid #d8d8d8;
    transition: height 0.5s ease-in-out, transform 0.35s, visibility 0.35s;
    z-index: 11;
}

    .country-selector a {
        text-decoration: none;
    }

@media screen and (min-width: 768px) and (max-width: 1200px) {
    .country-selector-container {
        position: fixed;
        bottom: 0;
        left: 50%;
        -ms-transform: translateX(-50%);
        transform: translateX(-50%);
        max-width: 330px;
        min-height: 70px;
        margin: auto;
        width: 100%;
        overflow: hidden;
        height: 0;
        transition: height 0.5s;
        z-index: 11;
    }

        .country-selector-container.active {
            height: 100%;
            transition: height 0.5s;
        }
}

.country-selector.active {
    height: 70px;
}

.country-selector.open {
    height: calc(100% - 66px);
    transition: height 0.5s ease-in-out;
}

.country-selector-toggle, .country-selector-static {
    position: relative;
    display: block;
    padding: 24px 24px 24px 16px;
    color: #333;
    font-family: 'Helvetica Neue LT W05_45 Light', Helvetica, sans-serif;
    font-weight: 300;
    font-family: 'Helvetica Neue LT W05_75 Bold', Helvetica, sans-serif;
    font-weight: 700;
    font-weight: 500;
    transition: color 0.35s;
}

    .country-selector-toggle:hover, .country-selector-static:hover {
        color: #545454;
        text-decoration: none;
        transition: color 0.35s;
    }

    .country-selector-toggle:after, .country-selector-static:after {
        content: "";
        display: block;
        width: 6px;
        height: 100%;
        position: absolute;
        top: -50%;
        right: 16px;
        -ms-transform: rotate(180deg);
        transform: rotate(180deg);
        transition: transform 0.35s ease-in-out;
        font-family: "font-icons";
        color: #9f9f9f;
        font-size: 4px;
    }

    .country-selector-toggle.active:after, .country-selector-static.active:after {
        -ms-transform: rotate(0);
        transform: rotate(0);
        top: 50%;
    }

    .country-selector-static:before, .country-selector-static:after {
        display: none;
    }

.country-selector-list {
    margin: 0 16px;
    padding: 0;
    list-style: none;
    background: #fff;
    border-top: 4px solid #ff0000;
    height: calc(100% - 75px);
    overflow: auto;
}

    .country-selector-list > li:not(:last-child) a {
        border-bottom: 1px solid rgba(186, 186, 186, 0.5);
    }

    .country-selector-list a {
        display: block;
        padding: 16px 14px;
        color: #333;
        font-size: 12px;
        font-family: 'Helvetica Neue LT W05_45 Light', Helvetica, sans-serif;
        font-weight: 300;
        font-family: 'Helvetica Neue LT W05_75 Bold', Helvetica, sans-serif;
        font-weight: 700;
    }

        .country-selector-list a small {
            color: #545454;
            font-size: 10px;
            font-family: 'Helvetica Neue LT W05_45 Light', Helvetica, sans-serif;
            font-weight: 300;
            font-family: 'Helvetica Neue LT W05_75 Bold', Helvetica, sans-serif;
            font-weight: 700;
        }

@media screen and (min-width: 1200px) {
    .country-selector {
        visibility: visible;
        display: block;
        position: relative;
        left: 0;
        margin: 0;
        border: none;
        height: 100% !important;
    }

        .country-selector.active {
            height: auto;
        }

    .country-selector-toggle, .country-selector-static {
        display: block;
        height: 100%;
        padding: 0 16px;
        line-height: 84px;
    }

        .country-selector-toggle span, .country-selector-static span {
            display: none;
        }

        .country-selector-toggle.active span, .country-selector-static.active span {
            display: inline-block;
        }

        .country-selector-toggle:before, .country-selector-static:before {
            content: '';
            position: absolute;
            bottom: 0;
            left: 0;
            right: 0;
            height: 0;
            background: #ff0000;
            -ms-transform-origin: 50% 100%;
            transform-origin: 50% 100%;
            transition: height 0.2s ease-in-out;
        }

        .country-selector-toggle:after, .country-selector-static:after {
            right: 0;
            -ms-transform: rotate(0);
            transform: rotate(0);
            top: 0;
        }

        .country-selector-toggle.active:before, .country-selector-static.active:before {
            height: 4px;
            transition: height 0.2s ease-in-out;
        }

        .country-selector-toggle.active:after, .country-selector-static.active:after {
            -ms-transform: rotate(180deg);
            transform: rotate(180deg);
            top: 0;
        }

        .country-selector-static span {
            display: inline;
        }

    .country-selector-list {
        display: none;
        position: absolute;
        top: 100%;
        right: 0;
        width: 100%;
        min-width: 185px;
        margin: 0;
        border: none;
        box-shadow: 0 10px 30px 0 rgba(151, 151, 151, 0.1), inset 0 10px 30px -10px rgba(151, 151, 151, 0.2);
        z-index: 0;
        height: auto;
        max-height: 364px;
        overflow: auto;
    }

        .country-selector-list a {
            transition: color 0.35s;
        }

            .country-selector-list a:hover {
                color: #545454;
                text-decoration: none;
                transition: color 0.35s;
            }
}

#GlobalSearchBox .magic-box-suggestions {
    top: 48px;
}

#SearchBox {
    position: relative;
}

    #SearchBox .magic-box-input input {
        padding-left: 40px;
    }

    #SearchBox .CoveoSearchButton {
        position: absolute;
        left: 0;
        top: 0;
    }

.navigation-search .coveo-search-section {
    border: 0 none !important;
}

.navigation-search button.navigation-search-toggle {
    opacity: 0;
}

.navigation {
    overflow-x: hidden;
    background: #fff;
    box-shadow: 0 10px 30px 0 rgba(151, 151, 151, 0.1), inset 0 10px 30px -10px rgba(151, 151, 151, 0.2);
}

.navigation-logo {
    width: 50px;
}

.navigation li.current-page a {
    text-decoration: underline;
}

.navigation-content {
    display: none;
    height: 100vh;
}

.navigation-menu-container {
    position: relative;
    transition: transform 0.35s ease-in-out;
}

.navigation-cart-toggle {
    position: relative;
}

    .navigation-cart-toggle .cart-badge {
        position: absolute;
        top: -7px;
        left: 6px;
        min-width: 14px;
        min-height: 14px;
        border: 2px solid #fff;
        border-radius: 100px;
        background: #2170CA;
        padding: 0 4px;
        font-size: 8px;
        font-family: 'Helvetica Neue LT W05_45 Light', Helvetica, sans-serif;
        font-weight: 300;
        font-family: 'Helvetica Neue LT W05_75 Bold', Helvetica, sans-serif;
        font-weight: 700;
        color: #fff;
        -ms-transform: scale(0);
        transform: scale(0);
        transition: transform 0.3s cubic-bezier(0.68, -0.55, 0.265, 1.55);
    }

    .navigation-cart-toggle.active .cart-badge {
        -ms-transform: scale(1);
        transform: scale(1);
        transition: transform 0.3s cubic-bezier(0.68, -0.55, 0.265, 1.55);
    }

.navigation-toggle {
    display: -ms-flexbox;
    display: flex;
    -ms-flex-align: center;
    align-items: center;
    text-decoration: none;
    line-height: 1;
}

    .navigation-toggle:hover {
        text-decoration: none;
    }

.navigation-toggle-icon {
    margin-right: 16px;
}

.navigation-toggle-text {
    display: none;
    font-size: 10px;
    font-family: 'Helvetica Neue LT W05_45 Light', Helvetica, sans-serif;
    font-weight: 300;
    font-family: 'Helvetica Neue LT W05_75 Bold', Helvetica, sans-serif;
    font-weight: 700;
    color: #000;
}

.navigation-toggle .bar {
    position: relative;
    display: block;
    height: 2px;
    width: 22px;
    margin-bottom: 4px;
    border-radius: 100px;
    background: #000;
    -ms-transform-origin: 50% 50%;
    transform-origin: 50% 50%;
    transition: transform 0.3s;
}

    .navigation-toggle .bar:nth-child(1) {
        top: 0;
        transition: top 0.3s 0.3s, transform 0.3s;
        transition-timing-function: cubic-bezier(0.4, 0, 0.2, 1);
    }

    .navigation-toggle .bar:nth-child(2) {
        width: 18px;
        -ms-transform-origin: 0 50%;
        transform-origin: 0 50%;
        transition-delay: 0.25s;
        transition-timing-function: cubic-bezier(0.4, 0, 0.2, 1);
    }

    .navigation-toggle .bar:nth-child(3) {
        bottom: 0;
        transition: bottom 0.3s 0.3s, transform 0.35s;
        transition-timing-function: cubic-bezier(0.4, 0, 0.2, 1);
    }

.navigation-toggle.active .bar {
    transition: transform 0.3s;
}

    .navigation-toggle.active .bar:nth-child(1) {
        top: 6px;
        -ms-transform: rotate(45deg);
        transform: rotate(45deg);
        transition: top 0.3s, transform 0.3s 0.3s;
        transition-timing-function: cubic-bezier(0.4, 0, 0.2, 1);
    }

    .navigation-toggle.active .bar:nth-child(2) {
        -ms-transform: scaleX(0);
        transform: scaleX(0);
    }

    .navigation-toggle.active .bar:nth-child(3) {
        bottom: 6px;
        -ms-transform: rotate(-45deg);
        transform: rotate(-45deg);
        transition: bottom 0.3s, transform 0.3s 0.3s;
        transition-timing-function: cubic-bezier(0.4, 0, 0.2, 1);
    }

.navigation-search {
    display: none;
    padding: 16px 15px 16px;
}

    .navigation-search .icon-search {
        font-size: 17px;
        color: #333333;
        top: 3px;
        position: relative;
    }

    .navigation-search .coveo-search-section {
        max-width: 600px;
        width: 100%;
        margin: 0 auto;
        border: 1px solid #bababa;
        border-radius: 22px;
    }

        .navigation-search .coveo-search-section .CoveoSearchInterface {
            border-radius: 22px;
            background: transparent;
        }

            .navigation-search .coveo-search-section .CoveoSearchInterface .CoveoSearchbox {
                margin-right: 0;
            }

        .navigation-search .coveo-search-section .CoveoSearchbox .CoveoSearchButton {
            float: left;
            height: 47px;
            width: 40px;
            border: 0 none;
        }

            .navigation-search .coveo-search-section .CoveoSearchbox .CoveoSearchButton svg {
                color: #333;
            }

            .navigation-search .coveo-search-section .CoveoSearchbox .CoveoSearchButton:hover .coveo-magnifier-circle-svg {
                fill: #333;
            }

        .navigation-search .coveo-search-section .CoveoSearchbox .magic-box-clear {
            width: 25px;
            height: 25px;
            background: transparent;
            line-height: 15px;
            margin: 0;
            top: 11px;
            right: 11px;
            background: #333;
            padding-top: 3px;
            border-radius: 50%;
            padding-left: 0px;
        }

            .navigation-search .coveo-search-section .CoveoSearchbox .magic-box-clear svg {
                width: 11px;
                height: 11px;
                color: #f9f7f6;
            }

        .navigation-search .coveo-search-section .CoveoSearchbox .magic-box {
            border: 0 none;
        }

            .navigation-search .coveo-search-section .CoveoSearchbox .magic-box:focus {
                outline: 0 none;
                box-shadow: none;
            }

            .navigation-search .coveo-search-section .CoveoSearchbox .magic-box .magic-box-input {
                height: 47px;
                border-radius: 22px;
                background: transparent;
                float: right;
                width: 87%;
            }

                .navigation-search .coveo-search-section .CoveoSearchbox .magic-box .magic-box-input input {
                    width: 100%;
                    padding: 16px 16px 16px 0;
                    text-indent: 0;
                    font-size: 1.2rem;
                    line-height: 1;
                }

.navigation-content .navigation-search {
    display: block;
}

.navigation-search-toggle-hide-search {
    display: none;
}

.navigation-search-toggle.active .navigation-search-toggle-search {
    display: none;
}

.navigation-search-toggle.active .navigation-search-toggle-hide-search {
    display: block;
}

.navigation-search-form {
    position: relative;
}

    .navigation-search-form > input[type="text"] {
        width: 100%;
        padding: 16px 16px 16px 44px;
        border: 0 none;
        border-radius: 22px;
        font-size: 1.2rem;
        line-height: 1;
    }

    .navigation-search-form > button {
        position: absolute;
        left: 0;
        top: 50%;
        -ms-transform: translateY(-50%);
        transform: translateY(-50%);
        border: none;
        padding: 12px;
        background: transparent;
    }

.navigation-utility-toggles {
    display: -ms-flexbox;
    display: flex;
}

    .navigation-utility-toggles > a {
        display: block;
    }

        .navigation-utility-toggles > a:not(:last-child) {
            margin-right: 24px;
        }

.navigation-menu, .navigation-submenu {
    margin: 0;
    padding: 0;
    list-style: none;
}

    .navigation-menu-item,
    .navigation-menu .navigation-back, .navigation-submenu-item,
    .navigation-submenu .navigation-back {
        margin: 0 15px;
        font-family: 'Helvetica Neue LT W05_45 Light', Helvetica, sans-serif;
        font-weight: 300;
        font-family: 'Helvetica Neue LT W05_75 Bold', Helvetica, sans-serif;
        font-weight: 700;
        cursor: pointer;
    }

        .navigation-menu-item.has-child > a,
        .navigation-menu .navigation-back.has-child > a, .navigation-submenu-item.has-child > a,
        .navigation-submenu .navigation-back.has-child > a {
            position: relative;
        }

            .navigation-menu-item.has-child > a:before,
            .navigation-menu .navigation-back.has-child > a:before, .navigation-submenu-item.has-child > a:before,
            .navigation-submenu .navigation-back.has-child > a:before {
                content: "";
                width: 3px;
                height: 10px;
                position: absolute;
                top: 50%;
                right: 20px;
                font-family: "font-icons";
                color: #333;
                font-size: 8px;
                -ms-transform: rotate(270deg);
                transform: rotate(270deg);
            }

        .navigation-menu-item > a,
        .navigation-menu .navigation-back > a, .navigation-submenu-item > a,
        .navigation-submenu .navigation-back > a {
            display: block;
            padding: 16px 8px;
            border-bottom: 1px solid #ddd;
            color: #333;
            text-decoration: none;
        }

        .navigation-menu .navigation-back > a, .navigation-submenu .navigation-back > a {
            display: block;
            padding: 24px 16px 24px 48px;
            border-bottom: none;
            position: relative;
        }

            .navigation-menu .navigation-back > a:before, .navigation-submenu .navigation-back > a:before {
                content: "";
                width: 22px;
                height: 20px;
                position: absolute;
                top: 26px;
                left: 15px;
                margin: 0;
                font-family: "font-icons";
                color: #333;
                font-size: 13px;
            }

.navigation-submenu {
    position: absolute;
    top: 0;
    left: 100%;
    width: 100%;
    visibility: hidden;
    transition: visibility 0s;
    transition-delay: 0.35s;
}

    .navigation-submenu.active {
        visibility: visible;
        transition: visibility 0s;
        transition-delay: 0s;
    }

@media screen and (min-width: 576px) {
    .navigation-search .coveo-search-section .CoveoSearchbox .magic-box .magic-box-input {
        width: 92%;
    }
}

@media screen and (min-width: 768px) {
    .navigation {
        width: 330px;
        margin: auto;
        box-shadow: none;
        margin-top: 30px;
    }

        .navigation:before {
            content: '';
            position: fixed;
            top: 0;
            bottom: 0;
            left: 0;
            right: 0;
            background: #fff;
            z-index: -1;
            -ms-transform: scaleY(0);
            transform: scaleY(0);
            -ms-transform-origin: 0 0;
            transform-origin: 0 0;
            transition: transform 0.35s ease-in;
        }

    .menu-open .navigation:before {
        -ms-transform: scaleY(1);
        transform: scaleY(1);
        transition: transform 0.35s ease-out;
    }

    .navigation-cart-toggle .cart-badge {
        top: 3px;
    }

    .navigation-logo {
        width: 68px;
    }

    .navigation-toggle-text {
        display: block;
    }

    .navigation-search {
        display: none;
        position: fixed;
        top: 60px;
        left: 0;
        right: 0;
        padding: 16px 0 16px;
        background: #fff;
        box-shadow: 0 10px 30px 0 rgba(151, 151, 151, 0.1), inset 0 10px 30px -10px rgba(151, 151, 151, 0.2);
    }

        .navigation-search .coveo-search-section {
            border: none;
        }

    .navigation-search-toggle-hide-search {
        display: none;
    }

    .navigation-search-toggle.active .navigation-search-toggle-search {
        display: none;
    }

    .navigation-search-toggle.active .navigation-search-toggle-hide-search {
        display: block;
    }

    .navigation-search-form {
        width: 600px;
        margin: auto;
    }

        .navigation-search-form > input[type="text"] {
            border: none;
        }

    .navigation-content .navigation-search {
        display: none;
    }

    .navigation-utility-toggles {
        display: -ms-flexbox;
        display: flex;
    }

        .navigation-utility-toggles > a {
            display: block;
        }

            .navigation-utility-toggles > a:not(:last-child) {
                margin-right: 24px;
            }

    .navigation-search .coveo-search-section .CoveoSearchbox .magic-box .magic-box-input {
        width: 93%;
    }
}

@media screen and (min-width: 992px) {
    .navigation-logo {
        width: 72px;
    }
}

@media screen and (min-width: 1200px) {
    .navigation {
        background: none;
        box-shadow: none;
        overflow: visible;
        height: auto;
        -ms-flex-positive: 1;
        flex-grow: 1;
        width: auto;
        margin-top: 0;
    }

        .navigation:before {
            content: none;
        }

        .navigation li.current-page a {
            text-decoration: none;
        }

    .navigation-back {
        display: none;
    }

    .navigation-container {
        display: -ms-flexbox;
        display: flex;
        width: 100%;
        position: relative;
    }

    .navigation-content {
        display: block !important;
        height: auto !important;
    }

    .navigation-logo {
        width: 88px;
    }

    .navigation-toggle, .navigation-cart-toggle {
        display: none;
    }

    .navigation-utility-toggles > a {
        display: none;
    }

    .navigation-menu-container {
        display: -ms-flexbox !important;
        display: flex !important;
        -ms-transform: none !important;
        transform: none !important;
        -ms-flex-pack: justify;
        justify-content: space-between;
        position: relative;
        top: auto;
        bottom: auto;
        left: auto;
        right: auto;
        width: 100%;
    }

    .navigation-menu-item, .navigation-submenu-item {
        margin: 0;
    }

        .navigation-menu-item > a, .navigation-submenu-item > a {
            border: none;
            transition: color 0.35s;
        }

            .navigation-menu-item > a:hover, .navigation-submenu-item > a:hover {
                color: #545454;
                transition: color 0.35s;
            }

        .navigation-menu-item.has-child, .navigation-submenu-item.has-child {
            background: none;
        }

            .navigation-menu-item.has-child > a:before, .navigation-submenu-item.has-child > a:before {
                content: '';
            }

    .navigation-menu {
        display: -ms-flexbox;
        display: flex;
        -ms-flex-align: start;
        align-items: flex-start;
    }

    .navigation-menu-item {
        position: relative;
        background: none;
    }

        .navigation-menu-item > a {
            margin: 0 12px;
            padding: 32px 0 38px;
            line-height: 1;
        }

        .navigation-menu-item.current-page:after {
            -ms-transform: translateX(-50%) scaleY(1) !important;
            transform: translateX(-50%) scaleY(1) !important;
        }

        .navigation-menu-item.has-child > a:before {
            content: '';
        }

        .navigation-menu-item.has-child:before {
            content: "";
            position: absolute;
            bottom: 19px;
            left: 50%;
            margin-left: -3px;
            width: 6px;
            height: 3px;
            transition: transform 0.2s ease-in-out;
            font-family: "font-icons";
            color: #9f9f9f;
            font-size: 4px;
        }

        .navigation-menu-item.has-child:after {
            content: '';
            position: absolute;
            bottom: 0;
            left: 50%;
            height: 4px;
            background: red;
            width: calc(100% - 16px);
            -ms-transform-origin: 100% 100%;
            transform-origin: 100% 100%;
            -ms-transform: translateX(-50%) scaleY(0);
            transform: translateX(-50%) scaleY(0);
            transition: transform 0.25s ease-in-out;
        }

        .navigation-menu-item.has-child.active {
            z-index: 200;
        }

            .navigation-menu-item.has-child.active:before {
                -ms-transform: rotate(180deg);
                transform: rotate(180deg);
                transition: transform 0.5s;
            }

            .navigation-menu-item.has-child.active:after {
                -ms-transform: translateX(-50%) scaleY(1);
                transform: translateX(-50%) scaleY(1);
                transition: transform 0.2s ease-in-out;
            }

    .navigation-submenu {
        display: none;
        top: 100%;
        left: -30px;
        width: 225px;
        background: #fefefe;
        box-shadow: 0 10px 30px 0 rgba(151, 151, 151, 0.1), inset 0 10px 30px -10px rgba(151, 151, 151, 0.2);
    }

    .navigation-submenu-item:nth-child(2) {
        margin-top: 32px;
    }

    .navigation-submenu-item:last-child {
        margin-bottom: 32px;
    }

    .navigation-submenu-item > a {
        padding: 9px 40px;
        margin: 0;
    }

    .navigation-search {
        display: none;
        position: fixed;
        top: 84px;
        left: 0;
        right: 0;
        padding: 24px 0;
        background: #fff;
        box-shadow: 0 10px 30px 0 rgba(151, 151, 151, 0.1), inset 0 10px 30px -10px rgba(151, 151, 151, 0.2);
    }

        .navigation-search .coveo-search-section {
            border: none;
        }

    .navigation-search-toggle-hide-search {
        display: none;
    }

    .navigation-search-toggle.active .navigation-search-toggle-search {
        display: none;
    }

    .navigation-search-toggle.active .navigation-search-toggle-hide-search {
        display: block;
    }

    .navigation-search-form {
        width: 600px;
        margin: auto;
    }

        .navigation-search-form > input[type="text"] {
            border: none;
        }

    .navigation-content .navigation-search {
        display: none;
    }
}

.secondary-nav {
    position: fixed;
    top: 50px;
    width: 100%;
    overflow: visible;
    background: #fff;
    z-index: 100;
    padding: 16px 0;
    box-shadow: 0 0 30px 0 rgba(151, 151, 151, 0.2);
}

    .secondary-nav .container, .secondary-nav .iframe-container {
        position: relative;
    }

    .secondary-nav .product-ordersample {
        display: none;
        max-width: 400px;
        overflow: hidden;
        min-height: 0;
        top: 80px;
        right: 0;
        border-radius: 5px;
        width: 100%;
        transition: max-height 0.8s;
    }

        .secondary-nav .product-ordersample.active {
            min-height: 500px;
        }

        .secondary-nav .product-ordersample .order-sample-note p {
            margin-bottom: 10px;
        }

        .secondary-nav .product-ordersample .product-range-card-actions {
            -ms-flex-pack: end;
            justify-content: flex-end;
        }

        .secondary-nav .product-ordersample .product-range-card-cta {
            display: none;
        }

.secondary-nav-title {
    display: block;
    margin: 0 0 8px;
    text-align: center;
}

.secondary-nav-link {
    display: none;
    text-decoration: none;
    line-height: 1;
    color: #333;
}

    .secondary-nav-link.active {
        font-family: 'Helvetica Neue LT W05_45 Light', Helvetica, sans-serif;
        font-weight: 300;
        font-family: 'Helvetica Neue LT W05_75 Bold', Helvetica, sans-serif;
        font-weight: 700;
        text-decoration: underline;
    }

    .secondary-nav-link:hover {
        color: #333333;
    }

.secondary-nav-left {
    padding: 0;
}

.secondary-nav-right {
    display: -ms-flexbox;
    display: flex;
    -ms-flex-pack: justify;
    justify-content: space-between;
    height: 34px;
}

    .secondary-nav-right > * {
        display: -ms-flexbox;
        display: flex;
        -ms-flex-align: center;
        align-items: center;
        padding-top: 0;
        padding-bottom: 0;
        min-width: 50%;
    }

    .secondary-nav-right select {
        min-width: 0;
        width: 50%;
    }

    .secondary-nav-right .btn, .secondary-nav-right .cart-total-cta, .secondary-nav-right .checkout form [type="submit"], .checkout form .secondary-nav-right [type="submit"], .secondary-nav-right .cookie-policy-cta {
        -ms-flex-pack: center;
        justify-content: center;
    }

.secondary-nav + * {
    margin-top: 80px;
}

.secondary-nav + .hero {
    margin-top: 64px;
}

@media screen and (min-width: 768px) {
    .secondary-nav {
        top: 60px;
    }

        .secondary-nav + * {
            margin-top: 100px;
        }

        .secondary-nav + .hero {
            margin-top: 64px;
        }
}

@media screen and (min-width: 1200px) {
    .secondary-nav {
        top: 84px;
    }

        .secondary-nav .product-ordersample {
            top: 51px;
        }

        .secondary-nav > .container, .secondary-nav > .iframe-container {
            display: -ms-flexbox;
            display: flex;
            -ms-flex-align: center;
            align-items: center;
            -ms-flex-pack: justify;
            justify-content: space-between;
        }

    .secondary-nav-title {
        display: inline-block;
        margin-bottom: 0;
    }

    .secondary-nav-link {
        display: inline-block;
    }

    .secondary-nav-left {
        display: -ms-flexbox;
        display: flex;
        -ms-flex-align: center;
        align-items: center;
        padding: 0;
    }

        .secondary-nav-left > * {
            margin-right: 24px;
        }

    .secondary-nav-right select {
        display: none;
    }

    .secondary-nav-right .btn, .secondary-nav-right .cart-total-cta, .secondary-nav-right .checkout form [type="submit"], .checkout form .secondary-nav-right [type="submit"], .secondary-nav-right .cookie-policy-cta {
        min-width: 0;
    }

    .secondary-nav + * {
        margin-top: 80px;
    }

    .secondary-nav + .hero {
        margin-top: 15px;
    }
}

@media only screen and (min-device-width: 375px) and (max-device-width: 667px) and (orientation: portrait) {
    .secondary-nav {
        padding: 10px 0;
    }

        .secondary-nav .product-ordersample {
            top: 73px;
        }

            .secondary-nav .product-ordersample.active {
                min-height: 427px;
            }

            .secondary-nav .product-ordersample .decor-order-sample .decor-order-sample-header {
                padding: 6px 16px 13px;
            }

            .secondary-nav .product-ordersample .decor-order-sample .decor-order-sample-content {
                padding: 5px 16px;
            }

            .secondary-nav .product-ordersample .decor-order-sample .decor-order-sample-form select {
                margin-bottom: 5px;
                padding: 8px 20px 8px 8px;
            }
}

.featured-article-card {
    display: -ms-flexbox;
    display: flex;
    -ms-flex-direction: column;
    flex-direction: column;
    margin-bottom: 32px;
}

.featured-article-card-image {
    -ms-flex-order: 0;
    order: 0;
    position: relative;
    margin: 0 -8px;
}

    .featured-article-card-image img {
        display: block;
        margin: auto;
    }

.featured-article-card-video {
    position: relative;
}

.featured-article-card-content {
    -ms-flex-order: 1;
    order: 1;
    position: relative;
    top: -80px;
    width: 100%;
    background: #fff;
    margin-bottom: -80px;
    padding: 32px 24px 48px;
    box-shadow: 0 0 30px 0 rgba(151, 151, 151, 0.2);
    z-index: 1;
}

.featured-article-card-category {
    font-size: 10px;
    text-transform: uppercase;
    font-family: 'Helvetica Neue LT W05_45 Light', Helvetica, sans-serif;
    font-weight: 300;
    font-family: 'Helvetica Neue LT W05_75 Bold', Helvetica, sans-serif;
    font-weight: 700;
    color: #595959;
    letter-spacing: 0.03125rem;
    display: inline-block;
    margin-bottom: 16px;
    line-height: 1;
    padding-bottom: 8px;
    border-bottom: 1px solid #d8d8d8;
}

.featured-article-card-title {
    font-size: 32px;
    color: #333;
    line-height: 40px;
    margin-bottom: 16px;
    font-family: Georgia, serif;
}

.featured-article-card-copy {
    font-size: 18px;
    margin-bottom: 16px;
    line-height: 32px;
    color: #333;
}

.featured-article-card .video-play {
    cursor: pointer;
    position: absolute;
    top: 20%;
    left: 50%;
    -ms-transform: translate(-50%, 0%);
    transform: translate(-50%, 0%);
    margin: 0;
    padding: 0;
    outline: 0 none;
    border-radius: 50%;
    height: 20vw;
    width: 20vw;
    background: transparent;
}

    .featured-article-card .video-play:after {
        background: url("../images/play.svg") no-repeat;
        position: absolute;
        top: 50%;
        left: 50%;
        -ms-transform: translate(-50%, -50%);
        transform: translate(-50%, -50%);
        height: 20vw;
        width: 20vw;
        content: '';
    }

@media screen and (min-width: 576px) {
    .featured-article-card .video-play {
        top: 50%;
        -ms-transform: translate(-50%, -50%);
        transform: translate(-50%, -50%);
        width: 100px;
        height: 100px;
    }

        .featured-article-card .video-play:after {
            width: 100px;
            height: 100px;
        }
}

@media screen and (min-width: 768px) {
    .featured-article-card .video-play {
        width: 200px;
        height: 200px;
    }

        .featured-article-card .video-play:after {
            width: 200px;
            height: 200px;
        }

    .featured-article-card-content {
        top: 0;
        margin: -80px 0 32px;
        float: right;
    }
}

@media screen and (min-width: 992px) {
    .featured-article-card {
        display: -ms-flexbox;
        display: flex;
        -ms-flex-direction: row;
        flex-direction: row;
        -ms-flex-align: center;
        align-items: center;
    }

    .featured-article-card-image {
        display: -ms-flexbox;
        display: flex;
        -ms-flex-positive: 1;
        flex-grow: 1;
        -ms-flex-negative: 0;
        flex-shrink: 0;
        margin: 0;
        max-width: 100%;
    }

        .featured-article-card-image img {
            margin: 0;
        }

    .featured-article-card-content {
        max-width: 540px;
        margin: 80px 0 48px;
        margin: 0;
        margin-left: -540px;
        -ms-flex-negative: 0;
        flex-shrink: 0;
        padding: 48px 48px 64px;
    }

    .featured-article-card.image-right .featured-article-card-image {
        -ms-flex-order: 1;
        order: 1;
        -ms-flex-pack: end;
        justify-content: flex-end;
    }

    .featured-article-card.image-right .featured-article-card-content {
        -ms-flex-order: 0;
        order: 0;
        margin-left: 0;
        margin-right: -540px;
    }
}

#article-list {
    margin-bottom: 16px;
}

.article-card {
    position: relative;
    height: 500px;
    margin-bottom: 32px;
    overflow: hidden;
    box-shadow: 0 0 30px 0 rgba(151, 151, 151, 0.2);
    display: -ms-flexbox;
    display: flex;
    -ms-flex-direction: column;
    flex-direction: column;
    text-decoration: none;
    color: #333;
}

    .article-card:hover {
        text-decoration: none;
        color: #333;
    }

    .article-card.video-card {
        display: -ms-flexbox;
        display: flex;
        -ms-flex-direction: column;
        flex-direction: column;
    }

        .article-card.video-card .video-card-play {
            overflow: hidden;
            position: relative;
            -ms-flex-positive: 1;
            flex-grow: 1;
        }

            .article-card.video-card .video-card-play:after {
                background: url("../images/play.svg") no-repeat;
                position: absolute;
                top: 50%;
                left: 50%;
                -ms-transform: translate(-50%, -50%);
                transform: translate(-50%, -50%);
                height: 100px;
                width: 100px;
                content: '';
            }

.article-card-image {
    position: absolute;
    top: 0;
    left: 0;
    min-height: calc(100% - 150px);
    min-width: 100%;
}

.article-card-content {
    background: #fff;
    padding: 32px 24px 24px;
    display: -ms-flexbox;
    display: flex;
    margin-top: auto;
    -ms-flex-direction: column;
    flex-direction: column;
    width: 100%;
    z-index: 10;
}

.article-card-title {
    border-bottom: 1px solid #d8d8d8;
    padding-bottom: 32px;
    font-size: 24px;
    font-family: Georgia, serif;
    line-height: 30px;
    text-decoration: none;
}

    .article-card-title > a {
        text-decoration: none;
        color: #333333;
    }

        .article-card-title > a:hover {
            text-decoration: none;
        }

.article-card-category {
    display: block;
    padding-top: 16px;
    font-size: 10px;
    text-transform: uppercase;
    text-decoration: none;
    color: #545454;
    font-family: 'Helvetica Neue LT W05_45 Light', Helvetica, sans-serif;
    font-weight: 300;
    font-family: 'Helvetica Neue LT W05_75 Bold', Helvetica, sans-serif;
    font-weight: 700;
}

    .article-card-category:hover {
        color: #545454;
    }

@media screen and (min-width: 1200px) {
    .article-card {
        transition: transform 0.35s, box-shadow 0.35s;
    }

        .article-card:hover {
            transform: translate3d(0, -8px, 0);
            box-shadow: 0 10px 30px 0 rgba(151, 151, 151, 0.5);
            transition: transform 0.35s, box-shadow 0.35s;
        }

    @supports (-ms-ime-align: auto) {
        .article-card {
            transition: none;
        }

            .article-card:hover {
                transition: none;
            }
    }
}

.news-room-filters {
    display: -ms-flexbox;
    display: flex;
    -ms-flex-pack: justify;
    justify-content: space-between;
    margin-bottom: 48px;
}

    .news-room-filters > .news-room-filter {
        width: 50%;
        min-width: 0;
    }

@media screen and (min-width: 992px) {
    .news-room-filters {
        -ms-flex-pack: start;
        justify-content: flex-start;
    }

        .news-room-filters > .news-room-filter {
            width: auto;
            min-width: 165px;
        }
}

.news-card {
    position: relative;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-direction: column;
    flex-direction: column;
    margin-bottom: 32px;
    padding: 32px 24px 96px;
    background: #fff;
    box-shadow: 0 0 30px 0 rgba(151, 151, 151, 0.2);
    text-decoration: none;
}

.news-card-title, .news-card-copy, .news-card-read-more {
    color: #333;
    text-decoration: none;
}

    .news-card-title:hover, .news-card-copy:hover, .news-card-read-more:hover {
        color: #333;
        text-decoration: none;
    }

.news-card-title {
    font-size: 24px;
    line-height: 30px;
    font-family: Georgia, serif;
    margin-bottom: 16px;
}

.news-card-copy {
    line-height: 24px;
    margin-bottom: 16px;
}

.news-card .read-more {
    position: absolute;
    bottom: 72px;
}

.news-card-info {
    position: absolute;
    bottom: 0;
    left: 24px;
    right: 24px;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-pack: justify;
    justify-content: space-between;
    -ms-flex-line-pack: center;
    align-content: center;
    padding: 16px 0 24px;
    border-top: 1px solid rgba(186, 186, 186, 0.5);
    font-size: 10px;
    text-transform: uppercase;
    font-family: 'Helvetica Neue LT W05_45 Light', Helvetica, sans-serif;
    font-weight: 300;
    font-family: 'Helvetica Neue LT W05_75 Bold', Helvetica, sans-serif;
    font-weight: 700;
    color: #595959;
    letter-spacing: 0.03125rem;
}

@media screen and (min-width: 992px) {
    .news-card {
        height: 400px;
        transition: transform 0.35s, box-shadow 0.35s;
    }

    .news-card-title, .news-card-copy {
        max-height: 120px;
        overflow: hidden;
    }

    .news-card:hover {
        transform: translate3d(0, -8px, 0);
        box-shadow: 0 10px 30px 0 rgba(151, 151, 151, 0.5);
        transition: transform 0.35s, box-shadow 0.35s;
    }

    @supports (-ms-ime-align: auto) {
        .news-card {
            transition: none;
        }

            .news-card:hover {
                transition: none;
            }
    }
}

.media-resource-card {
    min-height: 375px;
    height: calc(100% - 32px);
    background: #333;
    margin-bottom: 32px;
    padding: 32px 24px 24px;
}

#news-list .media-resource-card {
    display: none;
}

.media-resource-card-title {
    color: #fff;
    font-family: Georgia, serif;
    font-family: Georgia, serif;
    font-weight: bold;
    font-size: 26px;
    line-height: 30px;
    margin-bottom: 16px;
    letter-spacing: 0.0625rem;
}

.media-resource-card-list {
    list-style: none;
    padding: 0;
}

    .media-resource-card-list a {
        position: relative;
        display: block;
        color: #fff;
        text-decoration: none;
        padding: 15px 24px 16px 16px;
        line-height: 1;
        font-family: 'Helvetica Neue LT W05_45 Light', Helvetica, sans-serif;
        font-weight: 300;
        font-family: 'Helvetica Neue LT W05_75 Bold', Helvetica, sans-serif;
        font-weight: 700;
        background-position: calc(100% - 12px) 50%;
        transition: background-position 0.4s ease-in-out;
    }

        .media-resource-card-list a:hover {
            background-position: 100% 50%;
            transition: background-position 0.4s ease-out;
        }

        .media-resource-card-list a:after {
            content: '';
            display: block;
            height: 1px;
            position: absolute;
            bottom: 0;
            left: 0;
            right: 0;
            background: #d8d8d8;
            -ms-transform-origin: 100% 50%;
            transform-origin: 100% 50%;
        }

        .media-resource-card-list a:before {
            content: "";
            position: absolute;
            right: 11px;
            top: 50%;
            color: #fff;
            font-size: 13px;
            line-height: 1em;
            height: 15px;
            width: 10px;
            font-family: "font-icons";
            -ms-transform: translateY(-50%);
            transform: translateY(-50%);
        }

@media screen and (min-width: 992px) {
    .media-resource-card {
        display: none;
    }

    #news-list .media-resource-card {
        display: block;
    }

    .media-resource-card-list a:hover:after {
        animation: snake 0.8s cubic-bezier(0.58, 0.3, 0.005, 1);
    }
}

@media screen and (max-width: 992px) {
    .media-resource-card {
        margin-left: -16px;
        margin-right: -16px;
    }
}

.product-ordersample {
    position: absolute;
    width: 100%;
    height: 100%;
    background: #fff;
    bottom: 0;
    z-index: 2;
    display: none;
}

    .product-ordersample .order-sample-note p {
        margin-bottom: 10px;
    }

    .product-ordersample .decor-order-sample {
        margin-bottom: 0;
        height: calc(100% - 60px);
    }

        .product-ordersample .decor-order-sample .decor-order-sample-content {
            padding: 10px 16px;
        }

    .product-ordersample .product-range-card-copy {
        margin-bottom: 10px;
        overflow: hidden;
        position: relative;
        line-height: 1.4em;
        max-height: 4.2em;
        text-align: justify;
        margin-right: -1em;
        padding-right: 1em;
    }

        .product-ordersample .product-range-card-copy:before {
            content: '...';
            position: absolute;
            right: 0;
            bottom: 0;
        }

        .product-ordersample .product-range-card-copy:after {
            content: '';
            position: absolute;
            right: 0;
            width: 1em;
            height: 1em;
            margin-top: 0.2em;
            background: #F9F7F6;
        }

    .product-ordersample .product-range-card-actions {
        margin: 10px 26px 0;
        padding-top: 10px;
        display: -ms-flexbox;
        display: flex;
        -ms-flex-pack: justify;
        justify-content: space-between;
        border-top: 0 none;
    }

        .product-ordersample .product-range-card-actions .product-range-card-cta {
            padding-bottom: 0;
            margin-bottom: 0;
            border: 0 none;
        }

        .product-ordersample .product-range-card-actions .orderdone-cta {
            width: auto;
        }

.product-range-card {
    display: -ms-flexbox;
    display: flex;
    -ms-flex-direction: column;
    flex-direction: column;
    position: relative;
    height: 500px;
    overflow: hidden;
    margin-bottom: 32px;
    box-shadow: 0 0 30px 0 rgba(151, 151, 151, 0.2);
}

.product-range-card-image {
    -ms-flex-positive: 1;
    flex-grow: 1;
}

    .product-range-card-image > img {
        position: absolute;
        top: 0;
        left: 50%;
        -ms-transform: translateX(-50%);
        transform: translateX(-50%);
        min-width: 100%;
        min-height: 75%;
    }

.product-range-card-info {
    background: #fff;
    padding: 24px;
    z-index: 1;
}

.product-range-card-title {
    font-family: Georgia, serif;
    font-size: 21.4px;
    line-height: 26px;
    color: #333333;
    margin-bottom: 8px;
}

@media screen and (min-width: 768px) {
    .product-range-card-title {
        font-size: 23.54px;
        line-height: 28px;
    }
}

@media screen and (min-width: 992px) {
    .product-range-card-title {
        font-size: 21.4px;
        line-height: 26px;
    }
}

@media screen and (min-width: 1200px) {
    .product-range-card-title {
        font-size: 25.68px;
        line-height: 30px;
    }
}

.product-range-card-copy {
    font-family: 'Helvetica Neue LT W05_45 Light', Helvetica, sans-serif;
    font-weight: 300;
    font-size: 12px;
    line-height: 20px;
    margin-bottom: 24px;
}

@media screen and (min-width: 768px) {
    .product-range-card-copy {
        font-size: 14px;
        line-height: 22px;
    }
}

@media screen and (min-width: 1200px) {
    .product-range-card-copy {
        font-size: 16px;
        line-height: 24px;
    }
}

.product-range-card-cta {
    margin-bottom: 24px;
    padding-bottom: 24px;
    border-bottom: 1px solid rgba(186, 186, 186, 0.5);
}

.product-range-card-actions .btn-blue, .product-range-card-actions .cart-total-cta, .product-range-card-actions .checkout form [type="submit"], .checkout form .product-range-card-actions [type="submit"] {
    width: 100%;
}

@media screen and (min-width: 768px) {
    .product-range-card-cta {
        margin-bottom: 0;
        padding-bottom: 0;
        border-bottom: none;
    }

    .product-range-card-actions {
        padding-top: 16px;
        border-top: 1px solid rgba(186, 186, 186, 0.5);
        display: -ms-flexbox;
        display: flex;
        -ms-flex-pack: justify;
        justify-content: space-between;
        -ms-flex-align: center;
        align-items: center;
    }

        .product-range-card-actions .btn-blue, .product-range-card-actions .cart-total-cta, .product-range-card-actions .checkout form [type="submit"], .checkout form .product-range-card-actions [type="submit"] {
            width: auto;
        }

    .product-ordersample .product-range-card-actions {
        margin: 10px 26px 0;
        padding-top: 10px;
        display: -ms-flexbox;
        display: flex;
        -ms-flex-pack: justify;
        justify-content: space-between;
        border-top: 0 none;
    }
}

@media only screen and (min-device-width: 375px) and (max-device-width: 812px) and (-webkit-device-pixel-ratio: 3) and (orientation: landscape) {
    .product-ordersample.active {
        max-width: 100%;
    }

        .product-ordersample.active .decor-order-sample {
            height: 170px;
            overflow-y: scroll;
        }

            .product-ordersample.active .decor-order-sample .decor-order-sample-form select {
                width: calc(50% - 8px);
            }

        .product-ordersample.active .product-range-card-actions {
            margin-top: 0;
        }
}

@media only screen and (min-device-width: 375px) and (max-device-width: 667px) and (orientation: landscape) {
    .product-ordersample.active {
        max-width: 100%;
    }

        .product-ordersample.active .decor-order-sample {
            height: 170px;
            overflow-y: scroll;
        }

            .product-ordersample.active .decor-order-sample .decor-order-sample-form select {
                width: calc(50% - 8px);
            }

        .product-ordersample.active .product-range-card-actions {
            margin-top: 0;
        }
}

#gallery-list {
    width: 100%;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-pack: justify;
    justify-content: space-between;
    opacity: 0;
    transition: opacity 0.5s;
    margin-bottom: 25px;
}

.product-gallery-item {
    position: relative;
    margin-bottom: 24px;
}

    .product-gallery-item > img {
        display: block;
        margin: auto;
        cursor: pointer;
    }

    .product-gallery-item:after {
        content: '';
        position: absolute;
        top: -8px;
        right: 8px;
        width: 32px;
        height: 32px;
        box-shadow: 0 0 30px 0 rgba(151, 151, 151, 0.2);
        background: #fff;
    }

    .product-gallery-item:before {
        position: absolute;
        top: -2px;
        right: 18px;
        width: auto;
        height: auto;
        content: "";
        font-family: "font-icons";
        z-index: 2;
    }

.modal-header {
    border: none;
    padding-bottom: 16px;
}

.modal-dialog {
    max-width: 1100px;
}

#gallery-modal {
    padding: 0 16px;
    margin: auto;
    overflow: visible;
}

    #gallery-modal .carousel,
    #gallery-modal .carousel img,
    #gallery-modal .carousel-images .carousel-slide {
        max-height: 60vh;
    }

    #gallery-modal .carousel-images .carousel-slide {
        height: 60vh;
        display: -ms-flexbox !important;
        display: flex !important;
    }

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

.product-list-heading {
    font-family: 'Helvetica Neue LT W05_45 Light', Helvetica, sans-serif;
    font-weight: 300;
    font-size: 16px;
    line-height: 24px;
    margin-bottom: 32px;
    margin-bottom: 16px;
}

@media screen and (min-width: 1200px) {
    .product-list-heading {
        font-size: 20px;
        line-height: 36px;
        margin-bottom: 56px;
    }
}

.product-list-item {
    color: inherit;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-align: center;
    align-items: center;
    -ms-flex-pack: justify;
    justify-content: space-between;
    padding: 12px 34px 12px 8px;
    border-bottom: 1px solid #d8d8d8;
    transform: translate3d(0px, -50%, 0);
    transition: transform 0.25s ease-out;
    position: relative;
}

    .product-list-item:before {
        position: absolute;
        content: "";
        font-family: "font-icons";
        right: 16px;
        top: 50%;
        font-size: 13px;
        color: #333;
        -ms-transform: translateY(-50%);
        transform: translateY(-50%);
        transform: translate3d(0, -50%, 0);
        transition: transform 0.25s ease-out;
    }

    .product-list-item:hover {
        color: inherit;
        text-decoration: none;
        background-position-x: calc(100% - 8px);
    }

        .product-list-item:hover:before {
            transform: translate3d(6px, -50%, 0);
            transition: transform 0.25s ease-out;
        }

.product-list-item-left {
    margin-right: 16px;
}

    .product-list-item-left strong {
        display: block;
        line-height: 1;
        margin-bottom: 4px;
    }

    .product-list-item-left span {
        display: block;
        font-size: 12px;
        color: #595959;
        line-height: 1.4;
    }

.product-list-item-right {
    display: -ms-flexbox;
    display: flex;
    -ms-flex-align: center;
    align-items: center;
    -ms-flex-pack: end;
    justify-content: flex-end;
    font-size: 12px;
    color: #595959;
    min-width: 68px;
}

.product-list .badge-new,
.product-list .badge-discontinued {
    margin-bottom: 4px;
}

@media screen and (min-width: 1200px) {
    .product-list-heading {
        margin-bottom: 16px;
    }
}

.sc-edit-mode .ee-carousel-container .carousel {
    max-height: 100%;
}

.modal .carousel-info {
    opacity: 0;
}

.carousel {
    position: relative;
    margin-bottom: 0;
}

    .carousel .slick-arrow:before {
        content: '';
    }

.carousel-images {
    position: relative;
    margin-bottom: 0;
    opacity: 1;
}

    .carousel-images.slick-initialized {
        opacity: 1;
    }

.carousel-arrow {
    position: absolute;
    top: 50%;
    -ms-transform: translateY(-50%);
    transform: translateY(-50%);
    width: 44px;
    height: 44px;
    background: #fff;
    box-shadow: 0 0 30px 0 rgba(151, 151, 151, 0.2);
    border: none;
    z-index: 10;
}

    .carousel-arrow:focus {
        outline: none;
    }

    .carousel-arrow.arrow-prev {
        left: -16px;
        font-size: 12px;
        line-height: 1em;
    }

    .carousel-arrow.arrow-next {
        right: -16px;
        font-size: 12px;
        line-height: 1em;
    }

.carousel-download-btn {
    position: absolute;
    top: 0;
    right: 16px;
    display: block;
    width: 24px;
    height: 24px;
    font-size: 24px;
    line-height: 1em;
    color: #333;
}

    .carousel-download-btn:hover {
        text-decoration: none;
        color: #333;
    }

    .carousel-download-btn:focus {
        outline: none;
    }

.carousel-slide-image {
    margin: auto;
    max-height: 640px;
}

.carousel-slide-info {
    position: relative;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-pack: justify;
    justify-content: space-between;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
    width: 100% !important;
    margin: 16px 0 56px;
    padding: 0 16px 16px;
    border-bottom: 1px solid #C8C7C6;
}

.carousel-slide-copy {
    -ms-flex-order: 1;
    order: 1;
    font-size: 12px;
    line-height: 16px;
    text-align: center;
    width: 100%;
    margin-top: 8px;
    margin-bottom: 0;
    padding-top: 26px;
}

.carousel-slide-numbers {
    display: block;
    width: 100%;
    font-size: 20px;
    line-height: 26px;
    font-family: Georgia, serif;
    text-align: center;
}

    .carousel-slide-numbers + .carousel-slide-copy {
        padding-top: 0;
    }

.carousel,
.carousel img,
.carousel-images .carousel-slide {
    max-height: 200px;
}

.carousel-images .carousel-slide {
    height: 200px;
    display: -ms-flexbox !important;
    display: flex !important;
}

.carousel img {
    height: auto;
    max-height: 100%;
}

.carousel {
    width: 100%;
    max-width: 1100px;
    background: #333;
}

    .carousel img {
        margin: auto;
    }

@media screen and (min-width: 992px) {
    .carousel,
    .carousel img,
    .carousel-images .carousel-slide {
        max-height: 600px;
    }

    .carousel-images .carousel-slide {
        height: 600px;
        display: -ms-flexbox !important;
        display: flex !important;
    }
}

@media screen and (min-width: 1200px) {
    .carousel-arrow {
        width: 60px;
        height: 60px;
    }

    .carousel-slide-copy {
        padding-right: 48px;
        padding-top: 0;
    }

    .carousel-slide-numbers {
        width: auto;
    }

        .carousel-slide-numbers + .carousel-slide-copy {
            width: 60%;
            margin: auto;
        }

    .carousel-slide-info {
        padding-bottom: 32px;
        margin-bottom: 80px;
    }

    .carousel-download-btn {
        -ms-flex-order: 3;
        order: 3;
    }
}

.product-carousel {
    margin-bottom: 64px;
}

    .product-carousel button {
        cursor: pointer;
    }

    .product-carousel .slick-dots li button {
        padding: 8px;
        width: 16px;
        height: 16px;
        background: #979797;
        border-radius: 50%;
    }

        .product-carousel .slick-dots li button:before {
            content: none;
        }

    .product-carousel .slick-dots li.slick-active button {
        background: #2272CE;
    }

.product-carousel-fullscreen {
    display: none;
    position: absolute;
    top: -8px;
    right: -8px;
    width: 44px;
    height: 44px;
    border: none;
    box-shadow: 0 0 30px 0 rgba(151, 151, 151, 0.2);
    z-index: 10;
}

    .product-carousel-fullscreen .icon-full-screen {
        position: relative;
        top: 2px;
    }

.product-carousel-images {
    position: relative;
}

.product-carousel-images-content {
    position: relative;
    border: 1px solid #979797;
}

.product-carousel-thumbnails {
    display: none;
    position: relative;
}

.product-carousel-thumbnails-content .slick-slide {
    position: relative;
    margin: 0 16px 0 0;
    border: 1px solid #979797;
}

.product-carousel-thumbnails-content .slick-current {
    z-index: 1;
    border-color: #333;
}

    .product-carousel-thumbnails-content .slick-current:after {
        content: '';
        position: absolute;
        top: 0;
        bottom: 0;
        left: 0;
        right: 0;
        background: transparent;
        border: 4px solid #333;
    }

.product-carousel .carousel-arrow {
    width: 44px;
    height: 44px;
}

    .product-carousel .carousel-arrow.arrow-next {
        right: -8px;
    }

    .product-carousel .carousel-arrow.arrow-prev {
        left: -8px;
    }

#product-modal .carousel-slide {
    width: 100% !important;
}

@media screen and (min-width: 992px) {
    .product-carousel-fullscreen {
        display: block;
    }

    .product-carousel-images {
        cursor: pointer;
    }

        .product-carousel-images .carousel-arrow {
            display: none !important;
        }

    .product-carousel-thumbnails {
        display: block;
    }

        .product-carousel-thumbnails .slick-slide {
            cursor: pointer;
        }

        .product-carousel-thumbnails .carousel-arrow.slick-disabled {
            display: none !important;
        }

        .product-carousel-thumbnails .carousel-arrow.arrow-next {
            right: -16px;
        }

        .product-carousel-thumbnails .carousel-arrow.arrow-prev {
            left: -16px;
        }
}

.product-info ul {
    margin: 0;
    padding: 0;
}

    .product-info ul li.icon-list-item:last-child {
        margin-bottom: 25px;
    }

.product-info-number {
    display: inline-block;
    font-family: 'Helvetica Neue LT W05_45 Light', Helvetica, sans-serif;
    font-weight: 300;
    font-family: 'Helvetica Neue LT W05_75 Bold', Helvetica, sans-serif;
    font-weight: 700;
    font-size: 14px;
    text-transform: uppercase;
    color: #333333;
    letter-spacing: 0.04875rem;
    padding-bottom: 8px;
    margin-bottom: 24px;
    border-bottom: 1px solid #979797;
    line-height: 1;
}

@media screen and (min-width: 1200px) {
    .product-info-number {
        font-size: 18px;
        letter-spacing: 0.0625rem;
    }
}

.product-info-number .discontinued {
    color: #da3931;
}

.product-info-title {
    margin-bottom: 16px;
}

.product-info-subtitle {
    font-family: Georgia, serif;
    font-size: 23.54px;
    line-height: 28px;
    color: #333333;
}

@media screen and (min-width: 768px) {
    .product-info-subtitle {
        font-size: 29.96px;
        line-height: 34px;
    }
}

.product-info-note {
    padding: 0 0 24px 0;
    text-align: left;
}

    .product-info-note > * {
        display: block;
        font-size: 12px;
        line-height: 16px;
        margin-bottom: 0;
    }

    .product-info-note strong {
        text-align: left;
    }

    .product-info-note p {
        font-family: 'Helvetica Neue LT W05_45 Light', Helvetica, sans-serif;
        font-weight: 300;
        font-family: 'Helvetica Neue LT W05_55 Roman', Helvetica, sans-serif;
        font-weight: 400;
    }

.product-info-finish-type {
    margin-top: 24px;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-align: center;
    align-items: center;
    -ms-flex-pack: justify;
    justify-content: space-between;
}

    .product-info-finish-type span {
        font-family: 'Helvetica Neue LT W05_45 Light', Helvetica, sans-serif;
        font-weight: 300;
    }

    .product-info-finish-type a {
        text-decoration: underline;
    }

.product-info-finishes {
    padding: 24px 0 32px;
    margin-bottom: 32px;
    border-top: 1px solid rgba(186, 186, 186, 0.5);
    border-bottom: 1px solid rgba(186, 186, 186, 0.5);
}

.product-info li {
    font-family: 'Helvetica Neue LT W05_45 Light', Helvetica, sans-serif;
    font-weight: 300;
    font-size: 12px;
    line-height: 20px;
    margin-bottom: 32px;
    margin-bottom: 0;
}

@media screen and (min-width: 1200px) {
    .product-info li {
        font-size: 14px;
        line-height: 24px;
    }
}

.product-info li.finish-premium {
    font-family: 'Helvetica Neue LT W05_45 Light', Helvetica, sans-serif;
    font-weight: 300;
}

.product-info li.icon-list-item .icon-download {
    font-size: 23px;
    line-height: 1em;
    color: #333;
    display: inherit;
    margin-right: 10px;
}

.product-info .where-to-buy {
    margin-bottom: 24px;
    border: solid 1px #333;
    padding: 12px;
}

.product-info .request-quote {
    margin-bottom: 24px;
    border: solid 1px #333;
    padding: 12px;
}

.product-info-availability {
    display: -ms-flexbox;
    display: flex;
    -ms-flex-align: start;
    align-items: flex-start;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
    margin-bottom: 24px;
}

    .product-info-availability strong {
        width: 100%;
        display: block;
        margin-bottom: 16px;
    }

    .product-info-availability a img {
        display: block;
        width: 100px;
        margin-right: 16px;
        margin-bottom: 16px;
        border: 1px solid #979797;
    }

@media screen and (min-width: 992px) {
    .product-info-container {
        display: -ms-grid;
        display: grid;
        -ms-grid-columns: 50% calc(50% - 70px);
        grid-template-columns: 50% calc(50% - 70px);
        -ms-grid-rows: auto 1fr;
        grid-template-rows: auto 1fr;
        grid-template-areas: "carousel title" "carousel info";
        grid-column-gap: 70px;
    }

        .product-info-container .product-carousel {
            -ms-grid-row: 1;
            -ms-grid-row-span: 2;
            -ms-grid-column: 1;
            grid-area: carousel;
            overflow: hidden;
            padding: 30px;
            margin: -30px;
        }

        .product-info-container .product-info-header {
            -ms-grid-row: 1;
            -ms-grid-column: 2;
            grid-area: title;
        }

        .product-info-container .product-info {
            -ms-grid-row: 2;
            -ms-grid-column: 2;
            grid-area: info;
        }
}

.product-feature {
    position: relative;
    margin-bottom: 40px;
}

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

    .product-feature__img img {
        min-height: 700px;
        width: 100%;
        object-fit: cover;
    }

.product-feature .product__card__outer {
    position: absolute;
    top: 0;
    left: 0;
    height: 100%;
    width: 100%;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-pack: center;
    justify-content: center;
    -ms-flex-align: center;
    align-items: center;
}

.product-feature__card {
    max-width: 730px;
    background: #ffffff;
    padding: 56px 96px;
    width: 100%;
}

    .product-feature__card .product__card__copy h2 {
        margin-bottom: 25px;
    }

    .product-feature__card .product__card__copy ul {
        font-size: 18px;
        padding: 0 0 16px 32px;
    }

        .product-feature__card .product__card__copy ul li {
            padding-bottom: 5px;
        }

    .product-feature__card .product__card__note {
        padding-top: 30px;
        margin-top: 30px;
        border-top: solid 1px #d8d8d8;
    }

        .product-feature__card .product__card__note p {
            font-size: 12px;
            line-height: 17px;
            margin-bottom: 0;
        }

        .product-feature__card .product__card__note a,
        .product-feature__card .product__card__note a:hover {
            text-decoration: none;
        }

@media screen and (max-width: 768px) {
    .product-feature {
        position: relative;
        margin-bottom: 30px;
    }

    .product-feature__card {
        padding: 56px 32px;
        width: 90%;
    }

        .product-feature__card .product__card__copy h2 {
            margin-bottom: 25px;
        }

        .product-feature__card .product__card__copy ul {
            font-size: 18px;
            padding: 0 0 16px 32px;
        }

            .product-feature__card .product__card__copy ul li {
                padding-bottom: 5px;
            }

        .product-feature__card .product__card__note {
            padding-top: 30px;
            margin-top: 30px;
            border-top: solid 1px #d8d8d8;
        }

            .product-feature__card .product__card__note p {
                font-size: 12px;
                line-height: 17px;
                margin-bottom: 0;
            }

            .product-feature__card .product__card__note a, .product-feature__card .product__card__note a:hover {
                text-decoration: none;
            }
}

[data-toggle~="collapse"] {
    cursor: pointer;
}

.order-sample {
    margin-bottom: 24px;
}

    .order-sample select {
        min-width: 0;
    }

.order-sample-header {
    position: relative;
    padding: 11px 16px 17px;
    border: 1px solid #2272CE;
    border-radius: 0;
    font-family: 'Helvetica Neue LT W05_45 Light', Helvetica, sans-serif;
    font-weight: 300;
    font-family: 'Helvetica Neue LT W05_75 Bold', Helvetica, sans-serif;
    font-weight: 700;
    font-size: 12px;
    transition: border-radius 0.35s;
}

    .order-sample-header:after {
        content: "";
        display: block;
        position: absolute;
        right: 16px;
        top: 50%;
        -ms-transform: translateY(-50%) rotate(180deg);
        transform: translateY(-50%) rotate(180deg);
        width: 14px;
        height: 7px;
        transition: transform 0.35s;
        font-size: 8px;
        color: #2272CE;
        font-family: "font-icons";
    }

    .order-sample-header.collapsed {
        border-radius: 8px;
        transition: border-radius 0.35s;
        transition-delay: 0.25s;
    }

        .order-sample-header.collapsed:after {
            -ms-transform: translateY(-50%) rotate(0deg);
            transform: translateY(-50%) rotate(0deg);
        }

.order-sample-cart {
    position: relative;
}

    .order-sample-cart img {
        width: 24px;
    }

    .order-sample-cart .icon-cart {
        font-size: 22px;
        line-height: 1em;
        position: relative;
        top: 7px;
    }

    .order-sample-cart:before {
        content: '';
        position: absolute;
        top: -5px;
        left: 6px;
        width: 14px;
        height: 14px;
        border: 2px solid #fff;
        border-radius: 50%;
        background: #2170CA;
        z-index: 1;
    }

.order-sample-content {
    padding: 32px 24px 48px;
    background: #F9F7F6;
    border: 1px solid #2272CE;
    border-top: none;
}

.order-sample-note > * {
    font-size: 12px;
    line-height: 16px;
}

.order-sample-note p {
    text-align: left;
    margin-bottom: 24px;
}

.order-sample-form {
    display: -ms-flexbox;
    display: flex;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
    -ms-flex-pack: justify;
    justify-content: space-between;
}

    .order-sample-form select {
        margin-bottom: 8px;
        margin-right: 0;
        width: 100%;
    }

        .order-sample-form select.one-half {
            width: calc(50% - 8px);
        }

    .order-sample-form button {
        display: block;
        width: 100%;
        margin-top: 16px;
    }

.order-sample-status {
    display: none;
    margin-top: 8px;
    color: #00b300;
    font-family: 'Helvetica Neue LT W05_45 Light', Helvetica, sans-serif;
    font-weight: 300;
    font-family: 'Helvetica Neue LT W05_65 Medium', Helvetica, sans-serif;
    font-weight: 600;
}

    .order-sample-status.error {
        color: #da3931;
    }

[data-toggle~="collapse"] {
    cursor: pointer;
}

#decor-order-sample-btn {
    margin-top: 5px;
}

.decor-order-sample {
    margin-bottom: 24px;
}

    .decor-order-sample select {
        min-width: 0;
    }

.decor-order-sample-header {
    position: relative;
    padding: 11px 16px 17px;
    border: 1px solid #2272CE;
    border-radius: 0;
    font-family: 'Helvetica Neue LT W05_45 Light', Helvetica, sans-serif;
    font-weight: 300;
    font-family: 'Helvetica Neue LT W05_75 Bold', Helvetica, sans-serif;
    font-weight: 700;
    font-size: 12px;
    transition: border-radius 0.35s;
}

    .decor-order-sample-header:after {
        display: block;
        position: absolute;
        right: 16px;
        top: 50%;
        -ms-transform: translateY(-50%) rotate(180deg);
        transform: translateY(-50%) rotate(180deg);
        width: 14px;
        height: 7px;
        transition: transform 0.35s;
        font-size: 8px;
        color: #2272CE;
        font-family: "font-icons";
    }

    .decor-order-sample-header.collapsed {
        border-radius: 8px;
        transition: border-radius 0.35s;
        transition-delay: 0.25s;
    }

        .decor-order-sample-header.collapsed:after {
            -ms-transform: translateY(-50%) rotate(0deg);
            transform: translateY(-50%) rotate(0deg);
        }

.decor-order-sample-cart {
    position: relative;
}

    .decor-order-sample-cart img {
        width: 24px;
    }

    .decor-order-sample-cart .icon-cart {
        font-size: 22px;
        line-height: 1em;
        position: relative;
        top: 7px;
    }

    .decor-order-sample-cart:before {
        content: "";
        position: absolute;
        top: -5px;
        left: 6px;
        width: 14px;
        height: 14px;
        border: 2px solid #fff;
        border-radius: 50%;
        background: #2170ca;
        z-index: 1;
    }

.decor-order-sample-content {
    padding: 32px 24px 48px;
    background: #f9f7f6;
    border: 1px solid #2272CE;
    border-top: none;
}

.decor-order-sample-note > * {
    font-size: 12px;
    line-height: 16px;
}

.decor-order-sample-note p {
    text-align: center;
    margin-bottom: 24px;
}

.decor-order-sample-form {
    display: -ms-flexbox;
    display: flex;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
    -ms-flex-pack: justify;
    justify-content: space-between;
}

    .decor-order-sample-form select {
        margin-bottom: 8px;
        margin-right: 0;
        width: 100%;
    }

        .decor-order-sample-form select.one-half {
            width: calc(50% - 8px);
        }

    .decor-order-sample-form button {
        display: block;
        width: 100%;
        margin-top: 16px;
    }

.decor-order-sample-status {
    display: none;
    margin-top: 8px;
    color: #00b300;
    font-family: 'Helvetica Neue LT W05_45 Light', Helvetica, sans-serif;
    font-weight: 300;
    font-family: 'Helvetica Neue LT W05_65 Medium', Helvetica, sans-serif;
    font-weight: 600;
}

    .decor-order-sample-status.error {
        color: #da3931;
    }

.load-more {
    position: relative;
    display: block;
    width: 100%;
    max-width: 540px;
    margin: 0 auto 64px;
    padding: 16px 0;
    border-radius: 8px;
    font-family: 'Helvetica Neue LT W05_45 Light', Helvetica, sans-serif;
    font-weight: 300;
    font-family: 'Helvetica Neue LT W05_75 Bold', Helvetica, sans-serif;
    font-weight: 700;
    text-align: center;
    color: white;
    text-decoration: none;
    background: #595959;
    transition: background 0.35s, opacity 0.5s;
}

    .load-more:hover {
        color: #fff;
        background: #333;
        text-decoration: none;
    }

    .load-more.loading {
        opacity: 0.5;
        transition: opacity 0.5s;
        font-size: 0;
    }

        .load-more.loading:after {
            font-size: 14px;
            content: 'Loading...';
        }

.category-bar {
    position: fixed;
    top: 50px;
    box-shadow: 0 0 30px 0 rgba(151, 151, 151, 0.2);
    width: 100%;
    overflow: hidden;
    height: 70px;
    background: #fff;
    z-index: 100;
    padding: 0 16px;
}

.category-bar-links {
    display: -ms-flexbox;
    display: flex;
    -ms-flex-align: start;
    align-items: flex-start;
    width: 100%;
    padding-right: 16px;
    padding-left: 16px;
    margin-right: auto;
    margin-left: auto;
    height: 90px;
    padding: 0;
    overflow-x: scroll;
}

@media (min-width: 576px) {
    .category-bar-links {
        max-width: 540px;
    }
}

@media (min-width: 768px) {
    .category-bar-links {
        max-width: 720px;
    }
}

@media (min-width: 992px) {
    .category-bar-links {
        max-width: 960px;
    }
}

@media (min-width: 1200px) {
    .category-bar-links {
        max-width: 1140px;
    }
}

.category-bar-links > a {
    display: block;
    margin-right: 24px;
    text-decoration: none;
    padding: 28px 0;
    line-height: 1;
    color: #000;
}

    .category-bar-links > a.active {
        font-family: 'Helvetica Neue LT W05_45 Light', Helvetica, sans-serif;
        font-weight: 300;
        font-family: 'Helvetica Neue LT W05_75 Bold', Helvetica, sans-serif;
        font-weight: 700;
        text-decoration: underline;
    }

.category-bar + * {
    margin-top: 60px;
}

.category-bar + .hero {
    margin-top: 38px;
}

@media screen and (min-width: 768px) {
    .category-bar {
        top: 60px;
    }

        .category-bar + * {
            margin-top: 100px;
        }
}

@media screen and (min-width: 1200px) {
    .category-bar {
        top: 84px;
    }

    .category-bar-links {
        padding: 0 16px;
    }

    .category-bar + * {
        margin-top: 80px;
    }
}

#tag-container {
    padding-bottom: 40px;
    margin-bottom: 40px;
    border-bottom: 1px solid rgba(151, 151, 151, 0.5);
}

    #tag-container .tag {
        margin-bottom: 0;
    }

.tags {
    display: -ms-flexbox;
    display: flex;
    -ms-flex-pack: start;
    justify-content: flex-start;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
}

.tags-container {
    max-width: 920px;
    margin: auto;
}

.tag {
    display: -ms-flexbox;
    display: flex;
    -ms-flex-align: center;
    align-items: center;
    -ms-flex-pack: justify;
    justify-content: space-between;
    font-family: 'Helvetica Neue LT W05_45 Light', Helvetica, sans-serif;
    font-weight: 300;
    font-family: 'Helvetica Neue LT W05_75 Bold', Helvetica, sans-serif;
    font-weight: 700;
    font-size: 12px;
    line-height: 16px;
    padding: 8px 16px;
    text-transform: uppercase;
    text-align: center;
    color: #fff;
    background: #333333;
    border-radius: 20px;
    transition: background-color 0.35s;
    text-decoration: none;
    max-width: 50%;
    margin-bottom: 24px;
}

    .tag:not(:last-child) {
        margin-right: 24px;
    }

    .tag:hover {
        color: #fff;
        text-decoration: none;
        background: #545454;
        transition: background-color 0.35s;
    }

    .tag > a {
        color: #fff;
        text-decoration: none;
        font-size: 10px;
        line-height: 1em;
        margin-left: 8px;
        width: 10px;
        height: 10px;
    }

.callout {
    width: 100%;
    margin: 56px 0;
    padding: 32px 24px;
    box-shadow: 0 0 30px 0 rgba(151, 151, 151, 0.2);
    background: #fff;
}

    .callout p, .callout a {
        margin-bottom: 0;
    }

.callout-content > a {
    font-family: 'Helvetica Neue LT W05_45 Light', Helvetica, sans-serif;
    font-weight: 300;
    font-family: 'Helvetica Neue LT W05_55 Roman', Helvetica, sans-serif;
    font-weight: 400;
}

.callout-title {
    font-size: 22px;
    color: #333333;
    margin-bottom: 24px;
}

.callout.featured-products .callout-content > a {
    display: block;
    margin-bottom: 16px;
}

.callout.media-contact .callout-content > a {
    display: block;
}

@media screen and (min-width: 1200px) {
    .callout {
        margin: 80px 0;
        display: -ms-flexbox;
        display: flex;
        -ms-flex-pack: justify;
        justify-content: space-between;
        padding: 48px 96px;
    }

        .callout > * {
            width: 50%;
        }

    .callout-title {
        font-size: 28px;
    }
}

.footer {
    padding: 32px 0;
    background: #000;
    color: #fff;
    margin-bottom: 0;
}

    .footer a {
        color: #fff;
        text-decoration: none;
    }

        .footer a:hover {
            text-decoration: none;
        }

    .footer p {
        font-size: 10px;
        line-height: 14px;
        font-family: 'Helvetica Neue LT W05_45 Light', Helvetica, sans-serif;
        font-weight: 300;
        font-family: 'Helvetica Neue LT W05_55 Roman', Helvetica, sans-serif;
        font-weight: 400;
    }

.footer-links {
    margin-bottom: 32px;
    font-family: 'Helvetica Neue LT W05_45 Light', Helvetica, sans-serif;
    font-weight: 300;
    font-family: 'Helvetica Neue LT W05_55 Roman', Helvetica, sans-serif;
    font-weight: 400;
}

.footer-accordion {
    border: 1px solid #595959;
    margin-bottom: -1px;
    transition: background 0.35s, color 0.35s;
}

    .footer-accordion .accordion-toggle {
        cursor: pointer;
        position: relative;
        padding: 12px 56px 12px 16px;
        border: 1px solid #595959;
        margin: -1px;
        font-size: 14px;
        font-family: 'Helvetica Neue LT W05_45 Light', Helvetica, sans-serif;
        font-weight: 300;
        font-family: 'Helvetica Neue LT W05_55 Roman', Helvetica, sans-serif;
        font-weight: 400;
        color: #fff;
        line-height: 1;
        transition: background 0.35s, color 0.35s;
    }

        .footer-accordion .accordion-toggle:after {
            content: "";
            width: 10px;
            height: 10px;
            position: absolute;
            top: 14px;
            right: 14px;
            margin: 0;
            background-size: 10px 6px;
            font-family: "font-icons";
            color: #fff;
            font-size: 6px;
        }

        .footer-accordion .accordion-toggle:before {
            content: '';
            width: 40px;
            height: 100%;
            position: absolute;
            top: 0;
            right: 0;
            margin: 0;
            border-left: 0 none;
        }

    .footer-accordion .accordion-content {
        padding: 4px 0;
        transition: background 0.35s, color 0.35s;
    }

        .footer-accordion .accordion-content > a {
            display: block;
            padding: 10px 16px;
        }

    .footer-accordion.active {
        border-top: none;
    }

        .footer-accordion.active .accordion-toggle {
            background: #dedede;
            color: #000;
            border: none;
            padding-top: 13px;
            padding-bottom: 13px;
            margin: 0;
            transition: background 0.35s, color 0.35s;
        }

            .footer-accordion.active .accordion-toggle:after {
                border: none;
                -ms-transform: rotate(180deg);
                transform: rotate(180deg);
                color: #333;
                background: none;
                top: 14px;
                margin-top: 0;
            }

            .footer-accordion.active .accordion-toggle:before {
                border: none;
            }

        .footer-accordion.active .accordion-content {
            background: #fff;
            transition: background 0.35s, color 0.35s;
        }

            .footer-accordion.active .accordion-content a {
                color: #000;
            }

.footer-contact {
    padding: 24px 0;
    border-top: 1px solid #595959;
    border-bottom: 1px solid #595959;
}

.footer-contact-phone {
    text-align: center;
    display: block;
    margin-bottom: 24px;
}

.footer-contact-social {
    display: -ms-flexbox;
    display: flex;
    -ms-flex-pack: center;
    justify-content: center;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
}

.footer-contact-social-link {
    position: relative;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-align: center;
    align-items: center;
    -ms-flex-pack: center;
    justify-content: center;
    margin: 0 8px 20px;
    width: 40px;
    height: 40px;
    font-size: 20px;
    border-radius: 100%;
    border: 1px solid #595959;
    background: none;
    color: #fff;
}

    .footer-contact-social-link > a {
        display: -ms-flexbox;
        display: flex;
        -ms-flex-align: center;
        align-items: center;
        -ms-flex-pack: center;
        justify-content: center;
        width: 100%;
        height: 100%;
        border-radius: 100%;
    }

    .footer-contact-social-link.active .footer-contact-social-tooltip {
        visibility: visible;
        opacity: 1;
        -ms-transform: translate(-50%, -20px);
        transform: translate(-50%, -20px);
        transition: visibility 0.35s, opacity 0.35s, transform 0.35s;
    }

    .footer-contact-social-link.architizer img {
        width: 18px;
    }

.footer-contact-social-badge {
    position: absolute;
    bottom: -4px;
    right: -4px;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-align: center;
    align-items: center;
    -ms-flex-pack: center;
    justify-content: center;
    width: 20px;
    height: 20px;
    border-radius: 100%;
    background: #545454;
    color: #fff;
    font-size: 10px;
    font-family: 'Helvetica Neue LT W05_45 Light', Helvetica, sans-serif;
    font-weight: 300;
    font-family: 'Helvetica Neue LT W05_75 Bold', Helvetica, sans-serif;
    font-weight: 700;
}

.footer-contact-social-tooltip {
    visibility: hidden;
    opacity: 0;
    position: absolute;
    bottom: 100%;
    left: 50%;
    width: 160px;
    background: #fff;
    -ms-transform: translate(-50%, -10px);
    transform: translate(-50%, -10px);
    transition: visibility 0.35s, opacity 0.35s, transform 0.35s;
}

    .footer-contact-social-tooltip:before {
        content: '';
        width: 100%;
        height: 25px;
        background: none;
        display: block;
        position: absolute;
        top: 100%;
    }

    .footer-contact-social-tooltip:after {
        content: '';
        position: absolute;
        top: 100%;
        left: 50%;
        width: 20px;
        height: 20px;
        -ms-transform: translateX(-50%) translateY(-15px) rotate(45deg);
        transform: translateX(-50%) translateY(-15px) rotate(45deg);
        background: #fff;
        z-index: -1;
    }

    .footer-contact-social-tooltip a {
        display: block;
        padding: 12px 0;
        font-size: 12px;
        text-align: center;
        font-family: 'Helvetica Neue LT W05_45 Light', Helvetica, sans-serif;
        font-weight: 300;
        font-family: 'Helvetica Neue LT W05_75 Bold', Helvetica, sans-serif;
        font-weight: 700;
        color: #333;
    }

        .footer-contact-social-tooltip a:not(:last-child) {
            border-bottom: 1px solid #bababa;
        }

.footer-contact-b2b {
    font-size: 12px;
    font-family: 'Helvetica Neue LT W05_45 Light', Helvetica, sans-serif;
    font-weight: 300;
    font-family: 'Helvetica Neue LT W05_75 Bold', Helvetica, sans-serif;
    font-weight: 700;
    text-align: center;
    margin-right: 10px;
}

    .footer-contact-b2b i {
        margin-left: 5px;
    }

.footer-sublinks {
    padding: 24px 0 0;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
    border-bottom: 1px solid #595959;
    margin-bottom: 24px;
    font-family: 'Helvetica Neue LT W05_45 Light', Helvetica, sans-serif;
    font-weight: 300;
    font-family: 'Helvetica Neue LT W05_75 Bold', Helvetica, sans-serif;
    font-weight: 700;
}

.footer-sublinks-b2b {
    display: none;
}

.footer-sublinks a {
    width: 33%;
    text-align: center;
    margin-bottom: 24px;
}

.footer-disclaimer {
    padding: 0 16px 24px;
    font-size: 10px;
}

    .footer-disclaimer p {
        margin-bottom: 16px;
    }

@media screen and (min-width: 768px) {
    .footer-links {
        display: -ms-flexbox;
        display: flex;
    }

    .footer .footer-accordion {
        width: 33%;
        border: none;
    }

        .footer .footer-accordion .accordion-toggle {
            cursor: default;
            border: none;
            font-size: 16px;
            font-family: 'Helvetica Neue LT W05_45 Light', Helvetica, sans-serif;
            font-weight: 300;
            font-family: 'Helvetica Neue LT W05_75 Bold', Helvetica, sans-serif;
            font-weight: 700;
            color: #979797;
        }

            .footer .footer-accordion .accordion-toggle:after {
                content: none;
            }

            .footer .footer-accordion .accordion-toggle:before {
                border: 0 none;
            }

        .footer .footer-accordion .accordion-content {
            display: block;
        }

    .footer-contact {
        display: -ms-flexbox;
        display: flex;
        -ms-flex-align: center;
        align-items: center;
    }

    .footer-contact-phone {
        -ms-flex-order: 3;
        order: 3;
        margin-bottom: 0;
    }

    .footer-contact-social {
        -ms-flex-pack: start;
        justify-content: flex-start;
        -ms-flex-positive: 1;
        flex-grow: 1;
    }

    .footer-contact-social-link {
        margin-bottom: 0;
    }

    .footer-contact-social a {
        margin-bottom: 0;
    }

    .footer-contact-b2b {
        display: none;
    }

    .footer-sublinks {
        position: relative;
        display: -ms-flexbox;
        display: flex;
        padding: 24px 0 0;
        border-bottom: 0;
    }

        .footer-sublinks a {
            margin-right: 30px;
            margin-bottom: 0;
            width: auto;
        }

    .footer-sublinks-b2b {
        position: absolute;
        right: 0;
        display: block;
        justify-self: flex-end;
        margin: 0 !important;
    }

    .footer-disclaimer {
        padding-left: 0;
        padding-right: 0;
    }

        .footer-disclaimer p {
            margin: 0;
        }
}

@media screen and (min-width: 1200px) {
    .footer-links {
        width: 78%;
    }

    .footer .footer-accordion .accordion-toggle:before {
        border: 0 none;
    }

    .footer-contact-social-link:hover .footer-contact-social-tooltip {
        visibility: visible;
        opacity: 1;
        -ms-transform: translate(-50%, -20px);
        transform: translate(-50%, -20px);
        transition: visibility 0.35s, opacity 0.35s, transform 0.35s;
    }
}

.component-video {
    margin-top: 32px;
    margin-bottom: 32px;
}

    .component-video .js-youku.active {
        position: absolute;
        top: 0;
        left: 0;
        height: 100% !important;
        width: 100% !important;
    }

.component-video__thumbnail {
    position: absolute;
    left: 0;
    top: 0;
    width: 100%;
    height: 100%;
    z-index: 2;
}

    .component-video__thumbnail .video-play,
    .component-video__thumbnail .yt-modal-play {
        cursor: pointer;
        position: absolute;
        left: 50%;
        top: 50%;
        -ms-transform: translate(-50%, -50%);
        transform: translate(-50%, -50%);
        margin: 0;
        padding: 0;
        outline: 0 none;
        border-radius: 50%;
        height: 100px;
        width: 100px;
        background: transparent;
    }

        .component-video__thumbnail .video-play:after,
        .component-video__thumbnail .yt-modal-play:after {
            background: url("../images/play.svg") no-repeat;
            position: absolute;
            top: 50%;
            left: 50%;
            -ms-transform: translate(-50%, -50%);
            transform: translate(-50%, -50%);
            height: 100px;
            width: 100px;
            content: '';
        }

.component-video__copy p {
    font-size: 12px;
    line-height: 18px;
    text-align: center;
    padding: 24px 0px 16px;
    margin-bottom: 0;
}

@media screen and (min-width: 768px) {
    .component-video {
        margin-top: 56px;
        margin-bottom: 56px;
    }

    .component-video__thumbnail .video-play, .component-video__thumbnail .yt-modal-play {
        height: 200px;
        width: 200px;
        background: transparent;
    }

        .component-video__thumbnail .video-play:after, .component-video__thumbnail .yt-modal-play:after {
            width: 200px;
            height: 200px;
        }

    .component-video__copy p {
        padding: 24px 80px;
    }
}

.modal #youku-playerBox {
    height: 100% !important;
    width: 100% !important;
}

.modal .modal-header {
    padding: 10px 0 11px 20px;
}

    .modal .modal-header .close,
    .modal .modal-header .close:hover {
        opacity: 1;
        outline: 0 none;
        margin-right: 0;
    }

.modal .modal-content {
    border: 0 none;
}

.modal-backdrop.show {
    opacity: 1;
    background: #ffffff;
}

.cta-light {
    height: 44px;
    min-width: 132px;
    border-radius: 8px;
    background: #F9F7F6;
    color: #595959;
    font-size: 12px;
    line-height: 15px;
    text-align: center;
    display: inline-block;
    text-decoration: none;
    padding-top: 15px;
    font-family: 'Helvetica Neue LT W05_45 Light', Helvetica, sans-serif;
    font-weight: 300;
    font-family: 'Helvetica Neue LT W05_75 Bold', Helvetica, sans-serif;
    font-weight: 700;
    font-weight: normal;
}

    .cta-light:hover {
        color: #595959;
        text-decoration: none;
    }

.hero--video .hero--copy__img {
    display: none;
}

.hero--video__container {
    display: block;
}

    .hero--video__container:after {
        opacity: 0.5;
        background-color: #333333;
        content: '';
        top: 0;
        left: 0;
        width: 100%;
        height: 100%;
        position: absolute;
        z-index: 2;
    }

    .hero--video__container #hero--player-yuk {
        position: absolute;
        top: 0;
        left: 0;
        height: 100% !important;
        width: 100% !important;
        z-index: 1;
    }

.hero--copy {
    position: relative;
    max-width: 1900px;
    width: 100%;
    margin: 0 auto;
    overflow: hidden;
    padding-bottom: 55px;
}

.hero--copy__img {
    position: relative;
    text-align: center;
}

    .hero--copy__img img {
        height: 700px;
        object-fit: cover;
    }

    .hero--copy__img:before {
        opacity: 0.5;
        background-color: #333333;
        content: '';
        top: 0;
        left: 0;
        width: 100%;
        height: 100%;
        position: absolute;
        z-index: 2;
    }

.hero--copy__card {
    position: absolute;
    top: 50%;
    max-width: 750px;
    width: 100%;
    left: 50%;
    padding: 10px 15px;
    text-align: center;
    -ms-transform: translate(-50%, -50%);
    transform: translate(-50%, -50%);
    color: #ffffff;
    z-index: 3;
}

    .hero--copy__card h1 {
        color: #ffffff;
        font-size: 50px;
        line-height: 60px;
        margin-bottom: 20px;
    }

    .hero--copy__card p {
        font-family: 'Helvetica Neue LT W05_45 Light', Helvetica, sans-serif;
        font-weight: 300;
        font-family: 'Helvetica Neue LT W05_65 Medium', Helvetica, sans-serif;
        font-weight: 600;
    }

.hero--copy__card--left {
    left: 100px;
    -ms-transform: translate(0, -50%);
    transform: translate(0, -50%);
    text-align: left;
}

.hero--copy__card--right {
    left: auto;
    right: 100px;
    -ms-transform: translate(0, -50%);
    transform: translate(0, -50%);
    text-align: right;
}

.hero--fullimage {
    padding-bottom: 55px;
}

.hero__img {
    text-align: center;
}

.hero__card {
    padding: 60px 35px 35px;
    background: #ffffff;
    margin-top: -55px;
    box-shadow: 0 0 30px 0 rgba(151, 151, 151, 0.2);
    text-align: center;
}

    .hero__card h1 {
        position: relative;
        margin-bottom: 63px;
        font-size: 35px;
        line-height: 45px;
    }

        .hero__card h1:before {
            position: absolute;
            content: '';
            background: #d8d8d8;
            bottom: -35px;
            left: 50%;
            -ms-transform: translateX(-50%);
            transform: translateX(-50%);
            width: 80px;
            height: 1px;
        }

.hero__btn {
    background: #545454;
    display: inline-block;
    text-decoration: none;
    color: #ffffff;
    padding: 15px 30px;
    line-height: 1em;
    min-width: 160px;
    border-radius: 8px;
    font-family: 'Helvetica Neue LT W05_45 Light', Helvetica, sans-serif;
    font-weight: 300;
    font-family: 'Helvetica Neue LT W05_75 Bold', Helvetica, sans-serif;
    font-weight: 700;
    transition: background 0.35s, opacity 0.5s;
    margin-bottom: 30px;
}

    .hero__btn:hover {
        color: #ffffff;
        background: #333333;
        text-decoration: none;
    }

.hero__buttons {
    display: -ms-flexbox;
    display: flex;
    -ms-flex-direction: column;
    flex-direction: column;
    -ms-flex-pack: distribute;
    justify-content: space-around;
    border-top: solid 1px #d8d8d8;
    max-width: 540px;
    margin: 0 auto;
    padding: 0 0 33px 0;
}

    .hero__buttons .hero__button {
        display: -ms-flexbox;
        display: flex;
        -ms-flex-direction: column;
        flex-direction: column;
        text-decoration: none;
        color: #333333;
        padding: 20px 0 17px;
        border-bottom: solid 1px #d8d8d8;
        outline: 0 none;
    }

        .hero__buttons .hero__button img {
            height: 34px;
            width: 48px;
            margin: 0 auto;
        }

        .hero__buttons .hero__button span {
            font-size: 13px;
            line-height: 16px;
            padding-top: 8px;
        }

@media screen and (min-width: 992px) {
    .modal .modal-header {
        padding: 25px 0 26px 20px;
    }

    .modal .modal-content {
        border: 0 none;
    }

    .hero--fullimage {
        padding-bottom: 95px;
    }

    .hero--copy {
        padding-bottom: 95px;
    }

    .hero__card {
        padding: 100px 100px 50px;
        margin-top: -100px;
    }

        .hero__card h1 {
            margin-bottom: 70px;
            font-size: 50px;
            line-height: 60px;
        }

            .hero__card h1:before {
                position: absolute;
                content: '';
                background: #d8d8d8;
                bottom: -49px;
                left: 50%;
                -ms-transform: translateX(-50%);
                transform: translateX(-50%);
                width: 80px;
                height: 1px;
            }

        .hero__card p {
            margin-bottom: 48px;
        }

    .hero__buttons {
        -ms-flex-direction: row;
        flex-direction: row;
        padding: 50px 0;
    }

        .hero__buttons .hero__button {
            padding: 0;
            border-bottom: 0 none;
        }
}

@media screen and (max-width: 992px) {
    .hero--copy__card--left {
        left: 0;
    }

    .hero--copy__card--right {
        right: 0;
    }
}

@media screen and (max-width: 767px) {
    .hero--video .hero--copy__img {
        display: block;
    }

    .hero--video__container {
        display: none;
    }

    .hero--copy__card {
        padding: 10px 40px;
    }

        .hero--copy__card h1 {
            font-size: 28px;
            line-height: 36px;
        }

    .hero--copy__card--left {
        left: 0;
    }

    .hero--copy__card--right {
        right: 0;
    }

    .hero--copy__card .hero--copy__cta {
        padding-top: 20px;
    }

    .hero--copy__img img {
        height: 550px;
    }
}

.hero--fenix {
    position: relative;
    background: #9c8d80;
    margin-bottom: 55px;
}

.hero--fenix__logo {
    max-width: 270px;
    position: absolute;
    left: 5vw;
    top: 5vw;
    z-index: 10;
    float: left;
    margin: 0 10px 0 0;
    padding: 0;
}

.hero--fenix__image {
    padding: 0;
    line-height: 0;
    min-height: 250px;
}

    .hero--fenix__image img {
        width: 100%;
        max-width: 100%;
        height: auto;
    }

.hero--fenix__text {
    padding: 5vw;
}

    .hero--fenix__text h1 {
        font-family: 'Helvetica Neue LT W05_45 Light', Helvetica, sans-serif;
        font-weight: 300;
        color: white;
        background-size: 1px 1em;
        box-shadow: inset 0 -0.1em #9c8d80, inset 0 -0.125em #ffffff;
        display: inline;
        text-shadow: -2px -2px #9c8d80, -2px 2px #9c8d80, 2px -2px #9c8d80, 2px 2px #9c8d80;
        font-size: 48px;
        line-height: 1.175;
        text-transform: uppercase;
    }

@media (min-width: 992px) {
    .hero--fenix__text h1 {
        font-size: 52px;
    }
}

@media (min-width: 1200px) {
    .hero--fenix__text h1 {
        font-size: 64px;
    }
}

.hero--fenix__alternate {
    background: #36353b;
}

    .hero--fenix__alternate .align-items-center {
        -ms-flex-align: unset !important;
        align-items: unset !important;
    }

    .hero--fenix__alternate h1 {
        text-shadow: none;
        box-shadow: none;
        text-transform: unset;
        font-size: 45px;
    }

    .hero--fenix__alternate h2 {
        position: relative;
        padding-top: 18px;
        margin-top: 60px;
        color: #fff;
        font-size: 18px;
        line-height: 1.2;
        text-transform: unset;
        font-family: 'Helvetica Neue LT W05_45 Light', Helvetica, sans-serif;
        font-weight: 300;
    }

        .hero--fenix__alternate h2:before {
            position: absolute;
            content: '';
            top: 0;
            left: 0;
            width: 96px;
            height: 1px;
            background-color: #fff;
        }

@media (min-width: 992px) {
    h1 {
        font-size: 3.25em;
    }

    .col-lg-40 {
        -ms-flex: 0 0 40%;
        flex: 0 0 40%;
        -ms-flex-preferred-size: 40%;
        flex-basis: 40%;
        max-width: 40%;
    }

    .col-lg-60 {
        -ms-flex: 0 0 60%;
        flex: 0 0 60%;
        -ms-flex-preferred-size: 60%;
        flex-basis: 60%;
        max-width: 60%;
    }

    .hero--fenix {
        margin-bottom: 95px;
    }
}

@media (min-width: 1200px) {
    h1 {
        font-size: 3.25em;
    }
}

.cta-dark {
    background: #545454;
    display: inline-block;
    text-decoration: none;
    color: #ffffff;
    padding: 15px 50px;
    line-height: 1em;
    min-width: 160px;
    border-radius: 8px;
    font-family: 'Helvetica Neue LT W05_45 Light', Helvetica, sans-serif;
    font-weight: 300;
    font-family: 'Helvetica Neue LT W05_75 Bold', Helvetica, sans-serif;
    font-weight: 700;
    transition: background 0.35s, opacity 0.5s;
    margin-bottom: 30px;
    font-size: 12px;
}

    .cta-dark:hover {
        color: #ffffff;
        background: #333333;
        text-decoration: none;
    }

.visualizer-cta {
    background: #ffffff;
    text-align: center;
    box-shadow: 0 0 30px 0 rgba(151, 151, 151, 0.2);
    padding: 50px 55px 55px;
    margin-bottom: 80px;
}

.visualizer-cta__copy h2 {
    text-align: center;
    font-size: 28px;
    line-height: 34px;
    margin-bottom: 15px;
}

.visualizer-cta__copy p {
    font-size: 18px;
    margin-bottom: 30px;
}

.visualizer-cta__cta .cta-dark {
    padding: 19px 120px;
    margin-bottom: 0;
}

@media screen and (max-width: 768px) {
    .visualizer-cta {
        padding: 50px 45px 55px;
        margin-bottom: 55px;
    }

    .visualizer-cta__cta .cta-dark {
        padding: 19px 20px;
        margin-bottom: 0;
        width: 100%;
    }
}

.icon-list {
    padding: 0;
    list-style: none;
    margin-bottom: 32px;
}

.accordion .icon-list {
    margin-bottom: 0;
}

.icon-list-item {
    display: block;
    border-bottom: 1px solid rgba(186, 186, 186, 0.5);
}

    .icon-list-item .icon-download, .icon-list-item .icon-pdf, .icon-list-item .icon-external-link {
        font-size: 23px;
        line-height: 1em;
        color: #333;
        display: inherit;
        margin-right: 10px;
    }

    .icon-list-item a {
        display: -ms-flexbox;
        display: flex;
        -ms-flex-align: start;
        align-items: flex-start;
        padding: 10px 8px;
        text-decoration: none;
        color: #333;
    }

    .icon-list-item img {
        margin-right: 8px;
    }

    .icon-list-item strong {
        display: block;
        margin-right: 4px;
    }

@media screen and (min-width: 768px) {
    .icon-list-item a {
        -ms-flex-align: center;
        align-items: center;
    }

    .icon-list-item strong {
        display: inline-block;
    }
}

.related-links {
    margin-bottom: 40px;
}

.related-link, .related-link-download {
    display: block;
    position: relative;
    padding: 16px 40px 16px 8px;
    font-family: 'Helvetica Neue LT W05_45 Light', Helvetica, sans-serif;
    font-weight: 300;
    font-family: 'Helvetica Neue LT W05_75 Bold', Helvetica, sans-serif;
    font-weight: 700;
    border-bottom: 1px solid rgba(186, 186, 186, 0.5);
    text-decoration: none;
    color: #333333;
}

    .related-link:after, .related-link-download:after {
        content: '';
        position: absolute;
        top: 50%;
        right: 16px;
        width: 14px;
        height: 7px;
        background: url("../images/arrow-accordion.svg") center right no-repeat;
        -ms-transform: translateY(-50%) rotate(-90deg);
        transform: translateY(-50%) rotate(-90deg);
    }

    .related-link:hover, .related-link-download:hover {
        color: #333333;
        text-decoration: none;
    }

    .related-link-download:after {
        width: 14px;
        height: 14px;
        background-image: url("../images/download.svg");
        background-size: 14px;
        -ms-transform: translateY(-50%);
        transform: translateY(-50%);
    }

.content-block {
    margin-bottom: 32px;
}

    .content-block p {
        font-family: 'Helvetica Neue LT W05_45 Light', Helvetica, sans-serif;
        font-weight: 300;
        font-size: 14px;
        line-height: 22px;
        margin-bottom: 24px;
    }

@media screen and (min-width: 1200px) {
    .content-block p {
        font-size: 18px;
        line-height: 32px;
        margin-bottom: 32px;
    }
}

.content-block ul, .content-block ol {
    padding-left: 16px;
    margin-bottom: 32px;
}

    .content-block ul li, .content-block ol li {
        font-size: 18px;
        line-height: 32px;
        margin-bottom: 10px;
    }

.content-block-heading {
    font-family: Georgia, serif;
    font-size: 25.68px;
    line-height: 30px;
    margin-bottom: 32px;
}

@media screen and (min-width: 768px) {
    .content-block-heading {
        font-size: 34.24px;
        line-height: 40px;
    }
}

.content-block strong {
    font-family: 'Helvetica Neue LT W05_45 Light', Helvetica, sans-serif;
    font-weight: 300;
    font-family: 'Helvetica Neue LT W05_65 Medium', Helvetica, sans-serif;
    font-weight: 600;
}

.content-block-large {
    margin-bottom: 32px;
}

    .content-block-large p {
        font-family: 'Helvetica Neue LT W05_45 Light', Helvetica, sans-serif;
        font-weight: 300;
        font-size: 16px;
        line-height: 24px;
        margin-bottom: 32px;
    }

@media screen and (min-width: 1200px) {
    .content-block-large p {
        font-size: 20px;
        line-height: 36px;
        margin-bottom: 56px;
    }
}

.content-block-large ul, .content-block-large ol {
    padding-left: 16px;
    margin-bottom: 56px;
}

    .content-block-large ul li, .content-block-large ol li {
        font-size: 20px;
        line-height: 36px;
        margin-bottom: 8px;
    }

.content-block-large .content-block-heading {
    font-family: Georgia, serif;
    font-size: 27.82px;
    line-height: 32px;
    color: #333333;
    text-align: left;
    margin-bottom: 32px;
}

@media screen and (min-width: 768px) {
    .content-block-large .content-block-heading {
        font-size: 38.52px;
        line-height: 44px;
    }
}

.sticky-nav {
    position: fixed;
    top: 50px;
    width: 100%;
    overflow: hidden;
    background: #fff;
    z-index: 100;
    padding: 16px 0;
    box-shadow: 0 0 30px 0 rgba(151, 151, 151, 0.2);
}

.sticky-nav-left {
    padding: 0;
    text-align: center;
}

    .sticky-nav-left p {
        font-family: 'Helvetica Neue LT W05_45 Light', Helvetica, sans-serif;
        font-weight: 300;
        font-family: 'Helvetica Neue LT W05_75 Bold', Helvetica, sans-serif;
        font-weight: 700;
        font-size: 16px;
        line-height: 24px;
        margin: 0 0 10px;
    }

.sticky-nav-right {
    display: -ms-flexbox;
    display: flex;
    -ms-flex-pack: center;
    justify-content: center;
    height: 34px;
    padding: 0;
}

    .sticky-nav-right > * {
        display: -ms-flexbox;
        display: flex;
        -ms-flex-align: center;
        align-items: center;
        padding-top: 0;
        padding-bottom: 0;
    }

    .sticky-nav-right .btn, .sticky-nav-right .cart-total-cta, .sticky-nav-right .checkout form [type="submit"], .checkout form .sticky-nav-right [type="submit"], .sticky-nav-right .cookie-policy-cta {
        -ms-flex-pack: center;
        justify-content: center;
        padding-left: 30px;
        padding-right: 30px;
        min-width: 40%;
    }

.sticky-nav + * {
    margin-top: 80px;
}

.sticky-nav + .hero {
    margin-top: 64px;
}

@media screen and (min-width: 768px) {
    .sticky-nav {
        top: 60px;
    }

        .sticky-nav > .container, .sticky-nav > .iframe-container {
            display: -ms-flexbox;
            display: flex;
            -ms-flex-align: center;
            align-items: center;
            -ms-flex-pack: end;
            justify-content: flex-end;
        }

    .sticky-nav-left {
        display: -ms-flexbox;
        display: flex;
        -ms-flex-align: center;
        align-items: center;
        padding: 0 25px 0 0;
    }

        .sticky-nav-left > * {
            margin-right: 24px;
        }

        .sticky-nav-left p {
            margin: 0;
        }

    .sticky-nav-right {
        padding-left: 25px;
    }

    .sticky-nav + * {
        margin-top: 100px;
    }

    .sticky-nav + .hero {
        margin-top: 34px;
    }
}

@media screen and (min-width: 1200px) {
    .sticky-nav {
        top: 84px;
    }

        .sticky-nav > .container, .sticky-nav > .iframe-container {
            display: -ms-flexbox;
            display: flex;
            -ms-flex-align: center;
            align-items: center;
            -ms-flex-pack: end;
            justify-content: flex-end;
        }

    .sticky-nav-left {
        display: -ms-flexbox;
        display: flex;
        -ms-flex-align: center;
        align-items: center;
        padding: 0;
    }

        .sticky-nav-left p {
            margin: 0;
        }

        .sticky-nav-left > * {
            margin-right: 24px;
        }

    .sticky-nav-right {
        padding-left: 25px;
    }

        .sticky-nav-right select {
            display: none;
        }

        .sticky-nav-right .btn, .sticky-nav-right .cart-total-cta, .sticky-nav-right .checkout form [type="submit"], .checkout form .sticky-nav-right [type="submit"], .sticky-nav-right .cookie-policy-cta {
            min-width: 0;
        }

    .sticky-nav + * {
        margin-top: 80px;
    }

    .sticky-nav + .hero {
        margin-top: 15px;
    }
}

.column-row {
    display: -ms-flexbox;
    display: flex;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
}

.column-row__grid {
    display: -ms-flexbox;
    display: flex;
    -ms-flex-direction: column;
    flex-direction: column;
    -ms-flex-align: stretch;
    align-items: stretch;
}

.up-card {
    margin-bottom: 32px;
    -ms-flex-positive: 1;
    flex-grow: 1;
    background: #ffffff;
    box-shadow: 0 0 30px 0 rgba(151, 151, 151, 0.2);
    display: -ms-flexbox;
    display: flex;
    -ms-flex-direction: column;
    flex-direction: column;
}

    .up-card .btn-dark-gray, .up-card .cookie-policy-cta {
        min-width: 132px;
        height: 44px;
        padding-top: 15px;
    }

.up-card__copy__cta {
    height: 44px;
    margin-top: auto;
}

    .up-card__copy__cta .read-more {
        margin-top: 10px;
    }

.up-card--two .up-card__copy {
    padding: 33px 50px 50px;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-direction: column;
    flex-direction: column;
    -ms-flex-positive: 1;
    flex-grow: 1;
}

.up-card--two .up-card__copy__heading h2 {
    font-size: 28px;
    line-height: 34px;
    margin-bottom: 15px;
}

.up-card--two .up-card__copy__desc p {
    font-size: 16px;
    line-height: 24px;
    margin-bottom: 26px;
}

.up-card--three .up-card__copy {
    padding: 33px 30px 55px;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-direction: column;
    flex-direction: column;
    -ms-flex-positive: 1;
    flex-grow: 1;
}

.up-card--three .up-card__copy__heading h2 {
    font-size: 24px;
    line-height: 30px;
    margin-bottom: 15px;
}

.up-card--three .up-card__copy__desc p {
    font-size: 14px;
    line-height: 24px;
    margin-bottom: 23px;
}

@media screen and (max-width: 992px) {
    .up-card--two .up-card__copy {
        padding: 33px 30px 50px;
    }

    .up-card--three .up-card__copy {
        padding: 33px 30px 55px;
    }
}

@media screen and (max-width: 768px) {
    .up-card__copy__cta {
        height: auto;
    }

        .up-card__copy__cta .read-more {
            margin-top: 0;
        }

    .up-card--two {
        max-width: 540px;
        margin: 0 auto 20px;
    }

        .up-card--two .up-card__copy {
            padding: 33px 25px 50px;
        }

        .up-card--two .up-card__copy__heading h2 {
            font-size: 22px;
            line-height: 28px;
            margin-bottom: 5px;
        }

        .up-card--two .up-card__copy__desc p {
            font-size: 12px;
            line-height: 20px;
            margin-bottom: 26px;
        }

    .up-card--three {
        max-width: 350px;
        margin: 0 auto 20px;
    }

        .up-card--three .up-card__copy {
            padding: 33px 30px 50px;
        }

        .up-card--three .up-card__copy__heading h2 {
            font-size: 20px;
            line-height: 26px;
            margin-bottom: 5px;
        }

        .up-card--three .up-card__copy__desc p {
            font-size: 12px;
            line-height: 20px;
            margin-bottom: 26px;
        }
}

.featured-swatch {
    margin-bottom: 30px;
}

.featured-swatch__cta {
    display: block;
    text-decoration: none;
}

    .featured-swatch__cta:hover {
        text-decoration: none;
    }

.featured-swatch__img img {
    width: 100%;
}

.featured-swatch__copy {
    background: #ffffff;
    padding: 15px;
    border-top: solid 2px #d8d8d8;
}

.featured-swatch__no {
    color: #595959;
    display: block;
    font-size: 9px;
    line-height: 10px;
    font-family: 'Helvetica Neue LT W05_45 Light', Helvetica, sans-serif;
    font-weight: 300;
    font-family: 'Helvetica Neue LT W05_75 Bold', Helvetica, sans-serif;
    font-weight: 700;
    padding-bottom: 4px;
}

.featured-swatch__title {
    color: #333333;
    font-size: 14px;
    line-height: 18px;
    display: block;
    padding-bottom: 4px;
}

.featured-swatch__heading {
    color: #545454;
    font-size: 12px;
    line-height: 16px;
    font-family: 'Helvetica Neue LT W05_45 Light', Helvetica, sans-serif;
    font-weight: 300;
    font-family: 'Helvetica Neue LT W05_75 Bold', Helvetica, sans-serif;
    font-weight: 700;
    display: block;
}

@media screen and (max-width: 768px) {
    .featured-swatch {
        max-width: 350px;
        margin: 0 auto 20px;
    }
}

#swatch-overlay-container {
    position: fixed;
    top: 0;
    bottom: 0;
    left: 0;
    right: 0;
    transform: translate3d(100%, 0, 0);
    transition: transform 0.5s ease-in-out;
    z-index: 501;
}

.overlay-visible #swatch-overlay-container {
    transform: translate3d(0, 0, 0);
    transition: transform 0.5s ease-in-out;
}

.overlay-visible {
    overflow: hidden;
}

    .overlay-visible .swatch-overlay {
        max-height: 100%;
        overflow: auto;
    }

.swatch-overlay .product-list-item {
    transform: translate3d(0px, 0, 0);
}

.swatch-overlay-mask {
    position: fixed;
    top: 0;
    bottom: 0;
    left: 0;
    right: 0;
    background: rgba(255, 255, 255, 0.94);
    z-index: 500;
    opacity: 0;
    visibility: hidden;
    transition: 0.5s ease-in-out;
    transition-property: opacity, visibility;
}

.mask-visible .swatch-overlay-mask {
    opacity: 1;
    visibility: visible;
    transition: 0.5s ease-in-out;
    transition-property: opacity, visibility;
}

.swatch-overlay .rotation-wrapper-outer {
    display: table;
}

.swatch-overlay .rotation-wrapper-inner {
    padding: 50% 0;
    height: 0;
}

.swatch-overlay .rotation-wrapper-inner__tablet {
    padding: 20% 0;
}

.swatch-overlay-swatch {
    position: relative;
}

.swatch-overlay-image {
    display: block;
    -ms-transform-origin: top left;
    transform-origin: top left;
    -ms-transform: rotate(90deg) translate(0, -100%);
    transform: rotate(90deg) translate(0, -100%);
    margin-top: -50%;
    max-height: 100vw;
    max-width: 100%;
}

.swatch-overlay .tick {
    display: block;
    position: absolute;
    font-size: 8px;
    padding-right: 2px;
    font-family: 'Helvetica Neue LT W05_45 Light', Helvetica, sans-serif;
    font-weight: 300;
    font-family: 'Helvetica Neue LT W05_65 Medium', Helvetica, sans-serif;
    font-weight: 600;
    color: #979797;
    border-right: 1px solid rgba(186, 186, 186, 0.5);
    -ms-transform-origin: 0 0;
    transform-origin: 0 0;
}

.swatch-overlay-ruler:before {
    content: "";
    position: absolute;
    top: 0;
    left: 0;
    border-right: 1px solid rgba(186, 186, 186, 0.5);
    border-bottom: 1px solid rgba(186, 186, 186, 0.5);
    width: 16px;
    height: 16px;
    background: #fff;
}

.swatch-overlay-ruler-x, .swatch-overlay-ruler-y {
    position: absolute;
    background: #fff;
    -ms-transform-origin: top left;
    transform-origin: top left;
}

.swatch-overlay-ruler-x {
    height: 16px;
    top: 0;
    left: 16px;
    right: 0;
}

    .swatch-overlay-ruler-x .tick {
        -ms-transform: translateX(-100%);
        transform: translateX(-100%);
        height: 100%;
    }

    .swatch-overlay-ruler-x .tick-one-quarter {
        left: 25%;
    }

    .swatch-overlay-ruler-x .tick-one-half {
        left: 50%;
    }

    .swatch-overlay-ruler-x .tick-three-quarters {
        left: 75%;
    }

    .swatch-overlay-ruler-x .tick-full {
        left: 100%;
    }

.swatch-overlay-ruler-y {
    width: 16px;
    top: 16px;
    bottom: 0;
}

    .swatch-overlay-ruler-y .tick {
        -ms-transform: rotate(90deg) translateY(-100%) translateX(-100%);
        transform: rotate(90deg) translateY(-100%) translateX(-100%);
        height: 16px;
        width: auto;
    }

    .swatch-overlay-ruler-y .tick-one-quarter {
        top: 25%;
    }

    .swatch-overlay-ruler-y .tick-one-half {
        top: 50%;
    }

    .swatch-overlay-ruler-y .tick-three-quarters {
        top: 75%;
    }

    .swatch-overlay-ruler-y .tick-full {
        top: 100%;
    }

.swatch-overlay-content {
    display: -ms-flexbox;
    display: flex;
    -ms-flex-direction: column;
    flex-direction: column;
}

.swatch-overlay-info {
    background: #fff;
    position: relative;
    padding: 76px 24px 96px;
}

.swatch-overlay-key {
    position: absolute;
    top: 8px;
    left: 24px;
    font-family: 'Helvetica Neue LT W05_45 Light', Helvetica, sans-serif;
    font-weight: 300;
    font-family: 'Helvetica Neue LT W05_55 Roman', Helvetica, sans-serif;
    font-weight: 400;
    font-size: 12px;
}

    .swatch-overlay-key:before {
        content: "";
        display: block;
        margin-left: 4px;
        width: 0;
        height: 0;
        border-style: solid;
        border-width: 0 4px 4px 4px;
        border-color: transparent transparent #595959 transparent;
    }

.swatch-overlay-close {
    position: absolute;
    top: 16px;
    right: 16px;
}

.swatch-overlay .icon-list-item strong {
    margin-right: 0;
}

@keyframes overlayLoadingRotate {
    from {
        transform: rotate(0) translate(-50%, -50%);
    }

    to {
        transform: rotate(360deg) translate(-50%, -50%);
    }
}

@media screen and (min-width: 992px) {
    #swatch-overlay-container {
        left: auto;
    }

    .swatch-overlay-content {
        -ms-flex-direction: row;
        flex-direction: row;
        max-width: 1080px;
        height: auto;
        overflow: hidden;
        margin-left: auto;
        background: transparent;
        box-shadow: 0 0 20px rgba(0, 0, 0, 0.1);
    }

    .swatch-overlay-swatch {
        width: 100%;
        height: auto;
    }

    .swatch-overlay-info {
        padding: 80px;
        max-height: calc(100vh - 16px) !important;
    }

        .swatch-overlay-info::after {
            display: block;
            clear: both;
            content: "";
        }
}

@media screen and (min-width: 992px) and (min-width: 767px) {
    .swatch-overlay-info {
        overflow-y: auto;
    }
}

@media screen and (min-width: 992px) {
    .swatch-overlay-image {
        -ms-transform: rotate(0) translateX(0);
        transform: rotate(0) translateX(0);
        max-height: calc(100vh - 16px) !important;
        width: 100%;
        height: auto;
    }

    .swatch-overlay-key {
        top: 24px;
        left: 8px;
        padding-right: 124px;
    }

        .swatch-overlay-key em {
            display: block;
            margin-left: 16px;
        }

        .swatch-overlay-key:before {
            position: relative;
            bottom: 4px;
            display: inline-block;
            margin: 0 8px 0 0;
            -ms-transform: rotate(-90deg);
            transform: rotate(-90deg);
        }

    .swatch-overlay-key--square em {
        display: inline-block;
        margin-left: 0;
    }

    .swatch-overlay-close {
        top: 32px;
        right: 32px;
    }

    .rotation-wrapper-outer {
        display: block;
    }

    .rotation-wrapper-inner {
        padding: 16px 0 0 16px !important;
        height: auto;
    }

    .swatch-overlay-image {
        display: block;
        -ms-transform-origin: top left;
        transform-origin: top left;
        -ms-transform: rotate(0) translate(0, 0);
        transform: rotate(0) translate(0, 0);
        margin-top: 0;
        max-height: none;
    }
}

@media screen and (max-width: 991px) {
    #BlowupLens {
        border: 3px solid #fff !important;
        -ms-transform: rotate(90deg);
        transform: rotate(90deg);
    }
}

@media screen and (max-width: 767px) {
    #BlowupLens {
        height: 100px !important;
        width: 100px !important;
        border: 2px solid #fff !important;
    }
}

#fullsheet-popup .carousel-info {
    opacity: 1;
}

#fullsheet-popup .swatch-overlay .rotation-wrapper-inner {
    padding: 16px 0 0 16px;
    height: auto;
}

#fullsheet-popup .swatch-overlay-image {
    -ms-transform: rotate(0) translate(0, 0);
    transform: rotate(0) translate(0, 0);
}

#fullsheet-popup .swatch-overlay-content {
    -ms-flex-pack: center;
    justify-content: center;
    background: #333333;
    padding: 10px 0;
    -ms-flex-direction: row;
    flex-direction: row;
    max-width: 1080px;
    height: auto;
    overflow: hidden;
    margin-left: auto;
}

#fullsheet-popup .swatch-overlay-swatch {
    overflow: hidden;
    max-width: 441px;
}

.swatch-overlay-swatch {
    height: auto;
}

@media screen and (min-width: 991px) {
    .swatch-overlay-swatch--default {
        max-width: 441px;
    }
}

@media screen and (min-width: 991px) {
    .swatch-overlay-swatch--square {
        width: auto;
        height: auto;
    }
}

@media screen and (min-width: 992px) {
    .swatch-overlay-swatch--square {
        width: 450px;
        height: 450px;
    }
}

@media screen and (min-width: 1024px) {
    .swatch-overlay-swatch--square {
        width: 500px;
        height: 500px;
    }
}

@media screen and (min-width: 1025px) {
    .swatch-overlay-swatch--square {
        width: 540px;
        height: 540px;
    }
}

.swatch-overlay-info {
    padding: 80px;
}

    .swatch-overlay-info::after {
        display: block;
        clear: both;
        content: "";
    }

@media screen and (min-width: 992px) {
    .swatch-overlay-info {
        max-height: calc(100vh - 16px) !important;
        overflow-y: auto;
    }
}

@media screen and (min-width: 992px) {
    .swatch-overlay-info--square {
        width: 450px;
    }
}

@media screen and (min-width: 1024px) {
    .swatch-overlay-info--square {
        width: 500px;
    }
}

@media screen and (min-width: 1025px) {
    .swatch-overlay-info--square {
        width: 540px;
    }
}

.swatch-overlay .rotation-wrapper-inner--default .swatch-overlay-image {
    max-width: 98vw;
}

@media screen and (max-width: 991px) {
    .swatch-overlay .rotation-wrapper-inner--square {
        padding: 20% 0;
    }
}

.swatch-overlay .rotation-wrapper-outer {
    width: 100%;
}

@media screen and (max-width: 991px) {
    .swatch-overlay .rotation-wrapper-outer {
        width: auto;
    }
}

#compare-finishes-modal {
    background: #fafafa;
}

    #compare-finishes-modal .modal-content {
        width: calc(100% - 32px);
        max-width: 920px;
        margin: 16px auto;
        padding: 0 16px;
        border-radius: 0;
        box-shadow: 0 0 30px 0 rgba(151, 151, 151, 0.2);
    }

    #compare-finishes-modal .modal-body {
        padding: 0;
    }

    #compare-finishes-modal .modal-header {
        display: -ms-flexbox;
        display: flex;
        -ms-flex-align: center;
        align-items: center;
        padding: 24px 0;
        margin-bottom: 32px;
        border-bottom: 1px solid rgba(186, 186, 186, 0.5);
    }

        #compare-finishes-modal .modal-header > * {
            margin: 0;
        }

.compare-finishes-item {
    margin: 0 auto;
    max-width: 275px;
    border-bottom: 1px solid rgba(186, 186, 186, 0.5);
    margin-bottom: 32px;
}

.compare-finishes-image {
    margin-bottom: 16px;
}

.compare-finishes-title {
    font-family: 'Helvetica Neue LT W05_45 Light', Helvetica, sans-serif;
    font-weight: 300;
    font-size: 14px;
    line-height: 22px;
    margin-bottom: 24px;
    font-family: 'Helvetica Neue LT W05_45 Light', Helvetica, sans-serif;
    font-weight: 300;
    font-family: 'Helvetica Neue LT W05_65 Medium', Helvetica, sans-serif;
    font-weight: 600;
}

@media screen and (min-width: 1200px) {
    .compare-finishes-title {
        font-size: 18px;
        line-height: 32px;
        margin-bottom: 32px;
    }
}

.compare-finishes .compare-finishes-title {
    margin-bottom: 8px;
}

.compare-finishes-note {
    display: block;
    font-size: 12px;
    margin-bottom: 16px;
}

@media screen and (min-width: 768px) {
    #compare-finishes-modal .modal-header {
        padding: 32px 0 40px;
    }

    #compare-finishes-modal .modal-content {
        padding: 0px 32px 56px;
    }

    .compare-finishes {
        display: -ms-flexbox;
        display: flex;
        -ms-flex-wrap: wrap;
        flex-wrap: wrap;
        -ms-flex-pack: justify;
        justify-content: space-between;
        -ms-flex-align: stretch;
        align-items: stretch;
    }

    .compare-finishes-item {
        min-height: 250px;
        width: 275px;
    }
}

.size-grade-details .nav-tabs .nav-item {
    display: none;
}

.product-detail-results .tab-pane {
    display: none;
}

.loader-active {
    opacity: 0.1;
}

.loader {
    border: 5px solid #f3f3f3;
    border-radius: 50%;
    border-top: 5px solid #333;
    width: 50px;
    height: 50px;
    /* Safari */
    animation: spin 1s linear infinite;
    display: none;
    margin: 50px auto 50px;
}

/* Safari */

@keyframes spin {
    0% {
        transform: rotate(0deg);
    }

    100% {
        transform: rotate(360deg);
    }
}

.noresults {
    padding-top: 10px;
}

    .noresults p {
        font-size: 16px;
        line-height: 24px;
        margin-bottom: 23px;
    }

.size-grade-container {
    border-top: solid 1px #d8d8d8;
    padding-top: 65px;
    background: #F9F7F6;
    position: relative;
    box-shadow: inset 0 -30px 30px -30px rgba(151, 151, 151, 0.3);
}

    .size-grade-container:before, .size-grade-container:after {
        position: absolute;
        content: '';
        background: #F9F7F6;
        top: 0;
        height: 100%;
        width: 100%;
        box-shadow: inset 0 -30px 30px -30px rgba(151, 151, 151, 0.3);
    }

    .size-grade-container:before {
        left: 100%;
    }

    .size-grade-container:after {
        right: 100%;
    }

.nav-tabs {
    border: 0 none;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-align: end;
    align-items: flex-end;
}

    .nav-tabs .nav-item {
        margin-right: 30px;
    }

        .nav-tabs .nav-item:last-child {
            margin-right: 0;
        }

        .nav-tabs .nav-item a {
            font-family: 'Helvetica Neue LT W05_45 Light', Helvetica, sans-serif;
            font-weight: 300;
            font-family: 'Helvetica Neue LT W05_65 Medium', Helvetica, sans-serif;
            font-weight: 600;
            text-decoration: none;
            font-size: 16px;
            line-height: 24px;
            background: #595959;
            color: #ffffff;
            border-radius: 8px 8px 0 0;
            padding: 11px 32px;
        }

            .nav-tabs .nav-item a:hover {
                padding: 12px 33px;
                border: 0 none;
            }

            .nav-tabs .nav-item a.active {
                text-decoration: none;
                background: #ffffff;
                color: #333333;
                border: 0 none;
                padding: 20px 32px;
            }

.size-grade__copy h2 {
    font-size: 32px;
    line-height: 40px;
    margin-bottom: 16px;
}

.size-grade__copy p {
    font-size: 16px;
    line-height: 24px;
    margin-bottom: 40px;
}

.size-grade-tab-content {
    background: #ffffff;
    position: relative;
}

    .size-grade-tab-content:before, .size-grade-tab-content:after {
        position: absolute;
        content: '';
        background: #ffffff;
        top: 0;
        height: 100%;
        width: 100%;
    }

    .size-grade-tab-content:before {
        left: 100%;
    }

    .size-grade-tab-content:after {
        right: 100%;
    }

    .size-grade-tab-content .tab-copy {
        padding-top: 50px;
    }

        .size-grade-tab-content .tab-copy p {
            font-size: 16px;
            line-height: 24px;
            margin-bottom: 23px;
        }

    .size-grade-tab-content select {
        max-width: 350px;
        width: 100%;
        margin-bottom: 50px;
    }

.size-grade-results {
    border-top: solid 1px #d8d8d8;
    padding-top: 50px;
    margin-bottom: 50px;
}

.size-grade-results__copy h3 {
    font-size: 16px;
    line-height: 24px;
    margin: 0;
    font-family: 'Helvetica Neue LT W05_45 Light', Helvetica, sans-serif;
    font-weight: 300;
    font-family: 'Helvetica Neue LT W05_65 Medium', Helvetica, sans-serif;
    font-weight: 600;
}

.size-grade-results__copy p {
    font-size: 14px;
    line-height: 24px;
}

.grade-results .scroll {
    font-size: 10px;
    line-height: 11px;
    padding: 0 10px 15px 0;
    float: right;
    font-family: 'Helvetica Neue LT W05_45 Light', Helvetica, sans-serif;
    font-weight: 300;
    font-family: 'Helvetica Neue LT W05_65 Medium', Helvetica, sans-serif;
    font-weight: 600;
    position: relative;
    display: none;
}

    .grade-results .scroll:before {
        content: '';
        position: absolute;
        bottom: 18px;
        right: 2px;
        width: 6px;
        height: 3px;
        background: url(../images/arrow-nav-down.svg) center bottom no-repeat;
        -ms-transform: rotate(-90deg);
        transform: rotate(-90deg);
    }

    .grade-results .scroll:after {
        content: '';
        position: absolute;
        bottom: 18px;
        right: 0;
        width: 6px;
        height: 3px;
        background: url(../images/arrow-nav-down.svg) center bottom no-repeat;
        -ms-transform: rotate(-90deg);
        transform: rotate(-90deg);
    }

.grade-results .grade-table {
    margin-bottom: 50px;
    overflow-x: auto;
    clear: both;
}

.grade-results .grade-table__heading {
    display: -ms-flexbox;
    display: flex;
    font-family: 'Helvetica Neue LT W05_45 Light', Helvetica, sans-serif;
    font-weight: 300;
    font-family: 'Helvetica Neue LT W05_65 Medium', Helvetica, sans-serif;
    font-weight: 600;
    font-size: 12px;
    line-height: 24px;
    border-bottom: solid 2px #d8d8d8;
    width: 100%;
}

    .grade-results .grade-table__heading.fullwidth {
        width: 1076px;
    }

.grade-results .grade-table__heading__title--left {
    width: 200px;
    background: #F9F7F6;
    height: 90px;
    position: relative;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-direction: column;
    flex-direction: column;
    -ms-flex-pack: justify;
    justify-content: space-between;
}

    .grade-results .grade-table__heading__title--left:before {
        position: absolute;
        content: '';
        top: 0;
        width: 0;
        height: 0;
        border-style: solid;
        border-width: 0 200px 90px 0;
        border-color: transparent #fff transparent transparent;
    }

    .grade-results .grade-table__heading__title--left .heading__left--top {
        -ms-flex-pack: end;
        justify-content: flex-end;
        display: -ms-flexbox;
        display: flex;
        position: relative;
        padding-right: 16px;
        height: 45px;
        -ms-flex-align: center;
        align-items: center;
    }

    .grade-results .grade-table__heading__title--left .heading__left--bottom {
        padding-left: 16px;
        height: 45px;
        -ms-flex-align: center;
        align-items: center;
        display: -ms-flexbox;
        display: flex;
    }

.grade-results .grade-table__heading__title--right {
    display: -ms-flexbox;
    display: flex;
    -ms-flex-direction: column;
    flex-direction: column;
    -ms-flex-positive: 1;
    flex-grow: 1;
    border-left: solid 2px #d8d8d8;
}

    .grade-results .grade-table__heading__title--right .heading__right--top {
        height: 45px;
        border-bottom: solid 1px #d8d8d8;
        -ms-flex-align: center;
        align-items: center;
        display: -ms-flexbox;
        display: flex;
        -ms-flex-pack: center;
        justify-content: center;
        border-right: solid 2px #d8d8d8;
    }

    .grade-results .grade-table__heading__title--right .heading__right--bottom {
        display: -ms-flexbox;
        display: flex;
    }

        .grade-results .grade-table__heading__title--right .heading__right--bottom .sub-heading {
            height: 45px;
            display: -ms-flexbox;
            display: flex;
            -ms-flex-align: center;
            align-items: center;
            -ms-flex-pack: center;
            justify-content: center;
            -ms-flex-positive: 1;
            flex-grow: 1;
            -ms-flex-preferred-size: 0;
            flex-basis: 0;
            -ms-flex-negative: 0;
            flex-shrink: 0;
            border-right: solid 1px #d8d8d8;
        }

            .grade-results .grade-table__heading__title--right .heading__right--bottom .sub-heading:last-child {
                border-right: solid 2px #d8d8d8;
            }

.grade-results .grade-table__row {
    display: -ms-flexbox;
    display: flex;
    border-bottom: solid 1px #d8d8d8;
    width: 100%;
}

    .grade-results .grade-table__row.fullwidth {
        width: 1076px;
    }

.grade-results .grade-table__row__title--left {
    width: 200px;
    font-size: 12px;
    line-height: 24px;
    background: #F9F7F6;
}

    .grade-results .grade-table__row__title--left .row__left--top {
        height: 45px;
        display: -ms-flexbox;
        display: flex;
        -ms-flex-align: center;
        align-items: center;
        padding-left: 16px;
    }

.grade-results .grade-table__row__title--right {
    -ms-flex-positive: 1;
    flex-grow: 1;
}

    .grade-results .grade-table__row__title--right .row__right--bottom {
        display: -ms-flexbox;
        display: flex;
        border-left: solid 2px #d8d8d8;
    }

        .grade-results .grade-table__row__title--right .row__right--bottom .sub-heading {
            -ms-flex-positive: 1;
            flex-grow: 1;
            -ms-flex-preferred-size: 0;
            flex-basis: 0;
            -ms-flex-negative: 0;
            flex-shrink: 0;
            display: -ms-flexbox;
            display: flex;
            -ms-flex-align: center;
            align-items: center;
            -ms-flex-pack: center;
            justify-content: center;
            height: 45px;
            border-right: solid 1px #d8d8d8;
        }

            .grade-results .grade-table__row__title--right .row__right--bottom .sub-heading:last-child {
                border-right: solid 2px #d8d8d8;
            }

            .grade-results .grade-table__row__title--right .row__right--bottom .sub-heading .active {
                position: relative;
                display: inline-block;
                width: 23px;
                height: 23px;
                -ms-transform: rotate(45deg);
                transform: rotate(45deg);
                border-radius: 50%;
            }

                .grade-results .grade-table__row__title--right .row__right--bottom .sub-heading .active:before {
                    position: absolute;
                    width: 3px;
                    height: 17px;
                    background-color: #000;
                    left: 15px;
                    top: 4px;
                    content: '';
                }

                .grade-results .grade-table__row__title--right .row__right--bottom .sub-heading .active:after {
                    position: absolute;
                    width: 5px;
                    height: 3px;
                    background-color: #000;
                    left: 10px;
                    top: 18px;
                    content: '';
                }

.product-detail-results .size-grade-results:first-child {
    border-top: 0 none;
}

@media screen and (max-width: 1200px) {
    .grade-results .scroll {
        display: block;
    }
}

@media screen and (max-width: 768px) {
    .size-grade-container {
        padding-top: 40px;
    }

    .size-grade__copy h2 {
        font-size: 24px;
        line-height: 30px;
        margin-bottom: 16px;
    }

    .size-grade__copy p {
        font-size: 12px;
        line-height: 20px;
        margin-bottom: 40px;
    }

    .nav-tabs {
        border: 0 none;
        display: -ms-flexbox;
        display: flex;
        -ms-flex-align: end;
        align-items: flex-end;
    }

        .nav-tabs .nav-item {
            margin-right: 15px;
        }

            .nav-tabs .nav-item:last-child {
                margin-right: 0;
            }

            .nav-tabs .nav-item a {
                font-size: 12px;
                line-height: 20px;
                padding: 11px 25px;
            }

                .nav-tabs .nav-item a:hover {
                    padding: 12px 26px;
                    border: 0 none;
                }

                .nav-tabs .nav-item a.active {
                    padding: 20px 25px;
                }

    .size-grade-tab-content .tab-copy {
        padding-top: 30px;
    }

        .size-grade-tab-content .tab-copy p {
            font-size: 12px;
            line-height: 20px;
        }

    .size-grade-results {
        border-top: solid 1px #d8d8d8;
        padding-top: 40px;
        margin-bottom: 50px;
    }

    .size-grade-results__copy h3 {
        font-size: 12px;
        line-height: 20px;
    }

    .size-grade-results__copy p {
        font-size: 12px;
        line-height: 20px;
    }

    .grade-results .grade-table {
        margin-bottom: 40px;
    }

    .grade-results .grade-table__heading__title--left {
        width: 100px;
    }

        .grade-results .grade-table__heading__title--left:before {
            border-width: 0 100px 90px 0;
        }

    .grade-results .grade-table__heading__title--right {
        width: calc(100% - 100px);
    }

        .grade-results .grade-table__heading__title--right .heading__right--top {
            -ms-flex-pack: start;
            justify-content: flex-start;
            padding-left: 20px;
        }

    .grade-results .grade-table__row {
        display: -ms-flexbox;
        display: flex;
        border-bottom: solid 1px #d8d8d8;
        width: 100%;
    }

        .grade-results .grade-table__row.fullwidth {
            width: 1076px;
        }

    .grade-results .grade-table__row__title--left {
        width: 100px;
        font-size: 12px;
        line-height: 24px;
        background: #F9F7F6;
    }

        .grade-results .grade-table__row__title--left .row__left--top {
            height: 45px;
            display: -ms-flexbox;
            display: flex;
            -ms-flex-align: center;
            align-items: center;
            padding-left: 16px;
        }

    .grade-results .grade-table__row__title--right {
        -ms-flex-positive: 1;
        flex-grow: 1;
        width: calc(100% - 100px);
    }

        .grade-results .grade-table__row__title--right .row__right--bottom {
            display: -ms-flexbox;
            display: flex;
            border-left: solid 2px #d8d8d8;
        }

            .grade-results .grade-table__row__title--right .row__right--bottom .sub-heading {
                -ms-flex-positive: 1;
                flex-grow: 1;
                -ms-flex-preferred-size: 0;
                flex-basis: 0;
                -ms-flex-negative: 0;
                flex-shrink: 0;
                display: -ms-flexbox;
                display: flex;
                -ms-flex-align: center;
                align-items: center;
                -ms-flex-pack: center;
                justify-content: center;
                height: 45px;
                border-right: solid 1px #d8d8d8;
            }

                .grade-results .grade-table__row__title--right .row__right--bottom .sub-heading:last-child {
                    border-right: solid 2px #d8d8d8;
                }

                .grade-results .grade-table__row__title--right .row__right--bottom .sub-heading .active {
                    position: relative;
                    display: inline-block;
                    width: 23px;
                    height: 23px;
                    -ms-transform: rotate(45deg);
                    transform: rotate(45deg);
                    border-radius: 50%;
                }

                    .grade-results .grade-table__row__title--right .row__right--bottom .sub-heading .active:before {
                        position: absolute;
                        width: 3px;
                        height: 17px;
                        background-color: #000;
                        left: 15px;
                        top: 4px;
                        content: '';
                    }

                    .grade-results .grade-table__row__title--right .row__right--bottom .sub-heading .active:after {
                        position: absolute;
                        width: 5px;
                        height: 3px;
                        background-color: #000;
                        left: 10px;
                        top: 18px;
                        content: '';
                    }
}

@media screen and (max-width: 576px) {
    .grade-results .grade-table__heading__title--right .heading__right--top {
        padding-left: 10px;
    }
}

.cart-message {
    display: block;
    margin-bottom: 50px;
}

    .cart-message p {
        font-family: 'Helvetica Neue LT W05_45 Light', Helvetica, sans-serif;
        font-weight: 300;
        font-family: 'Helvetica Neue LT W05_65 Medium', Helvetica, sans-serif;
        font-weight: 600;
        margin-bottom: 10px;
        display: inline-block;
        padding-right: 10px;
    }

        .cart-message p.success {
            color: #00b300;
        }

        .cart-message p.error {
            color: #da3931;
        }

    .cart-message .cart-close {
        font-family: 'Helvetica Neue LT W05_45 Light', Helvetica, sans-serif;
        font-weight: 300;
        font-family: 'Helvetica Neue LT W05_75 Bold', Helvetica, sans-serif;
        font-weight: 700;
        font-size: 18px;
        background: #000;
        padding: 2px 9px;
        border-radius: 50%;
        cursor: pointer;
        color: #fff;
        display: inline-block;
    }

@media screen and (max-width: 991px) {
    .cart table {
        display: block;
    }

    .cart thead {
        display: none;
    }

    .cart tbody {
        display: block;
    }

        .cart tbody > tr {
            display: block;
        }

            .cart tbody > tr > td {
                display: -ms-flexbox;
                display: flex;
                -ms-flex-align: center;
                align-items: center;
                -ms-flex-positive: 1;
                flex-grow: 1;
            }
}

#cart-container {
    position: relative;
    min-height: 80px;
}

.cart-no-items {
    display: none;
    font-family: Georgia, serif;
    font-size: 23.54px;
    line-height: 28px;
    color: #333333;
    text-align: center;
    color: #545454;
    padding: 24px 0;
    border-top: 1px solid rgba(186, 186, 186, 0.5);
    border-bottom: 1px solid rgba(186, 186, 186, 0.5);
    margin-bottom: 24px;
}

@media screen and (min-width: 768px) {
    .cart-no-items {
        font-size: 29.96px;
        line-height: 34px;
    }
}

.cart select[disabled] {
    border: none;
    background-image: none !important;
    color: #333333;
    padding-left: 0;
}

.cart-header {
    margin-bottom: 48px;
}

    .cart-header p {
        margin-bottom: 0px;
    }

.cart tbody > tr {
    padding: 24px 0;
    border-bottom: 1px solid rgba(186, 186, 186, 0.5);
}

    .cart tbody > tr:first-child {
        border-top: 1px solid rgba(186, 186, 186, 0.5);
    }

    .cart tbody > tr > td {
        margin-bottom: 8px;
        text-align: left;
    }

        .cart tbody > tr > td > * + * {
            -ms-flex-positive: 1;
            flex-grow: 1;
        }

.cart-table {
    width: 100%;
}

    .cart-table-label,
    .cart-table th {
        font-size: 12px;
        width: 100px;
        margin-right: 16px;
        font-family: 'Helvetica Neue LT W05_45 Light', Helvetica, sans-serif;
        font-weight: 300;
        font-family: 'Helvetica Neue LT W05_75 Bold', Helvetica, sans-serif;
        font-weight: 700;
        text-transform: uppercase;
    }

.cart-table-text {
    display: block;
    margin-top: 12px;
}

.cart-header h1 {
    margin-bottom: 24px;
}

.cart-product {
    display: -ms-flexbox;
    display: flex;
    -ms-flex-align: start;
    align-items: flex-start;
}

.cart-product-image {
    width: 100px;
    margin-right: 16px;
}

.cart-product-number {
    font-size: 10px;
    text-transform: uppercase;
    font-family: 'Helvetica Neue LT W05_45 Light', Helvetica, sans-serif;
    font-weight: 300;
    font-family: 'Helvetica Neue LT W05_75 Bold', Helvetica, sans-serif;
    font-weight: 700;
    color: #595959;
    letter-spacing: 0.03125rem;
}

.cart-product-line, .cart-product-remove {
    font-family: 'Helvetica Neue LT W05_45 Light', Helvetica, sans-serif;
    font-weight: 300;
    font-family: 'Helvetica Neue LT W05_65 Medium', Helvetica, sans-serif;
    font-weight: 600;
    font-size: 12px;
}

.cart-total {
    display: -ms-flexbox;
    display: flex;
    -ms-flex-direction: column;
    flex-direction: column;
    margin: 56px 0;
    padding: 32px 24px 56px;
    background: #fff;
    box-shadow: 0 0 30px 0 rgba(151, 151, 151, 0.2);
}

.cart-total-samples {
    font-family: Georgia, serif;
    font-size: 23.54px;
    line-height: 28px;
    color: #333333;
    margin-bottom: 24px;
}

@media screen and (min-width: 768px) {
    .cart-total-samples {
        font-size: 29.96px;
        line-height: 34px;
    }
}

.cart-total-cta {
    -ms-flex-item-align: center;
    -ms-grid-row-align: center;
    align-self: center;
}

    .cart-total-cta.disabled {
        pointer-events: none;
        opacity: 0.65;
    }

.cart-errors {
    background: #da3931;
    padding: 16px;
    color: white;
    margin-top: 32px;
    font-size: 14px;
    line-height: 1.4;
    border-radius: 8px;
    font-family: 'Helvetica Neue LT W05_45 Light', Helvetica, sans-serif;
    font-weight: 300;
    font-family: 'Helvetica Neue LT W05_75 Bold', Helvetica, sans-serif;
    font-weight: 700;
}

    .cart-errors > * {
        font-size: 14px;
        line-height: 1.4;
        margin-bottom: 16px;
    }

@media screen and (min-width: 992px) {
    .cart tbody > tr > td {
        vertical-align: top;
        padding-top: 24px;
        padding-bottom: 24px;
    }

        .cart tbody > tr > td:not(:last-child) {
            padding-right: 16px;
        }

        .cart tbody > tr > td > * {
            min-width: 0;
            width: 100%;
        }

        .cart tbody > tr > td:nth-child(1) {
            min-width: 300px;
        }

        .cart tbody > tr > td:nth-child(2) {
            min-width: 150px;
        }

        .cart tbody > tr > td:nth-child(3) {
            min-width: 120px;
        }

        .cart tbody > tr > td:nth-child(4) {
            min-width: 60px;
        }

    .cart-table {
        width: 100%;
    }

    .cart-table-label {
        display: none;
    }

    .cart-table th {
        padding-bottom: 8px;
    }

    .cart-total {
        padding: 48px 120px;
        -ms-flex-direction: row;
        flex-direction: row;
        -ms-flex-pack: justify;
        justify-content: space-between;
        -ms-flex-align: center;
        align-items: center;
    }

    .cart-total-samples {
        margin-bottom: 0;
    }
}

.loading-overlay {
    position: absolute;
    height: 100%;
    width: 100%;
    background: #fff;
    opacity: 0.5;
    top: 0;
    z-index: 1;
}

.checkout [required] ~ label {
    font-family: 'Helvetica Neue LT W05_45 Light', Helvetica, sans-serif;
    font-weight: 300;
}

    .checkout [required] ~ label:after {
        content: '*';
    }

.checkout .form-group label.error {
    display: none !important;
}

.checkout .checkout-step.complete .form-group textarea {
    min-height: auto;
}

.checkout .form-group.field-hidden {
    display: none;
}

.checkout-step {
    position: relative;
    padding: 24px;
    border-bottom: 1px solid rgba(186, 186, 186, 0.5);
}

    .checkout-step:first-child {
        border-top: 1px solid rgba(186, 186, 186, 0.5);
    }

.checkout-step-title {
    font-family: 'Helvetica Neue LT W05_45 Light', Helvetica, sans-serif;
    font-weight: 300;
    font-size: 12px;
    line-height: 20px;
    font-family: 'Helvetica Neue LT W05_45 Light', Helvetica, sans-serif;
    font-weight: 300;
    font-family: 'Helvetica Neue LT W05_65 Medium', Helvetica, sans-serif;
    font-weight: 600;
    margin-bottom: 16px;
}

@media screen and (min-width: 768px) {
    .checkout-step-title {
        font-size: 14px;
        line-height: 22px;
    }
}

@media screen and (min-width: 1200px) {
    .checkout-step-title {
        font-size: 16px;
        line-height: 24px;
    }
}

.checkout-step-title-required {
    display: block;
    font-size: 12px;
    line-height: 14px;
    margin-left: 18px;
    font-family: 'Helvetica Neue LT W05_45 Light', Helvetica, sans-serif;
    font-weight: 300;
}

.checkout-step-edit {
    display: none;
    position: absolute;
    top: 24px;
    right: 24px;
    -ms-flex-item-align: start;
    align-self: flex-start;
}

.checkout-step.checkout-step-delivery-options .form-group {
    -ms-flex-direction: row;
    flex-direction: row;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
    -ms-flex-align: start;
    align-items: flex-start;
    -ms-flex-pack: justify;
    justify-content: space-between;
}

    .checkout-step.checkout-step-delivery-options .form-group input {
        width: 24px;
        margin-top: 2px;
    }

    .checkout-step.checkout-step-delivery-options .form-group div {
        width: calc(100% - 24px);
        margin-left: 24px;
        color: #545454;
        font-family: 'Helvetica Neue LT W05_45 Light', Helvetica, sans-serif;
        font-weight: 300;
        font-family: 'Helvetica Neue LT W05_55 Roman', Helvetica, sans-serif;
        font-weight: 400;
    }

    .checkout-step.checkout-step-delivery-options .form-group label {
        -ms-flex-order: 0;
        order: 0;
        width: calc(100% - 24px);
        text-align: left;
        margin-bottom: 0 !important;
        font-family: 'Helvetica Neue LT W05_45 Light', Helvetica, sans-serif;
        font-weight: 300;
        font-size: 12px;
        line-height: 20px;
        margin-bottom: 32px;
        font-family: 'Helvetica Neue LT W05_45 Light', Helvetica, sans-serif;
        font-weight: 300;
        font-family: 'Helvetica Neue LT W05_65 Medium', Helvetica, sans-serif;
        font-weight: 600;
    }

@media screen and (min-width: 1200px) {
    .checkout-step.checkout-step-delivery-options .form-group label {
        font-size: 14px;
        line-height: 24px;
    }
}

.checkout-step.checkout-step-delivery-options .form-group label ~ * {
    font-size: 12px;
}

.checkout-step.checkout-step-delivery-options .form-group button {
    width: 100%;
}

.checkout [data-state="active"] {
    background: #fff;
}

    .checkout [data-state="active"] .checkout-form-error {
        color: #da3931;
        border-color: #da3931;
    }

        .checkout [data-state="active"] .checkout-form-error ~ label {
            color: #da3931;
        }

    .checkout [data-state="active"] div.checkout-form-error {
        display: none;
        font-family: 'Helvetica Neue LT W05_45 Light', Helvetica, sans-serif;
        font-weight: 300;
        font-family: 'Helvetica Neue LT W05_65 Medium', Helvetica, sans-serif;
        font-weight: 600;
        font-size: 10px;
    }

.checkout [data-state="incomplete"] .checkout-step-content {
    display: none;
}

.checkout [data-state="incomplete"] .checkout-step-title {
    margin-bottom: 0;
}

.checkout [data-state="incomplete"] .checkout-step-title-required {
    display: none;
}

.checkout [data-state="incomplete"] .checkout-step-content {
    display: none;
}

.checkout [data-state="complete"] .checkout-form-note, .checkout [data-state="complete"] .checkout-form-error {
    display: none;
}

.checkout [data-state="complete"] .form-group {
    margin-bottom: 0;
}

.checkout [data-state="complete"] .form-group-confirm-email {
    display: none;
}

.checkout [data-state="complete"] .checkout-step-label {
    width: 240px;
}

.checkout [data-state="complete"] .checkout-step-content {
    -ms-flex-positive: 1;
    flex-grow: 1;
    padding-left: 16px;
    padding-right: 16px;
}

.checkout [data-state="complete"] .checkout-step-edit {
    display: block;
}

.checkout [data-state="complete"].checkout-step-delivery-options hr {
    display: none;
}

.checkout [data-state="complete"].checkout-step-delivery-options .form-group input {
    display: none !important;
}

    .checkout [data-state="complete"].checkout-step-delivery-options .form-group input[required] ~ label:after {
        content: none;
    }

    .checkout [data-state="complete"].checkout-step-delivery-options .form-group input:checked ~ .form-group-description-short {
        display: block !important;
    }

    .checkout [data-state="complete"].checkout-step-delivery-options .form-group input:checked ~ label {
        display: block !important;
    }

.checkout [data-state="complete"].checkout-step-delivery-options .form-group-description {
    display: none;
}

.checkout [data-state="complete"].checkout-step-delivery-options .form-group-description-short {
    display: none;
    text-align: left;
    margin-left: 0;
}

.checkout [data-state="complete"] input[type="text"],
.checkout [data-state="complete"] input[type="email"],
.checkout [data-state="complete"] input[type="phone"],
.checkout [data-state="complete"] select,
.checkout [data-state="complete"] textarea {
    display: none !important;
    border: none !important;
    padding: 0 !important;
    pointer-events: none;
    background: transparent !important;
    font-size: 14px;
    line-height: 24px;
    font-family: 'Helvetica Neue LT W05_45 Light', Helvetica, sans-serif;
    font-weight: 300;
    width: 100% !important;
}

    .checkout [data-state="complete"] input[type="text"][required],
    .checkout [data-state="complete"] input[type="email"][required],
    .checkout [data-state="complete"] input[type="phone"][required],
    .checkout [data-state="complete"] select[required],
    .checkout [data-state="complete"] textarea[required] {
        display: block !important;
    }

.checkout [data-state="complete"] label {
    display: none !important;
}

.checkout [data-state="complete"] [type="submit"] {
    display: none;
}

.checkout form input,
.checkout form textarea,
.checkout form select,
.checkout form label {
    width: 100%;
    font-size: 12px;
    line-height: 14px;
    transition: 0.5s;
    transition-property: color, border-color, box-shadow;
}

    .checkout form input[required],
    .checkout form textarea[required],
    .checkout form select[required],
    .checkout form label[required] {
        display: block !important;
    }

.checkout form [type="submit"] {
    width: 100%;
}

.checkout form textarea ~ label {
    -ms-flex-item-align: start;
    align-self: flex-start;
    padding-top: 12px;
}

.checkout form.submitted :invalid {
    color: #eb0000;
    border-color: #eb0000;
    box-shadow: inset 0 0 4px #eb0000;
    transition: 0.5s;
    transition-property: color, border-color, box-shadow;
}

    .checkout form.submitted :invalid ~ label {
        color: #eb0000;
        transition: 0.5s;
        transition-property: color, border-color, box-shadow;
    }

    .checkout form.submitted :invalid ~ .checkout-form-error {
        display: block;
    }

.checkout .checkout-form-note {
    text-align: center;
    font-size: 12px;
    line-height: 16px;
    padding-top: 4px;
}

.checkout .form-group {
    display: -ms-flexbox;
    display: flex;
    -ms-flex-direction: column;
    flex-direction: column;
    margin-bottom: 24px;
}

    .checkout .form-group label {
        -ms-flex-order: -1;
        order: -1;
    }

.checkout #reviewitems .form-group {
    -ms-flex-pack: start;
    justify-content: flex-start;
    padding: 32px 0 0;
}

    .checkout #reviewitems .form-group + .form-group {
        padding: 0;
    }

    .checkout #reviewitems .form-group > * {
        width: auto;
        margin-bottom: 0;
        -ms-flex-order: 0;
        order: 0;
    }

    .checkout #reviewitems .form-group > input {
        margin-right: 8px;
    }

    .checkout #reviewitems .form-group > label {
        font-family: 'Helvetica Neue LT W05_45 Light', Helvetica, sans-serif;
        font-weight: 300;
        font-family: 'Helvetica Neue LT W05_75 Bold', Helvetica, sans-serif;
        font-weight: 700;
        font-size: 14px;
    }

    .checkout #reviewitems .form-group button {
        width: 100%;
    }

.checkout .cart-errors {
    margin-top: 0;
}

.checkout .cart-total {
    display: none;
}

@media screen and (min-width: 992px) {
    .checkout-step {
        display: -ms-flexbox;
        display: flex;
        -ms-flex-pack: justify;
        justify-content: space-between;
    }

    .checkout-step-title {
        min-width: 240px;
    }

    .checkout-step-review-items {
        display: block;
    }

    .checkout .checkout-step-delivery-options .checkout-step-content {
        -ms-flex-positive: 1;
        flex-grow: 1;
        padding-left: 16px;
    }

    .checkout .checkout-step-delivery-options .form-group input {
        margin-top: 5px;
    }

    .checkout .checkout-step-delivery-options .form-group label {
        padding-right: 0;
    }

    .checkout .form-group {
        -ms-flex-direction: row;
        flex-direction: row;
        -ms-flex-pack: end;
        justify-content: flex-end;
        -ms-flex-wrap: wrap;
        flex-wrap: wrap;
        -ms-flex-align: center;
        align-items: center;
    }

        .checkout .form-group input,
        .checkout .form-group textarea,
        .checkout .form-group select,
        .checkout .form-group label {
            display: block;
        }

        .checkout .form-group input,
        .checkout .form-group select,
        .checkout .form-group textarea,
        .checkout .form-group [type="submit"] {
            -ms-flex-positive: 0;
            flex-grow: 0;
            -ms-flex-negative: 0;
            flex-shrink: 0;
            margin-right: 0;
            width: 256px;
        }

        .checkout .form-group label {
            width: auto;
            text-align: right;
            padding-right: 16px;
        }

    .checkout-form-note, .checkout-form-error {
        width: 256px;
    }

    .checkout .cart-dropdown {
        min-width: 0;
    }

    .checkout #cart-container .col-xl-8.offset-xl-2 {
        min-width: 100%;
        margin-left: 0;
    }
}

.checkout option {
    color: #333;
}

.noborder {
    border: 0 none !important;
}

.contact-wrapper {
    width: 100%;
}

    .contact-wrapper .thankyou-wrapper {
        background: #fff;
        box-shadow: 0 0 30px 0 rgba(151, 151, 151, 0.2);
        padding: 50px 95px 15px;
        margin-bottom: 30px;
    }

        .contact-wrapper .thankyou-wrapper p.thankyou-msg {
            margin-bottom: 40px;
        }

        .contact-wrapper .thankyou-wrapper .thanks-heading h2 {
            font-size: 28px;
            line-height: 34px;
            padding-right: 21%;
        }

        .contact-wrapper .thankyou-wrapper .thanks-email .form-group {
            border-bottom: solid 1px rgba(186, 186, 186, 0.5);
            padding-bottom: 22px;
            margin: 0 0 25px;
            max-width: 100%;
        }

            .contact-wrapper .thankyou-wrapper .thanks-email .form-group.thanks-checkboxes label {
                font-size: 14px;
                line-height: 24px;
                font-family: 'Helvetica Neue LT W05_45 Light', Helvetica, sans-serif;
                font-weight: 300;
                display: -ms-flexbox;
                display: flex;
                -ms-flex-align: center;
                align-items: center;
                margin-bottom: 12px;
            }

                .contact-wrapper .thankyou-wrapper .thanks-email .form-group.thanks-checkboxes label input[type="checkbox"] {
                    margin-right: 7px;
                    height: 16px;
                    width: 16px;
                }

    .contact-wrapper .content-block-large .content-block-heading {
        font-size: 50px;
        line-height: 58px;
    }

    .contact-wrapper .content-block-large .marginzero {
        margin-bottom: 0;
    }

    .contact-wrapper .required-title {
        font-size: 14px;
        line-height: 24px;
        font-family: 'Helvetica Neue LT W05_45 Light', Helvetica, sans-serif;
        font-weight: 300;
        padding-bottom: 25px;
        border-bottom: solid 1px #979797;
        display: block;
    }

    .contact-wrapper .form-group {
        margin: 25px 0 0 0;
        font-size: 12px;
        line-height: 14px;
        max-width: 350px;
        width: 100%;
    }

        .contact-wrapper .form-group.fullspace {
            max-width: 100%;
        }

        .contact-wrapper .form-group .emailmatch,
        .contact-wrapper .form-group .dropdown-error {
            display: none;
        }

        .contact-wrapper .form-group.privacy-wrapper {
            border-top: solid 1px #979797;
            border-bottom: solid 1px #979797;
            padding: 25px 0 20px;
            display: -ms-flexbox;
            display: flex;
            -ms-flex-align: center;
            align-items: center;
        }

            .contact-wrapper .form-group.privacy-wrapper span {
                font-size: 12px;
                line-height: 14px;
                font-family: 'Helvetica Neue LT W05_45 Light', Helvetica, sans-serif;
                font-weight: 300;
            }

                .contact-wrapper .form-group.privacy-wrapper span.field-validation-error {
                    -ms-flex-order: 2;
                    order: 2;
                    margin-left: 15px;
                }

                .contact-wrapper .form-group.privacy-wrapper span a {
                    color: #2577D3;
                    position: relative;
                }

                    .contact-wrapper .form-group.privacy-wrapper span a:before {
                        position: absolute;
                        content: '*';
                        top: 0;
                        right: 0;
                        width: 0;
                        height: 0;
                        color: #333;
                    }

                .contact-wrapper .form-group.privacy-wrapper span.privacycheckbox {
                    display: none;
                    padding: 4px 0 0 10px;
                    font-family: 'Helvetica Neue LT W05_45 Light', Helvetica, sans-serif;
                    font-weight: 300;
                    font-family: 'Helvetica Neue LT W05_65 Medium', Helvetica, sans-serif;
                    font-weight: 600;
                }

        .contact-wrapper .form-group .input-validation-error {
            border-color: #DA3931;
        }

        .contact-wrapper .form-group .field-validation-error {
            font-size: 11px;
            line-height: 14px;
            font-family: 'Helvetica Neue LT W05_45 Light', Helvetica, sans-serif;
            font-weight: 300;
            font-family: 'Helvetica Neue LT W05_65 Medium', Helvetica, sans-serif;
            font-weight: 600;
            color: #DA3931;
        }

        .contact-wrapper .form-group label {
            font-family: 'Helvetica Neue LT W05_45 Light', Helvetica, sans-serif;
            font-weight: 300;
            margin-bottom: 7px;
        }

        .contact-wrapper .form-group .checkbox-inline {
            font-size: 12px;
            line-height: 14px;
            font-family: 'Helvetica Neue LT W05_45 Light', Helvetica, sans-serif;
            font-weight: 300;
            margin-bottom: 0;
        }

            .contact-wrapper .form-group .checkbox-inline .checkbox {
                margin-right: 7px;
                width: 15px;
                height: 15px;
                position: relative;
            }

        .contact-wrapper .form-group .privacycta {
            font-size: 12px;
            line-height: 14px;
            font-family: 'Helvetica Neue LT W05_45 Light', Helvetica, sans-serif;
            font-weight: 300;
            color: #2577D3;
            position: relative;
        }

            .contact-wrapper .form-group .privacycta:before {
                position: absolute;
                content: '*';
                top: 0;
                right: 0;
                width: 0;
                height: 0;
                color: #333;
            }

        .contact-wrapper .form-group .formsubmit,
        .contact-wrapper .form-group input[type="submit"] {
            background: #545454;
            display: block;
            text-decoration: none;
            color: #ffffff;
            padding: 15px 30px;
            line-height: 1em;
            min-width: 160px;
            border-radius: 8px;
            font-family: 'Helvetica Neue LT W05_45 Light', Helvetica, sans-serif;
            font-weight: 300;
            font-family: 'Helvetica Neue LT W05_75 Bold', Helvetica, sans-serif;
            font-weight: 700;
            transition: background 0.35s, opacity 0.5s;
            width: 100%;
            outline: 0;
        }

            .contact-wrapper .form-group .formsubmit:hover,
            .contact-wrapper .form-group input[type="submit"]:hover {
                color: #ffffff;
                background: #333333;
                text-decoration: none;
            }

        .contact-wrapper .form-group.required label {
            font-family: 'Helvetica Neue LT W05_45 Light', Helvetica, sans-serif;
            font-weight: 300;
            position: relative;
        }

        .contact-wrapper .form-group .inputbox {
            border: 1px solid #595959;
            border-radius: 8px;
            height: 44px;
            font-size: 12px;
            line-height: 14px;
            color: #595959;
            margin-bottom: 3px;
        }

            .contact-wrapper .form-group .inputbox:focus {
                border: 1px solid #595959;
                box-shadow: none;
                outline: 0;
            }

            .contact-wrapper .form-group .inputbox.input-validation-error {
                border-color: #DA3931;
            }

        .contact-wrapper .form-group .inputtextarea {
            border: 1px solid #595959;
            border-radius: 8px;
            font-size: 12px;
            line-height: 14px;
            color: #595959;
            margin-bottom: 3px;
        }

            .contact-wrapper .form-group .inputtextarea:focus {
                border: 1px solid #595959;
                box-shadow: none;
                outline: 0;
            }

            .contact-wrapper .form-group .inputtextarea.input-validation-error {
                border-color: #DA3931;
            }

    .contact-wrapper .accordion.active .accordion-toggle {
        margin-bottom: 5px;
    }

    .contact-wrapper .accordion .accordion-toggle {
        font-size: 28px;
        line-height: 34px;
    }

@media screen and (max-width: 1200px) {
    .contact-wrapper .form-group .checkbox-inline .checkbox {
        top: 3px;
    }
}

@media screen and (max-width: 768px) {
    .contact-wrapper .thankyou-wrapper {
        padding: 40px 30px 0px;
        margin: 0;
    }

        .contact-wrapper .thankyou-wrapper .thanks-heading h2 {
            padding-right: 0;
            font-size: 22px;
            line-height: 28px;
            margin-bottom: 25px;
        }

    .contact-wrapper .content-block-large .content-block-heading {
        font-size: 28px;
        line-height: 34px;
        margin-bottom: 20px;
    }

    .contact-wrapper .content-block-large p {
        font-size: 16px;
        line-height: 24px;
    }

    .contact-wrapper .accordion .accordion-toggle {
        font-size: 22px;
        line-height: 28px;
    }
}

@media screen and (max-width: 576px) {
    .contact-wrapper .form-group {
        max-width: 100%;
    }
}

.buy-form {
    margin-bottom: 0;
}

    .buy-form .error-msg {
        display: none;
        color: red;
    }

    .buy-form .warning {
        pointer-events: none;
    }

    .buy-form .product__card__copy h1 {
        font-size: 50px;
        line-height: 58px;
        margin-bottom: 28px;
    }

    .buy-form .product__card__copy p {
        font-family: 'Helvetica Neue LT W05_45 Light', Helvetica, sans-serif;
        font-weight: 300;
        font-family: 'Helvetica Neue LT W05_65 Medium', Helvetica, sans-serif;
        font-weight: 600;
        margin-bottom: 15px;
    }

    .buy-form .radio-container {
        margin-bottom: 15px;
    }

    .buy-form .city-finder__heading {
        font-family: 'Helvetica Neue LT W05_45 Light', Helvetica, sans-serif;
        font-weight: 300;
        font-family: 'Helvetica Neue LT W05_65 Medium', Helvetica, sans-serif;
        font-weight: 600;
        margin-bottom: 15px;
    }

    .buy-form .city-finder__searchbar .inputbox {
        max-width: 250px;
        width: 100%;
    }

    .buy-form .city-finder__searchbar .btn, .buy-form .city-finder__searchbar .cart-total-cta, .buy-form .city-finder__searchbar .checkout form [type="submit"], .checkout form .buy-form .city-finder__searchbar [type="submit"], .buy-form .city-finder__searchbar .cookie-policy-cta {
        margin: -1px 0 0 5px;
    }

.current-target {
    margin-top: 27px;
    display: none;
}

    .current-target a {
        display: -ms-flexbox;
        display: flex;
        -ms-flex-align: start;
        align-items: start;
        -ms-flex-pack: center;
        justify-content: center;
        font-family: 'Helvetica Neue LT W05_45 Light', Helvetica, sans-serif;
        font-weight: 300;
        font-family: 'Helvetica Neue LT W05_65 Medium', Helvetica, sans-serif;
        font-weight: 600;
        font-size: 14px;
        line-height: 22px;
        color: #333;
    }

        .current-target a:hover, .current-target a:focus {
            text-decoration: none;
            outline: 0 none;
        }

        .current-target a .icon {
            font-size: 24px;
            margin-right: 5px;
        }

.wheretobuy {
    margin-top: 50px;
}

.wheretobuy__contact {
    border-top: solid 1px #979797;
    padding-top: 20px;
}

    .wheretobuy__contact p {
        font-size: 14px;
        line-height: 24px;
        margin-bottom: 20px;
    }

        .wheretobuy__contact p a {
            font-family: 'Helvetica Neue LT W05_45 Light', Helvetica, sans-serif;
            font-weight: 300;
            font-family: 'Helvetica Neue LT W05_55 Roman', Helvetica, sans-serif;
            font-weight: 400;
        }

.wheretobuy__header {
    padding-bottom: 20px;
    border-bottom: solid 1px rgba(186, 186, 186, 0.5);
    margin-bottom: 32px;
}

.wheretobuy__heading h1 {
    font-size: 50px;
    margin-bottom: 33px;
}

.wheretobuy__filters-wrapper {
    display: -ms-flexbox;
    display: flex;
    -ms-flex-pack: justify;
    justify-content: space-between;
    -ms-flex-align: center;
    align-items: center;
}

.wheretobuy__showresult.mobile {
    display: none;
}

.wheretobuy__showresult.desktop {
    display: block;
}

.wheretobuy__showresult p {
    margin-bottom: 0;
    font-size: 12px;
    line-height: 14px;
}

    .wheretobuy__showresult p span,
    .wheretobuy__showresult p i {
        font-family: 'Helvetica Neue LT W05_45 Light', Helvetica, sans-serif;
        font-weight: 300;
        font-family: 'Helvetica Neue LT W05_65 Medium', Helvetica, sans-serif;
        font-weight: 600;
        font-style: normal;
    }

.wheretobuy__filters select {
    width: 200px;
    margin-right: 20px;
}

    .wheretobuy__filters select:focus {
        box-shadow: none;
        border: 0 none;
        border: 1px solid #595959;
    }

.wheretobuy__filters .inputbox {
    background: #F9F7F6;
    width: 150px;
    margin-right: 20px;
    margin-bottom: 0;
}

    .wheretobuy__filters .inputbox:focus {
        box-shadow: none;
        border: 0 none;
        border: 1px solid #595959;
    }

.wheretobuy__filters .btn, .wheretobuy__filters .cart-total-cta, .wheretobuy__filters .checkout form [type="submit"], .checkout form .wheretobuy__filters [type="submit"], .wheretobuy__filters .cookie-policy-cta {
    margin-top: -2px;
}

    .wheretobuy__filters .btn:focus, .wheretobuy__filters .cart-total-cta:focus, .wheretobuy__filters .checkout form [type="submit"]:focus, .checkout form .wheretobuy__filters [type="submit"]:focus, .wheretobuy__filters .cookie-policy-cta:focus {
        box-shadow: none;
        border: 0 none;
    }

.wheretobuy__filters .error-msg {
    display: none;
    color: red;
    margin-top: 5px;
}

.wheretobuy__dealer-note .content {
    margin-top: 20px;
    margin-bottom: 20px;
    background: #fff;
    padding: 23px;
    box-shadow: 0 0 30px 0 rgba(151, 151, 151, 0.2);
    border: 1px solid #595959;
}

    .wheretobuy__dealer-note .content h1, .wheretobuy__dealer-note .content h2, .wheretobuy__dealer-note .content h3, .wheretobuy__dealer-note .content h4, .wheretobuy__dealer-note .content h5, .wheretobuy__dealer-note .content h6 {
        font-family: Georgia, serif;
        font-size: 24px;
        line-height: 26px;
        padding: 0;
        margin: 0;
    }

    .wheretobuy__dealer-note .content p {
        margin: 0;
        padding: 0;
        font-size: 16px;
    }

.wheretobuy__results__cards {
    margin-top: 20px;
    margin-bottom: 20px;
}

    .wheretobuy__results__cards .wtb-cards {
        display: -ms-flexbox;
        display: flex;
        -ms-flex-wrap: wrap;
        flex-wrap: wrap;
        margin-left: -8px;
        margin-right: -8px;
    }

        .wheretobuy__results__cards .wtb-cards .wtb-card-item {
            width: 33.33%;
            display: -ms-flexbox;
            display: flex;
            -ms-flex-align: stretch;
            align-items: stretch;
            padding-left: 8px;
            padding-right: 8px;
        }

            .wheretobuy__results__cards .wtb-cards .wtb-card-item .wtb-card {
                background: #fff;
                padding: 23px;
                margin-bottom: 16px;
                -ms-flex-positive: 1;
                flex-grow: 1;
                display: -ms-flexbox;
                display: flex;
                -ms-flex-direction: column;
                flex-direction: column;
                overflow: hidden;
                box-shadow: 0 0 30px 0 rgba(151, 151, 151, 0.2);
            }

                .wheretobuy__results__cards .wtb-cards .wtb-card-item .wtb-card .wtb-title {
                    margin-top: 10px;
                }

                    .wheretobuy__results__cards .wtb-cards .wtb-card-item .wtb-card .wtb-title p {
                        font-size: 24px;
                        line-height: 30px;
                        margin-bottom: 15px;
                        font-family: Georgia, serif;
                    }

                .wheretobuy__results__cards .wtb-cards .wtb-card-item .wtb-card .wtb-desi p {
                    font-size: 16px;
                    line-height: 24px;
                    margin-bottom: 15px;
                    font-family: 'Helvetica Neue LT W05_45 Light', Helvetica, sans-serif;
                    font-weight: 300;
                    font-family: 'Helvetica Neue LT W05_65 Medium', Helvetica, sans-serif;
                    font-weight: 600;
                }

                .wheretobuy__results__cards .wtb-cards .wtb-card-item .wtb-card .wtb-address {
                    margin-bottom: 70px;
                }

                    .wheretobuy__results__cards .wtb-cards .wtb-card-item .wtb-card .wtb-address p {
                        font-size: 16px;
                        line-height: 24px;
                        margin-bottom: 15px;
                    }

                        .wheretobuy__results__cards .wtb-cards .wtb-card-item .wtb-card .wtb-address p a {
                            color: #333;
                            text-decoration: none;
                        }

                .wheretobuy__results__cards .wtb-cards .wtb-card-item .wtb-card .wtb-email {
                    margin-top: auto;
                    border-top: solid 1px #d8d8d8;
                    position: relative;
                    padding-top: 25px;
                }

                    .wheretobuy__results__cards .wtb-cards .wtb-card-item .wtb-card .wtb-email a[href=''],
                    .wheretobuy__results__cards .wtb-cards .wtb-card-item .wtb-card .wtb-email a[href='mailto:'] {
                        visibility: hidden;
                        opacity: 0;
                    }

                    .wheretobuy__results__cards .wtb-cards .wtb-card-item .wtb-card .wtb-email .btn, .wheretobuy__results__cards .wtb-cards .wtb-card-item .wtb-card .wtb-email .cart-total-cta, .wheretobuy__results__cards .wtb-cards .wtb-card-item .wtb-card .wtb-email .checkout form [type="submit"], .checkout form .wheretobuy__results__cards .wtb-cards .wtb-card-item .wtb-card .wtb-email [type="submit"], .wheretobuy__results__cards .wtb-cards .wtb-card-item .wtb-card .wtb-email .cookie-policy-cta {
                        width: 100%;
                    }

                    .wheretobuy__results__cards .wtb-cards .wtb-card-item .wtb-card .wtb-email:before {
                        position: absolute;
                        content: '';
                        top: -1px;
                        left: 100%;
                        height: 100%;
                        width: 100%;
                        border-top: solid 1px #d8d8d8;
                    }

                    .wheretobuy__results__cards .wtb-cards .wtb-card-item .wtb-card .wtb-email:after {
                        position: absolute;
                        content: '';
                        top: -1px;
                        right: 100%;
                        height: 100%;
                        width: 100%;
                        border-top: solid 1px #d8d8d8;
                    }

.wheretobuy__results__map {
    display: -ms-flexbox;
    display: flex;
    width: 100%;
    height: 650px;
    box-shadow: 0 0 30px 0 rgba(151, 151, 151, 0.2);
}

    .wheretobuy__results__map .wtb-map-list {
        width: 32%;
        background: #fff;
        overflow-y: scroll;
    }

        .wheretobuy__results__map .wtb-map-list .accordion .accordion-toggle {
            display: -ms-flexbox;
            display: flex;
        }

            .wheretobuy__results__map .wtb-map-list .accordion .accordion-toggle:after {
                top: 28px;
            }

            .wheretobuy__results__map .wtb-map-list .accordion .accordion-toggle .accordion-cnt {
                width: 50px;
            }

                .wheretobuy__results__map .wtb-map-list .accordion .accordion-toggle .accordion-cnt span {
                    font-size: 12px;
                    line-height: 16px;
                    font-family: 'Helvetica Neue LT W05_45 Light', Helvetica, sans-serif;
                    font-weight: 300;
                    font-family: 'Helvetica Neue LT W05_75 Bold', Helvetica, sans-serif;
                    font-weight: 700;
                    color: #fff;
                    background: #595959;
                    height: 32px;
                    width: 32px;
                    border-radius: 50%;
                    display: -ms-flexbox;
                    display: flex;
                    -ms-flex-align: center;
                    align-items: center;
                    -ms-flex-pack: center;
                    justify-content: center;
                }

            .wheretobuy__results__map .wtb-map-list .accordion .accordion-toggle .accordion-title h2 {
                font-size: 20px;
                line-height: 24px;
                margin-bottom: 0;
            }

            .wheretobuy__results__map .wtb-map-list .accordion .accordion-toggle .accordion-title span {
                font-size: 14px;
                line-height: 24px;
                font-family: 'Helvetica Neue LT W05_45 Light', Helvetica, sans-serif;
                font-weight: 300;
            }

        .wheretobuy__results__map .wtb-map-list .accordion .accordion-content {
            margin-bottom: 0;
        }

            .wheretobuy__results__map .wtb-map-list .accordion .accordion-content .accordion-content-right {
                margin-left: 50px;
                margin-right: 15px;
            }

                .wheretobuy__results__map .wtb-map-list .accordion .accordion-content .accordion-content-right .accordion-address {
                    margin-bottom: 27px;
                }

                .wheretobuy__results__map .wtb-map-list .accordion .accordion-content .accordion-content-right .accordion-phone {
                    margin-bottom: 15px;
                }

                    .wheretobuy__results__map .wtb-map-list .accordion .accordion-content .accordion-content-right .accordion-phone a {
                        color: #333;
                        text-decoration: none;
                    }

                .wheretobuy__results__map .wtb-map-list .accordion .accordion-content .accordion-content-right .accodion-link {
                    margin-bottom: 20px;
                }

                    .wheretobuy__results__map .wtb-map-list .accordion .accordion-content .accordion-content-right .accodion-link a {
                        font-family: 'Helvetica Neue LT W05_45 Light', Helvetica, sans-serif;
                        font-weight: 300;
                        font-family: 'Helvetica Neue LT W05_55 Roman', Helvetica, sans-serif;
                        font-weight: 400;
                        text-decoration: underline;
                    }

                        .wheretobuy__results__map .wtb-map-list .accordion .accordion-content .accordion-content-right .accodion-link a[href=''] {
                            display: none;
                        }

                            .wheretobuy__results__map .wtb-map-list .accordion .accordion-content .accordion-content-right .accodion-link a[href=''] ~ i {
                                display: none;
                            }

                    .wheretobuy__results__map .wtb-map-list .accordion .accordion-content .accordion-content-right .accodion-link .fas {
                        margin-left: 7px;
                    }

                .wheretobuy__results__map .wtb-map-list .accordion .accordion-content .accordion-content-right .accordion-cta {
                    margin-bottom: 24px;
                }

                    .wheretobuy__results__map .wtb-map-list .accordion .accordion-content .accordion-content-right .accordion-cta a {
                        width: 100%;
                    }

                .wheretobuy__results__map .wtb-map-list .accordion .accordion-content .accordion-content-right .map-products strong {
                    font-family: 'Helvetica Neue LT W05_45 Light', Helvetica, sans-serif;
                    font-weight: 300;
                    font-family: 'Helvetica Neue LT W05_65 Medium', Helvetica, sans-serif;
                    font-weight: 600;
                }

                .wheretobuy__results__map .wtb-map-list .accordion .accordion-content .accordion-content-right .map-products ul {
                    list-style: none;
                    padding: 0;
                }

                    .wheretobuy__results__map .wtb-map-list .accordion .accordion-content .accordion-content-right .map-products ul li {
                        position: relative;
                        padding-left: 10px;
                    }

                        .wheretobuy__results__map .wtb-map-list .accordion .accordion-content .accordion-content-right .map-products ul li:before {
                            position: absolute;
                            content: "-";
                            top: 0;
                            left: 0;
                            height: 100%;
                            width: 100%;
                        }

        .wheretobuy__results__map .wtb-map-list .loadmore {
            display: none;
        }

            .wheretobuy__results__map .wtb-map-list .loadmore .btn, .wheretobuy__results__map .wtb-map-list .loadmore .cart-total-cta, .wheretobuy__results__map .wtb-map-list .loadmore .checkout form [type="submit"], .checkout form .wheretobuy__results__map .wtb-map-list .loadmore [type="submit"], .wheretobuy__results__map .wtb-map-list .loadmore .cookie-policy-cta {
                width: 100%;
            }

    .wheretobuy__results__map .wtb-map {
        width: 68%;
        background: #ccc;
    }

        .wheretobuy__results__map .wtb-map #map {
            height: 100%;
        }

@media screen and (max-width: 992px) {
    .wheretobuy__results__cards .wtb-cards .wtb-card-item {
        width: 50%;
    }

        .wheretobuy__results__cards .wtb-cards .wtb-card-item .wtb-card .wtb-address {
            margin-bottom: 40px;
        }

    .wheretobuy__results__map {
        height: 500px;
    }
}

@media screen and (max-width: 768px) {
    .current-target {
        display: block;
    }

    .wheretobuy {
        margin-top: 15px;
    }

    .wheretobuy__showresult.desktop {
        display: none;
    }

    .wheretobuy__showresult.mobile {
        display: block;
    }

    .wheretobuy__contact {
        border-top: none;
        padding-top: 0;
        margin-top: 20px;
    }

        .wheretobuy__contact p {
            margin-bottom: 0;
        }

    .wheretobuy__heading h1 {
        font-size: 28px;
        line-height: 34px;
        margin-bottom: 23px;
    }

    .wheretobuy__filters-wrapper {
        display: block;
    }

    .wheretobuy__showresult {
        border-top: solid 1px #979797;
        padding: 27px 0 7px 0;
    }

    .wheretobuy .current-target {
        margin: 20px 0 28px;
    }

    .wheretobuy__results__map {
        height: auto;
    }

        .wheretobuy__results__map .wtb-map-list {
            width: 100%;
        }

            .wheretobuy__results__map .wtb-map-list .loadmore {
                display: block;
                padding: 30px 20px;
            }

            .wheretobuy__results__map .wtb-map-list .accordion {
                display: none;
            }

        .wheretobuy__results__map .wtb-map {
            display: none;
        }
}

@media screen and (max-width: 576px) {
    .buy-form .product-feature__card {
        padding: 46px 32px 38px;
    }

    .buy-form .product__card__copy h1 {
        font-size: 28px;
        line-height: 34px;
        margin-bottom: 28px;
    }

    .buy-form .product__card__copy p {
        font-size: 16px;
        line-height: 24px;
    }

    .buy-form .radio-container .radio-wrap label {
        font-size: 12px;
        line-height: 20px;
    }

    .buy-form .city-finder__heading {
        font-size: 16px;
        line-height: 24px;
    }

    .buy-form .city-finder__searchbar .inputbox {
        max-width: 100%;
    }

    .buy-form .city-finder__searchbar .btn, .buy-form .city-finder__searchbar .cart-total-cta, .buy-form .city-finder__searchbar .checkout form [type="submit"], .checkout form .buy-form .city-finder__searchbar [type="submit"], .buy-form .city-finder__searchbar .cookie-policy-cta {
        margin: 10px 0 0 0;
        width: 100%;
    }

    .wheretobuy__results__cards .wtb-cards .wtb-card-item {
        width: 100%;
    }

    .wheretobuy__filters {
        display: -ms-flexbox;
        display: flex;
        -ms-flex-wrap: wrap;
        flex-wrap: wrap;
    }

        .wheretobuy__filters select {
            width: 100%;
            margin: 0 0 10px;
        }

        .wheretobuy__filters .btn, .wheretobuy__filters .cart-total-cta, .wheretobuy__filters .checkout form [type="submit"], .checkout form .wheretobuy__filters [type="submit"], .wheretobuy__filters .cookie-policy-cta {
            margin-top: 0;
        }

        .wheretobuy__filters .inputbox {
            -ms-flex-positive: 1;
            flex-grow: 1;
            margin-right: 10px;
        }
}

.newsletter-signup {
    margin-top: 0;
}

.newsletter-signup-heading {
    margin-bottom: 16px;
}

.newsletter-signup-header {
    border-bottom: 1px solid rgba(186, 186, 186, 0.5);
}

.newsletter-signup-required {
    font-family: 'Helvetica Neue LT W05_45 Light', Helvetica, sans-serif;
    font-weight: 300;
    font-size: 12px;
    line-height: 20px;
    margin-bottom: 32px;
    font-family: 'Helvetica Neue LT W05_45 Light', Helvetica, sans-serif;
    font-weight: 300;
    font-family: 'Helvetica Neue LT W05_75 Bold', Helvetica, sans-serif;
    font-weight: 700;
    margin-bottom: 24px;
}

@media screen and (min-width: 1200px) {
    .newsletter-signup-required {
        font-size: 14px;
        line-height: 24px;
    }
}

.newsletter-signup hr {
    margin: 0 0 24px;
}

.newsletter-signup select.input-validation-error {
    border-color: #da3931;
    color: #da3931;
}

.newsletter-signup input,
.newsletter-signup select,
.newsletter-signup textarea,
.newsletter-signup label {
    width: 100%;
    max-width: 350px;
}

.newsletter-signup-disclaimer p {
    font-family: 'Helvetica Neue LT W05_45 Light', Helvetica, sans-serif;
    font-weight: 300;
    font-size: 12px;
    line-height: 20px;
    margin-bottom: 32px;
}

@media screen and (min-width: 1200px) {
    .newsletter-signup-disclaimer p {
        font-size: 14px;
        line-height: 24px;
    }
}

.newsletter-signup [type="submit"] {
    max-width: 100%;
}

.newsletter-signup .which-newsletter {
    padding: 24px 0;
    border-top: 1px solid rgba(186, 186, 186, 0.5);
    border-bottom: 1px solid rgba(186, 186, 186, 0.5);
}

    .newsletter-signup .which-newsletter.required label ~ label:after {
        content: "";
    }

.newsletter-signup .privacy-policy {
    display: -ms-flexbox;
    display: flex;
    padding-bottom: 16px;
    border-bottom: 1px solid rgba(186, 186, 186, 0.5);
}

    .newsletter-signup .privacy-policy .field-validation-error {
        display: block;
        -ms-flex-order: 2;
        order: 2;
        width: auto;
        padding: 3px 0 0 5px;
    }

    .newsletter-signup .privacy-policy:after {
        content: '*';
    }

    .newsletter-signup .privacy-policy > a {
        display: block;
        margin-left: 4px;
    }

    .newsletter-signup .privacy-policy > label {
        width: auto;
    }

        .newsletter-signup .privacy-policy > label:after {
            content: none;
        }

.newsletter-signup .field-validation-error {
    display: block;
    width: 100%;
    font-family: 'Helvetica Neue LT W05_45 Light', Helvetica, sans-serif;
    font-weight: 300;
    font-size: 12px;
    color: #da3931;
}

.newsletter-email-confirm-message {
    display: none;
}

.newsletter-thank-you h1 {
    margin-bottom: 24px;
}

.newsletter-thank-you p {
    font-family: 'Helvetica Neue LT W05_45 Light', Helvetica, sans-serif;
    font-weight: 300;
    font-size: 12px;
    line-height: 20px;
    margin-bottom: 32px;
}

@media screen and (min-width: 1200px) {
    .newsletter-thank-you p {
        font-size: 14px;
        line-height: 24px;
    }
}

.newsletter-thank-you p strong {
    font-family: 'Helvetica Neue LT W05_45 Light', Helvetica, sans-serif;
    font-weight: 300;
    font-size: 16px;
    line-height: 24px;
    margin-bottom: 32px;
    font-family: 'Helvetica Neue LT W05_45 Light', Helvetica, sans-serif;
    font-weight: 300;
    font-family: 'Helvetica Neue LT W05_75 Bold', Helvetica, sans-serif;
    font-weight: 700;
}

@media screen and (min-width: 1200px) {
    .newsletter-thank-you p strong {
        font-size: 20px;
        line-height: 36px;
        margin-bottom: 56px;
    }
}

.cookie-policy-container {
    position: fixed;
    left: 0;
    right: 0;
    bottom: 0;
    background: #fafafa;
    border-top: 1px solid rgba(186, 186, 186, 0.5);
    padding: 24px 8px;
    z-index: 1000;
    color: #333333;
}

    .cookie-policy-container a {
        color: #2272CE;
    }

.cookie-policy-message-heading {
    font-family: 'Helvetica Neue LT W05_45 Light', Helvetica, sans-serif;
    font-weight: 300;
    font-size: 12px;
    line-height: 20px;
    font-family: 'Helvetica Neue LT W05_45 Light', Helvetica, sans-serif;
    font-weight: 300;
    font-family: 'Helvetica Neue LT W05_75 Bold', Helvetica, sans-serif;
    font-weight: 700;
}

@media screen and (min-width: 768px) {
    .cookie-policy-message-heading {
        font-size: 14px;
        line-height: 22px;
    }
}

@media screen and (min-width: 1200px) {
    .cookie-policy-message-heading {
        font-size: 16px;
        line-height: 24px;
    }
}

.cookie-policy-message p {
    font-family: 'Helvetica Neue LT W05_45 Light', Helvetica, sans-serif;
    font-weight: 300;
    font-size: 12px;
    line-height: 20px;
    margin-bottom: 24px;
}

@media screen and (min-width: 768px) {
    .cookie-policy-message p {
        font-size: 14px;
        line-height: 22px;
    }
}

@media screen and (min-width: 1200px) {
    .cookie-policy-message p {
        font-size: 16px;
        line-height: 24px;
    }
}

.cookie-policy-cta {
    width: 160px;
    padding: 9px 12px 10px;
}

@media screen and (min-width: 992px) {
    .cookie-policy {
        display: -ms-flexbox;
        display: flex;
        -ms-flex-pack: justify;
        justify-content: space-between;
        -ms-flex-align: center;
        align-items: center;
    }

    .cookie-policy-message {
        max-width: 730px;
    }

    .cookie-policy-cta {
        padding: 12px;
    }
}

.single-image {
    margin-bottom: 30px;
    text-align: center;
}

.color-match-info.color-border {
    border-bottom: 1px solid #d8d8d8;
    margin-bottom: 20px;
}

.color-match-info h2 {
    font-family: Georgia, serif;
    font-size: 23.54px;
    line-height: 28px;
    color: #333333;
}

@media screen and (min-width: 768px) {
    .color-match-info h2 {
        font-size: 29.96px;
        line-height: 34px;
    }
}

.color-match-info ul {
    padding-left: 0;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
}

    .color-match-info ul li {
        width: 50%;
        list-style: none;
        margin-bottom: 10px;
        font-family: 'Helvetica Neue LT W05_65 Medium';
    }

        .color-match-info ul li:before {
            content: '';
        }

@media screen and (max-width: 768px) {
    .color-match-info ul li {
        width: 100%;
    }
}

.table-responsive {
    margin-bottom: 30px;
}

.table th {
    font-family: 'Helvetica Neue LT W05_65 Medium';
    font-weight: normal;
}

/*
  *  Pages
  *
  */
.article-detail-categories {
    margin-bottom: 48px;
}

.article-detail-categories-cta {
    margin-bottom: 10px;
    font-size: 14px;
    line-height: 20px;
}

@media screen and (min-width: 1200px) {
    .article-detail-categories {
        margin-bottom: 0;
    }
}

.article-detail-subtitle {
    font-family: 'Helvetica Neue LT W05_45 Light', Helvetica, sans-serif;
    font-weight: 300;
    font-family: 'Helvetica Neue LT W05_65 Medium', Helvetica, sans-serif;
    font-weight: 600;
}

#news-list > [class*="col"] {
    -ms-flex-order: 4;
    order: 4;
}

    #news-list > [class*="col"]:nth-of-type(1) {
        -ms-flex-order: 3;
        order: 3;
    }

    #news-list > [class*="col"]:nth-of-type(2) {
        -ms-flex-order: 1;
        order: 1;
    }

    #news-list > [class*="col"]:nth-of-type(3) {
        -ms-flex-order: 2;
        order: 2;
    }

/*
* Global overrides
*
*/
.footer-disclaimer > * {
    font-size: 14px !important;
    line-height: 20px !important;
}

/*# sourceMappingURL=main-fallback-fonts.css.map */
