@charset "UTF-8";
.fa, .fab, .fad, .fal, .far, .fas {
    -moz-osx-font-smoothing: grayscale;
    -webkit-font-smoothing: antialiased;
    display: inline-block;
    font-style: normal;
    font-variant: normal;
    text-rendering: auto;
    line-height: 1
}

.fa-lg {
    font-size: 1.3333333333em;
    line-height: .75em;
    vertical-align: -.0667em
}

.fa-xs {
    font-size: .75em
}

.fa-sm {
    font-size: .875em
}

.fa-1x {
    font-size: 1em
}

.fa-2x {
    font-size: 2em
}

.fa-3x {
    font-size: 3em
}

.fa-4x {
    font-size: 4em
}

.fa-5x {
    font-size: 5em
}

.fa-6x {
    font-size: 6em
}

.fa-7x {
    font-size: 7em
}

.fa-8x {
    font-size: 8em
}

.fa-9x {
    font-size: 9em
}

.fa-10x {
    font-size: 10em
}

.fa-fw {
    text-align: center;
    width: 1.25em
}

.fa-ul {
    list-style-type: none;
    margin-left: 2.5em;
    padding-left: 0
}

.fa-ul > li {
    position: relative
}

.fa-li {
    left: -2em;
    position: absolute;
    text-align: center;
    width: 2em;
    line-height: inherit
}

.fa-border {
    border: solid .08em #eee;
    border-radius: .1em;
    padding: .2em .25em .15em
}

.fa-pull-left {
    float: left
}

.fa-pull-right {
    float: right
}

.fa.fa-pull-left, .fab.fa-pull-left, .fal.fa-pull-left, .far.fa-pull-left, .fas.fa-pull-left {
    margin-right: .3em
}

.fa.fa-pull-right, .fab.fa-pull-right, .fal.fa-pull-right, .far.fa-pull-right, .fas.fa-pull-right {
    margin-left: .3em
}

.fa-spin {
    animation: fa-spin 2s infinite linear
}

.fa-pulse {
    animation: fa-spin 1s infinite steps(8)
}

@keyframes fa-spin {
    0% {
        transform: rotate(0)
    }
    100% {
        transform: rotate(360deg)
    }
}

.fa-rotate-90 {
    transform: rotate(90deg)
}

.fa-rotate-180 {
    transform: rotate(180deg)
}

.fa-rotate-270 {
    transform: rotate(270deg)
}

.fa-flip-horizontal {
    transform: scale(-1, 1)
}

.fa-flip-vertical {
    transform: scale(1, -1)
}

.fa-flip-both, .fa-flip-horizontal.fa-flip-vertical {
    transform: scale(-1, -1)
}

:root .fa-flip-both, :root .fa-flip-horizontal, :root .fa-flip-vertical, :root .fa-rotate-180, :root .fa-rotate-270, :root .fa-rotate-90 {
    filter: none
}

.fa-stack {
    display: inline-block;
    height: 2em;
    line-height: 2em;
    position: relative;
    vertical-align: middle;
    width: 2.5em
}

.fa-stack-1x, .fa-stack-2x {
    left: 0;
    position: absolute;
    text-align: center;
    width: 100%
}

.fa-stack-1x {
    line-height: inherit
}

.fa-stack-2x {
    font-size: 2em
}

.fa-inverse {
    color: #fff
}

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

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

@font-face {
    font-family: fontawesome;
    src: url(../fonts/fontello/fontawesome.eot);
    src: url(../fonts/fontello/fontawesome.eot) format("embedded-opentype"), url(../fonts/fontello/fontawesome.woff2) format("woff2"), url(../fonts/fontello/fontawesome.woff) format("woff"), url(../fonts/fontello/fontawesome.ttf) format("truetype"), url(../fonts/fontello/fontawesome.svg) format("svg");
    font-weight: 400;
    font-style: normal;
    font-display: swap
}

[class*=" fa-"]:before, [class^=fa-]:before {
    font-family: fontawesome;
    font-style: normal;
    font-weight: 400;
    speak: never
}

.fa-print:before {
    content: '\e800'
}

.fa-star-o:before {
    content: '\e801'
}

.fa-scissors:before {
    content: '\e802'
}

.fa-shopping-cart:before {
    content: '\e804'
}

.fa-star:before {
    content: '\f005'
}

.fa-check:before {
    content: '\f00c'
}

.fa-times:before {
    content: '\f00d'
}

.fa-search-plus:before {
    content: '\f00e'
}

.fa-cog:before {
    content: '\f013'
}

.fa-home:before {
    content: '\f015'
}

.fa-clock:before {
    content: '\f017'
}

.fa-download:before {
    content: '\f019'
}

.fa-list-alt:before {
    content: '\f022'
}

.fa-book:before {
    content: '\f02d'
}

.fa-bookmark:before {
    content: '\f02e'
}

.fa-image:before {
    content: '\f03e'
}

.fa-play:before {
    content: '\f04b'
}

.fa-pause:before {
    content: '\f04c'
}

.fa-chevron-left:before {
    content: '\f053'
}

.fa-chevron-right:before {
    content: '\f054'
}

.fa-question-circle:before {
    content: '\f059'
}

.fa-info-circle:before {
    content: '\f05a'
}

.fa-ban:before {
    content: '\f05e'
}

.fa-arrow-left:before {
    content: '\f060'
}

.fa-arrow-right:before {
    content: '\f061'
}

.fa-gift:before {
    content: '\f06b'
}

.fa-eye:before {
    content: '\f06e'
}

.fa-calendar-alt:before {
    content: '\f073'
}

.fa-folder-open:before {
    content: '\f07c'
}

.fa-comments:before {
    content: '\f086'
}

.fa-sign-out:before {
    content: '\f08b'
}

.fa-external-link:before {
    content: '\f08e'
}

.fa-github-circled:before {
    content: '\f09b'
}

.fa-credit-card:before {
    content: '\f09d'
}

.fa-bullhorn:before {
    content: '\f0a1'
}

.fa-certificate:before {
    content: '\f0a3'
}

.fa-hand-point-up:before {
    content: '\f0a6'
}

.fa-briefcase:before {
    content: '\f0b1'
}

.fa-users:before {
    content: '\f0c0'
}

.fa-beaker:before {
    content: '\f0c3'
}

.fa-square:before {
    content: '\f0c8'
}

.fa-bars:before {
    content: '\f0c9'
}

.fa-envelope:before {
    content: '\f0e0'
}

.fa-bolt:before {
    content: '\f0e7'
}

.fa-sitemap:before {
    content: '\f0e8'
}

.fa-cloud-download:before {
    content: '\f0ed'
}

.fa-angle-left:before {
    content: '\f104'
}

.fa-angle-right:before {
    content: '\f105'
}

.fa-laptop:before {
    content: '\f109'
}

.fa-smile:before {
    content: '\f118'
}

.fa-frown:before {
    content: '\f119'
}

.fa-code:before {
    content: '\f121'
}

.fa-puzzle-piece:before {
    content: '\f12e'
}

.fa-unlock-alt:before {
    content: '\f13e'
}

.fa-play-circle:before {
    content: '\f144'
}

.fa-check-square:before {
    content: '\f14a'
}

.fa-compass:before {
    content: '\f14e'
}

.fa-file-text:before {
    content: '\f15c'
}

.fa-sort-amount-down:before {
    content: '\f160'
}

.fa-thumbs-up:before {
    content: '\f164'
}

.fa-thumbs-down:before {
    content: '\f165'
}

.fa-bug:before {
    content: '\f188'
}

.fa-graduation-cap:before {
    content: '\f19d'
}

.fa-google:before {
    content: '\f1a0'
}

.fa-language:before {
    content: '\f1ab'
}

.fa-cubes:before {
    content: '\f1b3'
}

.fa-recycle:before {
    content: '\f1b8'
}

.fa-database:before {
    content: '\f1c0'
}

.fa-file-pdf:before {
    content: '\f1c1'
}

.fa-file-image:before {
    content: '\f1c5'
}

.fa-file-archive:before {
    content: '\f1c6'
}

.fa-file-code:before {
    content: '\f1c9'
}

.fa-bomb:before {
    content: '\f1e2'
}

.fa-newspaper:before {
    content: '\f1ea'
}

.fa-copyright:before {
    content: '\f1f9'
}

.fa-facebook-official:before {
    content: '\f230'
}

.fa-balance-scale:before {
    content: '\f24e'
}

.fa-hourglass-half:before {
    content: '\f252'
}

.fa-hand-peace-o:before {
    content: '\f25b'
}

.fa-amazon:before {
    content: '\f270'
}

.fa-shopping-bag:before {
    content: '\f290'
}

.fa-hashtag:before {
    content: '\f292'
}

.fa-user-circle:before {
    content: '\f2bd'
}

.fa-shower:before {
    content: '\f2cc'
}

.fa-bath:before {
    content: '\f2cd'
}

.fa-trophy-alt:before {
    content: '\f2eb'
}

.fa-trash-alt:before {
    content: '\f2ed'
}

.fa-refresh:before {
    content: '\f2f1'
}

.fa-pencil-alt:before {
    content: '\f303'
}

.fa-lock:before {
    content: '\f30d'
}

.fa-chevron-double-right:before {
    content: '\f324'
}

.fa-arrow-to-right:before {
    content: '\f340'
}

.fa-exchange-alt:before {
    content: '\f362'
}

.fa-mobile-alt:before {
    content: '\f3cd'
}

.fa-money-bill:before {
    content: '\f3d1'
}

.fa-tablet:before {
    content: '\f3fa'
}

.fa-comment-alt-dots:before {
    content: '\f4a3'
}

.fa-user:before {
    content: '\f504'
}

.fa-globe:before {
    content: '\f57c'
}

.fa-smile-beam:before {
    content: '\f5b8'
}

.fa-car-side:before {
    content: '\f5e4'
}

.fa-badge-percent:before {
    content: '\f646'
}

.fa-lightbulb-on:before {
    content: '\f672'
}

.fa-dragon:before {
    content: '\f6d5'
}

.fa-ghost:before {
    content: '\f6e2'
}

.fa-helmet-battle:before {
    content: '\f6eb'
}

.fa-clipboard-list-check:before {
    content: '\f737'
}

.fa-heart-broken:before {
    content: '\f7a9'
}

.fa-debug:before {
    content: '\f7f9'
}

@font-face {
    font-family: 'Fira Code';
    src: local("Fira Code"), url(../fonts/FiraCode/woff2/FiraCode-Regular_latin.woff2) format("woff2");
    font-weight: 400;
    font-style: normal;
    font-display: swap;
    unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+2000-206F, U+2074, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD
}

@font-face {
    font-family: 'Fira Code';
    src: local("Fira Code"), url(../fonts/FiraCode/woff2/FiraCode-Bold_latin.woff2) format("woff2");
    font-weight: 700;
    font-style: normal;
    font-display: swap;
    unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+2000-206F, U+2074, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD
}

@font-face {
    font-family: 'Fira Code';
    src: local("Fira Code"), url(../fonts/FiraCode/woff2/FiraCode-Regular_latin-ext.woff2) format("woff2");
    font-weight: 400;
    font-style: normal;
    font-display: swap;
    unicode-range: U+0100-024F, U+0259, U+1E00-1EFF, U+2020, U+20A0-20AB, U+20AD-20CF, U+2113, U+2C60-2C7F, U+A720-A7FF
}

@font-face {
    font-family: 'Fira Code';
    src: local("Fira Code"), url(../fonts/FiraCode/woff2/FiraCode-Bold_latin-ext.woff2) format("woff2");
    font-weight: 700;
    font-style: normal;
    font-display: swap;
    unicode-range: U+0100-024F, U+0259, U+1E00-1EFF, U+2020, U+20A0-20AB, U+20AD-20CF, U+2113, U+2C60-2C7F, U+A720-A7FF
}

@font-face {
    font-family: 'Fira Code';
    src: local("Fira Code"), url(../fonts/FiraCode/woff2/FiraCode-Regular_cyrillic.woff2) format("woff2");
    font-weight: 400;
    font-style: normal;
    font-display: swap;
    unicode-range: U+0400-045F, U+0490-0491, U+04B0-04B1, U+2116
}

@font-face {
    font-family: 'Fira Code';
    src: local("Fira Code"), url(../fonts/FiraCode/woff2/FiraCode-Bold_cyrillic.woff2) format("woff2");
    font-weight: 700;
    font-style: normal;
    font-display: swap;
    unicode-range: U+0400-045F, U+0490-0491, U+04B0-04B1, U+2116
}

@font-face {
    font-family: 'Fira Code';
    src: local("Fira Code"), url(../fonts/FiraCode/woff2/FiraCode-Regular_cyrillic-ext.woff2) format("woff2");
    font-weight: 400;
    font-style: normal;
    font-display: swap;
    unicode-range: U+0460-052F, U+1C80-1C88, U+20B4, U+2DE0-2DFF, U+A640-A69F, U+FE2E-FE2F
}

@font-face {
    font-family: 'Fira Code';
    src: local("Fira Code"), url(../fonts/FiraCode/woff2/FiraCode-Bold_cyrillic-ext.woff2) format("woff2");
    font-weight: 700;
    font-style: normal;
    font-display: swap;
    unicode-range: U+0460-052F, U+1C80-1C88, U+20B4, U+2DE0-2DFF, U+A640-A69F, U+FE2E-FE2F
}

/*!
 * Bootstrap v4.5.2 (https://getbootstrap.com/)
 * Copyright 2011-2020 The Bootstrap Authors
 * Copyright 2011-2020 Twitter, Inc.
 * Licensed under MIT (https://github.com/twbs/bootstrap/blob/main/LICENSE)
 */
*, ::after, ::before {
    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: .5rem
}

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

abbr[data-original-title], abbr[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
}

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

ol ol, ol ul, ul ol, ul ul {
    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: #e74c3c;
    text-decoration: none;
    background-color: transparent
}

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

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

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

code, kbd, pre, 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: .75rem;
    padding-bottom: .75rem;
    color: #6c757d;
    text-align: left;
    caption-side: bottom
}

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

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

button {
    border-radius: 0
}

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

button, input, optgroup, select, 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
}

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

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

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

input[type=checkbox], input[type=radio] {
    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
}

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

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

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

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

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

.row {
    display: flex;
    flex-wrap: wrap;
    margin-right: -15px;
    margin-left: -15px
}

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

.order-first {
    order: -1
}

.order-last {
    order: 13
}

.order-0 {
    order: 0
}

.order-1 {
    order: 1
}

.order-2 {
    order: 2
}

.order-3 {
    order: 3
}

.order-4 {
    order: 4
}

.order-5 {
    order: 5
}

.order-6 {
    order: 6
}

.order-7 {
    order: 7
}

.order-8 {
    order: 8
}

.order-9 {
    order: 9
}

.order-10 {
    order: 10
}

.order-11 {
    order: 11
}

.order-12 {
    order: 12
}

.offset-1 {
    margin-left: 8.33333333%
}

.offset-2 {
    margin-left: 16.66666667%
}

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

.offset-4 {
    margin-left: 33.33333333%
}

.offset-5 {
    margin-left: 41.66666667%
}

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

.offset-7 {
    margin-left: 58.33333333%
}

.offset-8 {
    margin-left: 66.66666667%
}

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

.offset-10 {
    margin-left: 83.33333333%
}

.offset-11 {
    margin-left: 91.66666667%
}

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

    .order-sm-first {
        order: -1
    }

    .order-sm-last {
        order: 13
    }

    .order-sm-0 {
        order: 0
    }

    .order-sm-1 {
        order: 1
    }

    .order-sm-2 {
        order: 2
    }

    .order-sm-3 {
        order: 3
    }

    .order-sm-4 {
        order: 4
    }

    .order-sm-5 {
        order: 5
    }

    .order-sm-6 {
        order: 6
    }

    .order-sm-7 {
        order: 7
    }

    .order-sm-8 {
        order: 8
    }

    .order-sm-9 {
        order: 9
    }

    .order-sm-10 {
        order: 10
    }

    .order-sm-11 {
        order: 11
    }

    .order-sm-12 {
        order: 12
    }

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

    .offset-sm-1 {
        margin-left: 8.33333333%
    }

    .offset-sm-2 {
        margin-left: 16.66666667%
    }

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

    .offset-sm-4 {
        margin-left: 33.33333333%
    }

    .offset-sm-5 {
        margin-left: 41.66666667%
    }

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

    .offset-sm-7 {
        margin-left: 58.33333333%
    }

    .offset-sm-8 {
        margin-left: 66.66666667%
    }

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

    .offset-sm-10 {
        margin-left: 83.33333333%
    }

    .offset-sm-11 {
        margin-left: 91.66666667%
    }
}

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

    .order-md-first {
        order: -1
    }

    .order-md-last {
        order: 13
    }

    .order-md-0 {
        order: 0
    }

    .order-md-1 {
        order: 1
    }

    .order-md-2 {
        order: 2
    }

    .order-md-3 {
        order: 3
    }

    .order-md-4 {
        order: 4
    }

    .order-md-5 {
        order: 5
    }

    .order-md-6 {
        order: 6
    }

    .order-md-7 {
        order: 7
    }

    .order-md-8 {
        order: 8
    }

    .order-md-9 {
        order: 9
    }

    .order-md-10 {
        order: 10
    }

    .order-md-11 {
        order: 11
    }

    .order-md-12 {
        order: 12
    }

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

    .offset-md-1 {
        margin-left: 8.33333333%
    }

    .offset-md-2 {
        margin-left: 16.66666667%
    }

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

    .offset-md-4 {
        margin-left: 33.33333333%
    }

    .offset-md-5 {
        margin-left: 41.66666667%
    }

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

    .offset-md-7 {
        margin-left: 58.33333333%
    }

    .offset-md-8 {
        margin-left: 66.66666667%
    }

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

    .offset-md-10 {
        margin-left: 83.33333333%
    }

    .offset-md-11 {
        margin-left: 91.66666667%
    }
}

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

    .order-lg-first {
        order: -1
    }

    .order-lg-last {
        order: 13
    }

    .order-lg-0 {
        order: 0
    }

    .order-lg-1 {
        order: 1
    }

    .order-lg-2 {
        order: 2
    }

    .order-lg-3 {
        order: 3
    }

    .order-lg-4 {
        order: 4
    }

    .order-lg-5 {
        order: 5
    }

    .order-lg-6 {
        order: 6
    }

    .order-lg-7 {
        order: 7
    }

    .order-lg-8 {
        order: 8
    }

    .order-lg-9 {
        order: 9
    }

    .order-lg-10 {
        order: 10
    }

    .order-lg-11 {
        order: 11
    }

    .order-lg-12 {
        order: 12
    }

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

    .offset-lg-1 {
        margin-left: 8.33333333%
    }

    .offset-lg-2 {
        margin-left: 16.66666667%
    }

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

    .offset-lg-4 {
        margin-left: 33.33333333%
    }

    .offset-lg-5 {
        margin-left: 41.66666667%
    }

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

    .offset-lg-7 {
        margin-left: 58.33333333%
    }

    .offset-lg-8 {
        margin-left: 66.66666667%
    }

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

    .offset-lg-10 {
        margin-left: 83.33333333%
    }

    .offset-lg-11 {
        margin-left: 91.66666667%
    }
}

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

    .order-xl-first {
        order: -1
    }

    .order-xl-last {
        order: 13
    }

    .order-xl-0 {
        order: 0
    }

    .order-xl-1 {
        order: 1
    }

    .order-xl-2 {
        order: 2
    }

    .order-xl-3 {
        order: 3
    }

    .order-xl-4 {
        order: 4
    }

    .order-xl-5 {
        order: 5
    }

    .order-xl-6 {
        order: 6
    }

    .order-xl-7 {
        order: 7
    }

    .order-xl-8 {
        order: 8
    }

    .order-xl-9 {
        order: 9
    }

    .order-xl-10 {
        order: 10
    }

    .order-xl-11 {
        order: 11
    }

    .order-xl-12 {
        order: 12
    }

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

    .offset-xl-1 {
        margin-left: 8.33333333%
    }

    .offset-xl-2 {
        margin-left: 16.66666667%
    }

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

    .offset-xl-4 {
        margin-left: 33.33333333%
    }

    .offset-xl-5 {
        margin-left: 41.66666667%
    }

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

    .offset-xl-7 {
        margin-left: 58.33333333%
    }

    .offset-xl-8 {
        margin-left: 66.66666667%
    }

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

    .offset-xl-10 {
        margin-left: 83.33333333%
    }

    .offset-xl-11 {
        margin-left: 91.66666667%
    }
}

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

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

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

.form-control:focus {
    color: #495057;
    background-color: #fff;
    border-color: rgba(41, 128, 185, .5);
    outline: 0;
    box-shadow: 0 0 0 .2rem rgba(41, 128, 185, .25)
}

.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=datetime-local].form-control, input[type=month].form-control, input[type=time].form-control {
    appearance: none
}

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

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(.5rem + 2px);
    padding-bottom: calc(.5rem + 2px);
    margin-bottom: 0;
    font-size: inherit;
    line-height: 1.5
}

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

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

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

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

.form-control-sm {
    height: calc(1.5em + .5rem + 4px);
    padding: .25rem .5rem;
    font-size: .875rem;
    line-height: 1.5;
    border-radius: .2rem
}

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

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

textarea.form-control {
    height: auto
}

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

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

.form-row {
    display: flex;
    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: .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: inline-flex;
    align-items: center;
    padding-left: 0;
    margin-right: .75rem
}

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

.valid-feedback {
    display: none;
    width: 100%;
    margin-top: .25rem;
    font-size: .875em;
    color: #a0cfee
}

.valid-tooltip {
    position: absolute;
    top: 100%;
    left: 0;
    z-index: 5;
    display: none;
    max-width: 100%;
    padding: .25rem .5rem;
    margin-top: .1rem;
    font-size: .875rem;
    line-height: 1.5;
    color: #212529;
    background-color: rgba(160, 207, 238, .9);
    border-radius: .25rem
}

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

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

.form-control.is-valid, .was-validated .form-control:valid {
    border-color: #a0cfee
}

.form-control.is-valid:focus, .was-validated .form-control:valid:focus {
    border-color: #a0cfee;
    box-shadow: 0 0 0 .2rem rgba(160, 207, 238, .25)
}

.custom-select.is-valid, .was-validated .custom-select:valid {
    border-color: #a0cfee
}

.custom-select.is-valid:focus, .was-validated .custom-select:valid:focus {
    border-color: #a0cfee;
    box-shadow: 0 0 0 .2rem rgba(160, 207, 238, .25)
}

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

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

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

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

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

.custom-control-input.is-valid:focus ~ .custom-control-label::before, .was-validated .custom-control-input:valid:focus ~ .custom-control-label::before {
    box-shadow: 0 0 0 .2rem rgba(160, 207, 238, .25)
}

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

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

.custom-file-input.is-valid:focus ~ .custom-file-label, .was-validated .custom-file-input:valid:focus ~ .custom-file-label {
    border-color: #a0cfee;
    box-shadow: 0 0 0 .2rem rgba(160, 207, 238, .25)
}

.invalid-feedback {
    display: none;
    width: 100%;
    margin-top: .25rem;
    font-size: .875em;
    color: #e74c3c
}

.invalid-tooltip {
    position: absolute;
    top: 100%;
    left: 0;
    z-index: 5;
    display: none;
    max-width: 100%;
    padding: .25rem .5rem;
    margin-top: .1rem;
    font-size: .875rem;
    line-height: 1.5;
    color: #fff;
    background-color: rgba(231, 76, 60, .9);
    border-radius: .25rem
}

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

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

.form-control.is-invalid, .was-validated .form-control:invalid {
    border-color: #e74c3c
}

.form-control.is-invalid:focus, .was-validated .form-control:invalid:focus {
    border-color: #e74c3c;
    box-shadow: 0 0 0 .2rem rgba(231, 76, 60, .25)
}

.custom-select.is-invalid, .was-validated .custom-select:invalid {
    border-color: #e74c3c
}

.custom-select.is-invalid:focus, .was-validated .custom-select:invalid:focus {
    border-color: #e74c3c;
    box-shadow: 0 0 0 .2rem rgba(231, 76, 60, .25)
}

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

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

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

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

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

.custom-control-input.is-invalid:focus ~ .custom-control-label::before, .was-validated .custom-control-input:invalid:focus ~ .custom-control-label::before {
    box-shadow: 0 0 0 .2rem rgba(231, 76, 60, .25)
}

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

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

.custom-file-input.is-invalid:focus ~ .custom-file-label, .was-validated .custom-file-input:invalid:focus ~ .custom-file-label {
    border-color: #e74c3c;
    box-shadow: 0 0 0 .2rem rgba(231, 76, 60, .25)
}

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

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

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

    .form-inline .form-group {
        display: flex;
        flex: 0 0 auto;
        flex-flow: row wrap;
        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 .custom-select, .form-inline .input-group {
        width: auto
    }

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

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

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

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

.btn {
    display: inline-block;
    font-weight: 400;
    color: #212529;
    text-align: center;
    vertical-align: middle;
    user-select: none;
    background-color: transparent;
    border: 1px solid transparent;
    padding: .5rem .75rem;
    font-size: 1rem;
    line-height: 1.5;
    border-radius: .25rem;
    transition: color .15s ease-in-out, background-color .15s ease-in-out, border-color .15s ease-in-out, box-shadow .15s ease-in-out
}

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

.btn:hover {
    color: #212529;
    text-decoration: none
}

.btn.focus, .btn:focus {
    outline: 0;
    box-shadow: 0 0 0 .2rem rgba(41, 128, 185, .25)
}

.btn.disabled, .btn:disabled {
    opacity: .65
}

.btn:not(:disabled):not(.disabled) {
    cursor: pointer
}

a.btn.disabled, fieldset:disabled a.btn {
    pointer-events: none
}

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

.btn-primary:hover {
    color: #fff;
    background-color: #e12e1c;
    border-color: #d62c1a
}

.btn-primary.focus, .btn-primary:focus {
    color: #fff;
    background-color: #e12e1c;
    border-color: #d62c1a;
    box-shadow: 0 0 0 .2rem rgba(235, 103, 89, .5)
}

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

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

.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 .2rem rgba(235, 103, 89, .5)
}

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

.btn-secondary:hover {
    color: #fff;
    background-color: #b01e3a;
    border-color: #a51c37
}

.btn-secondary.focus, .btn-secondary:focus {
    color: #fff;
    background-color: #b01e3a;
    border-color: #a51c37;
    box-shadow: 0 0 0 .2rem rgba(216, 68, 97, .5)
}

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

.btn-secondary:not(:disabled):not(.disabled).active, .btn-secondary:not(:disabled):not(.disabled):active, .show > .btn-secondary.dropdown-toggle {
    color: #fff;
    background-color: #a51c37;
    border-color: #9a1a33
}

.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 .2rem rgba(216, 68, 97, .5)
}

.btn-success {
    color: #fff;
    background-color: #2ecc71;
    border-color: #2ecc71
}

.btn-success:hover {
    color: #fff;
    background-color: #27ad60;
    border-color: #25a25a
}

.btn-success.focus, .btn-success:focus {
    color: #fff;
    background-color: #27ad60;
    border-color: #25a25a;
    box-shadow: 0 0 0 .2rem rgba(77, 212, 134, .5)
}

.btn-success.disabled, .btn-success:disabled {
    color: #fff;
    background-color: #2ecc71;
    border-color: #2ecc71
}

.btn-success:not(:disabled):not(.disabled).active, .btn-success:not(:disabled):not(.disabled):active, .show > .btn-success.dropdown-toggle {
    color: #fff;
    background-color: #25a25a;
    border-color: #229854
}

.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 .2rem rgba(77, 212, 134, .5)
}

.btn-info {
    color: #fff;
    background-color: #3498db;
    border-color: #3498db
}

.btn-info:hover {
    color: #fff;
    background-color: #2384c6;
    border-color: #217dbb
}

.btn-info.focus, .btn-info:focus {
    color: #fff;
    background-color: #2384c6;
    border-color: #217dbb;
    box-shadow: 0 0 0 .2rem rgba(82, 167, 224, .5)
}

.btn-info.disabled, .btn-info:disabled {
    color: #fff;
    background-color: #3498db;
    border-color: #3498db
}

.btn-info:not(:disabled):not(.disabled).active, .btn-info:not(:disabled):not(.disabled):active, .show > .btn-info.dropdown-toggle {
    color: #fff;
    background-color: #217dbb;
    border-color: #1f76b0
}

.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 .2rem rgba(82, 167, 224, .5)
}

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

.btn-warning:hover {
    color: #212529;
    background-color: #cea70c;
    border-color: #c29d0b
}

.btn-warning.focus, .btn-warning:focus {
    color: #212529;
    background-color: #cea70c;
    border-color: #c29d0b;
    box-shadow: 0 0 0 .2rem rgba(210, 172, 19, .5)
}

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

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

.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 .2rem rgba(210, 172, 19, .5)
}

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

.btn-danger:hover {
    color: #fff;
    background-color: #e12e1c;
    border-color: #d62c1a
}

.btn-danger.focus, .btn-danger:focus {
    color: #fff;
    background-color: #e12e1c;
    border-color: #d62c1a;
    box-shadow: 0 0 0 .2rem rgba(235, 103, 89, .5)
}

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

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

.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 .2rem rgba(235, 103, 89, .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 .2rem rgba(216, 217, 219, .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 .2rem rgba(216, 217, 219, .5)
}

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

.btn-dark:hover {
    color: #fff;
    background-color: #101214;
    border-color: #0a0c0d
}

.btn-dark.focus, .btn-dark:focus {
    color: #fff;
    background-color: #101214;
    border-color: #0a0c0d;
    box-shadow: 0 0 0 .2rem rgba(66, 70, 73, .5)
}

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

.btn-dark:not(:disabled):not(.disabled).active, .btn-dark:not(:disabled):not(.disabled):active, .show > .btn-dark.dropdown-toggle {
    color: #fff;
    background-color: #0a0c0d;
    border-color: #050506
}

.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 .2rem rgba(66, 70, 73, .5)
}

.btn-default {
    color: #212529;
    background-color: #bdc3c7;
    border-color: #bdc3c7
}

.btn-default:hover {
    color: #212529;
    background-color: #a8b0b5;
    border-color: #a1aab0
}

.btn-default.focus, .btn-default:focus {
    color: #212529;
    background-color: #a8b0b5;
    border-color: #a1aab0;
    box-shadow: 0 0 0 .2rem rgba(166, 171, 175, .5)
}

.btn-default.disabled, .btn-default:disabled {
    color: #212529;
    background-color: #bdc3c7;
    border-color: #bdc3c7
}

.btn-default:not(:disabled):not(.disabled).active, .btn-default:not(:disabled):not(.disabled):active, .show > .btn-default.dropdown-toggle {
    color: #212529;
    background-color: #a1aab0;
    border-color: #9ba4aa
}

.btn-default:not(:disabled):not(.disabled).active:focus, .btn-default:not(:disabled):not(.disabled):active:focus, .show > .btn-default.dropdown-toggle:focus {
    box-shadow: 0 0 0 .2rem rgba(166, 171, 175, .5)
}

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

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

.btn-outline-primary.focus, .btn-outline-primary:focus {
    box-shadow: 0 0 0 .2rem rgba(231, 76, 60, .5)
}

.btn-outline-primary.disabled, .btn-outline-primary:disabled {
    color: #e74c3c;
    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: #e74c3c;
    border-color: #e74c3c
}

.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 .2rem rgba(231, 76, 60, .5)
}

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

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

.btn-outline-secondary.focus, .btn-outline-secondary:focus {
    box-shadow: 0 0 0 .2rem rgba(209, 35, 69, .5)
}

.btn-outline-secondary.disabled, .btn-outline-secondary:disabled {
    color: #d12345;
    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: #d12345;
    border-color: #d12345
}

.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 .2rem rgba(209, 35, 69, .5)
}

.btn-outline-success {
    color: #2ecc71;
    border-color: #2ecc71
}

.btn-outline-success:hover {
    color: #fff;
    background-color: #2ecc71;
    border-color: #2ecc71
}

.btn-outline-success.focus, .btn-outline-success:focus {
    box-shadow: 0 0 0 .2rem rgba(46, 204, 113, .5)
}

.btn-outline-success.disabled, .btn-outline-success:disabled {
    color: #2ecc71;
    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: #2ecc71;
    border-color: #2ecc71
}

.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 .2rem rgba(46, 204, 113, .5)
}

.btn-outline-info {
    color: #3498db;
    border-color: #3498db
}

.btn-outline-info:hover {
    color: #fff;
    background-color: #3498db;
    border-color: #3498db
}

.btn-outline-info.focus, .btn-outline-info:focus {
    box-shadow: 0 0 0 .2rem rgba(52, 152, 219, .5)
}

.btn-outline-info.disabled, .btn-outline-info:disabled {
    color: #3498db;
    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: #3498db;
    border-color: #3498db
}

.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 .2rem rgba(52, 152, 219, .5)
}

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

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

.btn-outline-warning.focus, .btn-outline-warning:focus {
    box-shadow: 0 0 0 .2rem rgba(241, 196, 15, .5)
}

.btn-outline-warning.disabled, .btn-outline-warning:disabled {
    color: #f1c40f;
    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: #f1c40f;
    border-color: #f1c40f
}

.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 .2rem rgba(241, 196, 15, .5)
}

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

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

.btn-outline-danger.focus, .btn-outline-danger:focus {
    box-shadow: 0 0 0 .2rem rgba(231, 76, 60, .5)
}

.btn-outline-danger.disabled, .btn-outline-danger:disabled {
    color: #e74c3c;
    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: #e74c3c;
    border-color: #e74c3c
}

.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 .2rem rgba(231, 76, 60, .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 .2rem rgba(248, 249, 250, .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 .2rem rgba(248, 249, 250, .5)
}

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

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

.btn-outline-dark.focus, .btn-outline-dark:focus {
    box-shadow: 0 0 0 .2rem rgba(33, 37, 41, .5)
}

.btn-outline-dark.disabled, .btn-outline-dark:disabled {
    color: #212529;
    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: #212529;
    border-color: #212529
}

.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 .2rem rgba(33, 37, 41, .5)
}

.btn-outline-default {
    color: #bdc3c7;
    border-color: #bdc3c7
}

.btn-outline-default:hover {
    color: #212529;
    background-color: #bdc3c7;
    border-color: #bdc3c7
}

.btn-outline-default.focus, .btn-outline-default:focus {
    box-shadow: 0 0 0 .2rem rgba(189, 195, 199, .5)
}

.btn-outline-default.disabled, .btn-outline-default:disabled {
    color: #bdc3c7;
    background-color: transparent
}

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

.btn-outline-default:not(:disabled):not(.disabled).active:focus, .btn-outline-default:not(:disabled):not(.disabled):active:focus, .show > .btn-outline-default.dropdown-toggle:focus {
    box-shadow: 0 0 0 .2rem rgba(189, 195, 199, .5)
}

.btn-link {
    font-weight: 400;
    color: #e74c3c;
    text-decoration: none
}

.btn-link:hover {
    color: #bf2718;
    text-decoration: underline
}

.btn-link.focus, .btn-link:focus {
    text-decoration: underline
}

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

.btn-group-lg > .btn, .btn-lg {
    padding: .5rem 1rem;
    font-size: 1.25rem;
    line-height: 1.5;
    border-radius: .3rem
}

.btn-group-sm > .btn, .btn-sm {
    padding: .25rem .5rem;
    font-size: .875rem;
    line-height: 1.5;
    border-radius: .2rem
}

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

.btn-block + .btn-block {
    margin-top: .5rem
}

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

.fade {
    transition: opacity .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 .35s ease
}

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

.collapsing.width {
    width: 0;
    height: auto;
    transition: width .35s ease
}

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

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

.dropdown-toggle {
    white-space: nowrap
}

.dropdown-toggle::after {
    display: inline-block;
    margin-left: .255em;
    vertical-align: .255em;
    content: "";
    border-top: .3em solid;
    border-right: .3em solid transparent;
    border-bottom: 0;
    border-left: .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: .5rem 0;
    margin: .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, .15);
    border-radius: .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: .125rem
}

.dropup .dropdown-toggle::after {
    display: inline-block;
    margin-left: .255em;
    vertical-align: .255em;
    content: "";
    border-top: 0;
    border-right: .3em solid transparent;
    border-bottom: .3em solid;
    border-left: .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: .125rem
}

.dropright .dropdown-toggle::after {
    display: inline-block;
    margin-left: .255em;
    vertical-align: .255em;
    content: "";
    border-top: .3em solid transparent;
    border-right: 0;
    border-bottom: .3em solid transparent;
    border-left: .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: .125rem
}

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

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

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

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

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

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

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

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

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

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

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

.dropdown-menu.show {
    display: block
}

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

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

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

.btn-group-vertical > .btn, .btn-group > .btn {
    position: relative;
    flex: 1 1 auto
}

.btn-group-vertical > .btn:hover, .btn-group > .btn:hover {
    z-index: 1
}

.btn-group-vertical > .btn.active, .btn-group-vertical > .btn:active, .btn-group-vertical > .btn:focus, .btn-group > .btn.active, .btn-group > .btn:active, .btn-group > .btn:focus {
    z-index: 1
}

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

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

.btn-group > .btn-group:not(:first-child), .btn-group > .btn:not(:first-child) {
    margin-left: -1px
}

.btn-group > .btn-group:not(:last-child) > .btn, .btn-group > .btn:not(:last-child):not(.dropdown-toggle) {
    border-top-right-radius: 0;
    border-bottom-right-radius: 0
}

.btn-group > .btn-group:not(:first-child) > .btn, .btn-group > .btn:not(:first-child) {
    border-top-left-radius: 0;
    border-bottom-left-radius: 0
}

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

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

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

.btn-group-sm > .btn + .dropdown-toggle-split, .btn-sm + .dropdown-toggle-split {
    padding-right: .375rem;
    padding-left: .375rem
}

.btn-group-lg > .btn + .dropdown-toggle-split, .btn-lg + .dropdown-toggle-split {
    padding-right: .75rem;
    padding-left: .75rem
}

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

.btn-group-vertical > .btn, .btn-group-vertical > .btn-group {
    width: 100%
}

.btn-group-vertical > .btn-group:not(:first-child), .btn-group-vertical > .btn:not(:first-child) {
    margin-top: -1px
}

.btn-group-vertical > .btn-group:not(:last-child) > .btn, .btn-group-vertical > .btn:not(:last-child):not(.dropdown-toggle) {
    border-bottom-right-radius: 0;
    border-bottom-left-radius: 0
}

.btn-group-vertical > .btn-group:not(:first-child) > .btn, .btn-group-vertical > .btn:not(:first-child) {
    border-top-left-radius: 0;
    border-top-right-radius: 0
}

.btn-group-toggle > .btn, .btn-group-toggle > .btn-group > .btn {
    margin-bottom: 0
}

.btn-group-toggle > .btn input[type=checkbox], .btn-group-toggle > .btn input[type=radio], .btn-group-toggle > .btn-group > .btn input[type=checkbox], .btn-group-toggle > .btn-group > .btn input[type=radio] {
    position: absolute;
    clip: rect(0, 0, 0, 0);
    pointer-events: none
}

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

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

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

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

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

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

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

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

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

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

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

.input-group-append .btn, .input-group-prepend .btn {
    position: relative;
    z-index: 2
}

.input-group-append .btn:focus, .input-group-prepend .btn:focus {
    z-index: 3
}

.input-group-append .btn + .btn, .input-group-append .btn + .input-group-text, .input-group-append .input-group-text + .btn, .input-group-append .input-group-text + .input-group-text, .input-group-prepend .btn + .btn, .input-group-prepend .btn + .input-group-text, .input-group-prepend .input-group-text + .btn, .input-group-prepend .input-group-text + .input-group-text {
    margin-left: -2px
}

.input-group-prepend {
    margin-right: -2px
}

.input-group-append {
    margin-left: -2px
}

.input-group-text {
    display: flex;
    align-items: center;
    padding: .5rem .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: 2px solid #ced4da;
    border-radius: .25rem
}

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

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

.input-group-lg > .custom-select, .input-group-lg > .form-control, .input-group-lg > .input-group-append > .btn, .input-group-lg > .input-group-append > .input-group-text, .input-group-lg > .input-group-prepend > .btn, .input-group-lg > .input-group-prepend > .input-group-text {
    padding: .5rem 1rem;
    font-size: 1.25rem;
    line-height: 1.5;
    border-radius: .3rem
}

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

.input-group-sm > .custom-select, .input-group-sm > .form-control, .input-group-sm > .input-group-append > .btn, .input-group-sm > .input-group-append > .input-group-text, .input-group-sm > .input-group-prepend > .btn, .input-group-sm > .input-group-prepend > .input-group-text {
    padding: .25rem .5rem;
    font-size: .875rem;
    line-height: 1.5;
    border-radius: .2rem
}

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

.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) > .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) > .input-group-text, .input-group > .input-group-append:last-child > .btn:not(:last-child):not(.dropdown-toggle), .input-group > .input-group-append:last-child > .input-group-text:not(:last-child), .input-group > .input-group-prepend > .btn, .input-group > .input-group-prepend > .input-group-text {
    border-top-right-radius: 0;
    border-bottom-right-radius: 0
}

.input-group > .input-group-append > .btn, .input-group > .input-group-append > .input-group-text, .input-group > .input-group-prepend:first-child > .btn:not(:first-child), .input-group > .input-group-prepend:first-child > .input-group-text:not(:first-child), .input-group > .input-group-prepend:not(:first-child) > .btn, .input-group > .input-group-prepend:not(:first-child) > .input-group-text {
    border-top-left-radius: 0;
    border-bottom-left-radius: 0
}

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

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

.nav-link:focus, .nav-link:hover {
    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;
    background-color: transparent;
    border: 1px solid transparent;
    border-top-left-radius: .25rem;
    border-top-right-radius: .25rem
}

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

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

.nav-tabs .nav-item.show .nav-link, .nav-tabs .nav-link.active {
    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 {
    background: 0 0;
    border: 0;
    border-radius: .25rem
}

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

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

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

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

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

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

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

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

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

.navbar-nav {
    display: flex;
    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: .5rem;
    padding-bottom: .5rem
}

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

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

.navbar-toggler:focus, .navbar-toggler:hover {
    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 > .container-fluid, .navbar-expand-sm > .container-lg, .navbar-expand-sm > .container-md, .navbar-expand-sm > .container-sm, .navbar-expand-sm > .container-xl {
        padding-right: 0;
        padding-left: 0
    }
}

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

.navbar-expand .navbar-collapse {
    display: flex !important;
    flex-basis: auto
}

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

.navbar-light .navbar-brand {
    color: rgba(0, 0, 0, .9)
}

.navbar-light .navbar-brand:focus, .navbar-light .navbar-brand:hover {
    color: rgba(0, 0, 0, .9)
}

.navbar-light .navbar-nav .nav-link {
    color: rgba(0, 0, 0, .5)
}

.navbar-light .navbar-nav .nav-link:focus, .navbar-light .navbar-nav .nav-link:hover {
    color: rgba(0, 0, 0, .7)
}

.navbar-light .navbar-nav .nav-link.disabled {
    color: rgba(0, 0, 0, .3)
}

.navbar-light .navbar-nav .active > .nav-link, .navbar-light .navbar-nav .nav-link.active, .navbar-light .navbar-nav .nav-link.show, .navbar-light .navbar-nav .show > .nav-link {
    color: rgba(0, 0, 0, .9)
}

.navbar-light .navbar-toggler {
    color: rgba(0, 0, 0, .5);
    border-color: rgba(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, .5)
}

.navbar-light .navbar-text a {
    color: rgba(0, 0, 0, .9)
}

.navbar-light .navbar-text a:focus, .navbar-light .navbar-text a:hover {
    color: rgba(0, 0, 0, .9)
}

.navbar-dark .navbar-brand {
    color: #fff
}

.navbar-dark .navbar-brand:focus, .navbar-dark .navbar-brand:hover {
    color: #fff
}

.navbar-dark .navbar-nav .nav-link {
    color: rgba(255, 255, 255, .5)
}

.navbar-dark .navbar-nav .nav-link:focus, .navbar-dark .navbar-nav .nav-link:hover {
    color: rgba(255, 255, 255, .75)
}

.navbar-dark .navbar-nav .nav-link.disabled {
    color: rgba(255, 255, 255, .25)
}

.navbar-dark .navbar-nav .active > .nav-link, .navbar-dark .navbar-nav .nav-link.active, .navbar-dark .navbar-nav .nav-link.show, .navbar-dark .navbar-nav .show > .nav-link {
    color: #fff
}

.navbar-dark .navbar-toggler {
    color: rgba(255, 255, 255, .5);
    border-color: rgba(255, 255, 255, .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, .5)
}

.navbar-dark .navbar-text a {
    color: #fff
}

.navbar-dark .navbar-text a:focus, .navbar-dark .navbar-text a:hover {
    color: #fff
}

.alert {
    position: relative;
    padding: .75rem 1.25rem;
    margin-bottom: 1rem;
    border: 1px solid transparent;
    border-radius: .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: .75rem 1.25rem;
    color: inherit
}

.alert-primary {
    color: #78281f;
    background-color: #fadbd8;
    border-color: #f8cdc8
}

.alert-primary hr {
    border-top-color: #f5b8b1
}

.alert-primary .alert-link {
    color: #4f1a15
}

.alert-secondary {
    color: #6d1224;
    background-color: #f6d3da;
    border-color: #f2c1cb
}

.alert-secondary hr {
    border-top-color: #eeacb9
}

.alert-secondary .alert-link {
    color: #410b16
}

.alert-success {
    color: #186a3b;
    background-color: #d5f5e3;
    border-color: #c4f1d7
}

.alert-success hr {
    border-top-color: #afecc9
}

.alert-success .alert-link {
    color: #0f4024
}

.alert-info {
    color: #1b4f72;
    background-color: #d6eaf8;
    border-color: #c6e2f5
}

.alert-info hr {
    border-top-color: #b0d7f1
}

.alert-info .alert-link {
    color: #113249
}

.alert-warning {
    color: #7d6608;
    background-color: #fcf3cf;
    border-color: #fbeebc
}

.alert-warning hr {
    border-top-color: #fae8a4
}

.alert-warning .alert-link {
    color: #4d3f05
}

.alert-danger {
    color: #78281f;
    background-color: #fadbd8;
    border-color: #f8cdc8
}

.alert-danger hr {
    border-top-color: #f5b8b1
}

.alert-danger .alert-link {
    color: #4f1a15
}

.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: #111315;
    background-color: #d3d3d4;
    border-color: #c1c2c3
}

.alert-dark hr {
    border-top-color: #b4b5b6
}

.alert-dark .alert-link {
    color: #000
}

.alert-default {
    color: #626567;
    background-color: #f2f3f4;
    border-color: #edeeef
}

.alert-default hr {
    border-top-color: #e0e1e3
}

.alert-default .alert-link {
    color: #494b4d
}

.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):focus, .close:not(:disabled):not(.disabled):hover {
    opacity: .75
}

button.close {
    padding: 0;
    background-color: transparent;
    border: 0
}

a.close.disabled {
    pointer-events: none
}

.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: .5rem;
    pointer-events: none
}

.modal.fade .modal-dialog {
    transition: transform .3s ease-out;
    transform: translate(0, -50px)
}

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

.modal.show .modal-dialog {
    transform: none
}

.modal.modal-static .modal-dialog {
    transform: scale(1.02)
}

.modal-dialog-scrollable {
    display: flex;
    max-height: calc(100% - 1rem)
}

.modal-dialog-scrollable .modal-content {
    max-height: calc(100vh - 1rem);
    overflow: hidden
}

.modal-dialog-scrollable .modal-footer, .modal-dialog-scrollable .modal-header {
    flex-shrink: 0
}

.modal-dialog-scrollable .modal-body {
    overflow-y: auto
}

.modal-dialog-centered {
    display: flex;
    align-items: center;
    min-height: calc(100% - 1rem)
}

.modal-dialog-centered::before {
    display: block;
    height: calc(100vh - 1rem);
    height: min-content;
    content: ""
}

.modal-dialog-centered.modal-dialog-scrollable {
    flex-direction: column;
    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: flex;
    flex-direction: column;
    width: 100%;
    pointer-events: auto;
    background-color: #fff;
    background-clip: padding-box;
    border: 1px solid rgba(0, 0, 0, .2);
    border-radius: .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: .5
}

.modal-header {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    padding: 1rem 1rem;
    border-bottom: 1px solid #dee2e6;
    border-top-left-radius: calc(.3rem - 1px);
    border-top-right-radius: calc(.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;
    flex: 1 1 auto;
    padding: 1rem
}

.modal-footer {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    justify-content: flex-end;
    padding: .75rem;
    border-top: 1px solid #dee2e6;
    border-bottom-right-radius: calc(.3rem - 1px);
    border-bottom-left-radius: calc(.3rem - 1px)
}

.modal-footer > * {
    margin: .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: 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;
    white-space: normal;
    word-spacing: normal;
    line-break: auto;
    font-size: .875rem;
    word-wrap: break-word;
    opacity: 0
}

.tooltip.show {
    opacity: .9
}

.tooltip .arrow {
    position: absolute;
    display: block;
    width: .8rem;
    height: .4rem
}

.tooltip .arrow::before {
    position: absolute;
    content: "";
    border-color: transparent;
    border-style: solid
}

.bs-tooltip-auto[x-placement^=top], .bs-tooltip-top {
    padding: .4rem 0
}

.bs-tooltip-auto[x-placement^=top] .arrow, .bs-tooltip-top .arrow {
    bottom: 0
}

.bs-tooltip-auto[x-placement^=top] .arrow::before, .bs-tooltip-top .arrow::before {
    top: 0;
    border-width: .4rem .4rem 0;
    border-top-color: #000
}

.bs-tooltip-auto[x-placement^=right], .bs-tooltip-right {
    padding: 0 .4rem
}

.bs-tooltip-auto[x-placement^=right] .arrow, .bs-tooltip-right .arrow {
    left: 0;
    width: .4rem;
    height: .8rem
}

.bs-tooltip-auto[x-placement^=right] .arrow::before, .bs-tooltip-right .arrow::before {
    right: 0;
    border-width: .4rem .4rem .4rem 0;
    border-right-color: #000
}

.bs-tooltip-auto[x-placement^=bottom], .bs-tooltip-bottom {
    padding: .4rem 0
}

.bs-tooltip-auto[x-placement^=bottom] .arrow, .bs-tooltip-bottom .arrow {
    top: 0
}

.bs-tooltip-auto[x-placement^=bottom] .arrow::before, .bs-tooltip-bottom .arrow::before {
    bottom: 0;
    border-width: 0 .4rem .4rem;
    border-bottom-color: #000
}

.bs-tooltip-auto[x-placement^=left], .bs-tooltip-left {
    padding: 0 .4rem
}

.bs-tooltip-auto[x-placement^=left] .arrow, .bs-tooltip-left .arrow {
    right: 0;
    width: .4rem;
    height: .8rem
}

.bs-tooltip-auto[x-placement^=left] .arrow::before, .bs-tooltip-left .arrow::before {
    left: 0;
    border-width: .4rem 0 .4rem .4rem;
    border-left-color: #000
}

.tooltip-inner {
    max-width: 200px;
    padding: .25rem .5rem;
    color: #fff;
    text-align: center;
    background-color: #000;
    border-radius: .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;
    white-space: normal;
    word-spacing: normal;
    line-break: auto;
    font-size: .875rem;
    word-wrap: break-word;
    background-color: #fff;
    background-clip: padding-box;
    border: 1px solid rgba(0, 0, 0, .2);
    border-radius: .3rem
}

.popover .arrow {
    position: absolute;
    display: block;
    width: 1rem;
    height: .5rem;
    margin: 0 .3rem
}

.popover .arrow::after, .popover .arrow::before {
    position: absolute;
    display: block;
    content: "";
    border-color: transparent;
    border-style: solid
}

.bs-popover-auto[x-placement^=top], .bs-popover-top {
    margin-bottom: .5rem
}

.bs-popover-auto[x-placement^=top] > .arrow, .bs-popover-top > .arrow {
    bottom: calc(-.5rem - 1px)
}

.bs-popover-auto[x-placement^=top] > .arrow::before, .bs-popover-top > .arrow::before {
    bottom: 0;
    border-width: .5rem .5rem 0;
    border-top-color: rgba(0, 0, 0, .25)
}

.bs-popover-auto[x-placement^=top] > .arrow::after, .bs-popover-top > .arrow::after {
    bottom: 1px;
    border-width: .5rem .5rem 0;
    border-top-color: #fff
}

.bs-popover-auto[x-placement^=right], .bs-popover-right {
    margin-left: .5rem
}

.bs-popover-auto[x-placement^=right] > .arrow, .bs-popover-right > .arrow {
    left: calc(-.5rem - 1px);
    width: .5rem;
    height: 1rem;
    margin: .3rem 0
}

.bs-popover-auto[x-placement^=right] > .arrow::before, .bs-popover-right > .arrow::before {
    left: 0;
    border-width: .5rem .5rem .5rem 0;
    border-right-color: rgba(0, 0, 0, .25)
}

.bs-popover-auto[x-placement^=right] > .arrow::after, .bs-popover-right > .arrow::after {
    left: 1px;
    border-width: .5rem .5rem .5rem 0;
    border-right-color: #fff
}

.bs-popover-auto[x-placement^=bottom], .bs-popover-bottom {
    margin-top: .5rem
}

.bs-popover-auto[x-placement^=bottom] > .arrow, .bs-popover-bottom > .arrow {
    top: calc(-.5rem - 1px)
}

.bs-popover-auto[x-placement^=bottom] > .arrow::before, .bs-popover-bottom > .arrow::before {
    top: 0;
    border-width: 0 .5rem .5rem .5rem;
    border-bottom-color: rgba(0, 0, 0, .25)
}

.bs-popover-auto[x-placement^=bottom] > .arrow::after, .bs-popover-bottom > .arrow::after {
    top: 1px;
    border-width: 0 .5rem .5rem .5rem;
    border-bottom-color: #fff
}

.bs-popover-auto[x-placement^=bottom] .popover-header::before, .bs-popover-bottom .popover-header::before {
    position: absolute;
    top: 0;
    left: 50%;
    display: block;
    width: 1rem;
    margin-left: -.5rem;
    content: "";
    border-bottom: 1px solid #f7f7f7
}

.bs-popover-auto[x-placement^=left], .bs-popover-left {
    margin-right: .5rem
}

.bs-popover-auto[x-placement^=left] > .arrow, .bs-popover-left > .arrow {
    right: calc(-.5rem - 1px);
    width: .5rem;
    height: 1rem;
    margin: .3rem 0
}

.bs-popover-auto[x-placement^=left] > .arrow::before, .bs-popover-left > .arrow::before {
    right: 0;
    border-width: .5rem 0 .5rem .5rem;
    border-left-color: rgba(0, 0, 0, .25)
}

.bs-popover-auto[x-placement^=left] > .arrow::after, .bs-popover-left > .arrow::after {
    right: 1px;
    border-width: .5rem 0 .5rem .5rem;
    border-left-color: #fff
}

.popover-header {
    padding: .5rem .75rem;
    margin-bottom: 0;
    font-size: 1rem;
    background-color: #f7f7f7;
    border-bottom: 1px solid #ebebeb;
    border-top-left-radius: calc(.3rem - 1px);
    border-top-right-radius: calc(.3rem - 1px)
}

.popover-header:empty {
    display: none
}

.popover-body {
    padding: .5rem .75rem;
    color: #212529
}

.bg-primary {
    background-color: #e74c3c !important
}

a.bg-primary:focus, a.bg-primary:hover, button.bg-primary:focus, button.bg-primary:hover {
    background-color: #d62c1a !important
}

.bg-secondary {
    background-color: #d12345 !important
}

a.bg-secondary:focus, a.bg-secondary:hover, button.bg-secondary:focus, button.bg-secondary:hover {
    background-color: #a51c37 !important
}

.bg-success {
    background-color: #2ecc71 !important
}

a.bg-success:focus, a.bg-success:hover, button.bg-success:focus, button.bg-success:hover {
    background-color: #25a25a !important
}

.bg-info {
    background-color: #3498db !important
}

a.bg-info:focus, a.bg-info:hover, button.bg-info:focus, button.bg-info:hover {
    background-color: #217dbb !important
}

.bg-warning {
    background-color: #f1c40f !important
}

a.bg-warning:focus, a.bg-warning:hover, button.bg-warning:focus, button.bg-warning:hover {
    background-color: #c29d0b !important
}

.bg-danger {
    background-color: #e74c3c !important
}

a.bg-danger:focus, a.bg-danger:hover, button.bg-danger:focus, button.bg-danger:hover {
    background-color: #d62c1a !important
}

.bg-light {
    background-color: #f8f9fa !important
}

a.bg-light:focus, a.bg-light:hover, button.bg-light:focus, button.bg-light:hover {
    background-color: #dae0e5 !important
}

.bg-dark {
    background-color: #212529 !important
}

a.bg-dark:focus, a.bg-dark:hover, button.bg-dark:focus, button.bg-dark:hover {
    background-color: #0a0c0d !important
}

.bg-default {
    background-color: #bdc3c7 !important
}

a.bg-default:focus, a.bg-default:hover, button.bg-default:focus, button.bg-default:hover {
    background-color: #a1aab0 !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: #e74c3c !important
}

.border-secondary {
    border-color: #d12345 !important
}

.border-success {
    border-color: #2ecc71 !important
}

.border-info {
    border-color: #3498db !important
}

.border-warning {
    border-color: #f1c40f !important
}

.border-danger {
    border-color: #e74c3c !important
}

.border-light {
    border-color: #f8f9fa !important
}

.border-dark {
    border-color: #212529 !important
}

.border-default {
    border-color: #bdc3c7 !important
}

.border-white {
    border-color: #fff !important
}

.rounded-sm {
    border-radius: .2rem !important
}

.rounded {
    border-radius: .25rem !important
}

.rounded-top {
    border-top-left-radius: .25rem !important;
    border-top-right-radius: .25rem !important
}

.rounded-right {
    border-top-right-radius: .25rem !important;
    border-bottom-right-radius: .25rem !important
}

.rounded-bottom {
    border-bottom-right-radius: .25rem !important;
    border-bottom-left-radius: .25rem !important
}

.rounded-left {
    border-top-left-radius: .25rem !important;
    border-bottom-left-radius: .25rem !important
}

.rounded-lg {
    border-radius: .3rem !important
}

.rounded-circle {
    border-radius: 50% !important
}

.rounded-pill {
    border-radius: 50rem !important
}

.rounded-0 {
    border-radius: 0 !important
}

.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: flex !important
}

.d-inline-flex {
    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: flex !important
    }

    .d-sm-inline-flex {
        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: flex !important
    }

    .d-md-inline-flex {
        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: flex !important
    }

    .d-lg-inline-flex {
        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: flex !important
    }

    .d-xl-inline-flex {
        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: flex !important
    }

    .d-print-inline-flex {
        display: inline-flex !important
    }
}

.flex-row {
    flex-direction: row !important
}

.flex-column {
    flex-direction: column !important
}

.flex-row-reverse {
    flex-direction: row-reverse !important
}

.flex-column-reverse {
    flex-direction: column-reverse !important
}

.flex-wrap {
    flex-wrap: wrap !important
}

.flex-nowrap {
    flex-wrap: nowrap !important
}

.flex-wrap-reverse {
    flex-wrap: wrap-reverse !important
}

.flex-fill {
    flex: 1 1 auto !important
}

.flex-grow-0 {
    flex-grow: 0 !important
}

.flex-grow-1 {
    flex-grow: 1 !important
}

.flex-shrink-0 {
    flex-shrink: 0 !important
}

.flex-shrink-1 {
    flex-shrink: 1 !important
}

.justify-content-start {
    justify-content: flex-start !important
}

.justify-content-end {
    justify-content: flex-end !important
}

.justify-content-center {
    justify-content: center !important
}

.justify-content-between {
    justify-content: space-between !important
}

.justify-content-around {
    justify-content: space-around !important
}

.align-items-start {
    align-items: flex-start !important
}

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

.align-items-center {
    align-items: center !important
}

.align-items-baseline {
    align-items: baseline !important
}

.align-items-stretch {
    align-items: stretch !important
}

.align-content-start {
    align-content: flex-start !important
}

.align-content-end {
    align-content: flex-end !important
}

.align-content-center {
    align-content: center !important
}

.align-content-between {
    align-content: space-between !important
}

.align-content-around {
    align-content: space-around !important
}

.align-content-stretch {
    align-content: stretch !important
}

.align-self-auto {
    align-self: auto !important
}

.align-self-start {
    align-self: flex-start !important
}

.align-self-end {
    align-self: flex-end !important
}

.align-self-center {
    align-self: center !important
}

.align-self-baseline {
    align-self: baseline !important
}

.align-self-stretch {
    align-self: stretch !important
}

@media (min-width: 576px) {
    .flex-sm-row {
        flex-direction: row !important
    }

    .flex-sm-column {
        flex-direction: column !important
    }

    .flex-sm-row-reverse {
        flex-direction: row-reverse !important
    }

    .flex-sm-column-reverse {
        flex-direction: column-reverse !important
    }

    .flex-sm-wrap {
        flex-wrap: wrap !important
    }

    .flex-sm-nowrap {
        flex-wrap: nowrap !important
    }

    .flex-sm-wrap-reverse {
        flex-wrap: wrap-reverse !important
    }

    .flex-sm-fill {
        flex: 1 1 auto !important
    }

    .flex-sm-grow-0 {
        flex-grow: 0 !important
    }

    .flex-sm-grow-1 {
        flex-grow: 1 !important
    }

    .flex-sm-shrink-0 {
        flex-shrink: 0 !important
    }

    .flex-sm-shrink-1 {
        flex-shrink: 1 !important
    }

    .justify-content-sm-start {
        justify-content: flex-start !important
    }

    .justify-content-sm-end {
        justify-content: flex-end !important
    }

    .justify-content-sm-center {
        justify-content: center !important
    }

    .justify-content-sm-between {
        justify-content: space-between !important
    }

    .justify-content-sm-around {
        justify-content: space-around !important
    }

    .align-items-sm-start {
        align-items: flex-start !important
    }

    .align-items-sm-end {
        align-items: flex-end !important
    }

    .align-items-sm-center {
        align-items: center !important
    }

    .align-items-sm-baseline {
        align-items: baseline !important
    }

    .align-items-sm-stretch {
        align-items: stretch !important
    }

    .align-content-sm-start {
        align-content: flex-start !important
    }

    .align-content-sm-end {
        align-content: flex-end !important
    }

    .align-content-sm-center {
        align-content: center !important
    }

    .align-content-sm-between {
        align-content: space-between !important
    }

    .align-content-sm-around {
        align-content: space-around !important
    }

    .align-content-sm-stretch {
        align-content: stretch !important
    }

    .align-self-sm-auto {
        align-self: auto !important
    }

    .align-self-sm-start {
        align-self: flex-start !important
    }

    .align-self-sm-end {
        align-self: flex-end !important
    }

    .align-self-sm-center {
        align-self: center !important
    }

    .align-self-sm-baseline {
        align-self: baseline !important
    }

    .align-self-sm-stretch {
        align-self: stretch !important
    }
}

@media (min-width: 768px) {
    .flex-md-row {
        flex-direction: row !important
    }

    .flex-md-column {
        flex-direction: column !important
    }

    .flex-md-row-reverse {
        flex-direction: row-reverse !important
    }

    .flex-md-column-reverse {
        flex-direction: column-reverse !important
    }

    .flex-md-wrap {
        flex-wrap: wrap !important
    }

    .flex-md-nowrap {
        flex-wrap: nowrap !important
    }

    .flex-md-wrap-reverse {
        flex-wrap: wrap-reverse !important
    }

    .flex-md-fill {
        flex: 1 1 auto !important
    }

    .flex-md-grow-0 {
        flex-grow: 0 !important
    }

    .flex-md-grow-1 {
        flex-grow: 1 !important
    }

    .flex-md-shrink-0 {
        flex-shrink: 0 !important
    }

    .flex-md-shrink-1 {
        flex-shrink: 1 !important
    }

    .justify-content-md-start {
        justify-content: flex-start !important
    }

    .justify-content-md-end {
        justify-content: flex-end !important
    }

    .justify-content-md-center {
        justify-content: center !important
    }

    .justify-content-md-between {
        justify-content: space-between !important
    }

    .justify-content-md-around {
        justify-content: space-around !important
    }

    .align-items-md-start {
        align-items: flex-start !important
    }

    .align-items-md-end {
        align-items: flex-end !important
    }

    .align-items-md-center {
        align-items: center !important
    }

    .align-items-md-baseline {
        align-items: baseline !important
    }

    .align-items-md-stretch {
        align-items: stretch !important
    }

    .align-content-md-start {
        align-content: flex-start !important
    }

    .align-content-md-end {
        align-content: flex-end !important
    }

    .align-content-md-center {
        align-content: center !important
    }

    .align-content-md-between {
        align-content: space-between !important
    }

    .align-content-md-around {
        align-content: space-around !important
    }

    .align-content-md-stretch {
        align-content: stretch !important
    }

    .align-self-md-auto {
        align-self: auto !important
    }

    .align-self-md-start {
        align-self: flex-start !important
    }

    .align-self-md-end {
        align-self: flex-end !important
    }

    .align-self-md-center {
        align-self: center !important
    }

    .align-self-md-baseline {
        align-self: baseline !important
    }

    .align-self-md-stretch {
        align-self: stretch !important
    }
}

@media (min-width: 992px) {
    .flex-lg-row {
        flex-direction: row !important
    }

    .flex-lg-column {
        flex-direction: column !important
    }

    .flex-lg-row-reverse {
        flex-direction: row-reverse !important
    }

    .flex-lg-column-reverse {
        flex-direction: column-reverse !important
    }

    .flex-lg-wrap {
        flex-wrap: wrap !important
    }

    .flex-lg-nowrap {
        flex-wrap: nowrap !important
    }

    .flex-lg-wrap-reverse {
        flex-wrap: wrap-reverse !important
    }

    .flex-lg-fill {
        flex: 1 1 auto !important
    }

    .flex-lg-grow-0 {
        flex-grow: 0 !important
    }

    .flex-lg-grow-1 {
        flex-grow: 1 !important
    }

    .flex-lg-shrink-0 {
        flex-shrink: 0 !important
    }

    .flex-lg-shrink-1 {
        flex-shrink: 1 !important
    }

    .justify-content-lg-start {
        justify-content: flex-start !important
    }

    .justify-content-lg-end {
        justify-content: flex-end !important
    }

    .justify-content-lg-center {
        justify-content: center !important
    }

    .justify-content-lg-between {
        justify-content: space-between !important
    }

    .justify-content-lg-around {
        justify-content: space-around !important
    }

    .align-items-lg-start {
        align-items: flex-start !important
    }

    .align-items-lg-end {
        align-items: flex-end !important
    }

    .align-items-lg-center {
        align-items: center !important
    }

    .align-items-lg-baseline {
        align-items: baseline !important
    }

    .align-items-lg-stretch {
        align-items: stretch !important
    }

    .align-content-lg-start {
        align-content: flex-start !important
    }

    .align-content-lg-end {
        align-content: flex-end !important
    }

    .align-content-lg-center {
        align-content: center !important
    }

    .align-content-lg-between {
        align-content: space-between !important
    }

    .align-content-lg-around {
        align-content: space-around !important
    }

    .align-content-lg-stretch {
        align-content: stretch !important
    }

    .align-self-lg-auto {
        align-self: auto !important
    }

    .align-self-lg-start {
        align-self: flex-start !important
    }

    .align-self-lg-end {
        align-self: flex-end !important
    }

    .align-self-lg-center {
        align-self: center !important
    }

    .align-self-lg-baseline {
        align-self: baseline !important
    }

    .align-self-lg-stretch {
        align-self: stretch !important
    }
}

@media (min-width: 1200px) {
    .flex-xl-row {
        flex-direction: row !important
    }

    .flex-xl-column {
        flex-direction: column !important
    }

    .flex-xl-row-reverse {
        flex-direction: row-reverse !important
    }

    .flex-xl-column-reverse {
        flex-direction: column-reverse !important
    }

    .flex-xl-wrap {
        flex-wrap: wrap !important
    }

    .flex-xl-nowrap {
        flex-wrap: nowrap !important
    }

    .flex-xl-wrap-reverse {
        flex-wrap: wrap-reverse !important
    }

    .flex-xl-fill {
        flex: 1 1 auto !important
    }

    .flex-xl-grow-0 {
        flex-grow: 0 !important
    }

    .flex-xl-grow-1 {
        flex-grow: 1 !important
    }

    .flex-xl-shrink-0 {
        flex-shrink: 0 !important
    }

    .flex-xl-shrink-1 {
        flex-shrink: 1 !important
    }

    .justify-content-xl-start {
        justify-content: flex-start !important
    }

    .justify-content-xl-end {
        justify-content: flex-end !important
    }

    .justify-content-xl-center {
        justify-content: center !important
    }

    .justify-content-xl-between {
        justify-content: space-between !important
    }

    .justify-content-xl-around {
        justify-content: space-around !important
    }

    .align-items-xl-start {
        align-items: flex-start !important
    }

    .align-items-xl-end {
        align-items: flex-end !important
    }

    .align-items-xl-center {
        align-items: center !important
    }

    .align-items-xl-baseline {
        align-items: baseline !important
    }

    .align-items-xl-stretch {
        align-items: stretch !important
    }

    .align-content-xl-start {
        align-content: flex-start !important
    }

    .align-content-xl-end {
        align-content: flex-end !important
    }

    .align-content-xl-center {
        align-content: center !important
    }

    .align-content-xl-between {
        align-content: space-between !important
    }

    .align-content-xl-around {
        align-content: space-around !important
    }

    .align-content-xl-stretch {
        align-content: stretch !important
    }

    .align-self-xl-auto {
        align-self: auto !important
    }

    .align-self-xl-start {
        align-self: flex-start !important
    }

    .align-self-xl-end {
        align-self: flex-end !important
    }

    .align-self-xl-center {
        align-self: center !important
    }

    .align-self-xl-baseline {
        align-self: baseline !important
    }

    .align-self-xl-stretch {
        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
    }
}

.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: 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:sticky) {
    .sticky-top {
        position: sticky;
        top: 0;
        z-index: 1020
    }
}

.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: .25rem !important
}

.mt-1, .my-1 {
    margin-top: .25rem !important
}

.mr-1, .mx-1 {
    margin-right: .25rem !important
}

.mb-1, .my-1 {
    margin-bottom: .25rem !important
}

.ml-1, .mx-1 {
    margin-left: .25rem !important
}

.m-2 {
    margin: .5rem !important
}

.mt-2, .my-2 {
    margin-top: .5rem !important
}

.mr-2, .mx-2 {
    margin-right: .5rem !important
}

.mb-2, .my-2 {
    margin-bottom: .5rem !important
}

.ml-2, .mx-2 {
    margin-left: .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: .25rem !important
}

.pt-1, .py-1 {
    padding-top: .25rem !important
}

.pr-1, .px-1 {
    padding-right: .25rem !important
}

.pb-1, .py-1 {
    padding-bottom: .25rem !important
}

.pl-1, .px-1 {
    padding-left: .25rem !important
}

.p-2 {
    padding: .5rem !important
}

.pt-2, .py-2 {
    padding-top: .5rem !important
}

.pr-2, .px-2 {
    padding-right: .5rem !important
}

.pb-2, .py-2 {
    padding-bottom: .5rem !important
}

.pl-2, .px-2 {
    padding-left: .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: -.25rem !important
}

.mt-n1, .my-n1 {
    margin-top: -.25rem !important
}

.mr-n1, .mx-n1 {
    margin-right: -.25rem !important
}

.mb-n1, .my-n1 {
    margin-bottom: -.25rem !important
}

.ml-n1, .mx-n1 {
    margin-left: -.25rem !important
}

.m-n2 {
    margin: -.5rem !important
}

.mt-n2, .my-n2 {
    margin-top: -.5rem !important
}

.mr-n2, .mx-n2 {
    margin-right: -.5rem !important
}

.mb-n2, .my-n2 {
    margin-bottom: -.5rem !important
}

.ml-n2, .mx-n2 {
    margin-left: -.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: .25rem !important
    }

    .mt-sm-1, .my-sm-1 {
        margin-top: .25rem !important
    }

    .mr-sm-1, .mx-sm-1 {
        margin-right: .25rem !important
    }

    .mb-sm-1, .my-sm-1 {
        margin-bottom: .25rem !important
    }

    .ml-sm-1, .mx-sm-1 {
        margin-left: .25rem !important
    }

    .m-sm-2 {
        margin: .5rem !important
    }

    .mt-sm-2, .my-sm-2 {
        margin-top: .5rem !important
    }

    .mr-sm-2, .mx-sm-2 {
        margin-right: .5rem !important
    }

    .mb-sm-2, .my-sm-2 {
        margin-bottom: .5rem !important
    }

    .ml-sm-2, .mx-sm-2 {
        margin-left: .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: .25rem !important
    }

    .pt-sm-1, .py-sm-1 {
        padding-top: .25rem !important
    }

    .pr-sm-1, .px-sm-1 {
        padding-right: .25rem !important
    }

    .pb-sm-1, .py-sm-1 {
        padding-bottom: .25rem !important
    }

    .pl-sm-1, .px-sm-1 {
        padding-left: .25rem !important
    }

    .p-sm-2 {
        padding: .5rem !important
    }

    .pt-sm-2, .py-sm-2 {
        padding-top: .5rem !important
    }

    .pr-sm-2, .px-sm-2 {
        padding-right: .5rem !important
    }

    .pb-sm-2, .py-sm-2 {
        padding-bottom: .5rem !important
    }

    .pl-sm-2, .px-sm-2 {
        padding-left: .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: -.25rem !important
    }

    .mt-sm-n1, .my-sm-n1 {
        margin-top: -.25rem !important
    }

    .mr-sm-n1, .mx-sm-n1 {
        margin-right: -.25rem !important
    }

    .mb-sm-n1, .my-sm-n1 {
        margin-bottom: -.25rem !important
    }

    .ml-sm-n1, .mx-sm-n1 {
        margin-left: -.25rem !important
    }

    .m-sm-n2 {
        margin: -.5rem !important
    }

    .mt-sm-n2, .my-sm-n2 {
        margin-top: -.5rem !important
    }

    .mr-sm-n2, .mx-sm-n2 {
        margin-right: -.5rem !important
    }

    .mb-sm-n2, .my-sm-n2 {
        margin-bottom: -.5rem !important
    }

    .ml-sm-n2, .mx-sm-n2 {
        margin-left: -.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: .25rem !important
    }

    .mt-md-1, .my-md-1 {
        margin-top: .25rem !important
    }

    .mr-md-1, .mx-md-1 {
        margin-right: .25rem !important
    }

    .mb-md-1, .my-md-1 {
        margin-bottom: .25rem !important
    }

    .ml-md-1, .mx-md-1 {
        margin-left: .25rem !important
    }

    .m-md-2 {
        margin: .5rem !important
    }

    .mt-md-2, .my-md-2 {
        margin-top: .5rem !important
    }

    .mr-md-2, .mx-md-2 {
        margin-right: .5rem !important
    }

    .mb-md-2, .my-md-2 {
        margin-bottom: .5rem !important
    }

    .ml-md-2, .mx-md-2 {
        margin-left: .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: .25rem !important
    }

    .pt-md-1, .py-md-1 {
        padding-top: .25rem !important
    }

    .pr-md-1, .px-md-1 {
        padding-right: .25rem !important
    }

    .pb-md-1, .py-md-1 {
        padding-bottom: .25rem !important
    }

    .pl-md-1, .px-md-1 {
        padding-left: .25rem !important
    }

    .p-md-2 {
        padding: .5rem !important
    }

    .pt-md-2, .py-md-2 {
        padding-top: .5rem !important
    }

    .pr-md-2, .px-md-2 {
        padding-right: .5rem !important
    }

    .pb-md-2, .py-md-2 {
        padding-bottom: .5rem !important
    }

    .pl-md-2, .px-md-2 {
        padding-left: .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: -.25rem !important
    }

    .mt-md-n1, .my-md-n1 {
        margin-top: -.25rem !important
    }

    .mr-md-n1, .mx-md-n1 {
        margin-right: -.25rem !important
    }

    .mb-md-n1, .my-md-n1 {
        margin-bottom: -.25rem !important
    }

    .ml-md-n1, .mx-md-n1 {
        margin-left: -.25rem !important
    }

    .m-md-n2 {
        margin: -.5rem !important
    }

    .mt-md-n2, .my-md-n2 {
        margin-top: -.5rem !important
    }

    .mr-md-n2, .mx-md-n2 {
        margin-right: -.5rem !important
    }

    .mb-md-n2, .my-md-n2 {
        margin-bottom: -.5rem !important
    }

    .ml-md-n2, .mx-md-n2 {
        margin-left: -.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: .25rem !important
    }

    .mt-lg-1, .my-lg-1 {
        margin-top: .25rem !important
    }

    .mr-lg-1, .mx-lg-1 {
        margin-right: .25rem !important
    }

    .mb-lg-1, .my-lg-1 {
        margin-bottom: .25rem !important
    }

    .ml-lg-1, .mx-lg-1 {
        margin-left: .25rem !important
    }

    .m-lg-2 {
        margin: .5rem !important
    }

    .mt-lg-2, .my-lg-2 {
        margin-top: .5rem !important
    }

    .mr-lg-2, .mx-lg-2 {
        margin-right: .5rem !important
    }

    .mb-lg-2, .my-lg-2 {
        margin-bottom: .5rem !important
    }

    .ml-lg-2, .mx-lg-2 {
        margin-left: .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: .25rem !important
    }

    .pt-lg-1, .py-lg-1 {
        padding-top: .25rem !important
    }

    .pr-lg-1, .px-lg-1 {
        padding-right: .25rem !important
    }

    .pb-lg-1, .py-lg-1 {
        padding-bottom: .25rem !important
    }

    .pl-lg-1, .px-lg-1 {
        padding-left: .25rem !important
    }

    .p-lg-2 {
        padding: .5rem !important
    }

    .pt-lg-2, .py-lg-2 {
        padding-top: .5rem !important
    }

    .pr-lg-2, .px-lg-2 {
        padding-right: .5rem !important
    }

    .pb-lg-2, .py-lg-2 {
        padding-bottom: .5rem !important
    }

    .pl-lg-2, .px-lg-2 {
        padding-left: .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: -.25rem !important
    }

    .mt-lg-n1, .my-lg-n1 {
        margin-top: -.25rem !important
    }

    .mr-lg-n1, .mx-lg-n1 {
        margin-right: -.25rem !important
    }

    .mb-lg-n1, .my-lg-n1 {
        margin-bottom: -.25rem !important
    }

    .ml-lg-n1, .mx-lg-n1 {
        margin-left: -.25rem !important
    }

    .m-lg-n2 {
        margin: -.5rem !important
    }

    .mt-lg-n2, .my-lg-n2 {
        margin-top: -.5rem !important
    }

    .mr-lg-n2, .mx-lg-n2 {
        margin-right: -.5rem !important
    }

    .mb-lg-n2, .my-lg-n2 {
        margin-bottom: -.5rem !important
    }

    .ml-lg-n2, .mx-lg-n2 {
        margin-left: -.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: .25rem !important
    }

    .mt-xl-1, .my-xl-1 {
        margin-top: .25rem !important
    }

    .mr-xl-1, .mx-xl-1 {
        margin-right: .25rem !important
    }

    .mb-xl-1, .my-xl-1 {
        margin-bottom: .25rem !important
    }

    .ml-xl-1, .mx-xl-1 {
        margin-left: .25rem !important
    }

    .m-xl-2 {
        margin: .5rem !important
    }

    .mt-xl-2, .my-xl-2 {
        margin-top: .5rem !important
    }

    .mr-xl-2, .mx-xl-2 {
        margin-right: .5rem !important
    }

    .mb-xl-2, .my-xl-2 {
        margin-bottom: .5rem !important
    }

    .ml-xl-2, .mx-xl-2 {
        margin-left: .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: .25rem !important
    }

    .pt-xl-1, .py-xl-1 {
        padding-top: .25rem !important
    }

    .pr-xl-1, .px-xl-1 {
        padding-right: .25rem !important
    }

    .pb-xl-1, .py-xl-1 {
        padding-bottom: .25rem !important
    }

    .pl-xl-1, .px-xl-1 {
        padding-left: .25rem !important
    }

    .p-xl-2 {
        padding: .5rem !important
    }

    .pt-xl-2, .py-xl-2 {
        padding-top: .5rem !important
    }

    .pr-xl-2, .px-xl-2 {
        padding-right: .5rem !important
    }

    .pb-xl-2, .py-xl-2 {
        padding-bottom: .5rem !important
    }

    .pl-xl-2, .px-xl-2 {
        padding-left: .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: -.25rem !important
    }

    .mt-xl-n1, .my-xl-n1 {
        margin-top: -.25rem !important
    }

    .mr-xl-n1, .mx-xl-n1 {
        margin-right: -.25rem !important
    }

    .mb-xl-n1, .my-xl-n1 {
        margin-bottom: -.25rem !important
    }

    .ml-xl-n1, .mx-xl-n1 {
        margin-left: -.25rem !important
    }

    .m-xl-n2 {
        margin: -.5rem !important
    }

    .mt-xl-n2, .my-xl-n2 {
        margin-top: -.5rem !important
    }

    .mr-xl-n2, .mx-xl-n2 {
        margin-right: -.5rem !important
    }

    .mb-xl-n2, .my-xl-n2 {
        margin-bottom: -.5rem !important
    }

    .ml-xl-n2, .mx-xl-n2 {
        margin-left: -.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
    }
}

.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: #e74c3c !important
}

a.text-primary:focus, a.text-primary:hover {
    color: #bf2718 !important
}

.text-secondary {
    color: #d12345 !important
}

a.text-secondary:focus, a.text-secondary:hover {
    color: #8f182f !important
}

.text-success {
    color: #2ecc71 !important
}

a.text-success:focus, a.text-success:hover {
    color: #208e4e !important
}

.text-info {
    color: #3498db !important
}

a.text-info:focus, a.text-info:hover {
    color: #1d6fa5 !important
}

.text-warning {
    color: #f1c40f !important
}

a.text-warning:focus, a.text-warning:hover {
    color: #aa8a0a !important
}

.text-danger {
    color: #e74c3c !important
}

a.text-danger:focus, a.text-danger:hover {
    color: #bf2718 !important
}

.text-light {
    color: #f8f9fa !important
}

a.text-light:focus, a.text-light:hover {
    color: #cbd3da !important
}

.text-dark {
    color: #212529 !important
}

a.text-dark:focus, a.text-dark:hover {
    color: #000 !important
}

.text-default {
    color: #bdc3c7 !important
}

a.text-default:focus, a.text-default:hover {
    color: #949da4 !important
}

.text-body {
    color: #212529 !important
}

.text-muted {
    color: #6c757d !important
}

.text-black-50 {
    color: rgba(0, 0, 0, .5) !important
}

.text-white-50 {
    color: rgba(255, 255, 255, .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
}

.CodeMirror {
    font-family: monospace;
    height: 300px;
    color: #000;
    direction: ltr
}

.CodeMirror-lines {
    padding: 4px 0
}

.CodeMirror pre {
    padding: 0 4px
}

.CodeMirror-gutter-filler, .CodeMirror-scrollbar-filler {
    background-color: #fff
}

.CodeMirror-gutters {
    border-right: 1px solid #ddd;
    background-color: #f7f7f7;
    white-space: nowrap
}

.CodeMirror-linenumber {
    padding: 0 3px 0 5px;
    min-width: 20px;
    text-align: right;
    color: #999;
    white-space: nowrap
}

.CodeMirror-guttermarker {
    color: #000
}

.CodeMirror-guttermarker-subtle {
    color: #999
}

.CodeMirror-cursor {
    border-left: 1px solid #000;
    border-right: none;
    width: 0
}

.CodeMirror div.CodeMirror-secondarycursor {
    border-left: 1px solid silver
}

.cm-fat-cursor .CodeMirror-cursor {
    width: auto;
    border: 0 !important;
    background: #7e7
}

.cm-fat-cursor div.CodeMirror-cursors {
    z-index: 1
}

.cm-fat-cursor-mark {
    background-color: rgba(20, 255, 20, .5);
    -webkit-animation: blink 1.06s steps(1) infinite;
    -moz-animation: blink 1.06s steps(1) infinite;
    animation: blink 1.06s steps(1) infinite
}

.cm-animate-fat-cursor {
    width: auto;
    border: 0;
    -webkit-animation: blink 1.06s steps(1) infinite;
    -moz-animation: blink 1.06s steps(1) infinite;
    animation: blink 1.06s steps(1) infinite;
    background-color: #7e7
}

@-moz-keyframes blink {
    50% {
        background-color: transparent
    }
}

@-webkit-keyframes blink {
    50% {
        background-color: transparent
    }
}

@keyframes blink {
    50% {
        background-color: transparent
    }
}

.cm-tab {
    display: inline-block;
    text-decoration: inherit
}

.CodeMirror-rulers {
    position: absolute;
    left: 0;
    right: 0;
    top: -50px;
    bottom: -20px;
    overflow: hidden
}

.CodeMirror-ruler {
    border-left: 1px solid #ccc;
    top: 0;
    bottom: 0;
    position: absolute
}

.cm-s-default .cm-header {
    color: #00f
}

.cm-s-default .cm-quote {
    color: #090
}

.cm-negative {
    color: #d44
}

.cm-positive {
    color: #292
}

.cm-header, .cm-strong {
    font-weight: 700
}

.cm-em {
    font-style: italic
}

.cm-link {
    text-decoration: underline
}

.cm-strikethrough {
    text-decoration: line-through
}

.cm-s-default .cm-keyword {
    color: #708
}

.cm-s-default .cm-atom {
    color: #219
}

.cm-s-default .cm-number {
    color: #164
}

.cm-s-default .cm-def {
    color: #00f
}

.cm-s-default .cm-variable-2 {
    color: #05a
}

.cm-s-default .cm-type, .cm-s-default .cm-variable-3 {
    color: #085
}

.cm-s-default .cm-comment {
    color: #a50
}

.cm-s-default .cm-string {
    color: #a11
}

.cm-s-default .cm-string-2 {
    color: #f50
}

.cm-s-default .cm-meta {
    color: #555
}

.cm-s-default .cm-qualifier {
    color: #555
}

.cm-s-default .cm-builtin {
    color: #30a
}

.cm-s-default .cm-bracket {
    color: #997
}

.cm-s-default .cm-tag {
    color: #170
}

.cm-s-default .cm-attribute {
    color: #00c
}

.cm-s-default .cm-hr {
    color: #999
}

.cm-s-default .cm-link {
    color: #00c
}

.cm-s-default .cm-error {
    color: red
}

.cm-invalidchar {
    color: red
}

.CodeMirror-composing {
    border-bottom: 2px solid
}

div.CodeMirror span.CodeMirror-matchingbracket {
    color: #0f0
}

div.CodeMirror span.CodeMirror-nonmatchingbracket {
    color: #f22
}

.CodeMirror-matchingtag {
    background: rgba(255, 150, 0, .3)
}

.CodeMirror-activeline-background {
    background: #e8f2ff
}

.CodeMirror {
    position: relative;
    overflow: hidden;
    background: #fff
}

.CodeMirror-scroll {
    overflow: scroll !important;
    margin-bottom: -30px;
    margin-right: -30px;
    padding-bottom: 30px;
    height: 100%;
    outline: 0;
    position: relative
}

.CodeMirror-sizer {
    position: relative;
    border-right: 30px solid transparent
}

.CodeMirror-gutter-filler, .CodeMirror-hscrollbar, .CodeMirror-scrollbar-filler, .CodeMirror-vscrollbar {
    position: absolute;
    z-index: 6;
    display: none
}

.CodeMirror-vscrollbar {
    right: 0;
    top: 0;
    overflow-x: hidden;
    overflow-y: scroll
}

.CodeMirror-hscrollbar {
    bottom: 0;
    left: 0;
    overflow-y: hidden;
    overflow-x: scroll
}

.CodeMirror-scrollbar-filler {
    right: 0;
    bottom: 0
}

.CodeMirror-gutter-filler {
    left: 0;
    bottom: 0
}

.CodeMirror-gutters {
    position: absolute;
    left: 0;
    top: 0;
    min-height: 100%;
    z-index: 3
}

.CodeMirror-gutter {
    white-space: normal;
    height: 100%;
    display: inline-block;
    vertical-align: top;
    margin-bottom: -30px
}

.CodeMirror-gutter-wrapper {
    position: absolute;
    z-index: 4;
    background: 0 0 !important;
    border: none !important
}

.CodeMirror-gutter-background {
    position: absolute;
    top: 0;
    bottom: 0;
    z-index: 4
}

.CodeMirror-gutter-elt {
    position: absolute;
    cursor: default;
    z-index: 4
}

.CodeMirror-gutter-wrapper ::selection {
    background-color: transparent
}

.CodeMirror-gutter-wrapper ::-moz-selection {
    background-color: transparent
}

.CodeMirror-lines {
    cursor: text;
    min-height: 1px
}

.CodeMirror pre {
    -moz-border-radius: 0;
    -webkit-border-radius: 0;
    border-radius: 0;
    border-width: 0;
    background: 0 0;
    font-family: inherit;
    font-size: inherit;
    margin: 0;
    white-space: pre;
    word-wrap: normal;
    line-height: inherit;
    color: inherit;
    z-index: 2;
    position: relative;
    overflow: visible;
    -webkit-tap-highlight-color: transparent;
    -webkit-font-variant-ligatures: contextual;
    font-variant-ligatures: contextual
}

.CodeMirror-wrap pre {
    word-wrap: break-word;
    white-space: pre-wrap;
    word-break: normal
}

.CodeMirror-linebackground {
    position: absolute;
    left: 0;
    right: 0;
    top: 0;
    bottom: 0;
    z-index: 0
}

.CodeMirror-linewidget {
    position: relative;
    z-index: 2;
    overflow: auto
}

.CodeMirror-rtl pre {
    direction: rtl
}

.CodeMirror-code {
    outline: 0
}

.CodeMirror-gutter, .CodeMirror-gutters, .CodeMirror-linenumber, .CodeMirror-scroll, .CodeMirror-sizer {
    -moz-box-sizing: content-box;
    box-sizing: content-box
}

.CodeMirror-measure {
    position: absolute;
    width: 100%;
    height: 0;
    overflow: hidden;
    visibility: hidden
}

.CodeMirror-cursor {
    position: absolute;
    pointer-events: none
}

.CodeMirror-measure pre {
    position: static
}

div.CodeMirror-cursors {
    visibility: hidden;
    position: relative;
    z-index: 3
}

div.CodeMirror-dragcursors {
    visibility: visible
}

.CodeMirror-focused div.CodeMirror-cursors {
    visibility: visible
}

.CodeMirror-selected {
    background: #d9d9d9
}

.CodeMirror-focused .CodeMirror-selected {
    background: #d7d4f0
}

.CodeMirror-crosshair {
    cursor: crosshair
}

.CodeMirror-line::selection, .CodeMirror-line > span::selection, .CodeMirror-line > span > span::selection {
    background: #d7d4f0
}

.CodeMirror-line::-moz-selection, .CodeMirror-line > span::-moz-selection, .CodeMirror-line > span > span::-moz-selection {
    background: #d7d4f0
}

.cm-searching {
    background-color: #ffa;
    background-color: rgba(255, 255, 0, .4)
}

.cm-force-border {
    padding-right: .1px
}

@media print {
    .CodeMirror div.CodeMirror-cursors {
        visibility: hidden
    }
}

.cm-tab-wrap-hack:after {
    content: ''
}

span.CodeMirror-selectedtext {
    background: 0 0
}

html.os-html, html.os-html > .os-host {
    display: block;
    overflow: hidden;
    box-sizing: border-box;
    height: 100% !important;
    width: 100% !important;
    min-width: 100% !important;
    min-height: 100% !important;
    margin: 0 !important;
    position: absolute !important
}

html.os-html > .os-host > .os-padding {
    position: absolute
}

body.os-dragging, body.os-dragging * {
    cursor: default
}

.os-host, .os-host-textarea {
    position: relative;
    overflow: visible !important;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -ms-flex-direction: column;
    flex-direction: column;
    -ms-flex-wrap: nowrap;
    flex-wrap: nowrap;
    -webkit-box-pack: start;
    -ms-flex-pack: start;
    justify-content: flex-start;
    -ms-flex-line-pack: start;
    align-content: flex-start;
    -webkit-box-align: start;
    -ms-flex-align: start;
    -ms-grid-row-align: flex-start;
    align-items: flex-start
}

.os-host-flexbox {
    overflow: hidden !important;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex
}

.os-host-flexbox > .os-size-auto-observer {
    height: inherit !important
}

.os-host-flexbox > .os-content-glue {
    -webkit-box-flex: 1;
    -ms-flex-positive: 1;
    flex-grow: 1;
    -ms-flex-negative: 0;
    flex-shrink: 0
}

.os-host-flexbox > .os-content-glue, .os-host-flexbox > .os-size-auto-observer {
    min-height: 0;
    min-width: 0;
    -webkit-box-flex: 0;
    -ms-flex-positive: 0;
    flex-grow: 0;
    -ms-flex-negative: 1;
    flex-shrink: 1;
    -ms-flex-preferred-size: auto;
    flex-basis: auto
}

#os-dummy-scrollbar-size {
    position: fixed;
    opacity: 0;
    visibility: hidden;
    overflow: scroll;
    height: 500px;
    width: 500px
}

#os-dummy-scrollbar-size > div {
    width: 200%;
    height: 200%;
    margin: 10px 0
}

#os-dummy-scrollbar-size:after, #os-dummy-scrollbar-size:before, .os-content:after, .os-content:before {
    content: '';
    display: table;
    width: .01px;
    height: .01px;
    line-height: 0;
    font-size: 0;
    flex-grow: 0;
    flex-shrink: 0;
    visibility: hidden
}

#os-dummy-scrollbar-size, .os-viewport {
    -ms-overflow-style: scrollbar !important
}

.os-viewport-native-scrollbars-invisible#os-dummy-scrollbar-size, .os-viewport-native-scrollbars-invisible.os-viewport {
    scrollbar-width: none !important
}

.os-viewport-native-scrollbars-invisible#os-dummy-scrollbar-size::-webkit-scrollbar, .os-viewport-native-scrollbars-invisible#os-dummy-scrollbar-size::-webkit-scrollbar-corner, .os-viewport-native-scrollbars-invisible.os-viewport::-webkit-scrollbar, .os-viewport-native-scrollbars-invisible.os-viewport::-webkit-scrollbar-corner {
    display: none !important;
    width: 0 !important;
    height: 0 !important;
    visibility: hidden !important;
    background: 0 0 !important
}

.os-content-glue {
    box-sizing: inherit;
    max-height: 100%;
    max-width: 100%;
    width: 100%;
    pointer-events: none
}

.os-padding {
    box-sizing: inherit;
    direction: inherit;
    position: absolute;
    overflow: visible;
    padding: 0;
    margin: 0;
    left: 0;
    top: 0;
    bottom: 0;
    right: 0;
    width: auto !important;
    height: auto !important
}

.os-host-overflow > .os-padding {
    overflow: hidden
}

.os-viewport {
    direction: inherit !important;
    box-sizing: inherit !important;
    resize: none !important;
    outline: 0 !important;
    position: absolute;
    overflow: hidden;
    top: 0;
    left: 0;
    bottom: 0;
    right: 0;
    padding: 0;
    margin: 0;
    -webkit-overflow-scrolling: touch
}

.os-content-arrange {
    position: absolute;
    z-index: -1;
    min-height: 1px;
    min-width: 1px;
    pointer-events: none
}

.os-content {
    direction: inherit;
    box-sizing: border-box !important;
    position: relative;
    display: block;
    height: 100%;
    width: 100%;
    height: 100%;
    width: 100%;
    visibility: visible
}

.os-content > .os-textarea {
    box-sizing: border-box !important;
    direction: inherit !important;
    background: 0 0 !important;
    outline: 0 none transparent !important;
    overflow: hidden !important;
    position: absolute !important;
    display: block !important;
    top: 0 !important;
    left: 0 !important;
    margin: 0 !important;
    border-radius: 0 !important;
    float: none !important;
    -webkit-filter: none !important;
    filter: none !important;
    border: none !important;
    resize: none !important;
    -webkit-transform: none !important;
    transform: none !important;
    max-width: none !important;
    max-height: none !important;
    box-shadow: none !important;
    -webkit-perspective: none !important;
    perspective: none !important;
    opacity: 1 !important;
    z-index: 1 !important;
    clip: auto !important;
    vertical-align: baseline !important;
    padding: 0
}

.os-host-rtl > .os-padding > .os-viewport > .os-content > .os-textarea {
    right: 0 !important
}

.os-content > .os-textarea-cover {
    z-index: -1;
    pointer-events: none
}

.os-content > .os-textarea[wrap=off] {
    white-space: pre !important;
    margin: 0 !important
}

.os-text-inherit {
    font-family: inherit;
    font-size: inherit;
    font-weight: inherit;
    font-style: inherit;
    font-variant: inherit;
    text-transform: inherit;
    text-decoration: inherit;
    text-indent: inherit;
    text-align: inherit;
    text-shadow: inherit;
    text-overflow: inherit;
    letter-spacing: inherit;
    word-spacing: inherit;
    line-height: inherit;
    unicode-bidi: inherit;
    direction: inherit;
    color: inherit;
    cursor: text
}

.os-resize-observer, .os-resize-observer-host {
    box-sizing: inherit;
    display: block;
    visibility: hidden;
    position: absolute;
    top: 0;
    left: 0;
    height: 100%;
    width: 100%;
    overflow: hidden;
    pointer-events: none;
    z-index: -1
}

.os-resize-observer-host {
    padding: inherit;
    border: inherit;
    border-color: transparent;
    border-style: solid;
    box-sizing: border-box
}

.os-resize-observer-host.observed {
    display: flex;
    flex-direction: column;
    justify-content: flex-start;
    align-items: flex-start
}

.os-resize-observer-host.observed > .os-resize-observer, .os-resize-observer-host > .os-resize-observer {
    height: 200%;
    width: 200%;
    padding: inherit;
    border: inherit;
    margin: 0;
    display: block;
    box-sizing: content-box
}

.os-resize-observer-host.observed > .os-resize-observer, .os-resize-observer-host.observed > .os-resize-observer:before {
    display: flex;
    position: relative;
    flex-grow: 1;
    flex-shrink: 0;
    flex-basis: auto;
    box-sizing: border-box
}

.os-resize-observer-host.observed > .os-resize-observer:before {
    content: '';
    box-sizing: content-box;
    padding: inherit;
    border: inherit;
    margin: 0
}

.os-size-auto-observer {
    box-sizing: inherit !important;
    height: 100%;
    width: inherit;
    max-width: 1px;
    position: relative;
    float: left;
    max-height: 1px;
    overflow: hidden;
    z-index: -1;
    padding: 0;
    margin: 0;
    pointer-events: none;
    -webkit-box-flex: inherit;
    -ms-flex-positive: inherit;
    flex-grow: inherit;
    -ms-flex-negative: 0;
    flex-shrink: 0;
    -ms-flex-preferred-size: 0;
    flex-basis: 0
}

.os-size-auto-observer > .os-resize-observer {
    width: 1000%;
    height: 1000%;
    min-height: 1px;
    min-width: 1px
}

.os-resize-observer-item {
    position: absolute;
    top: 0;
    right: 0;
    bottom: 0;
    left: 0;
    overflow: hidden;
    z-index: -1;
    opacity: 0;
    direction: ltr !important;
    -webkit-box-flex: 0 !important;
    -ms-flex: none !important;
    flex: none !important
}

.os-resize-observer-item-final {
    position: absolute;
    left: 0;
    top: 0;
    -webkit-transition: none !important;
    transition: none !important;
    -webkit-box-flex: 0 !important;
    -ms-flex: none !important;
    flex: none !important
}

.os-resize-observer {
    -webkit-animation-duration: 1ms;
    animation-duration: 1ms;
    -webkit-animation-name: os-resize-observer-dummy-animation;
    animation-name: os-resize-observer-dummy-animation
}

object.os-resize-observer {
    box-sizing: border-box !important
}

@-webkit-keyframes os-resize-observer-dummy-animation {
    from {
        z-index: 0
    }
    to {
        z-index: -1
    }
}

@keyframes os-resize-observer-dummy-animation {
    from {
        z-index: 0
    }
    to {
        z-index: -1
    }
}

.os-host-transition > .os-scrollbar, .os-host-transition > .os-scrollbar-corner {
    -webkit-transition: opacity .3s, visibility .3s, top .3s, right .3s, bottom .3s, left .3s;
    transition: opacity .3s, visibility .3s, top .3s, right .3s, bottom .3s, left .3s
}

html.os-html > .os-host > .os-scrollbar {
    position: absolute;
    z-index: 999999
}

.os-scrollbar, .os-scrollbar-corner {
    position: absolute;
    opacity: 1;
    z-index: 1
}

.os-scrollbar-corner {
    bottom: 0;
    right: 0
}

.os-scrollbar {
    pointer-events: none
}

.os-scrollbar-track {
    pointer-events: auto;
    position: relative;
    height: 100%;
    width: 100%;
    padding: 0 !important;
    border: none !important
}

.os-scrollbar-handle {
    pointer-events: auto;
    position: absolute;
    width: 100%;
    height: 100%
}

.os-scrollbar-handle-off, .os-scrollbar-track-off {
    pointer-events: none
}

.os-scrollbar.os-scrollbar-unusable, .os-scrollbar.os-scrollbar-unusable * {
    pointer-events: none !important
}

.os-scrollbar.os-scrollbar-unusable .os-scrollbar-handle {
    opacity: 0 !important
}

.os-scrollbar-horizontal {
    bottom: 0;
    left: 0
}

.os-scrollbar-vertical {
    top: 0;
    right: 0
}

.os-host-rtl > .os-scrollbar-horizontal {
    right: 0
}

.os-host-rtl > .os-scrollbar-vertical {
    right: auto;
    left: 0
}

.os-host-rtl > .os-scrollbar-corner {
    right: auto;
    left: 0
}

.os-host-resize-disabled.os-host-scrollbar-horizontal-hidden > .os-scrollbar-corner, .os-host-resize-disabled.os-host-scrollbar-vertical-hidden > .os-scrollbar-corner, .os-host-scrollbar-horizontal-hidden > .os-scrollbar-horizontal, .os-host-scrollbar-vertical-hidden > .os-scrollbar-vertical, .os-padding + .os-scrollbar-corner, .os-scrollbar-auto-hidden, .os-scrollbar-horizontal + .os-scrollbar-vertical.os-scrollbar-auto-hidden + .os-scrollbar-corner, .os-scrollbar-horizontal.os-scrollbar-auto-hidden + .os-scrollbar-vertical + .os-scrollbar-corner, .os-scrollbar-horizontal.os-scrollbar-auto-hidden + .os-scrollbar-vertical.os-scrollbar-auto-hidden + .os-scrollbar-corner {
    opacity: 0;
    visibility: hidden;
    pointer-events: none
}

.os-scrollbar-corner-resize-both {
    cursor: nwse-resize
}

.os-host-rtl > .os-scrollbar-corner-resize-both {
    cursor: nesw-resize
}

.os-scrollbar-corner-resize-horizontal {
    cursor: ew-resize
}

.os-scrollbar-corner-resize-vertical {
    cursor: ns-resize
}

.os-dragging .os-scrollbar-corner.os-scrollbar-corner-resize {
    cursor: default
}

.os-host-resize-disabled.os-host-scrollbar-horizontal-hidden > .os-scrollbar-vertical {
    top: 0;
    bottom: 0
}

.os-host-resize-disabled.os-host-scrollbar-vertical-hidden > .os-scrollbar-horizontal, .os-host-rtl.os-host-resize-disabled.os-host-scrollbar-vertical-hidden > .os-scrollbar-horizontal {
    right: 0;
    left: 0
}

.os-scrollbar-corner.os-scrollbar-corner-resize, .os-scrollbar:hover {
    opacity: 1 !important;
    visibility: visible !important
}

.os-scrollbar-corner.os-scrollbar-corner-resize {
    background-image: url(data:image/svg+xml;base64,PD94bWwgdmVyc2lvbj0iMS4wIiBlbmNvZGluZz0iVVRGLTgiIHN0YW5kYWxvbmU9Im5vIj8+PHN2ZyAgIHhtbG5zOmRjPSJodHRwOi8vcHVybC5vcmcvZGMvZWxlbWVudHMvMS4xLyIgICB4bWxuczpjYz0iaHR0cDovL2NyZWF0aXZlY29tbW9ucy5vcmcvbnMjIiAgIHhtbG5zOnJkZj0iaHR0cDovL3d3dy53My5vcmcvMTk5OS8wMi8yMi1yZGYtc3ludGF4LW5zIyIgICB4bWxuczpzdmc9Imh0dHA6Ly93d3cudzMub3JnLzIwMDAvc3ZnIiAgIHhtbG5zPSJodHRwOi8vd3d3LnczLm9yZy8yMDAwL3N2ZyIgICB3aWR0aD0iMTAiICAgaGVpZ2h0PSIxMCIgICB2ZXJzaW9uPSIxLjEiPiAgPGcgICAgIHRyYW5zZm9ybT0idHJhbnNsYXRlKDAsLTEwNDIuMzYyMikiICAgICBzdHlsZT0iZGlzcGxheTppbmxpbmUiPiAgICA8cGF0aCAgICAgICBzdHlsZT0iZmlsbDojMDAwMDAwO2ZpbGwtb3BhY2l0eTowLjQ5NDExNzY1O2ZpbGwtcnVsZTpldmVub2RkO3N0cm9rZTpub25lIiAgICAgICBkPSJtIDcuNDI0MjE4NywxMDQyLjM2MjIgYyAtMC43MjM1NzkyLDAgLTEuMzEwMTU2MiwwLjU4NjYgLTEuMzEwMTU2MiwxLjMxMDIgMCwwLjI5OSAwLjEwNDM0MTksMC41NzEgMC4yNzI5NDkyLDAuNzkxNSAwLjIwOTEwMjQsMC4xNDEzIDAuNDY1NjIwNiwwLjIxODQgMC43MzY5NjI5LDAuMjE4NCAwLjcyMzU3OTMsMCAxLjMxMDE1NjMsLTAuNTg2NiAxLjMxMDE1NjMsLTEuMzEwMiAwLC0wLjI3MTMgLTAuMDc3MDkzLC0wLjUyNzggLTAuMjE4MzU5NCwtMC43MzcgLTAuMjIwNDk0MSwtMC4xNjg2IC0wLjQ5MjU0NDMsLTAuMjcyOSAtMC43OTE1NTI4LC0wLjI3MjkgeiBtIDAsMy4wODQzIGMgLTAuNzIzNTc5MiwwIC0xLjMxMDE1NjIsMC41ODY2IC0xLjMxMDE1NjIsMS4zMTAyIDAsMC4yOTkgMC4xMDQzNDE5LDAuNTcxIDAuMjcyOTQ5MiwwLjc5MTUgMC4yMDkxMDI0LDAuMTQxMyAwLjQ2NTYyMDYsMC4yMTg0IDAuNzM2OTYyOSwwLjIxODQgMC43MjM1NzkzLDAgMS4zMTAxNTYzLC0wLjU4NjYgMS4zMTAxNTYzLC0xLjMxMDIgMCwtMC4yNzEzIC0wLjA3NzA5MywtMC41Mjc4IC0wLjIxODM1OTQsLTAuNzM2OSAtMC4yMjA0OTQxLC0wLjE2ODYgLTAuNDkyNTQ0MywtMC4yNzMgLTAuNzkxNTUyOCwtMC4yNzMgeiBtIC0zLjA4NDMyNjEsMCBjIC0wLjcyMzU3OTMsMCAtMS4zMTAxNTYzLDAuNTg2NiAtMS4zMTAxNTYzLDEuMzEwMiAwLDAuMjk5IDAuMTA0MzQxOSwwLjU3MSAwLjI3Mjk0OTIsMC43OTE1IDAuMjA5MTAyNCwwLjE0MTMgMC40NjU2MjA3LDAuMjE4NCAwLjczNjk2MjksMC4yMTg0IDAuNzIzNTc5MywwIDEuMzEwMTU2MywtMC41ODY2IDEuMzEwMTU2MywtMS4zMTAyIDAsLTAuMjcxMyAtMC4wNzcwOTMsLTAuNTI3OCAtMC4yMTgzNTk0LC0wLjczNjkgLTAuMjIwNDk0LC0wLjE2ODYgLTAuNDkyNTQ0MiwtMC4yNzMgLTAuNzkxNTUyNywtMC4yNzMgeiBtIC0zLjAyOTczNjQsMy4wMjk4IEMgMC41ODY1NzY5MywxMDQ4LjQ3NjMgMCwxMDQ5LjA2MjggMCwxMDQ5Ljc4NjQgYyAwLDAuMjk5IDAuMTA0MzQxOSwwLjU3MTEgMC4yNzI5NDkyMiwwLjc5MTYgMC4yMDkxMDIyOSwwLjE0MTIgMC40NjU2MjA2NSwwLjIxODMgMC43MzY5NjI4OCwwLjIxODMgMC43MjM1NzkzLDAgMS4zMTAxNTYzLC0wLjU4NjUgMS4zMTAxNTYzLC0xLjMxMDEgMCwtMC4yNzE0IC0wLjA3NzA5MywtMC41Mjc5IC0wLjIxODM1OTQsLTAuNzM3IC0wLjIyMDQ5NDEsLTAuMTY4NiAtMC40OTI1NDQzLC0wLjI3MjkgLTAuNzkxNTUyOCwtMC4yNzI5IHogbSAzLjAyOTczNjQsMCBjIC0wLjcyMzU3OTMsMCAtMS4zMTAxNTYzLDAuNTg2NSAtMS4zMTAxNTYzLDEuMzEwMSAwLDAuMjk5IDAuMTA0MzQxOSwwLjU3MTEgMC4yNzI5NDkyLDAuNzkxNiAwLjIwOTEwMjQsMC4xNDEyIDAuNDY1NjIwNywwLjIxODMgMC43MzY5NjI5LDAuMjE4MyAwLjcyMzU3OTMsMCAxLjMxMDE1NjMsLTAuNTg2NSAxLjMxMDE1NjMsLTEuMzEwMSAwLC0wLjI3MTQgLTAuMDc3MDkzLC0wLjUyNzkgLTAuMjE4MzU5NCwtMC43MzcgLTAuMjIwNDk0LC0wLjE2ODYgLTAuNDkyNTQ0MiwtMC4yNzI5IC0wLjc5MTU1MjcsLTAuMjcyOSB6IG0gMy4wODQzMjYxLDAgYyAtMC43MjM1NzkyLDAgLTEuMzEwMTU2MiwwLjU4NjUgLTEuMzEwMTU2MiwxLjMxMDEgMCwwLjI5OSAwLjEwNDM0MTksMC41NzExIDAuMjcyOTQ5MiwwLjc5MTYgMC4yMDkxMDI0LDAuMTQxMiAwLjQ2NTYyMDYsMC4yMTgzIDAuNzM2OTYyOSwwLjIxODMgMC43MjM1NzkzLDAgMS4zMTAxNTYzLC0wLjU4NjUgMS4zMTAxNTYzLC0xLjMxMDEgMCwtMC4yNzE0IC0wLjA3NzA5MywtMC41Mjc5IC0wLjIxODM1OTQsLTAuNzM3IC0wLjIyMDQ5NDEsLTAuMTY4NiAtMC40OTI1NDQzLC0wLjI3MjkgLTAuNzkxNTUyOCwtMC4yNzI5IHoiLz4gIDwvZz4gIDxnICAgICBzdHlsZT0iZGlzcGxheTppbmxpbmUiPiAgICA8cGF0aCAgICAgICBzdHlsZT0iZmlsbDojZmZmZmZmO2ZpbGwtb3BhY2l0eToxO2ZpbGwtcnVsZTpldmVub2RkO3N0cm9rZTpub25lIiAgICAgICBkPSJtIDguMjE1NzcxNSwwLjI3Mjk0OTIyIGMgMC4xNDEyNjY3LDAuMjA5MTAyMjkgMC4yMTgzNTk0LDAuNDY1NjIwNjUgMC4yMTgzNTk0LDAuNzM2OTYyODggMCwwLjcyMzU3OTMgLTAuNTg2NTc3LDEuMzEwMTU2MyAtMS4zMTAxNTYzLDEuMzEwMTU2MyAtMC4yNzEzNDIzLDAgLTAuNTI3ODYwNSwtMC4wNzcwOTMgLTAuNzM2OTYyOSwtMC4yMTgzNTk0IDAuMjM5NDEwNCwwLjMxMzA4NTkgMC42MTI2MzYyLDAuNTE4NjAzNSAxLjAzNzIwNywwLjUxODYwMzUgMC43MjM1NzkzLDAgMS4zMTAxNTYzLC0wLjU4NjU3NyAxLjMxMDE1NjMsLTEuMzEwMTU2MyAwLC0wLjQyNDU3MDc2IC0wLjIwNTUxNzYsLTAuNzk3Nzk2NTkgLTAuNTE4NjAzNSwtMS4wMzcyMDY5OCB6IG0gMCwzLjA4NDMyNjE4IGMgMC4xNDEyNjY3LDAuMjA5MTAyMyAwLjIxODM1OTQsMC40NjU2MjA2IDAuMjE4MzU5NCwwLjczNjk2MjkgMCwwLjcyMzU3OTMgLTAuNTg2NTc3LDEuMzEwMTU2MiAtMS4zMTAxNTYzLDEuMzEwMTU2MiAtMC4yNzEzNDIzLDAgLTAuNTI3ODYwNSwtMC4wNzcwOTMgLTAuNzM2OTYyOSwtMC4yMTgzNTkzIDAuMjM5NDEwNCwwLjMxMzA4NTkgMC42MTI2MzYyLDAuNTE4NjAzNSAxLjAzNzIwNywwLjUxODYwMzUgMC43MjM1NzkzLDAgMS4zMTAxNTYzLC0wLjU4NjU3NyAxLjMxMDE1NjMsLTEuMzEwMTU2MyAwLC0wLjQyNDU3MDggLTAuMjA1NTE3NiwtMC43OTc3OTY3IC0wLjUxODYwMzUsLTEuMDM3MjA3IHogbSAtMy4wODQzMjYyLDAgYyAwLjE0MTI2NjcsMC4yMDkxMDIzIDAuMjE4MzU5NCwwLjQ2NTYyMDYgMC4yMTgzNTk0LDAuNzM2OTYyOSAwLDAuNzIzNTc5MyAtMC41ODY1NzcsMS4zMTAxNTYyIC0xLjMxMDE1NjMsMS4zMTAxNTYyIC0wLjI3MTM0MjIsMCAtMC41Mjc4NjA1LC0wLjA3NzA5MyAtMC43MzY5NjI5LC0wLjIxODM1OTMgMC4yMzk0MTA0LDAuMzEzMDg1OSAwLjYxMjYzNjMsMC41MTg2MDM1IDEuMDM3MjA3MSwwLjUxODYwMzUgMC43MjM1NzkzLDAgMS4zMTAxNTYyLC0wLjU4NjU3NyAxLjMxMDE1NjIsLTEuMzEwMTU2MyAwLC0wLjQyNDU3MDggLTAuMjA1NTE3NSwtMC43OTc3OTY3IC0wLjUxODYwMzUsLTEuMDM3MjA3IHogTSAyLjEwMTcwOSw2LjM4NzAxMTcgYyAwLjE0MTI2NjcsMC4yMDkxMDI0IDAuMjE4MzU5NCwwLjQ2NTYyMDYgMC4yMTgzNTk0LDAuNzM2OTYyOSAwLDAuNzIzNTc5MyAtMC41ODY1NzcsMS4zMTAxNTYzIC0xLjMxMDE1NjMsMS4zMTAxNTYzIC0wLjI3MTM0MjIzLDAgLTAuNTI3ODYwNTksLTAuMDc3MDkzIC0wLjczNjk2Mjg4LC0wLjIxODM1OTQgMC4yMzk0MTAzOSwwLjMxMzA4NTkgMC42MTI2MzYyMiwwLjUxODYwMzUgMS4wMzcyMDY5OCwwLjUxODYwMzUgMC43MjM1NzkzLDAgMS4zMTAxNTYzLC0wLjU4NjU3NyAxLjMxMDE1NjMsLTEuMzEwMTU2MyAwLC0wLjQyNDU3MDggLTAuMjA1NTE3NiwtMC43OTc3OTY2IC0wLjUxODYwMzUsLTEuMDM3MjA3IHogbSAzLjAyOTczNjMsMCBjIDAuMTQxMjY2NywwLjIwOTEwMjQgMC4yMTgzNTk0LDAuNDY1NjIwNiAwLjIxODM1OTQsMC43MzY5NjI5IDAsMC43MjM1NzkzIC0wLjU4NjU3NywxLjMxMDE1NjMgLTEuMzEwMTU2MywxLjMxMDE1NjMgLTAuMjcxMzQyMiwwIC0wLjUyNzg2MDUsLTAuMDc3MDkzIC0wLjczNjk2MjksLTAuMjE4MzU5NCAwLjIzOTQxMDQsMC4zMTMwODU5IDAuNjEyNjM2MywwLjUxODYwMzUgMS4wMzcyMDcxLDAuNTE4NjAzNSAwLjcyMzU3OTMsMCAxLjMxMDE1NjIsLTAuNTg2NTc3IDEuMzEwMTU2MiwtMS4zMTAxNTYzIDAsLTAuNDI0NTcwOCAtMC4yMDU1MTc1LC0wLjc5Nzc5NjYgLTAuNTE4NjAzNSwtMS4wMzcyMDcgeiBtIDMuMDg0MzI2MiwwIGMgMC4xNDEyNjY3LDAuMjA5MTAyNCAwLjIxODM1OTQsMC40NjU2MjA2IDAuMjE4MzU5NCwwLjczNjk2MjkgMCwwLjcyMzU3OTMgLTAuNTg2NTc3LDEuMzEwMTU2MyAtMS4zMTAxNTYzLDEuMzEwMTU2MyAtMC4yNzEzNDIzLDAgLTAuNTI3ODYwNSwtMC4wNzcwOTMgLTAuNzM2OTYyOSwtMC4yMTgzNTk0IDAuMjM5NDEwNCwwLjMxMzA4NTkgMC42MTI2MzYyLDAuNTE4NjAzNSAxLjAzNzIwNywwLjUxODYwMzUgMC43MjM1NzkzLDAgMS4zMTAxNTYzLC0wLjU4NjU3NyAxLjMxMDE1NjMsLTEuMzEwMTU2MyAwLC0wLjQyNDU3MDggLTAuMjA1NTE3NiwtMC43OTc3OTY2IC0wLjUxODYwMzUsLTEuMDM3MjA3IHoiIC8+ICA8L2c+PC9zdmc+);
    background-repeat: no-repeat;
    background-position: 100% 100%;
    pointer-events: auto !important
}

.os-host-rtl > .os-scrollbar-corner.os-scrollbar-corner-resize {
    -webkit-transform: scale(-1, 1);
    transform: scale(-1, 1)
}

.os-host-overflow {
    overflow: hidden !important
}

.os-theme-none > .os-scrollbar-corner, .os-theme-none > .os-scrollbar-horizontal, .os-theme-none > .os-scrollbar-vertical {
    display: none !important
}

.os-theme-none > .os-scrollbar-corner-resize {
    display: block !important;
    min-width: 10px;
    min-height: 10px
}

.os-theme-light > .os-scrollbar-horizontal {
    right: 10px;
    height: 10px
}

.os-theme-light > .os-scrollbar-vertical {
    bottom: 10px;
    width: 10px
}

.os-theme-light.os-host-rtl > .os-scrollbar-horizontal {
    left: 10px;
    right: 0
}

.os-theme-light > .os-scrollbar-corner {
    height: 10px;
    width: 10px
}

.os-theme-light > .os-scrollbar-corner {
    background-color: transparent
}

.os-theme-light > .os-scrollbar {
    padding: 2px;
    box-sizing: border-box;
    background: 0 0
}

.os-theme-light > .os-scrollbar.os-scrollbar-unusable {
    background: 0 0
}

.os-theme-light > .os-scrollbar > .os-scrollbar-track {
    background: 0 0
}

.os-theme-light > .os-scrollbar-horizontal > .os-scrollbar-track > .os-scrollbar-handle {
    min-width: 30px
}

.os-theme-light > .os-scrollbar-vertical > .os-scrollbar-track > .os-scrollbar-handle {
    min-height: 30px
}

.os-theme-light.os-host-transition > .os-scrollbar > .os-scrollbar-track > .os-scrollbar-handle {
    -webkit-transition: background-color .3s;
    transition: background-color .3s
}

.os-theme-light > .os-scrollbar > .os-scrollbar-track, .os-theme-light > .os-scrollbar > .os-scrollbar-track > .os-scrollbar-handle {
    border-radius: 10px
}

.os-theme-light > .os-scrollbar > .os-scrollbar-track > .os-scrollbar-handle {
    background: rgba(255, 255, 255, .4)
}

.os-theme-light > .os-scrollbar:hover > .os-scrollbar-track > .os-scrollbar-handle {
    background: rgba(255, 255, 255, .55)
}

.os-theme-light > .os-scrollbar > .os-scrollbar-track > .os-scrollbar-handle.active {
    background: rgba(255, 255, 255, .7)
}

.os-theme-light > .os-scrollbar-horizontal .os-scrollbar-handle:before, .os-theme-light > .os-scrollbar-vertical .os-scrollbar-handle:before {
    content: '';
    position: absolute;
    left: 0;
    right: 0;
    top: 0;
    bottom: 0;
    display: block
}

.os-theme-light.os-host-scrollbar-horizontal-hidden > .os-scrollbar-horizontal .os-scrollbar-handle:before, .os-theme-light.os-host-scrollbar-vertical-hidden > .os-scrollbar-vertical .os-scrollbar-handle:before {
    display: none
}

.os-theme-light > .os-scrollbar-horizontal .os-scrollbar-handle:before {
    top: -6px;
    bottom: -2px
}

.os-theme-light > .os-scrollbar-vertical .os-scrollbar-handle:before {
    left: -6px;
    right: -2px
}

.os-host-rtl.os-theme-light > .os-scrollbar-vertical .os-scrollbar-handle:before {
    right: -6px;
    left: -2px
}

html {
    -webkit-font-smoothing: antialiased
}

body, html {
    font-family: "PT Sans", "Helvetica Neue", Arial, sans-serif;
    font-size: 16px;
    font-weight: 400;
    line-height: 1.5;
    color: #444
}

a:focus {
    outline: dotted 2px #0004
}

.font-money {
    font-family: "helvetica neue", Arial, "PingFang SC", "microsoft yahei", "hiragino sans gb", sans-serif;
    word-break: keep-all
}

hr {
    border: none;
    border-top: solid 1px #ecf0f1
}

.breadcrumb {
    color: #ccc;
    font-weight: 400;
    font-size: 1rem;
    padding: 0 0 0 2px;
    background: 0 0;
    margin: 0 0 1.5rem 0
}

.breadcrumb a, .breadcrumb a:visited {
    text-decoration: none;
    color: #ccc;
    background-size: 2px 2px;
    background-position: 0 1em;
    box-shadow: inset 0 -2px 0 #eee
}

.breadcrumb a:focus, .breadcrumb a:hover, .breadcrumb a:visited:focus, .breadcrumb a:visited:hover {
    box-shadow: inset 0 -2px 0 #ccc
}

.text .dt a, .text h1 a, .text h2 a, .text h3 a, .text h4 a, .text h5 a, .text li a, .text p a, .text table a {
    text-decoration: none;
    font-weight: 700;
    color: #444;
    box-shadow: inset 0 -2px 0 #f29f97
}

.text .dt a:focus, .text .dt a:hover, .text h1 a:focus, .text h1 a:hover, .text h2 a:focus, .text h2 a:hover, .text h3 a:focus, .text h3 a:hover, .text h4 a:focus, .text h4 a:hover, .text h5 a:focus, .text h5 a:hover, .text li a:focus, .text li a:hover, .text p a:focus, .text p a:hover, .text table a:focus, .text table a:hover {
    color: #ea6153;
    box-shadow: inset 0 -2px 0 #ea6153
}

.text .dt a:visited, .text h1 a:visited, .text h2 a:visited, .text h3 a:visited, .text h4 a:visited, .text h5 a:visited, .text li a:visited, .text p a:visited, .text table a:visited {
    color: #4f1f46
}

.text .anchor {
    box-shadow: none
}

.sidebar-navigation a, .text .link-list a {
    font-weight: 700;
    color: #444;
    box-shadow: inset 0 -2px 0 #ccc
}

.sidebar-navigation a:visited, .text .link-list a:visited {
    color: #4f1f46
}

.sidebar-navigation a.active, .sidebar-navigation a:focus, .sidebar-navigation a:hover, .text .link-list a.active, .text .link-list a:focus, .text .link-list a:hover {
    color: #ea6153;
    box-shadow: inset 0 -2px 0 #ea6153
}

.text .big {
    font-size: 1.25rem;
    line-height: 1.5rem
}

.text .small {
    font-size: .875rem;
    line-height: 1.25rem
}

.text .smaller {
    font-size: .75rem;
    line-height: 1rem
}

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

.text p code {
    font-family: Menlo, "Fira Code", Monaco, Consolas, "Courier New", monospace;
    font-variant-ligatures: none;
    font-size: .75rem;
    line-height: 1.25rem;
    color: #444;
    background: #f6f8f8;
    white-space: pre;
    word-break: keep-all;
    word-wrap: normal;
    display: inline-block;
    vertical-align: text-top;
    padding: 0 .25rem;
    background: #eee;
    border-radius: 3px;
    box-shadow: 0 1px 1px #ccc
}

.text .h1, .text .h2, .text .h3, .text .h4, .text h1, .text h2, .text h3, .text h4 {
    font-weight: 700
}

.text .h1, .text h1 {
    margin: 3rem 0 1.5rem
}

.text .breadcrumb + .h1, .text .breadcrumb + h1, .text .h1:first-child, .text h1:first-child {
    margin-top: 0
}

.text .h1 strong, .text .h2 strong, .text .h3 strong, .text .h4 strong, .text h1 strong, .text h2 strong, .text h3 strong, .text h4 strong {
    color: #000
}

.text .h2, .text .h3, .text .h4, .text h2, .text h3, .text h4 {
    margin: 3rem 0 1.5rem
}

.text .h2 + .h3, .text .h2 + .h4, .text .h3 + .h4, .text h2 + h3, .text h2 + h4, .text h3 + h4 {
    margin-top: 1.5rem
}

.text .h1, .text h1 {
    font-size: 3rem;
    line-height: 3rem
}

.text .h1.smaller, .text h1.smaller {
    font-size: 2rem;
    line-height: 2rem
}

.text .h2, .text h2 {
    font-size: 1.75rem;
    line-height: 2rem
}

.text .h3, .text h3 {
    font-size: 1.375rem;
    line-height: 1.75rem
}

.text .h4, .text h4 {
    font-size: 1.125rem;
    line-height: 1.5rem
}

@media (min-width: 768px) {
    .text .big {
        font-size: 1.5rem;
        line-height: 1.8rem
    }

    .text .h1, .text h1 {
        font-size: 4rem;
        line-height: 4rem
    }

    .text .h1.smaller, .text h1.smaller {
        font-size: 3rem;
        line-height: 3rem
    }

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

    .text .h3, .text h3 {
        font-size: 1.75rem;
        line-height: 2rem
    }

    .text .h4, .text h4 {
        font-size: 1.125rem;
        line-height: 1.5rem
    }
}

.text .cell .h1:first-child, .text .cell .h2:first-child, .text .cell .h3:first-child, .text .cell .h4:first-child, .text .cell .h5:first-child, .text .cell h1:first-child, .text .cell h2:first-child, .text .cell h3:first-child, .text .cell h4:first-child, .text .cell h5:first-child, .text article .h1:first-child, .text article .h2:first-child, .text article .h3:first-child, .text article .h4:first-child, .text article .h5:first-child, .text article h1:first-child, .text article h2:first-child, .text article h3:first-child, .text article h4:first-child, .text article h5:first-child, .text div .h1:first-child, .text div .h2:first-child, .text div .h3:first-child, .text div .h4:first-child, .text div .h5:first-child, .text div h1:first-child, .text div h2:first-child, .text div h3:first-child, .text div h4:first-child, .text div h5:first-child {
    margin-top: 0
}

.text .section .h5:first-child, .text .section h5:first-child, .text .section > .h1:first-child, .text .section > .h2:first-child, .text .section > .h3:first-child, .text .section > .h4:first-child, .text .section > h1:first-child, .text .section > h2:first-child, .text .section > h3:first-child, .text .section > h4:first-child {
    margin-top: 3rem
}

.text .h2 .anchor, .text .h3 .anchor, .text .h4 .anchor, .text h2 .anchor, .text h3 .anchor, .text h4 .anchor {
    color: silver;
    cursor: pointer;
    margin: 0 -3px 0 -26px;
    background: 0 0
}

.text .h2 .anchor:focus, .text .h2 .anchor:hover, .text .h3 .anchor:focus, .text .h3 .anchor:hover, .text .h4 .anchor:focus, .text .h4 .anchor:hover, .text h2 .anchor:focus, .text h2 .anchor:hover, .text h3 .anchor:focus, .text h3 .anchor:hover, .text h4 .anchor:focus, .text h4 .anchor:hover {
    color: #e74c3c;
    background: 0 0
}

.text .h2 .anchor .fa, .text .h3 .anchor .fa, .text .h4 .anchor .fa, .text h2 .anchor .fa, .text h3 .anchor .fa, .text h4 .anchor .fa {
    font-size: 18px
}

.text .h2.example-title, .text h2.example-title {
    font-size: 26px
}

.text .h3.example-title, .text h3.example-title {
    font-size: 18px;
    line-height: 1.5rem
}

.text ol, .text ul {
    margin: 0;
    padding: 0 0 0 21px
}

.text .dl, .text .p, .text ol, .text p, .text ul {
    margin-top: 0;
    margin-bottom: 1.5rem;
    text-align: justify;
}

.text li, .text li > ol, .text li > ul, .text p.list {
    margin: .5rem 0
}

.text li > p, .text li > p:first-child, .text li > p:last-child {
    margin: 1.5rem 0
}

.text .p .h3, .text .p h3 {
    margin-top: 10px
}

.text > article > ol li:first-child:last-child, .text > article > ul li:first-child:last-child, .text > ol li:first-child:last-child, .text > ul li:first-child:last-child {
    list-style: none;
    margin-left: -21px
}

.text li > li {
    margin: 0
}

.text li:first-child, .text li:first-child > p:first-child {
    margin-top: 0
}

.text li:last-child, .text li:last-child > p:last-child {
    margin-bottom: 0
}

.text p:first-child {
    margin-top: 0
}

.text p:last-child {
    margin-bottom: 0
}

.text .dl:first-child {
    margin-top: 0
}

.text .dl:last-child {
    margin-bottom: 0
}

.text q {
    quotes: "«" "»";
    margin-left: -9px
}

.text q:before {
    content: open-quote;
    font-size: 1em
}

.text q:after {
    content: close-quote
}

.text img {
    max-width: 100%
}

@media (max-width: 600px) {
    .text img[width="500"] {
        height: auto
    }
}

.text .strike {
    text-decoration: line-through
}

.text abbr {
    border-bottom: dotted 1px;
    text-decoration: none
}

.text blockquote {
    margin: 0 0 1.5rem;
    padding: 1.5rem;
    background-color: transparent;
    border-radius: 3px;
    border: dotted 2px #e74c3c
}

.text blockquote > :first-child {
    margin-top: 0
}

.text blockquote > :last-child {
    margin-bottom: 0
}

.text blockquote cite {
    font-size: 16px
}

.text blockquote cite:before {
    content: "— "
}

.text .dl {
    margin-top: 0
}

.text .dt {
    font-weight: 700;
    margin: 0 0 0 4px;
    padding: 0 0 0 11px;
    position: relative
}

.text .dt:before, .text .link-list .catalog-list > ul > li:before {
    content: "§";
    font-weight: 400;
    margin-left: -15px;
    margin-right: 8px
}

.text .link-list .catalog-list > ul > li {
    list-style-type: none
}

.text .dd {
    margin: 0 0 0 4px;
    padding: .75rem 0 0 11px;
    color: #7f8c8d;
    border-left: solid 1px #ecf0f1
}

.text .dd a {
    color: #7f8c8d !important;
    text-decoration: underline
}

.text .dd a:focus, .text .dd a:hover {
    color: #e74c3c !important
}

.text .dd code {
    color: #7f8c8d
}

.text .dd ul {
    padding: 0 0 0 16px
}

.text .dd ul li {
    list-style-type: square
}

.text .dd ul li:before {
    content: ""
}

.text .blue, .text .red {
    padding: 0 3px;
    border-radius: 3px;
    color: #fff
}

.text .red {
    background-color: #e74c3c
}

.text .blue {
    background-color: #3498db
}

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

.image, figure {
    text-align: center;
    margin: 3rem 0;
    max-width: 100%
}

.image p, figure p {
    text-align: center
}

figure.code {
    margin: 1.5rem 0
}

figure img {
    display: block;
    margin: 0 auto
}

.image-caption, figcaption {
    font-style: italic;
    font-size: .875rem;
    color: #999;
    margin-top: .5rem
}

.inline-block {
    display: inline-block;
    vertical-align: middle
}

.inline-with-section-h {
    margin-top: -5px;
    margin-left: 5px
}

.inline-with-h1 {
    margin-top: -28px;
    margin-left: 5px
}

.inline-with-h2 {
    margin-top: 22px;
    margin-left: 5px
}

.section {
    margin-top: 2rem
}

.section-bordered {
    padding: 3rem 0;
    border-top: solid 1px rgba(0, 0, 0, .125);
    border-bottom: solid 1px rgba(0, 0, 0, .125)
}

.section-bordered:first-child {
    padding-top: 0;
    border-top: 0
}

.section-bordered:last-child {
    padding-bottom: 0;
    border-bottom: 0
}

@media (min-width: 992px) {
    .section-bordered {
        padding: 3rem 0;
        border-top: solid 1px rgba(0, 0, 0, .125);
        border-bottom: solid 1px rgba(0, 0, 0, .125)
    }

    .section-bordered:first-child {
        padding-top: 0;
        border-top: 0
    }

    .section-bordered:last-child {
        padding-bottom: 0;
        border-bottom: 0
    }
}

.section-bordered + .section-bordered {
    border-top: none
}

.text .section-bordered > :last-child, .text .section > :last-child {
    margin-bottom: 0
}

.noto {
    font-family: sans-serif;
    display: inline-block;
    min-width: 1em;
    vertical-align: bottom
}

.noto-open {
    text-align: right
}

.ml-05 {
    margin-left: -.5em
}

.ls-05 {
    letter-spacing: -.5em
}

.ls-05 .noto {
    min-width: .5em
}

.ls-075 {
    letter-spacing: -.75em
}

.ls-075 .noto {
    min-width: .25em
}

.ls-1 {
    letter-spacing: -1em
}

.ls-1 .noto {
    min-width: auto
}

.chpule1 {
    letter-spacing: .25rem
}

.chpuri1 {
    margin-left: -.5em
}

.chpule2 {
    letter-spacing: -.6em
}

.chpule2 .noto {
    min-width: .5em
}

.chpuri2 {
    letter-spacing: .4rem
}

.code-pair.ml, code.ml {
    margin-left: -.5em
}

.code-pair.ml .with-parentheses, code.ml .with-parentheses {
    margin-left: 0
}

.btn-primary {
    position: relative
}

.btn-primary:after {
    content: " ";
    position: absolute;
    left: 0;
    right: 0;
    top: 0;
    bottom: -1px;
    border-radius: .25rem;
    box-shadow: inset 0 -3px 0 rgba(0, 0, 0, .15) !important
}

.btn-primary:not(:disabled):not(.disabled).active:after, .btn-primary:not(:disabled):not(.disabled):active:after {
    box-shadow: inset 0 3px 0 rgba(0, 0, 0, .15) !important
}

.btn-secondary {
    position: relative
}

.btn-secondary:after {
    content: " ";
    position: absolute;
    left: 0;
    right: 0;
    top: 0;
    bottom: -1px;
    border-radius: .25rem;
    box-shadow: inset 0 -3px 0 rgba(0, 0, 0, .15) !important
}

.btn-secondary:not(:disabled):not(.disabled).active:after, .btn-secondary:not(:disabled):not(.disabled):active:after {
    box-shadow: inset 0 3px 0 rgba(0, 0, 0, .15) !important
}

.btn-success {
    position: relative
}

.btn-success:after {
    content: " ";
    position: absolute;
    left: 0;
    right: 0;
    top: 0;
    bottom: -1px;
    border-radius: .25rem;
    box-shadow: inset 0 -3px 0 rgba(0, 0, 0, .15) !important
}

.btn-success:not(:disabled):not(.disabled).active:after, .btn-success:not(:disabled):not(.disabled):active:after {
    box-shadow: inset 0 3px 0 rgba(0, 0, 0, .15) !important
}

.btn-info {
    position: relative
}

.btn-info:after {
    content: " ";
    position: absolute;
    left: 0;
    right: 0;
    top: 0;
    bottom: -1px;
    border-radius: .25rem;
    box-shadow: inset 0 -3px 0 rgba(0, 0, 0, .15) !important
}

.btn-info:not(:disabled):not(.disabled).active:after, .btn-info:not(:disabled):not(.disabled):active:after {
    box-shadow: inset 0 3px 0 rgba(0, 0, 0, .15) !important
}

.btn-warning {
    position: relative
}

.btn-warning:after {
    content: " ";
    position: absolute;
    left: 0;
    right: 0;
    top: 0;
    bottom: -1px;
    border-radius: .25rem;
    box-shadow: inset 0 -3px 0 rgba(0, 0, 0, .15) !important
}

.btn-warning:not(:disabled):not(.disabled).active:after, .btn-warning:not(:disabled):not(.disabled):active:after {
    box-shadow: inset 0 3px 0 rgba(0, 0, 0, .15) !important
}

.btn-danger {
    position: relative
}

.btn-danger:after {
    content: " ";
    position: absolute;
    left: 0;
    right: 0;
    top: 0;
    bottom: -1px;
    border-radius: .25rem;
    box-shadow: inset 0 -3px 0 rgba(0, 0, 0, .15) !important
}

.btn-danger:not(:disabled):not(.disabled).active:after, .btn-danger:not(:disabled):not(.disabled):active:after {
    box-shadow: inset 0 3px 0 rgba(0, 0, 0, .15) !important
}

.btn-light {
    position: relative
}

.btn-light:after {
    content: " ";
    position: absolute;
    left: 0;
    right: 0;
    top: 0;
    bottom: -1px;
    border-radius: .25rem;
    box-shadow: inset 0 -3px 0 rgba(0, 0, 0, .15) !important
}

.btn-light:not(:disabled):not(.disabled).active:after, .btn-light:not(:disabled):not(.disabled):active:after {
    box-shadow: inset 0 3px 0 rgba(0, 0, 0, .15) !important
}

.btn-dark {
    position: relative
}

.btn-dark:after {
    content: " ";
    position: absolute;
    left: 0;
    right: 0;
    top: 0;
    bottom: -1px;
    border-radius: .25rem;
    box-shadow: inset 0 -3px 0 rgba(0, 0, 0, .15) !important
}

.btn-dark:not(:disabled):not(.disabled).active:after, .btn-dark:not(:disabled):not(.disabled):active:after {
    box-shadow: inset 0 3px 0 rgba(0, 0, 0, .15) !important
}

.btn-default {
    position: relative
}

.btn-default:after {
    content: " ";
    position: absolute;
    left: 0;
    right: 0;
    top: 0;
    bottom: -1px;
    border-radius: .25rem;
    box-shadow: inset 0 -3px 0 rgba(0, 0, 0, .15) !important
}

.btn-default:not(:disabled):not(.disabled).active:after, .btn-default:not(:disabled):not(.disabled):active:after {
    box-shadow: inset 0 3px 0 rgba(0, 0, 0, .15) !important
}

.btn-embossed {
    position: relative
}

.btn-embossed:after {
    content: " ";
    position: absolute;
    left: 0;
    right: 0;
    top: 0;
    bottom: -1px;
    border-radius: .25rem;
    box-shadow: inset 0 -3px 0 rgba(0, 0, 0, .15) !important
}

.btn-embossed:not(:disabled):not(.disabled).active:after, .btn-embossed:not(:disabled):not(.disabled):active:after {
    box-shadow: inset 0 3px 0 rgba(0, 0, 0, .15) !important
}

.btn-group > .btn-group:not(:last-child) > .btn.btn-embossed:after, .btn-group > .btn:not(:last-child):not(.dropdown-toggle).btn-embossed:after {
    border-top-right-radius: 0;
    border-bottom-right-radius: 0
}

.btn-group > .btn-group:not(:first-child) > .btn.btn-embossed:after, .btn-group > .btn:not(:first-child).btn-embossed:after {
    border-top-left-radius: 0;
    border-bottom-left-radius: 0
}

.btn-group-sm > .btn:after, .btn-sm:after {
    border-radius: .2rem
}

.btn-group-lg > .btn:after, .btn-lg:after {
    border-radius: .3rem
}

.btn-group-xs > .btn:after, .btn-xs:after {
    border-radius: .1rem
}

.btn-group-hg > .btn:after, .btn-hg:after {
    border-radius: .4rem
}

.btn-default {
    color: #fff
}

.btn-default:focus, .btn-default:hover, .btn-default:not(:disabled):not(.disabled):active {
    color: #fff
}

.btn-block {
    white-space: normal
}

.btn-wide {
    min-width: 140px;
    padding-left: 30px;
    padding-right: 30px
}

.btn-link {
    color: #e74c3c
}

.btn-link:focus, .btn-link:hover {
    color: #ea6153;
    text-decoration: underline;
    background-color: transparent
}

.btn-link[disabled]:focus, .btn-link[disabled]:hover, fieldset[disabled] .btn-link:focus, fieldset[disabled] .btn-link:hover {
    color: #6c757d;
    text-decoration: none
}

.btn-xs {
    padding: .25rem .5rem;
    font-size: .8125rem;
    line-height: 1.083;
    border-radius: .1rem
}

.btn-hg {
    padding: .5rem 1rem;
    font-size: 1.4375rem;
    line-height: 1.227;
    border-radius: .4rem
}

.btn-outline-primary {
    border-width: 2px
}

.btn-group-sm .btn-outline-primary, .btn-outline-primary.btn-sm, .btn-outline-primary.btn-xs {
    border-width: 1px
}

.btn-outline-secondary {
    border-width: 2px
}

.btn-group-sm .btn-outline-secondary, .btn-outline-secondary.btn-sm, .btn-outline-secondary.btn-xs {
    border-width: 1px
}

.btn-outline-success {
    border-width: 2px
}

.btn-group-sm .btn-outline-success, .btn-outline-success.btn-sm, .btn-outline-success.btn-xs {
    border-width: 1px
}

.btn-outline-info {
    border-width: 2px
}

.btn-group-sm .btn-outline-info, .btn-outline-info.btn-sm, .btn-outline-info.btn-xs {
    border-width: 1px
}

.btn-outline-warning {
    border-width: 2px
}

.btn-group-sm .btn-outline-warning, .btn-outline-warning.btn-sm, .btn-outline-warning.btn-xs {
    border-width: 1px
}

.btn-outline-danger {
    border-width: 2px
}

.btn-group-sm .btn-outline-danger, .btn-outline-danger.btn-sm, .btn-outline-danger.btn-xs {
    border-width: 1px
}

.btn-outline-light {
    border-width: 2px
}

.btn-group-sm .btn-outline-light, .btn-outline-light.btn-sm, .btn-outline-light.btn-xs {
    border-width: 1px
}

.btn-outline-dark {
    border-width: 2px
}

.btn-group-sm .btn-outline-dark, .btn-outline-dark.btn-sm, .btn-outline-dark.btn-xs {
    border-width: 1px
}

.btn-outline-default {
    border-width: 2px
}

.btn-group-sm .btn-outline-default, .btn-outline-default.btn-sm, .btn-outline-default.btn-xs {
    border-width: 1px
}

.screenshot-container {
    display: flex;
    flex-wrap: wrap;
    justify-content: space-around;
    align-items: center;
    align-content: space-around
}

@media (min-width: 576px) {
    .screenshot-container {
        border: solid 1px #eee;
        box-shadow: inset 0 0 50px #ccc;
        padding: 15px
    }
}

.screenshot {
    width: 262px;
    height: 262px;
    box-sizing: content-box;
    display: inline-block;
    position: relative
}

@media (min-width: 576px) {
    .screenshot {
        margin: 20px 10px
    }
}

.screenshot .description {
    font-size: 14px;
    line-height: 18px;
    text-align: center;
    margin-top: 5px
}

.screenshot .screenshot-thumb {
    position: relative;
    cursor: pointer;
    z-index: 1
}

.screenshot .screenshot-thumb img {
    border: solid 3px #aaa
}

.screenshot .screenshot-thumb:after {
    content: " ";
    position: absolute;
    left: 3px;
    right: 3px;
    top: 3px;
    height: 192px;
    transition: box-shadow .5s
}

.screenshot .screenshot-thumb:before {
    content: "\F00E";
    font: 100px fontawesome;
    position: absolute;
    left: 90px;
    top: 84px;
    line-height: 36px;
    text-align: center;
    text-shadow: 0 0 40px #000;
    color: #eee;
    transition: color .5s
}

.screenshot-video .screenshot-thumb:before {
    content: "\F144"
}

.screenshot .screenshot-thumb:hover:after {
    box-shadow: inset 0 0 120px #e74c3c
}

.screenshot .screenshot-thumb:hover:before {
    color: #e74c3c
}

.screenshot .screenshot-thumb:hover img {
    border: solid 3px #e74c3c
}

.screenshot-content .browser-title {
    background: url(../images/content-public/landings/browser-title.png@1) no-repeat 0 0;
    height: 36px;
    width: 100%;
    position: relative
}

.screenshot-content .browser-title .browser-url {
    position: absolute;
    left: 105px;
    top: 7px;
    font-size: 14px;
    color: #aaa
}

.screenshot-full {
    position: absolute;
    top: 0;
    left: 0;
    width: 256px;
    height: 192px;
    z-index: 0
}

.screenshot-full .browser-title {
    display: none
}

.screenshot-full img, .screenshot-full video {
    width: 100%;
    height: 100%;
    background: #eee url(../images/content-public/landings/progress.gif@1) 50% 50% no-repeat
}

.screenshot-full.active {
    position: fixed;
    z-index: 3;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background: rgba(0, 0, 0, .2)
}

.screenshot-full.active .browser-title {
    display: block
}

.screenshot-full.active .screenshot-content {
    box-shadow: 0 0 100px #000
}

body.locale-en .loc-en-d-none, html[lang=en] .loc-en-d-none {
    display: none !important
}

body.locale-en .loc-en-d-block, html[lang=en] .loc-en-d-block {
    display: block !important
}

body.locale-es .loc-es-d-none, html[lang=es] .loc-es-d-none {
    display: none !important
}

body.locale-es .loc-es-d-block, html[lang=es] .loc-es-d-block {
    display: block !important
}

body.locale-fr .loc-fr-d-none, html[lang=fr] .loc-fr-d-none {
    display: none !important
}

body.locale-fr .loc-fr-d-block, html[lang=fr] .loc-fr-d-block {
    display: block !important
}

body.locale-ja .loc-ja-d-none, html[lang=ja] .loc-ja-d-none {
    display: none !important
}

body.locale-ja .loc-ja-d-block, html[lang=ja] .loc-ja-d-block {
    display: block !important
}

body.locale-ko .loc-ko-d-none, html[lang=ko] .loc-ko-d-none {
    display: none !important
}

body.locale-ko .loc-ko-d-block, html[lang=ko] .loc-ko-d-block {
    display: block !important
}

body.locale-pl .loc-pl-d-none, html[lang=pl] .loc-pl-d-none {
    display: none !important
}

body.locale-pl .loc-pl-d-block, html[lang=pl] .loc-pl-d-block {
    display: block !important
}

body.locale-pt-br .loc-pt-br-d-none, html[lang=pt-br] .loc-pt-br-d-none {
    display: none !important
}

body.locale-pt-br .loc-pt-br-d-block, html[lang=pt-br] .loc-pt-br-d-block {
    display: block !important
}

body.locale-ru .loc-ru-d-none, html[lang=ru] .loc-ru-d-none {
    display: none !important
}

body.locale-ru .loc-ru-d-block, html[lang=ru] .loc-ru-d-block {
    display: block !important
}

body.locale-uk .loc-uk-d-none, html[lang=uk] .loc-uk-d-none {
    display: none !important
}

body.locale-uk .loc-uk-d-block, html[lang=uk] .loc-uk-d-block {
    display: block !important
}

body.locale-zh .loc-zh-d-none, html[lang=zh] .loc-zh-d-none {
    display: none !important
}

body.locale-zh .loc-zh-d-block, html[lang=zh] .loc-zh-d-block {
    display: block !important
}

@media (min-width: 1340px) {
    .d-hg-none {
        display: none !important
    }

    .d-hg-inline {
        display: inline !important
    }

    .d-hg-inline-block {
        display: inline-block !important
    }

    .d-hg-block {
        display: block !important
    }

    .d-hg-table {
        display: table !important
    }

    .d-hg-table-row {
        display: table-row !important
    }

    .d-hg-table-cell {
        display: table-cell !important
    }

    .d-hg-flex {
        display: -ms-flexbox !important;
        display: flex !important
    }

    .d-hg-inline-flex {
        display: -ms-inline-flexbox !important;
        display: inline-flex !important
    }
}

html[lang=en] .text, html[lang=en] pre.code {
    direction: ltr;
    text-align: left
}

.body-holder {
    display: flex;
    flex-direction: column
}

.navigation {
    order: -1
}

@media (min-width: 992px) {
    .center-content {
        margin-left: 15.625rem
    }
}

@media (min-width: 1340px) {
    .center-content .center-content-container {
        max-width: 1090px
    }

    .hg-width .center-content .center-content-container {
        max-width: 1340px
    }

    .max-width .center-content .center-content-container {
        max-width: 100%
    }
}

.center-content .page {
    padding: 2rem
}

@media (min-width: 992px) {
    .center-content .page {
        padding: 2rem 4rem
    }
}

@media (min-width: 1200px) {
    .center-content .page {
        padding-right: 2rem;
        width: calc(100% - 5.625rem - 4rem - 2rem)
    }
}

.feature, .no-feature .feature {
    display: none
}

@media (min-width: 1200px) {
    .no-feature .page {
        padding: 4rem;
        width: 100%
    }

    .feature {
        display: block;
        position: absolute;
        left: calc(100% - 15.625rem - 4rem);
        top: 4rem;
        width: 15.625rem
    }

    .feature img {
        max-width: 100%
    }

    .feature.affix {
        position: fixed;
        left: calc(100% - 15.625rem - 4rem);
        top: 4rem
    }

    .dynamic .feature {
        left: calc(100% - 15.625rem - 4rem);
        top: 4rem
    }
}

@media (min-width: 1340px) {
    .feature.affix {
        left: 1026px
    }

    .hg-width .feature.affix {
        left: calc(100% - 15.625rem - 4rem)
    }

    .max-width .feature.affix {
        left: calc(100% - 15.625rem - 4rem)
    }
}

@media (min-width: 1590px) {
    .hg-width .feature.affix {
        left: 1276px
    }
}

@media (min-width: 1200px) {
    .full-width-container {
        margin-right: -19.625rem;
        background: #fff;
        box-shadow: 0 0 10px 10px #fff;
        position: relative;
        z-index: 5
    }
}

.no-feature .full-width-container {
    margin-right: auto;
    box-shadow: none;
    position: static
}

.featured-content .top-content {
    margin-top: 0
}

.featured-content .center-content {
    margin-left: 0
}

.featured-content .center-content-container {
    max-width: 100% !important
}

.featured-content .navigation {
    transform: translateY(-4rem)
}

.featured-content .main-menu {
    transform: translateX(-15.625rem)
}

.featured-content.index-new .navigation {
    transform: translateY(0)
}

.featured-content.index-new .top-content {
    margin-top: 4rem
}

body.transitions .navigation {
    transition: transform .3s, background-color .3s
}

body.transitions .main-menu {
    transition: transform .3s
}

.main-content {
    position: relative
}

.main-content .main-content-container {
    position: relative
}

@media (min-width: 992px) {
    .main-content {
        z-index: 3
    }
}

.main-content.dynamic .main-content-container {
    animation: new-content .3s;
    animation-fill-mode: both;
    opacity: 0
}

@keyframes new-content {
    0% {
        opacity: 0;
        transform: translateY(300px)
    }
    100% {
        opacity: 1;
        transform: translateY(0)
    }
}

.modal-backdrop {
    z-index: 1040;
    background-color: #222
}

.modal-backdrop.show {
    opacity: .95
}

.navigation {
    background-color: #e74c3c;
    color: #fff;
    border: none;
    border-radius: 0;
    font-size: 24px;
    height: 4rem;
    z-index: 4
}

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

.navigation a, .navigation button {
    display: inline-block;
    text-decoration: none;
    transition: none
}

.navigation a:hover, .navigation button:hover {
    text-decoration: none
}

.navigation .navigation-container > a, .navigation .navigation-container > button, .navigation .navigation-menu > li > a, .navigation .navigation-menu > li > button, .navigation .navigation-menu > li > form > button {
    color: #fff;
    cursor: pointer;
    font-size: 19px;
    line-height: 34px;
    padding: 11px 6px;
    vertical-align: middle;
    text-shadow: #74261e 0 1px 1px;
    background: 0 0;
    border: none;
    box-shadow: none;
    border-radius: 10px
}

@media (min-width: 375px) {
    .navigation .navigation-container > a, .navigation .navigation-container > button, .navigation .navigation-menu > li > a, .navigation .navigation-menu > li > button, .navigation .navigation-menu > li > form > button {
        font-size: 19px;
        line-height: 34px;
        padding: 11px 11px
    }
}

@media (min-width: 576px) {
    .navigation .navigation-container > a, .navigation .navigation-container > button, .navigation .navigation-menu > li > a, .navigation .navigation-menu > li > button, .navigation .navigation-menu > li > form > button {
        font-size: 24px;
        line-height: 34px;
        padding: 11px 13px
    }
}

.navigation .navigation-container > a:hover, .navigation .navigation-container > button:hover, .navigation .navigation-menu > li > a:hover, .navigation .navigation-menu > li > button:hover, .navigation .navigation-menu > li > form > button:hover {
    background-color: #fff;
    color: #e74c3c;
    text-shadow: none
}

.navigation .navigation-container > a:active, .navigation .navigation-container > button:active, .navigation .navigation-menu > li > a:active, .navigation .navigation-menu > li > button:active, .navigation .navigation-menu > li > form > button:active {
    background-color: #fff2;
    color: #fff7;
    text-shadow: none
}

.navigation .navigation-container > a:focus, .navigation .navigation-container > button:focus, .navigation .navigation-menu > li > a:focus, .navigation .navigation-menu > li > button:focus, .navigation .navigation-menu > li > form > button:focus {
    outline: 0;
    background-color: #fff3
}

.navigation .navigation-container > a .caption, .navigation .navigation-container > button .caption, .navigation .navigation-menu > li > a .caption, .navigation .navigation-menu > li > button .caption, .navigation .navigation-menu > li > form > button .caption {
    display: none
}

.navigation .navigation-menu > li.show > a, .navigation .navigation-menu > li.show > button {
    background-color: #fff;
    color: #e74c3c;
    text-shadow: none;
    border-bottom-left-radius: 0;
    border-bottom-right-radius: 0
}

.navigation .navigation-toggle {
    align-self: flex-start;
    margin-right: 0
}

.sidebar-nav .navigation .navigation-toggle {
    visibility: hidden
}

.navigation .navigation-container > .navigation-brand {
    height: 4rem;
    padding: 6px 15px;
    border-bottom-left-radius: 0;
    border-top-left-radius: 0
}

.navigation .navigation-container > .navigation-brand:hover {
    background: 0 0
}

.navigation .navigation-container .dropdown-toggle::after {
    display: none
}

.navigation .navigation-menu, .navigation .navigation-menu > li {
    list-style: none;
    display: inline-block;
    margin: 0;
    padding: 0
}

.navigation .navigation-menu {
    display: flex;
    gap: 2px;
    padding-right: 4px
}

.navigation .nav-locale {
    order: 1
}

@media (min-width: 992px) {
    .navigation .nav-locale {
        order: -1
    }
}

.navigation .nav-menu {
    order: 2
}

.navigation .dropdown-menu {
    border-radius: 0;
    margin-top: 0;
    padding: 0;
    box-shadow: 0 5px 20px rgba(0, 0, 0, .4);
    border: none
}

.navigation .dropdown-menu li a:hover {
    background: #e74c3c;
    color: #fff
}

.navigation .dropdown-menu .suggest {
    font-weight: 700
}

.navigation .dropdown-item {
    padding: .5rem 1.5rem
}

.navigation .navigation-chapters {
    display: none
}

@media (min-width: 992px) {
    .navigation {
        background-color: #fff;
        color: #444;
        transform: translateX(15.625rem);
        width: calc(100% - 15.625rem);
        border-bottom: solid 1px #ecf0f1
    }

    .navigation .navigation-container {
        padding: 0
    }

    .navigation .navigation-container > a, .navigation .navigation-container > button, .navigation .navigation-menu > li > a, .navigation .navigation-menu > li > button, .navigation .navigation-menu > li > form > button {
        color: #444;
        text-shadow: none;
        white-space: nowrap;
        padding: 15px 20px;
        border-radius: 0
    }

    .navigation .navigation-container > a:hover, .navigation .navigation-container > button:hover, .navigation .navigation-menu > li > a:hover, .navigation .navigation-menu > li > button:hover, .navigation .navigation-menu > li > form > button:hover {
        background: 0 0;
        border-bottom: solid 3px #e74c3c;
        padding-bottom: 12px
    }

    .navigation .navigation-container > a:active, .navigation .navigation-container > button:active, .navigation .navigation-menu > li > a:active, .navigation .navigation-menu > li > button:active, .navigation .navigation-menu > li > form > button:active {
        color: #444;
        border-bottom: none;
        padding-bottom: 15px
    }

    .navigation .navigation-container > a:focus, .navigation .navigation-container > button:focus, .navigation .navigation-menu > li > a:focus, .navigation .navigation-menu > li > button:focus, .navigation .navigation-menu > li > form > button:focus {
        background-color: #00000009
    }

    .navigation .navigation-container > a .caption, .navigation .navigation-container > button .caption, .navigation .navigation-menu > li > a .caption, .navigation .navigation-menu > li > button .caption, .navigation .navigation-menu > li > form > button .caption {
        display: inline-block;
        font-size: 18px;
        line-height: 30px
    }

    .navigation .navigation-container > a .caption, .navigation .navigation-container > a .fa, .navigation .navigation-container > button .caption, .navigation .navigation-container > button .fa, .navigation .navigation-menu > li > a .caption, .navigation .navigation-menu > li > a .fa, .navigation .navigation-menu > li > button .caption, .navigation .navigation-menu > li > button .fa, .navigation .navigation-menu > li > form > button .caption, .navigation .navigation-menu > li > form > button .fa {
        vertical-align: middle
    }

    .navigation .navigation-menu > li.show > a, .navigation .navigation-menu > li.show > button {
        background-color: #eee;
        color: #e74c3c;
        text-shadow: none
    }

    .navigation .navigation-menu > li.show > a:hover, .navigation .navigation-menu > li.show > button:hover {
        background-color: #eee;
        color: #e74c3c;
        border-bottom: none
    }

    .navigation .navigation-brand, .navigation .navigation-toggle {
        display: none
    }

    .navigation .navigation-menu {
        margin: 0 0 0 auto
    }
}

.shop-link {
    padding: 0 3rem
}

.shop-link a, .shop-link a:after {
    border-radius: 50px
}

.beta {
    opacity: .8
}

.main-menu {
    position: fixed;
    z-index: 5;
    transform: translateX(15.5625rem);
    width: 15.625rem;
    right: 0;
    top: 0;
    bottom: 0;
    background-color: #e74c3c;
    opacity: .95;
    color: #fff;
    margin: 0
}

@media (min-width: 992px) {
    .main-menu {
        right: auto
    }
}

.main-menu > .os-padding > .os-viewport {
    overscroll-behavior: none
}

.sidebar-nav > .body-holder > .main-menu {
    transform: translateX(0)
}

.main-menu a, .main-menu button {
    display: block;
    position: relative;
    color: #fff;
    cursor: pointer;
    font-weight: 400;
    text-shadow: #74261e 0 1px 1px;
    outline: 0;
    background: 0 0;
    border: none
}

.main-menu a:focus, .main-menu a:hover, .main-menu button:focus, .main-menu button:hover {
    text-decoration: none;
    background: rgba(255, 255, 255, .1)
}

.main-menu a:active, .main-menu button:active {
    text-decoration: none;
    background: 0 0
}

.main-menu li, .main-menu ul {
    display: block;
    list-style: none;
    margin: 0;
    padding: 0
}

.main-menu .main-menu-controls {
    display: flex;
    justify-content: end;
    padding: 4px
}

@media (min-width: 992px) {
    .main-menu .main-menu-controls {
        display: none
    }
}

.main-menu .main-menu-controls a, .main-menu .main-menu-controls button {
    display: inline-block;
    font-size: 24px;
    line-height: 34px;
    padding: 11px 13px;
    margin: 0;
    color: #fff;
    vertical-align: middle;
    text-shadow: #74261e 0 1px 1px;
    background: 0 0;
    border: none;
    box-shadow: none;
    border-radius: 10px
}

.main-menu .main-menu-controls a:hover, .main-menu .main-menu-controls button:hover {
    background-color: #fff;
    color: #e74c3c;
    text-shadow: none
}

.main-menu .main-menu-controls a:active, .main-menu .main-menu-controls button:active {
    background-color: #fff2;
    color: #fff7;
    text-shadow: none
}

.main-menu .main-menu-controls a:focus, .main-menu .main-menu-controls button:focus {
    outline: 0;
    background-color: #fff3
}

.main-menu .menu-brand {
    display: none
}

.main-menu .main-menu-list-wrapper {
    height: calc(100% - 64px)
}

@media (min-width: 992px) {
    .main-menu .main-menu-list-wrapper {
        height: 100%
    }
}

.main-menu .main-menu-list {
    display: flex;
    flex-direction: column
}

.main-menu .main-menu-aux-controls {
    display: none
}

@media (min-width: 992px) {
    .main-menu .main-menu-aux-controls {
        display: flex;
        justify-content: space-between;
        gap: 5px;
        margin-top: 1rem;
        padding: 1rem 1rem;
        border-top: solid 1px rgba(255, 255, 255, .2)
    }
}

.main-menu .main-menu-aux-controls a, .main-menu .main-menu-aux-controls button {
    display: block;
    padding: 5px;
    flex-grow: 1
}

@media (min-width: 992px) {
    .main-menu {
        opacity: 1;
        transform: translateX(0)
    }

    .main-menu .navigation-toggle {
        display: none
    }

    .main-menu .menu-brand {
        display: block;
        text-align: center;
        padding: 20px 0
    }

    .main-menu .menu-brand img {
        width: 80%
    }

    .main-menu .sidebar-controls a, .main-menu .sidebar-controls button, .main-menu .sidebar-controls form {
        display: inline-block;
        padding: 5px
    }
}

.main-menu .menu-list a {
    padding: .75rem 1.25rem;
    line-height: 1.5em
}

.main-menu .menu-list li.trail > a, .main-menu .menu-list li.trail > ul {
    background: rgba(0, 0, 0, .1)
}

.main-menu .menu-list li.trail.active > a {
    background: rgba(0, 0, 0, .2)
}

.main-menu .menu-list li.active > a {
    background: rgba(0, 0, 0, .15);
    color: #fff
}

.main-menu .menu-list li.active > a:before {
    content: "\f061";
    font: normal normal normal 14px/1 fontawesome;
    position: absolute;
    top: 50%;
    margin-top: -8px;
    margin-left: -1.5rem;
    width: 12px;
    color: #fff
}

.main-menu .menu-list > li.active > a:before {
    content: ""
}

.main-menu .menu-list > li {
    margin: 0
}

.main-menu .menu-list > li > a {
    font-size: 18px
}

.main-menu .menu-list > li > a > i {
    font-size: 18px;
    vertical-align: middle;
    margin-top: -5px
}

.main-menu .menu-list > li.menu-second-level > a, .main-menu .menu-list > li > ul > li > a {
    font-size: 1rem;
    padding: .5rem 1.5rem .5rem 3rem;
    color: #fef6f5
}

.main-menu .menu-list > li.menu-second-level.lm > a, .main-menu .menu-list > li > ul > li.lm > a {
    padding: .5rem 1.5rem .5rem 2rem
}

.main-menu .menu-list > li.menu-second-level.menu-third-level > a, .main-menu .menu-list > li.menu-second-level > ul > li > a, .main-menu .menu-list > li > ul > li.menu-third-level > a, .main-menu .menu-list > li > ul > li > ul > li > a {
    font-size: .875rem;
    padding: .25rem 1.5rem .25rem 4rem;
    color: #fdedec
}

.main-menu .menu-list > li.menu-second-level.menu-third-level.menu-fourth-level > a, .main-menu .menu-list > li.menu-second-level.menu-third-level > ul > li > a, .main-menu .menu-list > li.menu-second-level > ul > li.menu-fourth-level > a, .main-menu .menu-list > li.menu-second-level > ul > li > ul > li > a, .main-menu .menu-list > li > ul > li.menu-third-level.menu-fourth-level > a, .main-menu .menu-list > li > ul > li.menu-third-level > ul > li > a, .main-menu .menu-list > li > ul > li > ul > li.menu-fourth-level > a, .main-menu .menu-list > li > ul > li > ul > li > ul > li > a {
    font-size: .75rem;
    padding: .25rem 1.5rem .25rem 5rem;
    color: #fdedec
}

.main-menu .menu-list .menu-tag {
    background: #d12346;
    padding: 2px 5px;
    border-radius: 30px;
    font-size: 11px;
    margin-left: 5px
}

.main-menu .menu-list .menu-code-examples ul {
    padding-left: 2.5rem
}

.main-menu .menu-list li.menu-code-examples-item {
    display: inline-block
}

.main-menu .menu-list li.menu-code-examples-item > a {
    display: inline-block;
    padding: .25rem 1.5rem;
    width: 95px;
    font-size: .875rem
}

.main-menu .menu-list li.menu-code-examples-item > a:before {
    margin-left: -1rem
}

.main-menu .menu-list li {
    perspective: 1000px
}

.main-menu .menu-list li > ul {
    transform-origin: 0 0;
    max-height: 0;
    overflow: hidden;
    visibility: hidden
}

.main-menu .menu-list li.animated > ul {
    animation: menu-item-reverse-sm .5s;
    animation-fill-mode: both
}

.main-menu .menu-list li.trail > ul {
    max-height: 220vh;
    visibility: visible
}

.main-menu .menu-list li.trail.animated > ul {
    animation: menu-item-sm .5s;
    animation-fill-mode: both
}

.main-menu .menu-list li.featured {
    margin: 0
}

.main-menu .menu-list li.featured > a {
    font-weight: 700;
    background: rgba(200, 34, 66, .5)
}

.main-menu .menu-list li.featured > a:hover {
    background: rgba(213, 36, 70, .5)
}

.main-menu .menu-list li.featured.active > a, .main-menu .menu-list li.featured > a:active, .main-menu .menu-list li.featured > a:focus {
    background: rgba(165, 28, 55, .7)
}

@media (min-width: 992px) {
    .main-menu .menu-list > li > a {
        font-size: 20px
    }

    .main-menu .menu-list li.animated > ul {
        animation: menu-item-reverse .5s
    }

    .main-menu .menu-list li.trail.animated > ul {
        animation: menu-item .5s
    }
}

@keyframes menu-item {
    0% {
        transform: rotateX(-90deg)
    }
    10% {
        max-height: 100px
    }
    100% {
        max-height: 220vh;
        transform: rotateX(0)
    }
}

@keyframes menu-item-reverse {
    0% {
        max-height: 220vh;
        transform: rotateX(0)
    }
    10% {
        max-height: 100px
    }
    50% {
        max-height: 0;
        transform: rotateX(-90deg)
    }
    100% {
        max-height: 0
    }
}

@keyframes menu-item-sm {
    0% {
        transform: rotateX(-90deg)
    }
    100% {
        transform: rotateX(0)
    }
}

@keyframes menu-item-reverse-sm {
    0% {
        transform: rotateX(0)
    }
    100% {
        transform: rotateX(-90deg)
    }
}

.nano {
    z-index: 3
}

.nano > .nano-content {
    top: 63px
}

.nano > .nano-pane {
    top: 63px;
    width: 5px;
    background: 0 0;
    opacity: 1 !important
}

.os-scrollbar {
    padding: 0 !important;
    width: 5px !important
}

.os-theme-red .os-scrollbar-handle {
    background: #ee8277 !important;
    border-radius: 0 !important
}

@media (min-width: 992px) {
    .nano > .nano-content {
        top: 0
    }

    .nano > .nano-pane {
        top: 0
    }
}

html {
    position: relative;
    min-height: 100%
}

body {
    margin-bottom: 128px
}

.footer {
    position: absolute;
    bottom: 0;
    right: 0;
    left: 0
}

.footer {
    background-color: #e9ecef;
    color: #6c757d;
    padding: 0;
    line-height: 1
}

.footer a {
    color: #6c757d
}

.footer a:hover, .footer a:visited {
    color: #6c757d
}

.footer-second {
    font-size: .875rem;
    line-height: 1.3125rem;
    background: #dee2e6
}

.footer-inner {
    padding: 2rem
}

@media (min-width: 992px) {
    .footer-inner {
        padding: 2rem 4rem
    }
}

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

.footer-list li {
    display: block
}

.footer-list a {
    display: inline-block
}

.footer-list-horizontal li {
    display: inline-block;
    margin-right: 0
}

.footer-list-right {
    justify-content: flex-end
}

.footer-list-iconic {
    margin: 0 15px
}

.footer-list-iconic li {
    display: block;
    text-align: right
}

.footer-list-iconic li:last-child {
    margin-right: 0
}

@media (min-width: 768px) {
    .footer-list-iconic {
        margin-right: 0;
        margin-left: 0
    }

    .footer-list-iconic li {
        display: inline-block;
        margin-right: 1rem
    }
}

@media (min-width: 576px) {
    .footer-links-right, .footer-list-iconic {
        text-align: right
    }

    .footer-links-right li:last-child, .footer-list-iconic li:last-child {
        margin: 0
    }
}

.list h1 {
    margin: 0 0 40px 0
}

@media (min-width: 768px) {
    .list .row {
        padding: 30px 15px
    }

    .list .row h2, .list .row h3 {
        margin-top: 0
    }
}

.cell-flex {
    display: flex
}

.cell-flex * {
    flex-basis: auto
}

.cell-image {
    display: none
}

.catalog-list ul {
    margin: 0
}

.catalog-list ul li {
    margin: 8px 0
}

@media (min-width: 576px) {
    .cell-image {
        display: block;
        width: 190px;
        text-align: left
    }

    .cell-text {
        width: calc(100% - 190px)
    }

    .catalog-list {
        display: flex
    }

    .catalog-list ul {
        justify-content: space-between;
        flex-basis: 33%;
        padding: 0 20px
    }
}

.annotation {
    margin-bottom: 1.5rem
}

.featured.cell {
    border: solid 10px #eee;
    padding: 20px 15px 30px
}

.aka {
    font-weight: 700;
    margin-top: -1rem;
    margin-bottom: 1.5rem
}

.aka span {
    font-weight: 400;
    display: block
}

.lang-switcher {
    position: absolute
}

@media (min-width: 992px) {
    .lang-switcher {
        opacity: .5
    }

    .lang-switcher:hover {
        opacity: 1
    }
}

.lang-switcher a {
    position: relative;
    display: inline-block;
    text-align: center;
    background: #ecf0f1;
    font-size: 14px;
    text-decoration: none;
    padding: 5px 10px;
    border-radius: 5px;
    margin: 0 2px 2px 0;
    color: #444;
    z-index: 2
}

.lang-switcher a:hover {
    color: #444;
    background: #d5dadc
}

.lang-switcher a.active {
    font-weight: 700;
    background: #d5dadc;
    box-shadow: inset 3px 3px 3px #bdc3c7
}

.examples {
    position: relative;
    padding: 0;
    margin: 0;
    min-width: 0
}

@media (min-width: 768px) {
    .examples {
        border-bottom: solid 1px #ecf0f1;
        padding: 0 0 50px 0;
        margin: 0 0 40px
    }
}

@media (min-width: 1340px) {
    .examples {
        z-index: 1;
        transition: min-width .5s;
        transition-timing-function: ease-in;
        transition-delay: .1s
    }

    .examples:hover {
        min-width: 962px
    }
}

.examples .lang-switcher {
    right: 15px;
    z-index: 3
}

@media (min-width: 768px) {
    .examples .lang-switcher {
        width: 300px;
        position: absolute;
        margin: 0;
        margin-left: -150px;
        bottom: 16px;
        left: 50%;
        text-align: center
    }
}

@media (min-width: 1340px) {
    .examples .lang-switcher {
        left: 185px;
        margin-left: 0
    }
}

.before-after .ba {
    font-size: 16px;
    padding: 5px 15px;
    color: #3a3a3c;
    background: #f6f8f8;
    font-weight: 700;
    border-bottom: solid 2px #e74c3c;
    border-top-right-radius: 5px;
    border-top-left-radius: 5px;
    position: relative;
    z-index: 2
}

@media (min-width: 768px) {
    .before-after .ba {
        display: none
    }
}

.before-after .ba-container, .before-after pre {
    margin: -2px 0 0 0;
    padding: 1.5rem 0 0;
    border-radius: 0;
    border: none;
    border-top: dotted 2px #f3a69e;
    overflow-x: auto
}

.before-after .ba-container img {
    max-width: 100%;
    margin: 0 auto;
    display: block
}

.before-after > div:first-child {
    margin-bottom: 20px
}

.before-after-container {
    margin-top: 3rem
}

.before-after-container .after, .before-after-container .before {
    margin-bottom: 1.5rem
}

@media (min-width: 768px) {
    .before-after-container {
        display: flex;
        justify-content: space-between
    }

    .before-after-container .after, .before-after-container .before {
        width: 48%
    }
}

.live-example-container {
    position: relative
}

.live-example-container .lang-switcher {
    right: 0;
    left: auto;
    width: auto;
    top: 32px
}

ol.nomargin, ul.nomargin {
    margin: 0;
    padding: 0
}

ol.nomargin li, ul.nomargin li {
    list-style: none
}

.relations {
    border-top: solid 1px #ecf0f1;
    font-size: 16px;
    margin: 40px 0 0 0;
    padding: 40px 0 0
}

.relations::after {
    display: block;
    clear: both;
    content: ""
}

.relations .col-sm-6 {
    margin-bottom: 32px
}

.relations h3 {
    font-size: 22px;
    line-height: 24px;
    margin: 0 0 24px
}

@media (min-width: 1200px) {
    .relations h3 {
        vertical-align: top
    }
}

.pattern .relations {
    border-top: none;
    padding: 0
}

.pop {
    border: none;
    background: 0 0;
    padding: 0;
    margin: 0;
    display: inline-block;
    position: relative
}

.pop .pop-content {
    display: none
}

.prev-next {
    border-top: solid 1px #ecf0f1;
    font-size: 16px;
    padding: 20px 0 0;
    margin-top: 40px
}

.refactoring .prev-next {
    margin-top: 0
}

.prev-next h4 {
    color: #bdc3c7;
    margin: 10px 0;
    text-transform: uppercase
}

.prev-next .btn {
    min-width: 75%;
    display: inline-flex;
    gap: .5rem;
    flex-direction: row-reverse;
    flex-direction: row;
    justify-content: center;
    align-items: center
}

.prev-next .fa {
    display: inline
}

.prev-next .prev {
    overflow: auto
}

.prev-next .prev .btn {
    float: left
}

.prev-next .prev .btn .fa-arrow-left:before {
    content: '\f061';
    content: '\f060'
}

.prev-next .next {
    margin-bottom: 1.5rem;
    overflow: auto
}

.prev-next .next h4 {
    text-align: right
}

.prev-next .next .btn {
    float: right
}

.prev-next .next .btn .fa-arrow-right:before {
    content: '\f060';
    content: '\f061'
}

@media (min-width: 576px) {
    .prev-next {
        display: flex;
        justify-content: space-between;
        flex-direction: row-reverse
    }

    .prev-next .next, .prev-next .prev {
        width: 48%
    }

    .prev-next .prev {
        margin-top: auto;
        margin-right: auto
    }

    .prev-next .prev .btn {
        float: none
    }

    .prev-next .next {
        margin-bottom: 0;
        text-align: right
    }

    .prev-next .next .btn {
        float: none
    }

    .prev-next .btn {
        display: flex
    }
}

.prev-next .next h4 {
    color: #e74c3c
}

.prev-next .prev h4 {
    color: #bdc3c7
}

.CodeMirror, code, kbd, pre, samp {
    font-family: Menlo, "Fira Code", Monaco, Consolas, "Courier New", monospace;
    font-size: .75rem;
    line-height: 1.25rem;
    font-variant-ligatures: none
}

.CodeMirror {
    height: auto
}

pre.code {
    font-family: Menlo, "Fira Code", Monaco, Consolas, "Courier New", monospace;
    font-size: .75rem;
    line-height: 1.25rem;
    padding: 15px;
    overflow: auto;
    text-align: left;
    font-variant-ligatures: none
}

code {
    padding: 2px 6px;
    color: #444;
    border-radius: 5px;
    white-space: pre;
    vertical-align: middle
}

code, pre.code {
    background: #f6f8f8
}

a code {
    border-bottom: solid 1px #aaa;
    text-shadow: none
}

a code:hover {
    background: #f8c9c4;
    border-bottom: solid 1px #ea6153
}

.codeplayer {
    padding-left: 0
}

.codeplayer .codeplayer-roadmap {
    font-size: .75rem;
    line-height: 1rem
}

.codeplayer-help {
    display: inline-block;
    margin-left: 5px;
    margin-bottom: 20px;
    line-height: 30px;
    vertical-align: middle
}

.codeplayer-help a {
    color: #444
}

.codeplayer-help a:hover {
    color: #e74c3c;
    cursor: pointer
}

.codeplayer-help-container {
    display: none
}

.live-example-container {
    box-shadow: 0 0 20px 20px #fff;
    background: #fff;
    z-index: 5
}

@media (min-width: 768px) {
    .live-example-container {
        width: 100%
    }
}

@media (min-width: 1200px) {
    .live-example-container {
        width: calc(100% + 60px + 250px)
    }
}

.live-example-container .popover {
    min-width: 50%
}

.live-example-container .popover h3 {
    margin-top: 0
}

.cm-s-default .cm-keyword {
    font-weight: 700;
    color: #000
}

.cm-s-default .cm-atom {
    font-weight: 700;
    color: #000
}

.cm-s-default .cm-number {
    color: #005cc5
}

.cm-s-default .cm-def {
    font-weight: 700;
    color: teal
}

.cm-s-default .cm-operator, .cm-s-default .cm-property, .cm-s-default .cm-punctuation, .cm-s-default .cm-variable {
    color: #000
}

.cm-s-default .cm-variable-2 {
    color: #000
}

.cm-s-default .cm-type, .cm-s-default .cm-variable-3 {
    color: #000;
    font-weight: 700
}

.cm-s-default .cm-def {
    font-weight: 700;
    color: #900
}

.cm-s-default .cm-property {
    color: #000
}

.cm-s-default .cm-operator {
    color: #000
}

.cm-s-default .cm-comment {
    color: #090
}

.cm-s-default .cm-string {
    color: #d14
}

.cm-s-default .cm-string-2 {
    color: #f50
}

.cm-s-default .cm-meta {
    font-weight: 700;
    color: #999
}

.cm-s-default .cm-qualifier {
    color: #555
}

.cm-s-default .cm-builtin {
    color: #0086b3
}

.cm-s-default .cm-bracket {
    color: #997
}

.cm-s-default .cm-tag {
    color: #170
}

.cm-s-default[lang=ruby] .cm-tag {
    font-weight: 700;
    color: #900
}

.cm-s-default .cm-attribute {
    color: #00c
}

.cm-s-default .cm-header {
    color: #00f
}

.cm-s-default .cm-quote {
    color: #090
}

.cm-s-default .cm-hr {
    color: #999
}

.cm-s-default .cm-link {
    color: #00c
}

.cm-s-default .cm-def1 {
    font-weight: 700;
    color: #900
}

.cm-s-default .cm-def2 {
    color: #900
}

.cm-s-default .cm-def3 {
    color: #500
}

.cm-s-default .cm-doc {
    color: #090
}

.cm-negative {
    color: #d44
}

.cm-positive {
    color: #292
}

.cm-header, .cm-strong {
    font-weight: 700
}

.cm-em {
    font-style: italic
}

.cm-link {
    text-decoration: underline
}

div.CodeMirror span.CodeMirror-matchingbracket {
    color: #0f0
}

div.CodeMirror span.CodeMirror-nonmatchingbracket {
    color: #f22
}

.CodeMirror-activeline-background {
    background: #e8f2ff
}

.product-image {
    margin: 0
}

.product-image .image3d-cover, .product-image img {
    border-radius: 30px
}

.product-block {
    margin: 0 auto;
    z-index: 1;
    padding-bottom: 30px;
    margin-bottom: 30px;
    border-bottom: solid 1px #eee
}

@media (min-width: 768px) {
    .product-block {
        margin: 0;
        z-index: 1;
        padding-bottom: 15px;
        border-bottom: solid 0 #eee
    }
}

.product-block .image, .product-block .price {
    margin: 0 0 16px
}

.product-block .buy-widget {
    justify-content: center
}

.product-block .product-features {
    margin-top: 40px
}

.product-block .product-features .product-feature {
    margin: 0 0 20px;
    display: flex;
    justify-content: flex-start;
    align-items: center
}

.product-block .product-features .product-feature .image {
    width: 80px;
    margin: 0;
    flex-shrink: 0
}

.product-block .buy-options {
    max-width: 250px;
    margin: auto
}

.product-block .buy-options .alert {
    border-top-left-radius: 0;
    border-top-right-radius: 0;
    margin-top: -2px;
    border: solid 2px #f8c9c4;
    border-top: none
}

.product-block .buy-options .btn {
    position: relative;
    z-index: 2
}

.buy-widget-new {
    text-align: center;
    margin-top: -5px
}

.buy-widget-new-old-price {
    display: inline-block;
    font-size: 24px;
    line-height: 32px;
    color: #444;
    font-weight: 400;
    position: relative;
    margin-right: 5px
}

.buy-widget-new-old-price:after {
    content: " ";
    background: linear-gradient(-6deg, transparent 0, transparent 43%, #d12345 44%, #d12345 51%, transparent 52%, transparent 100%);
    position: absolute;
    left: 0;
    right: 0;
    top: 0;
    bottom: 0
}

.buy-widget-new-new-price {
    color: #d12345;
    font-weight: 700;
    z-index: 2;
    position: relative;
    display: inline-block;
    font-size: 32px;
    line-height: 32px
}

.buy-widget-new-offer-text {
    color: #d12345;
    font-weight: 700;
    z-index: 2;
    position: relative;
    font-size: 20px
}

.buy-widget-local-taxes {
    color: #c44C68FF;
    font-weight: 400;
    z-index: 2;
    position: relative;
    font-size: 14px;
    line-height: 20px
}

.btn-buy {
    font-weight: 700;
    white-space: nowrap
}

.btn-buy.btn-gh {
    font-size: 21px;
    line-height: 21px;
    padding: 20px;
    border-radius: 15px
}

.btn-buy span {
    font-size: 14px;
    font-weight: 400
}

.buy-widget {
    position: relative;
    display: flex;
    justify-content: flex-end;
    align-items: center
}

.price-tag {
    color: #d12345;
    font-weight: 700;
    display: inline-block;
    padding: 0 5px 15px;
    line-height: 16px;
    text-align: right
}

.price-tag.price-tag-lg {
    font-size: 24px
}

.price-tag.price-tag-hg {
    padding: 0;
    font-size: 30px;
    line-height: 30px
}

.price-tag.price-tag-hg .old-price {
    font-size: 30px
}

.price-tag.price-tag-hg .price-tag {
    line-height: 40px
}

.price-tag .old-price {
    color: #444;
    font-weight: 400;
    position: relative
}

.price-tag .old-price:after {
    content: " ";
    background: linear-gradient(-6deg, transparent 0, transparent 43%, #d12345 44%, #d12345 51%, transparent 52%, transparent 100%);
    position: absolute;
    left: 0;
    right: 0;
    top: 0;
    bottom: 0
}

.price-tag .new-price {
    color: #d12345;
    font-weight: 700;
    margin-top: 5px;
    z-index: 2;
    position: relative;
    display: inline-block
}

.price-tag .offer-text {
    position: absolute;
    font-size: 16px;
    line-height: 16px;
    right: 0;
    text-align: right;
    bottom: -18px;
    white-space: pre;
    font-style: italic
}

.price-tag.compact {
    padding: 0 5px
}

.price-tag.compact .old-price {
    display: inline-block;
    position: absolute;
    font-size: 18px;
    line-height: 25px;
    transform: rotate(-19deg);
    margin-top: -37px;
    background: rgba(255, 255, 255, .9);
    margin-left: -19px
}

:lang(pl) .price-tag .offer-text {
    font-size: 14px;
    line-height: 14px
}

.product-block .offer-text {
    right: 0;
    text-align: center;
    bottom: auto;
    top: -17px;
    white-space: nowrap;
    background: #fff;
    position: absolute
}

.questions .dl.icon .dt {
    padding: 0;
    margin: 0 0 0 1px;
    border-left: none
}

.questions .dl.icon .dt:before {
    content: ""
}

.feedback-container .feedback-list {
    padding: 0 !important;
    margin: 20px 0
}

.feedback-container .feedback-item {
    display: none;
    padding: 2rem;
    margin: 1rem 0;
    border: solid 1px rgba(0, 0, 0, .125);
    border-radius: .25rem;
    list-style: none
}

.feedback-container .feedback-item.visible {
    display: block
}

.feedback-container .feedback-item:first-child {
    margin-top: 0
}

.feedback-container .feedback-item:last-child {
    margin-bottom: 0
}

.feedback-container .feedback-reply {
    background: #eee;
    padding: 10px
}

.feedback-container .feedback {
    font-style: italic
}

.feedback-container .feedback-details {
    margin: 1.5rem 0 0
}

.feedback-container .stars {
    display: inline-block;
    color: #d35400
}

.feedback-container .name {
    display: inline-block;
    font-weight: 700;
    white-space: pre
}

.feedback-container .name:before {
    content: " / ";
    font-style: normal;
    font-weight: 400;
    color: silver
}

.feedback-container .location {
    display: inline-block;
    font-style: italic;
    white-space: pre
}

.feedback-container .location:before {
    content: " / ";
    font-style: normal;
    font-weight: 400;
    color: silver
}

.feedback-container .feedback-controls {
    text-align: center
}

:lang(ko) .product-block .offer-text {
    white-space: normal;
    width: 85px
}

.btn .title {
    margin-left: 10px
}

label {
    font-size: 18px;
    line-height: 1.4
}

.layout-table {
    display: table;
    table-layout: fixed;
    height: 100vh;
    width: 100%
}

.layout-table-cell {
    display: table-cell;
    vertical-align: middle
}

.checkbox .icons, .radio .icons {
    font-size: 26px
}

.select {
    margin-bottom: 0
}

.form-control::placeholder {
    color: #b7b7b7
}

.form-control.no-value {
    color: #b7b7b7
}

.is-invalid > .form-control.no-value {
    color: #e74c3c
}

.help-block {
    color: #bdc3c7
}

@media (min-width: 576px) {
    .layout-table .login-box, .layout-table .password-reset {
        width: 554px;
        margin: auto
    }
}

.login-box .content, .password-reset .content {
    border-radius: 15px;
    padding: 20px 20px 40px
}

@media (min-width: 576px) {
    .login-box .content, .password-reset .content {
        border: solid 3px #ecf0f1;
        padding: 40px 40px 20px 40px
    }
}

.login-box > h1, .login-box > h2, .password-reset > h1, .password-reset > h2 {
    text-align: center
}

.login-box > h1, .password-reset > h1 {
    font-size: 64px;
    line-height: 64px;
    margin: 0 0 .5rem
}

.login-box > h2, .password-reset > h2 {
    font-size: 32px;
    line-height: 32px;
    margin: 0 0 1rem
}

.login-box #email, .login-box #password {
    padding-left: 30px
}

.login-box .email svg, .login-box .password svg {
    position: absolute;
    color: #ccc;
    pointer-events: none
}

.login-box .email svg {
    margin-top: 14px;
    margin-left: 10px
}

.login-box .password svg {
    margin-top: 12px;
    margin-left: 10px
}

.login-box .modal-footer > a {
    margin: 0
}

.login .submit {
    margin-top: 24px;
    font-size: 23px;
    padding: 3px 5px;
    display: inline-flex;
    align-items: center;
    justify-content: center
}

@media (min-width: 576px) {
    .login .submit {
        margin-top: 0
    }
}

.login .forgot {
    display: block;
    margin-top: -80px;
    margin-bottom: 10px
}

@media (min-width: 576px) {
    .login .forgot {
        display: inline-block;
        margin: 9px 0
    }
}

@media (min-width: 576px) {
    .login .flex-item-66 {
        padding-right: 10px
    }

    .login .flex-item-33 {
        border-left: solid 1px #eee;
        padding-left: 10px
    }
}

.login .sign-in-header {
    text-transform: uppercase;
    color: #999;
    margin: .5rem 0;
    text-align: center
}

.login .toc-box {
    border-top: solid 1px #eee;
    padding: 20px 20px 0;
    text-align: center;
    margin: 0 -20px
}

@media (min-width: 576px) {
    .login .toc-box {
        margin: 0 -40px;
        padding: 20px 40px 0
    }
}

@media (min-width: 576px) {
    .login .login-box-right-col-border {
        border-left: solid 1px #eee
    }
}

.form-control.is-valid, .was-validated .form-control:valid {
    border-color: #ced4da
}

.social-login .btn {
    display: inline-block;
    border-radius: .25rem;
    text-align: left;
    width: 60px;
    padding: 4px;
    margin: 0 0 1rem
}

.social-login .btn i {
    font-size: 24px;
    margin-top: 5px;
    margin-left: 0
}

.social-login .btn svg {
    vertical-align: middle
}

.social-login .btn .si-icon {
    display: inline-block;
    vertical-align: middle;
    background: #fff;
    width: 50px;
    text-align: center;
    border-radius: 2px
}

.social-login .btn .si-text {
    display: block;
    padding: 4px;
    vertical-align: middle;
    text-align: center;
    font-size: 14px
}

@media (min-width: 576px) {
    .social-login .btn {
        padding: 3px 10px 3px 3px;
        display: block;
        width: auto
    }

    .social-login .btn .si-icon {
        width: 34px;
        height: 34px
    }

    .social-login .btn .si-text {
        display: inline-block;
        padding: 0;
        font-size: 1rem;
        line-height: 1.5rem
    }
}

.social-login .btn-vertical {
    display: inline-block;
    width: 58px;
    padding: 4px
}

.social-login .btn-vertical .si-icon {
    width: 48px
}

.social-login .btn-vertical .si-text {
    padding: 0;
    vertical-align: middle;
    display: block;
    text-align: center;
    font-size: 14px;
    line-height: 1.5rem
}

@media (min-width: 576px) {
    .social-login .btn-vertical .si-text {
        padding: 4px 0
    }
}

.social-login .btn.google-plus-signin {
    color: #fff;
    background-color: #f44542;
    border-color: #f44542
}

.social-login .btn.google-plus-signin:hover {
    color: #fff;
    background-color: #f2211e;
    border-color: #f11612
}

.social-login .btn.google-plus-signin.focus, .social-login .btn.google-plus-signin:focus {
    color: #fff;
    background-color: #f2211e;
    border-color: #f11612;
    box-shadow: 0 0 0 .2rem rgba(246, 97, 94, .5)
}

.social-login .btn.google-plus-signin.disabled, .social-login .btn.google-plus-signin:disabled {
    color: #fff;
    background-color: #f44542;
    border-color: #f44542
}

.show > .social-login .btn.google-plus-signin.dropdown-toggle, .social-login .btn.google-plus-signin:not(:disabled):not(.disabled).active, .social-login .btn.google-plus-signin:not(:disabled):not(.disabled):active {
    color: #fff;
    background-color: #f11612;
    border-color: #e9110e
}

.show > .social-login .btn.google-plus-signin.dropdown-toggle:focus, .social-login .btn.google-plus-signin:not(:disabled):not(.disabled).active:focus, .social-login .btn.google-plus-signin:not(:disabled):not(.disabled):active:focus {
    box-shadow: 0 0 0 .2rem rgba(246, 97, 94, .5)
}

.social-login .btn.facebook-signin {
    color: #fff;
    background-color: #4285f4;
    border-color: #4285f4
}

.social-login .btn.facebook-signin:hover {
    color: #fff;
    background-color: #1e6ef2;
    border-color: #1266f1
}

.social-login .btn.facebook-signin.focus, .social-login .btn.facebook-signin:focus {
    color: #fff;
    background-color: #1e6ef2;
    border-color: #1266f1;
    box-shadow: 0 0 0 .2rem rgba(94, 151, 246, .5)
}

.social-login .btn.facebook-signin.disabled, .social-login .btn.facebook-signin:disabled {
    color: #fff;
    background-color: #4285f4;
    border-color: #4285f4
}

.show > .social-login .btn.facebook-signin.dropdown-toggle, .social-login .btn.facebook-signin:not(:disabled):not(.disabled).active, .social-login .btn.facebook-signin:not(:disabled):not(.disabled):active {
    color: #fff;
    background-color: #1266f1;
    border-color: #0e60e9
}

.show > .social-login .btn.facebook-signin.dropdown-toggle:focus, .social-login .btn.facebook-signin:not(:disabled):not(.disabled).active:focus, .social-login .btn.facebook-signin:not(:disabled):not(.disabled):active:focus {
    box-shadow: 0 0 0 .2rem rgba(94, 151, 246, .5)
}

.social-login .btn.facebook-signin.btn-vertical .si-text {
    font-size: 12px;
    line-height: 1.5rem
}

.social-login .btn.github-signin {
    color: #fff;
    background-color: #666;
    border-color: #666
}

.social-login .btn.github-signin:hover {
    color: #fff;
    background-color: #535353;
    border-color: #4d4c4c
}

.social-login .btn.github-signin.focus, .social-login .btn.github-signin:focus {
    color: #fff;
    background-color: #535353;
    border-color: #4d4c4c;
    box-shadow: 0 0 0 .2rem rgba(125, 125, 125, .5)
}

.social-login .btn.github-signin.disabled, .social-login .btn.github-signin:disabled {
    color: #fff;
    background-color: #666;
    border-color: #666
}

.show > .social-login .btn.github-signin.dropdown-toggle, .social-login .btn.github-signin:not(:disabled):not(.disabled).active, .social-login .btn.github-signin:not(:disabled):not(.disabled):active {
    color: #fff;
    background-color: #4d4c4c;
    border-color: #464646
}

.show > .social-login .btn.github-signin.dropdown-toggle:focus, .social-login .btn.github-signin:not(:disabled):not(.disabled).active:focus, .social-login .btn.github-signin:not(:disabled):not(.disabled):active:focus {
    box-shadow: 0 0 0 .2rem rgba(125, 125, 125, .5)
}

.alert {
    margin-bottom: 15px
}

.alert a {
    text-shadow: none !important
}

.alert ul:last-child {
    margin-bottom: 0
}

@media (min-width: 576px) {
    :lang(pl) .login .forgot {
        margin-left: -15px
    }
}

@media (min-width: 576px) {
    :lang(fr) .password-reset .submit {
        max-width: 100%;
        letter-spacing: -1px;
        font-size: 19px
    }
}

@media (min-width: 576px) {
    :lang(ko) .login .forgot {
        margin-left: -15px
    }
}

html:has(.modal-open) {
    overscroll-behavior: none
}

@media (min-width: 576px) {
    body.modal-open {
        overflow-y: hidden
    }
}

#checkout.enable-reveal-transitions .cart-upsell {
    transition: transform .5s ease-out, opacity .5s ease-out
}

#checkout .checkout-wrapper {
    display: none
}

#checkout .modal-dialog {
    display: none
}

#checkout.prepare-reveal-transitions {
    overflow: hidden;
    display: block
}

#checkout.prepare-reveal-transitions .checkout-wrapper {
    transform: translateY(100px);
    opacity: 0;
    display: flex
}

#checkout.prepare-reveal-transitions .modal-dialog {
    display: block;
    transform: translateY(100px);
    opacity: 0
}

#checkout.prepare-reveal-transitions .flip-back, #checkout.prepare-reveal-transitions .flip-next {
    display: none
}

#checkout.enable-reveal-transitions .checkout-wrapper {
    transition: transform .25s ease-out, opacity .25s;
    transform: translateY(0);
    opacity: 1
}

#checkout.enable-reveal-transitions .modal-dialog {
    transition: transform .25s ease-out, opacity .25s ease-out;
    transform: translateY(0);
    opacity: 1
}

#checkout.ready {
    display: block
}

#checkout.ready .checkout-wrapper {
    display: flex
}

#checkout.ready .modal-dialog {
    display: block
}

#checkout.prepare-pane-flip-hide-back-transitions, #checkout.prepare-pane-flip-hide-next-transitions, #checkout.prepare-pane-flip-show-back-transitions, #checkout.prepare-pane-flip-show-next-transitions, #checkout.ready.prepare-pane-flip-hide-back-transitions, #checkout.ready.prepare-pane-flip-hide-next-transitions, #checkout.ready.prepare-pane-flip-show-back-transitions, #checkout.ready.prepare-pane-flip-show-next-transitions {
    overflow: hidden
}

#checkout .flip-back, #checkout .flip-next, #checkout.ready .flip-back, #checkout.ready .flip-next {
    display: none
}

#checkout.ready .prepare-pane-flip-show-next-transitions {
    display: block;
    perspective: 100vh
}

#checkout.ready .prepare-pane-flip-show-next-transitions .modal-content {
    transform: rotateY(-90deg);
    opacity: 0
}

#checkout.ready .prepare-pane-flip-show-back-transitions {
    display: block;
    perspective: 100vh
}

#checkout.ready .prepare-pane-flip-show-back-transitions .modal-content {
    transform: rotateY(90deg);
    opacity: 0
}

#checkout.ready .enable-pane-flip-show-back-transitions, #checkout.ready .enable-pane-flip-show-next-transitions {
    display: block
}

#checkout.ready .enable-pane-flip-show-back-transitions .modal-content, #checkout.ready .enable-pane-flip-show-next-transitions .modal-content {
    transition: transform .25s, opacity .25s;
    transform: rotateY(0);
    opacity: 1
}

#checkout.ready .prepare-pane-flip-hide-back-transitions, #checkout.ready .prepare-pane-flip-hide-next-transitions {
    display: block;
    perspective: 100vh
}

#checkout.ready .prepare-pane-flip-hide-back-transitions .modal-content, #checkout.ready .prepare-pane-flip-hide-next-transitions .modal-content {
    transform: rotateY(0);
    opacity: 1
}

#checkout.ready .enable-pane-flip-hide-back-transitions {
    display: block
}

#checkout.ready .enable-pane-flip-hide-back-transitions .modal-content {
    transition: transform .25s, opacity .25s;
    transform: rotateY(-90deg);
    opacity: 0
}

#checkout.ready .enable-pane-flip-hide-next-transitions {
    display: block
}

#checkout.ready .enable-pane-flip-hide-next-transitions .modal-content {
    transition: transform .25s, opacity .25s;
    transform: rotateY(90deg);
    opacity: 0
}

.modal {
    position: absolute
}

#checkout {
    height: 100vh
}

#checkout .checkout-wrapper {
    display: flex
}

#checkout .modal-dialog {
    width: 500px;
    margin: auto
}

#checkout .modal-content {
    box-shadow: none;
    margin: 0 auto;
    background: 0 0;
    border: none;
    backface-visibility: hidden;
    -webkit-backface-visibility: hidden
}

#checkout .modal-header {
    background: linear-gradient(to bottom, #ecf0f1 0, #e3e6e7 100%);
    border-top-left-radius: 7px;
    border-top-right-radius: 7px;
    border: none;
    align-items: stretch
}

#checkout .modal-header h2 {
    margin: 0;
    font-size: 24px;
    line-height: 24px;
    text-shadow: 1px 1px #fff;
    display: flex;
    gap: 8px
}

@media (min-width: 576px) {
    #checkout .modal-header h2 {
        font-size: 36px;
        line-height: 36px
    }
}

#checkout .modal-header .close {
    overflow: hidden;
    color: #444;
    vertical-align: middle
}

#checkout .modal-header .close:focus {
    outline: 0;
    box-shadow: inset 0 0 0 .2rem rgba(0, 0, 0, .15);
    border-top-right-radius: 5px
}

#checkout .modal-header .close:active {
    background: rgba(0, 0, 0, .2)
}

#checkout .modal-body {
    background: #fff
}

@media (max-width: 767.98px) {
    #checkout .modal-body {
        padding: 1rem 2rem
    }
}

#checkout .modal-footer {
    background: #fff;
    box-shadow: inset 0 0 30px rgba(0, 0, 0, .1);
    display: flex;
    text-align: center;
    align-content: center;
    justify-content: center;
    border-bottom-right-radius: .3rem;
    border-bottom-left-radius: .3rem
}

@media (max-width: 767.98px) {
    #checkout .modal-footer {
        padding: 1rem 2rem
    }
}

#checkout .modal-footer .btn {
    margin: 0 10px;
    display: inline-flex;
    align-items: center;
    justify-content: center
}

#checkout .modal-footer .btn-back {
    order: 1;
    -webkit-order: 1;
    gap: 2px
}

#checkout .modal-footer .btn-next {
    order: 2;
    -webkit-order: 2;
    gap: 4px
}

#checkout h3 {
    font-size: 22px;
    line-height: 22px;
    margin: 0 0 10px 0
}

#checkout h4 {
    margin: 0 0 15px
}

#checkout p {
    margin-bottom: 15px
}

#checkout p:first-child {
    margin-top: 0
}

#checkout .sign-title {
    font-size: 19px
}

#checkout .ajax-link {
    text-decoration: none;
    border-bottom: dotted 1px;
    box-shadow: none
}

#checkout .ajax-link:hover {
    border-bottom: solid 1px
}

#checkout .ajax-link.active, #checkout .ajax-link.active:hover {
    color: #444;
    font-weight: 700;
    border: none
}

#checkout .btn-paypal {
    display: inline-block;
    height: 34px;
    margin: 0;
    padding: 2px 15px;
    background: #fad994;
    background-image: linear-gradient(to bottom, #fad994, #ffa028);
    border: 2px solid #ffa028;
    border-radius: 17px
}

#checkout .btn-paypal:active, #checkout .btn-paypal:focus {
    background: #f8c863;
    background-image: linear-gradient(to bottom, #f8c863, #f48800);
    border: 2px solid #f48800
}

#checkout .taxes-and-totals {
    margin: 0 auto 1rem auto;
    display: flex;
    justify-content: space-around
}

#checkout .taxes-and-totals-inner {
    padding: 0 1rem
}

#checkout .final-totals {
    font-size: 16px;
    line-height: 24px;
    border-spacing: 0
}

#checkout .final-totals td {
    box-sizing: content-box
}

#checkout .final-totals.no-tax .price-brief, #checkout .final-totals.no-tax .tax-brief {
    display: none
}

#checkout .price-brief, #checkout .tax-brief, #checkout .total-brief {
    text-align: right;
    padding: 5px 10px
}

#checkout .total-brief-title {
    padding: 10px 10px
}

#checkout .price-brief-title, #checkout .tax-brief-title {
    padding: 5px 10px
}

#checkout .total-brief-amount {
    padding: 10px
}

#checkout .price-brief-currency, #checkout .tax-brief-currency, #checkout .total-brief-currency {
    text-align: left
}

#checkout .total-brief-currency {
    padding: 10px 10px 10px 0
}

#checkout .price-brief-amount, #checkout .tax-brief-amount {
    padding: 5px 10px
}

#checkout .price-brief {
    font-size: 20px;
    line-height: 20px;
    font-weight: 700
}

#checkout .tax-brief {
    border-bottom: solid 1px #aaa
}

#checkout .total-brief {
    font-weight: 700;
    font-size: 30px;
    line-height: 30px
}

#checkout .total-brief .real-total {
    display: block;
    text-align: center;
    font-weight: 700;
    font-size: 1.5rem;
    line-height: 1.5rem;
    color: #999
}

#checkout .top-paysystems-message {
    font-size: .875rem
}

#checkout .hidden-paysystems-message {
    font-size: .875rem
}

#checkout .btn-next .real-total, #checkout .btn-next .visible-total {
    display: inline-block
}

#checkout .btn-next .real-total {
    margin-left: 5px
}

#checkout .form-control {
    padding: 10px 12px 6px 12px
}

#checkout .form-select {
    appearance: none;
    -webkit-appearance: none;
    background-image: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' fill='none' viewBox='0 0 20 20'%3e%3cpath stroke='%236b7280' stroke-linecap='round' stroke-linejoin='round' stroke-width='1.5' d='M6 8l4 4 4-4'/%3e%3c/svg%3e");
    background-position: right .5rem center;
    background-repeat: no-repeat;
    background-size: 1.5em 1.5em;
    padding-right: 2.5rem;
    -webkit-print-color-adjust: exact;
    print-color-adjust: exact
}

#checkout #step_login .form-control {
    padding: 8px 12px 8px 30px
}

#checkout .login-title {
    text-align: center
}

#checkout .login-terms {
    border-top: solid 1px #eee;
    padding: 20px 25px;
    margin: 0 -15px -15px;
    display: block;
    color: #666;
    font-size: .875rem
}

#checkout .login-terms a {
    color: #666;
    text-decoration: underline
}

:lang(en) > #checkout .login-terms {
    padding: 20px 70px
}

#checkout .login-box-social {
    border-left: solid 1px #eee
}

#checkout .billing-box .form-group {
    margin: 7.5px 0
}

#checkout .billing_type {
    display: flex;
    align-items: center
}

#checkout .form-check label {
    font-size: 16px;
    line-height: 1.5
}

#checkout .form-check-radio-panel {
    background: 0 0;
    padding: 1rem;
    border: solid 2px #ecf0f1;
    border-radius: 5px;
    margin-bottom: 1rem;
    text-align: left;
    display: block;
    width: 100%
}

#checkout .form-check-radio-panel * {
    cursor: pointer
}

#checkout .form-check-radio-panel p:last-child {
    margin-bottom: 0
}

#checkout .form-check-radio-panel:focus {
    outline: 0;
    border: solid 2px rgba(41, 128, 185, .5);
    box-shadow: 0 0 0 .2rem rgba(41, 128, 185, .25)
}

#checkout .form-check-radio-panel.checked {
    border: solid 2px #3498db
}

#checkout .name-caption {
    color: #6c757d !important;
    font-size: .875rem;
    line-height: 1.25rem;
    padding: 0 1rem;
    margin-top: -5px;
    text-align: justify
}

#checkout .form-group {
    position: relative
}

#checkout .form-group.is-valid .help-block {
    color: #bdc3c7
}

#checkout .form-group label {
    font-size: 14px;
    margin-left: 10px;
    position: absolute;
    z-index: 1;
    background: #fff;
    border-radius: 20px;
    padding: 0 5px;
    top: -5px;
    line-height: 16px;
    overflow: hidden
}

#checkout .form-group .field-check {
    position: absolute;
    top: -7px;
    right: 7px;
    background: #fff;
    border-radius: 10px;
    width: 16px;
    pointer-events: none;
    line-height: 15px;
    font-size: 12px;
    text-align: center;
    transform: scale(1) rotateX(0);
    transition: .2s transform
}

#checkout .form-group .field-check .field-check-success {
    width: 16px;
    height: 16px;
    color: #2ecc71
}

#checkout .form-group .field-check.hidden {
    transform: scale(0) rotateZ(360deg)
}

#checkout .messages {
    margin-bottom: 15px
}

#checkout .messages ul {
    padding-left: 15px
}

#checkout .messages ul li {
    margin: 0
}

#checkout .form-group-icon input {
    padding-left: 31px
}

#checkout .field-icon {
    position: absolute;
    top: 11px;
    left: 23px;
    width: 20px;
    text-align: center;
    cursor: text;
    z-index: 1;
    pointer-events: none
}

#checkout .card-type {
    position: absolute;
    cursor: text;
    opacity: 0;
    z-index: 1;
    transform: translateX(-100px) scale(.5);
    transition: transform .2s ease-out, opacity .2s ease-out
}

#checkout .card-type.identified {
    opacity: 1;
    transform: translateX(0) scale(.5)
}

#checkout .paddle-card-type {
    width: 64px;
    height: 40px
}

#checkout .card-type-bg {
    display: block;
    width: 64px;
    height: 40px;
    background: transparent url(../images/sg/store/cards.png@3) no-repeat;
    scale: .75
}

#checkout .card-type-bg.amex {
    background-position: 0 0
}

#checkout .card-type-bg.cartebleue {
    background-position: 0 -40px
}

#checkout .card-type-bg.dankort {
    background-position: 0 -80px
}

#checkout .card-type-bg.discover {
    background-position: 0 -120px
}

#checkout .card-type-bg.jcb {
    background-position: 0 -160px
}

#checkout .card-type-bg.maestro {
    background-position: 0 -200px
}

#checkout .card-type-bg.mastercard {
    background-position: 0 -240px
}

#checkout .card-type-bg.visa {
    background-position: 0 -320px
}

#checkout .card-type-bg.visaelectron {
    background-position: 0 -360px
}

#checkout .card-type-bg.elo {
    background-position: 0 -400px
}

#checkout .card-type-bg.hipercard {
    background-position: 0 -440px
}

#checkout .card-type-bg.rupay {
    background-position: 0 -480px
}

#checkout .card-type-bg.diners {
    background-position: 0 -520px
}

#checkout .form-group .card-type {
    right: 1.5rem;
    top: -4.15rem
}

@media (min-width: 576px) {
    #checkout .form-group .card-type {
        left: -72px;
        top: 2px
    }
}

#checkout .btn-payment-method#tco_card {
    grid-column-start: span 6
}

#checkout .btn-payment-method#paddle_inline {
    grid-column-start: span 6
}

#checkout .btn-payment-method .card-list {
    perspective: 200px;
    transform-origin: center center;
    display: inline-block;
    margin: 0 -10px
}

#checkout .btn-payment-method .card-list .card-type {
    display: inline-block !important;
    opacity: 1 !important;
    position: relative;
    left: auto;
    top: auto;
    transform: translateX(0) translateY(10px) scale(.65);
    margin: -10px -10px -4px;
    cursor: pointer;
    z-index: 2
}

@media (min-width: 544px) {
    #checkout .btn-payment-method .card-list .card-type {
        margin: -10px 0 -4px
    }
}

#checkout .btn-payment-method .paddle-list {
    display: flex;
    flex-wrap: wrap;
    gap: .25rem;
    align-items: center;
    justify-content: center
}

#checkout .billing-help {
    float: right;
    margin-top: 5px;
    font-size: 20px
}

#checkout .billing-help:hover {
    color: #3498db
}

#checkout .checkout-wrapper {
    min-height: 100vh;
    margin: 0 auto;
    position: relative;
    display: flex;
    flex-direction: row;
    justify-content: center;
    align-items: center;
    padding: 16px
}

@media (max-width: 575.98px) {
    #checkout .checkout-wrapper {
        vertical-align: middle;
        width: 100vw;
        min-height: auto;
        padding: 0
    }
}

@media (min-width: 1280px) {
    #checkout .checkout-wrapper.with-cart {
        padding-right: 330px
    }
}

#checkout .cart-disabled {
    pointer-events: none;
    opacity: .5;
    filter: blur(3px)
}

#checkout .cart-upsell-hidden {
    opacity: 0
}

#checkout .cart-upsell {
    text-align: center;
    display: none;
    transition: opacity .5s ease-out;
    width: 300px;
    margin-right: 30px
}

@media (min-width: 830px) {
    #checkout .cart-upsell {
        display: flex;
        flex-direction: column;
        justify-content: center
    }
}

#checkout .cart-upsell .cart, #checkout .cart-upsell .upsell {
    margin: 0 auto 20px;
    width: 300px
}

#checkout .cart-upsell .cart {
    position: relative;
    padding: 0 0 20px 0
}

#checkout .cart-upsell .cart:after, #checkout .cart-upsell .cart:before {
    content: " ";
    position: absolute;
    top: 25px;
    width: 10px;
    bottom: 0;
    border: #fff 1px dashed
}

#checkout .cart-upsell .cart:before {
    left: 0;
    border-right: none;
    border-top-left-radius: 10px;
    border-bottom-left-radius: 10px
}

#checkout .cart-upsell .cart:after {
    right: 0;
    border-left: none;
    border-top-right-radius: 10px;
    border-bottom-right-radius: 10px
}

#checkout .cart-upsell .cart-empty, #checkout .cart-upsell .cart-progress {
    color: #fff
}

#checkout .cart-upsell .bulk-info {
    padding: 0 26px 0 50px;
    color: #eee;
    font-size: 14px
}

#checkout .cart-upsell .cart-progress {
    position: absolute;
    left: 0;
    right: 0;
    text-align: center
}

#checkout .cart-upsell h2 {
    color: #fff;
    font-size: 36px;
    line-height: 50px;
    margin: 0 0 20px
}

#checkout .cart-upsell h3 {
    color: #fff;
    font-size: 22px
}

#checkout .cart-upsell .cart-total {
    font-size: 15px;
    line-height: 1;
    font-weight: 400;
    text-align: center;
    display: inline-block;
    vertical-align: middle
}

#checkout .cart-upsell .cart-total .cart-total-title {
    display: block
}

#checkout .cart-upsell .cart-total .cart-total-value {
    font-size: 18px;
    font-weight: 700
}

#checkout .cart-upsell .cart-item {
    position: relative;
    margin: 10px 25px 10px 50px;
    transition: transform .5s
}

#checkout .cart-upsell .cart-item.adding {
    transform: translateY(-70px)
}

#checkout .cart-upsell .cart-item.removing {
    transform: translateY(70px)
}

#checkout .cart-upsell .cart-item-info {
    position: relative;
    background: #fff;
    border-top-left-radius: 5px;
    border-top-right-radius: 5px;
    width: 225px;
    padding: 5px 5px 35px;
    min-height: 90px;
    text-align: left
}

#checkout .cart-upsell .cart-item-info-limit-quantity {
    border-radius: 5px
}

#checkout .cart-upsell .upsell .cart-item-info {
    border-radius: 5px
}

#checkout .cart-upsell .cart-quantity-controls {
    background: #555;
    border-bottom-left-radius: 15px;
    border-bottom-right-radius: 15px;
    width: 225px;
    padding: 10px 10px 10px
}

#checkout .cart-upsell .cart-item-image {
    position: absolute;
    top: 5px;
    left: 5px;
    bottom: 5px;
    width: 75px;
    margin-right: 10px;
    display: flex;
    justify-content: center;
    align-items: center;
    overflow: hidden
}

#checkout .cart-upsell .cart-item-image img {
    max-width: 75px;
    max-height: 95px
}

#checkout .cart-upsell .cart-item-title {
    font-size: 14px;
    line-height: 18px;
    font-weight: 700;
    margin: 5px 0 10px 85px
}

#checkout .cart-upsell .cart-item-title a {
    display: inline-block
}

#checkout .cart-upsell .cart-item-price {
    position: absolute;
    left: 90px;
    bottom: 5px;
    font-weight: 700
}

#checkout .cart-upsell .cart-item-discount {
    position: absolute;
    right: 0;
    bottom: 7px;
    background: #d12345;
    color: #fff;
    padding: 0 3px
}

#checkout .cart-upsell .cart-item-old_price {
    position: absolute;
    left: 90px;
    bottom: 22px;
    color: #d12345;
    text-decoration: line-through;
    transform: rotate(-11deg);
    font-size: 12px
}

#checkout .cart-upsell .cart-item-quantity {
    display: none
}

#checkout .cart-upsell .cart-item-action {
    position: absolute;
    left: -40px;
    top: 40px;
    margin-top: -14px;
    padding: 6px 6px 6px;
    transition: transform .5s ease-out, opacity .5s ease-out;
    opacity: 1;
    transform: translateX(0);
    font-size: 1.2rem;
    line-height: 1.5rem
}

#checkout .cart-upsell .cart-item-action.fadeOut {
    opacity: 0;
    transform: translateX(50px)
}

#checkout .cart-upsell .cart-item-action svg {
    display: inline-block
}

#checkout .cart-upsell .cart-item-action-remove {
    width: 2rem;
    height: 2rem;
    line-height: 0;
    padding: 0
}

#checkout .cart-upsell .cart-item-action-add-text {
    vertical-align: middle
}

#checkout .cart-upsell .quantity-input {
    width: 90px;
    padding: 4px 4px 4px 12px;
    margin: 0 6px;
    font-size: 24px;
    height: 40px
}

#checkout .cart-upsell .cart-quantity-action {
    font-size: 48px;
    line-height: 2px;
    padding: 5px;
    width: 50px
}

#checkout .cart-upsell .cart-quantity-action:after {
    left: -1px;
    right: -1px;
    bottom: -2px;
    box-shadow: inset 0 -4px 0 rgba(0, 0, 0, .15) !important
}

#checkout.progress .checkout-wrapper {
    filter: blur(2px) grayscale(1);
    opacity: .8
}

.modal-seals {
    position: absolute;
    margin-top: -40px;
    top: 0;
    width: 100%;
    text-align: center
}

.modal-seals #siteseal {
    border-radius: 3px;
    overflow: hidden;
    display: inline-block
}

.modal-seals #siteseal, .modal-seals #siteseal img {
    width: 122px
}

.modal-content.shake {
    animation: shakeAnimation linear .5s 2 forwards
}

.cart.shake {
    animation: shakeAnimation linear .5s 2 forwards
}

@keyframes shakeAnimation {
    0% {
        transform: translateX(0)
    }
    12.5% {
        transform: translateX(-6px) rotateY(-5deg)
    }
    37.5% {
        transform: translateX(5px) rotateY(4deg)
    }
    62.5% {
        transform: translateX(-3px) rotateY(-2deg)
    }
    87.5% {
        transform: translateX(2px) rotateY(1deg)
    }
    100% {
        transform: translateX(0)
    }
}

.cart-block-container {
    position: relative;
    display: block;
    padding: 1rem 2rem
}

@media (min-width: 992px) {
    .cart-block-container {
        position: absolute;
        left: 15.625rem;
        margin-top: -4rem;
        padding: 10px 0 10px 4rem;
        z-index: 5
    }
}

.cart-block-container .btn.cart {
    display: block;
    float: none;
    transition: none;
    margin-right: 46px
}

@media (min-width: 576px) {
    .cart-block-container .btn.cart {
        margin-right: 120px
    }
}

@media (min-width: 1007px) and (max-width: 1380px) {
    .cart-block-container .btn.cart {
        margin-right: 46px
    }
}

@media (min-width: 1340px) {
    .cart-block-container .btn.cart {
        margin-right: 120px
    }
}

.cart-block-container .btn.checkout {
    position: absolute;
    right: 0;
    top: 0;
    z-index: 2;
    width: 46px
}

@media (min-width: 576px) {
    .cart-block-container .btn.checkout {
        width: 120px
    }
}

@media (min-width: 1007px) and (max-width: 1380px) {
    .cart-block-container .btn.checkout {
        width: 46px
    }
}

@media (min-width: 1340px) {
    .cart-block-container .btn.checkout {
        width: 120px
    }
}

.cart-block-container .cart-block {
    display: block
}

@media (min-width: 992px) {
    .cart-block-container .cart-block {
        display: inline-block
    }
}

.cart-block-container .cart-block a span {
    display: inline-block;
    vertical-align: top
}

.cart-block-container .cart-block .btn {
    transition: background .25s, color .25s, border-color .25s
}

.cart-block-container .cart-block .btn.cart {
    background: #fff;
    padding-top: 8px;
    padding-bottom: 8px;
    height: 42px;
    border: solid 2px rgba(0, 0, 0, .125);
    border-right: none;
    border-bottom-right-radius: 0;
    border-top-right-radius: 0;
    color: #777;
    box-shadow: none
}

.cart-block-container .cart-block .btn.cart span {
    max-width: calc(100% - 80px);
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap
}

@media (min-width: 1007px) and (max-width: 1380px) {
    .cart-block-container .cart-block .btn.cart span {
        max-width: 180px
    }
}

@media (min-width: 1340px) {
    .cart-block-container .cart-block .btn.cart span {
        max-width: 100%
    }
}

.cart-block-container .cart-block .btn.checkout {
    padding-top: 8px;
    padding-bottom: 8px
}

.cart-block-container .cart-block:hover .btn.cart {
    color: #d12345 !important;
    border: solid 2px #d12345;
    border-right: none;
    box-shadow: none
}

.cart-block-container .cart-block:hover .btn.checkout {
    background-color: #d12345
}

.cart-block-container .cart-block:active .btn.cart {
    box-shadow: none
}

.cart-block-container .cart-block:active .btn.checkout {
    background-color: #d12345
}

.billing-info-help {
    font-size: 12px;
    line-height: 1.5
}

.twoco-seal {
    text-align: center
}

.twoco-seal .twoco-seal-img {
    display: inline-block;
    padding: 5px 10px 7px;
    text-align: center;
    background: rgba(255, 255, 255, .8);
    border-radius: 25px;
    margin: 10px 0 0;
    transition: all .25s
}

.hidden-payment-methods, .paysystems-payment-methods, .visible-payment-methods {
    display: flex;
    gap: 1rem;
    flex-direction: column
}

.hidden-payment-methods, .visible-payment-methods {
    gap: .625rem
}

.hidden-payment-methods {
    margin: 0 -1rem -1rem -1rem;
    padding: 1rem 1rem 2rem 1rem;
    background: #fff linear-gradient(180deg, #eee 0, #fff 20%, #fff 80%, #eee 100%)
}

@media (max-width: 767.98px) {
    .hidden-payment-methods {
        margin: 0 -2rem -1rem -2rem
    }
}

.payment-methods-grid {
    display: grid;
    grid-template-columns:repeat(6, 1fr);
    grid-gap: .625rem
}

.paysystems-show-hidden-payment-methods {
    margin-top: 5px !important;
    padding: 3px 13px !important;
    display: block
}

#checkout .btn-payment-method {
    min-height: 91px;
    border-width: 2px;
    color: #444;
    transition: background;
    background-color: #fff;
    position: relative;
    grid-column-start: span 3
}

@media (max-width: 374px) {
    #checkout .btn-payment-method:last-child:nth-child(2n-1) {
        grid-column-start: 2;
        grid-column-end: 6
    }

    #checkout .btn-payment-method:last-child:nth-child(2n-1)#cryptomus_cryptomus img {
        margin: 0 -17px 0 0
    }

    #checkout .btn-payment-method:last-child:nth-child(2n-1)#cryptomus_cryptomus img:first-child {
        margin: 0 -17px 0 -16px
    }
}

@media (min-width: 375px) {
    #checkout .btn-payment-method {
        grid-column-start: span 2
    }

    #checkout .btn-payment-method:nth-last-child(2):nth-child(3n+1) {
        grid-column-start: 1;
        grid-column-end: 4
    }

    #checkout .btn-payment-method:last-child:nth-child(3n-1) {
        grid-column-start: 4;
        grid-column-end: 7
    }

    #checkout .btn-payment-method:last-child:nth-child(3n-2) {
        grid-column-start: 2;
        grid-column-end: 6
    }
}

#checkout .btn-payment-method:after {
    content: " ";
    position: absolute;
    left: -2px;
    right: -2px;
    top: -2px;
    bottom: -2px;
    border-radius: .25rem;
    box-shadow: inset 0 0 0 #3498db !important
}

#checkout .btn-payment-method:hover {
    color: #444 !important
}

#checkout .btn-payment-method:hover:after {
    box-shadow: inset 0 0 10px #3498db !important
}

#checkout .btn-payment-method.active:after, #checkout .btn-payment-method:active:after {
    box-shadow: inset 0 0 50px #3498db !important
}

#checkout .btn-payment-method.btn-progress {
    background-color: #3498db;
    color: #fff !important
}

#checkout .btn-payment-method.btn-progress svg {
    filter: drop-shadow(0 0 5px #fff)
}

#checkout .btn-payment-method img, #checkout .btn-payment-method svg {
    display: inline-block
}

#checkout .btn-payment-method .fa {
    color: #3498db;
    height: 40px
}

#checkout .btn-payment-method .fa-btc {
    color: #ff8c00
}

#checkout .btn-payment-method .fa-money-bill {
    color: #5b9b21
}

#checkout .btn-payment-method#cryptomus_cryptomus img {
    width: 34px;
    height: 34px;
    transform: rotateY(-20deg);
    position: relative;
    margin: -10px -10px -12px 0
}

#checkout .btn-payment-method#cryptomus_cryptomus img:first-child {
    margin: -10px -10px -12px -6px
}

@media (min-width: 495px) {
    #checkout .btn-payment-method#cryptomus_cryptomus img {
        margin: 0 0 0 -21px
    }
}

#checkout .btn-progress, #checkout .btn-progress.active, #checkout .btn-progress:active, #checkout .btn-progress:hover {
    background-image: linear-gradient(-45deg, rgba(255, 255, 255, .2) 25%, transparent 25%, transparent 50%, rgba(255, 255, 255, .2) 50%, rgba(255, 255, 255, .2) 75%, transparent 75%, transparent);
    background-image: -webkit-gradient(linear, 0 0, 100% 100%, color-stop(.25, rgba(255, 255, 255, .2)), color-stop(.25, transparent), color-stop(.5, transparent), color-stop(.5, rgba(255, 255, 255, .2)), color-stop(.75, rgba(255, 255, 255, .2)), color-stop(.75, transparent), to(transparent));
    background-image: -moz-linear-gradient(-45deg, rgba(255, 255, 255, .2) 25%, transparent 25%, transparent 50%, rgba(255, 255, 255, .2) 50%, rgba(255, 255, 255, .2) 75%, transparent 75%, transparent);
    -webkit-background-size: 50px 50px;
    -moz-background-size: 50px 50px;
    background-size: 50px 50px;
    -webkit-animation: buttonProgress 2s linear infinite;
    -moz-animation: buttonProgress 2s linear infinite;
    animation: buttonProgress 2s linear infinite
}

@keyframes buttonProgress {
    0% {
        background-position: 0 0
    }
    100% {
        background-position: 50px 50px
    }
}

.ellipsis-loading:after {
    overflow: hidden;
    display: inline-block;
    vertical-align: bottom;
    -webkit-animation: ellipsis steps(4, end) .5s infinite;
    animation: ellipsis-loading steps(4, end) .5s infinite;
    content: "\2026";
    width: 0
}

@keyframes ellipsis-loading {
    to {
        width: 1.25em
    }
}

@-webkit-keyframes ellipsis-loading {
    to {
        width: 1.25em
    }
}

#tco_alipay, #tco_wechat {
    z-index: 2
}

.btn-payment-method img, .btn-payment-method svg {
    width: 40px;
    height: 40px
}

#tco_alipay svg {
    width: 100px
}

#fondy_mir svg, #ik_card svg, #tco_card svg, #wfp_applepay svg, #wfp_card svg, #wfp_googlepay svg {
    width: 52px
}

#tco_paypal svg {
    width: 110px
}

#fondy_googlepay img, #fondy_googlepay_direct img {
    width: 54px
}

#wfp_googlepay img {
    width: 54px
}

#checkout .tco-reseller-methods {
    text-align: center;
    position: relative
}

#checkout .tco-reseller-methods .btn-payment-method {
    z-index: 2;
    position: relative
}

.tco-reseller-info {
    text-align: center;
    padding: 10px;
    font-size: .9rem
}

.tco-reseller-methods-blue-border {
    border: solid 1px #3498db;
    border-radius: 10px;
    z-index: 1;
    position: absolute;
    top: 50px;
    left: 0;
    right: 0;
    bottom: 0
}

.tooltip {
    width: 175px;
    font-size: 12px
}

.cart-buttons-mobile {
    display: none
}

.card-box {
    padding-top: 12px
}

.paddle_iframe_target {
    min-height: 500px;
    position: relative
}

.paddle_iframe_target_placeholder {
    position: absolute;
    inset: 0;
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
    text-align: center;
    font-size: .875rem;
    gap: 2rem;
    color: #777
}

.paddle_iframe_target_placeholder a {
    color: #444;
    font-weight: 700
}

.paddle_iframe_target_loading_problem {
    width: 80%
}

.paddle_iframe_target_spinner {
    color: #ccc;
    width: 50px;
    height: 50px;
    animation-name: paddle_iframe_spin;
    animation-duration: 1s;
    animation-iteration-count: infinite;
    animation-timing-function: linear
}

@keyframes paddle_iframe_spin {
    from {
        transform: rotate(0)
    }
    to {
        transform: rotate(360deg)
    }
}

@media (max-width: 575.98px) {
    #checkout {
        overflow: hidden !important;
        height: auto !important
    }

    #checkout .modal-dialog {
        margin: 0;
        width: 100vw
    }

    #checkout .checkout-wrapper {
        overflow: hidden
    }

    #checkout .cart-upsell {
        display: block;
        margin: 0;
        background: #444;
        min-height: 100vh;
        position: absolute;
        top: 0;
        width: 90%;
        left: 0;
        bottom: 0
    }

    #checkout .cart-upsell .cart {
        margin-top: 20px
    }

    #checkout .cart-buttons-mobile {
        display: block;
        position: absolute;
        top: 0;
        left: 0;
        right: 0;
        bottom: 0;
        pointer-events: none;
        overflow: hidden
    }

    #checkout .cart-button-show {
        position: absolute;
        top: 0;
        z-index: 2;
        padding: 17px 18px 6px;
        font-size: 26px;
        left: -10px;
        border-radius: 50px;
        border-top-left-radius: 0;
        border-bottom-left-radius: 0;
        transition: transform .25s;
        transform: translateX(0);
        pointer-events: all
    }

    #checkout .cart-button-show:after {
        border-radius: 50px;
        border-top-left-radius: 0;
        border-bottom-left-radius: 0
    }

    #checkout .cart-button-show.shake {
        transform: translateX(0) scale(1.5)
    }

    #checkout .cart-button-hide {
        position: absolute;
        top: 0;
        z-index: 2;
        padding: 10px 18px 14px 18px;
        font-size: 31px;
        right: -5px;
        border-radius: 50px;
        border-top-right-radius: 0;
        border-bottom-right-radius: 0;
        transition: transform .25s;
        transform: translateX(150px);
        pointer-events: all
    }

    #checkout .cart-button-hide:after {
        border-radius: 50px;
        border-top-right-radius: 0;
        border-bottom-right-radius: 0
    }

    #checkout .cart-count-indicator {
        position: absolute;
        top: 14px;
        z-index: 2;
        padding: 5px 5px 3px;
        left: 14px;
        border-radius: 50%;
        transition: transform .25s;
        transform: translateX(0);
        font-weight: 700;
        background: #256fa0;
        color: #fff;
        line-height: 10px;
        border-bottom-left-radius: 4px;
        border-bottom-right-radius: 4px;
        border-bottom: solid 1px #fff
    }

    #checkout .cart-count-indicator.danger {
        background: #e7230e
    }

    #checkout .modals {
        width: 100%;
        display: block;
        min-height: 100vh;
        background: #fff;
        position: relative;
        transition: transform .25s;
        transform: translateX(0)
    }

    #checkout .modal-header h2 {
        margin-left: 45px
    }

    #checkout #step_paddle .modal-header h2 {
        margin-left: 0
    }

    #checkout.cart-open .modals {
        transform: translateX(90%)
    }

    #checkout.cart-open .cart-button-show {
        transform: translateX(-150px)
    }

    #checkout.cart-open .cart-button-hide {
        transform: translateX(0)
    }

    #checkout.cart-open .cart-count-indicator {
        transform: translateX(-150px)
    }

    #checkout .modal-header {
        background: linear-gradient(to bottom, #ecf0f1 0, #e3e6e7 100%);
        border-top-left-radius: 0;
        border-top-right-radius: 0
    }

    #checkout .modal-footer {
        border-bottom-right-radius: 0;
        border-bottom-left-radius: 0;
        background: #eee;
        background: linear-gradient(180deg, #eee 0, #fff 100%);
        box-shadow: none
    }

    #checkout .twoco-seal {
        box-shadow: inset 0 0 30px rgba(0, 0, 0, .1);
        padding: 0 0 5px 0
    }

    #checkout .twoco-seal {
        padding: 0
    }

    #checkout .btn-back, #checkout .btn-next {
        font-size: 24px
    }

    #checkout .login .btn-next {
        font-size: 34px;
        margin-top: 2rem
    }

    #checkout .login .form-group-register .btn-next {
        margin-top: 0
    }

    #checkout .login .forgot {
        margin-top: -100px;
        font-size: 1.25rem
    }

    #checkout .modal-footer {
        flex-direction: column-reverse;
        gap: 5px
    }
}

@media (max-width: 575.98px) and (min-width: 400px) {
    #checkout .modal-footer {
        flex-direction: row;
        gap: 10px
    }
}

@media (max-width: 575.98px) {
    #checkout .modal-footer .btn-back {
        flex-grow: 2;
        margin-top: 5px;
        width: 100%
    }
}

@media (max-width: 575.98px) and (min-width: 400px) {
    #checkout .modal-footer .btn-back {
        flex-grow: 1;
        margin-top: 0;
        width: auto
    }
}

@media (max-width: 575.98px) {
    #checkout .modal-footer .btn-next {
        flex-grow: 2;
        width: 100%
    }
}

@media (max-width: 575.98px) and (min-width: 400px) {
    #checkout .modal-footer .btn-next {
        width: auto
    }
}

@media (max-width: 575.98px) {
    #checkout .form-control {
        padding: 15px 12px 11px 12px;
        height: 62px;
        font-size: 22px
    }

    #checkout .form-group .field-check {
        top: -10px;
        right: 8px;
        width: 24px;
        line-height: 24px;
        font-size: 24px
    }

    #checkout .field-icon {
        top: 20px
    }

    #checkout .login .email svg {
        margin-top: 24px
    }

    #checkout .login .password svg {
        margin-top: 22px
    }

    #checkout .sign-in-title {
        margin-bottom: 16px
    }

    #checkout .login-terms {
        border-top: solid 1px #eee;
        padding: 1rem;
        margin: 0 -2rem -1rem;
        display: block;
        font-size: 12px
    }

    #checkout .login-box-social {
        border-left: none
    }

    #tco_alipay svg {
        width: 80px
    }

    #tco_paypal svg {
        width: 80px
    }

    #fondy_card .caption svg, #ik_card svg, #tco_card svg, #wfp_card svg {
        width: 38px
    }
}

:lang(pl) .sign-in-title {
    margin: 0 0 20px
}

:lang(pl) .login-title {
    text-align: center;
    font-size: 16px;
    line-height: 16px
}

:lang(pl) #fondy_card .caption, :lang(pl) #wfp_card .caption {
    font-size: 13px;
    letter-spacing: -.75px;
    display: inline-block;
    margin: 0 -20px
}

@media (max-width: 575.98px) {
    :lang(pl) #fondy_card .caption, :lang(pl) #wfp_card .caption {
        margin: 0 -20px
    }
}

:lang(pt-br) #checkout .login-title {
    font-size: 20px
}

:lang(pt-br) #fondy_card .caption, :lang(pt-br) #wfp_card .caption {
    font-size: 14px;
    letter-spacing: -.75px;
    display: inline-block;
    margin: 0 -20px
}

@media (max-width: 575.98px) {
    :lang(pt-br) #fondy_card .caption, :lang(pt-br) #wfp_card .caption {
        margin: 0 -20px
    }
}

.locale-es #checkout .login-title {
    font-size: 16px;
    margin: 0 -10px 10px
}

@media (min-width: 576px) {
    .locale-es .cart-block-container .btn.cart {
        margin-right: 160px
    }
}

@media (min-width: 992px) {
    .locale-es .cart-block-container .btn.cart {
        margin-right: 60px
    }
}

@media (min-width: 1340px) {
    .locale-es .cart-block-container .btn.cart {
        margin-right: 160px
    }
}

@media (min-width: 576px) {
    .locale-es .cart-block-container .btn.checkout {
        width: 160px
    }
}

@media (min-width: 992px) {
    .locale-es .cart-block-container .btn.checkout {
        width: 60px
    }
}

@media (min-width: 1340px) {
    .locale-es .cart-block-container .btn.checkout {
        width: 160px
    }
}

@media (min-width: 576px) {
    .locale-es .login .submit {
        margin: 0;
        font-size: 20px;
        padding: 5px 0
    }

    .locale-es .login .forgot {
        margin: 0;
        line-height: 1.25rem
    }
}

.locale-es #fondy_card .caption, .locale-es #wfp_card .caption {
    font-size: 14px;
    letter-spacing: -.75px;
    display: inline-block;
    margin: 0 -20px
}

@media (max-width: 575.98px) {
    .locale-es #fondy_card .caption, .locale-es #wfp_card .caption {
        margin: 0 -20px
    }
}

.locale-es .card_expiry label {
    letter-spacing: -1px
}

.locale-pl #checkout .login-title {
    font-size: 16px;
    letter-spacing: -1px;
    margin: 0 -10px 10px
}

@media (min-width: 576px) {
    .locale-fr .cart-block-container .btn.cart {
        margin-right: 200px
    }
}

@media (min-width: 992px) {
    .locale-fr .cart-block-container .btn.cart {
        margin-right: 60px
    }
}

@media (min-width: 1340px) {
    .locale-fr .cart-block-container .btn.cart {
        margin-right: 200px
    }
}

@media (min-width: 576px) {
    .locale-fr .cart-block-container .btn.checkout {
        width: 200px
    }
}

@media (min-width: 992px) {
    .locale-fr .cart-block-container .btn.checkout {
        width: 60px
    }
}

@media (min-width: 1340px) {
    .locale-fr .cart-block-container .btn.checkout {
        width: 200px
    }
}

@media (min-width: 544px) {
    .locale-fr .login .forgot {
        margin: 0;
        line-height: 1.25rem
    }
}

.locale-fr #checkout .login-title {
    font-size: 16px;
    margin: 0 -10px 10px
}

.locale-fr #fondy_card .caption, .locale-fr #wfp_card .caption {
    font-size: 15px;
    letter-spacing: -.25px;
    display: inline-block;
    margin: 0 -20px
}

@media (min-width: 576px) {
    .locale-ja .cart-block-container .btn.cart {
        margin-right: 160px
    }
}

@media (min-width: 992px) {
    .locale-ja .cart-block-container .btn.cart {
        margin-right: 60px
    }
}

@media (min-width: 1340px) {
    .locale-ja .cart-block-container .btn.cart {
        margin-right: 160px
    }
}

@media (min-width: 576px) {
    .locale-ja .cart-block-container .btn.checkout {
        width: 160px
    }
}

@media (min-width: 992px) {
    .locale-ja .cart-block-container .btn.checkout {
        width: 60px
    }
}

@media (min-width: 1340px) {
    .locale-ja .cart-block-container .btn.checkout {
        width: 160px
    }
}

.spin-animation {
    animation-name: checkout-spin;
    animation-duration: 1s;
    animation-iteration-count: infinite;
    animation-timing-function: linear
}

@keyframes checkout-spin {
    from {
        transform: rotate(0)
    }
    to {
        transform: rotate(360deg)
    }
}

.modal-backdrop-checkout, .modal-backdrop-progress {
    animation: none !important
}

.modal-backdrop-checkout:after, .modal-backdrop-progress:after {
    transform-origin: 50% 50%;
    -webkit-animation: rotate 1s linear infinite;
    animation: rotate 1s linear infinite
}

.modal-backdrop {
    position: absolute
}

.modal-backdrop-checkout, .modal-backdrop-progress {
    animation: none !important
}

.modal-backdrop-checkout:after, .modal-backdrop-progress:after {
    font-family: Helvetica Neue, Helvetica, Arial, sans-serif;
    content: "*";
    color: #3498db;
    font-size: 150px;
    line-height: 150px;
    position: fixed;
    left: 50%;
    top: 50%;
    margin-left: -35px;
    margin-top: -50px;
    width: 70px;
    height: 100px;
    overflow: hidden;
    padding-top: 5px;
    text-align: center;
    z-index: 100
}

.modal-backdrop-progress {
    background: 0 0;
    z-index: 2000
}

.modal-backdrop-progress .text-wrapper {
    position: fixed;
    top: calc(50% - 3px);
    left: 0;
    right: 0;
    text-align: center;
    z-index: 101
}

.modal-backdrop-progress .text {
    display: inline-block;
    font-weight: 700;
    background-color: #3498db;
    padding: 2px 5px;
    color: #fff
}

@keyframes rotate {
    from {
        transform: scale(1) rotate(0)
    }
    to {
        transform: scale(1) rotate(360deg)
    }
}

.modal-open .body-holder.hiding {
    height: 100vh;
    overflow: hidden
}

@media (max-width: 575.98px) {
    .modal-backdrop {
        display: none
    }

    .modal-backdrop-progress {
        display: block
    }

    .modal-open {
        overflow: auto
    }
}

/*body.announcement .body-holder {
    margin-top: 2.25rem
}*/

body.announcement .navigation {
    top: 2.25rem
}

body.announcement .main-menu {
/*    top: 2.25rem*/
}

.announcement-block-christmas {
    display: block;
    position: fixed;
    order: -10;
    left: 0;
    right: 0;
    top: 0;
    height: 2.25rem;
    text-align: center;
    color: #fff;
    z-index: 6;
    overflow: hidden;
    background: linear-gradient(90deg, #1b2735 0, #090a0f 100%)
}

.announcement-block-christmas a {
    position: absolute;
    left: 0;
    right: 0;
    top: 0;
    bottom: 0;
    color: #fff;
    font-size: 1.6rem;
    font-weight: 700
}

.announcement-block-christmas a:hover {
    text-decoration: none;
    background: rgba(255, 255, 255, .1)
}

.announcement-block-christmas span {
    display: block;
    width: 20rem;
    height: 20rem;
    position: absolute;
    pointer-events: none;
    animation: shine 3s ease-in-out infinite;
    opacity: 0
}

@keyframes shine {
    0% {
        opacity: 0
    }
    50% {
        opacity: 1
    }
    100% {
        opacity: 0
    }
}

@media (prefers-reduced-motion) {
    .announcement-block-christmas span {
        animation: none
    }
}

.announcement-block-christmas span.a1 {
    left: 0;
    top: -3rem;
    background: radial-gradient(circle 10rem at center, red 0, transparent 100%);
    animation-delay: 0s
}

@media (prefers-reduced-motion) {
    .announcement-block-christmas span.a1 {
        opacity: 1
    }
}

.announcement-block-christmas span.a2 {
    right: 0;
    top: -3rem;
    background: radial-gradient(circle 10rem at center, violet 0, transparent 100%);
    animation-delay: 1s
}

@media (prefers-reduced-motion) {
    .announcement-block-christmas span.a2 {
        opacity: 1
    }
}

.announcement-block-christmas span.a3 {
    left: calc(30% - 10rem);
    top: -17rem;
    background: radial-gradient(circle 10rem at center, green 0, transparent 100%);
    animation-delay: 2s
}

@media (prefers-reduced-motion) {
    .announcement-block-christmas span.a3 {
        opacity: 1
    }
}

.announcement-block-christmas span.a4 {
    right: calc(30% - 10rem);
    top: -17rem;
    background: radial-gradient(circle 10rem at center, #fc0 0, transparent 100%);
    animation-delay: 3s
}

@media (prefers-reduced-motion) {
    .announcement-block-christmas span.a4 {
        animation: none;
        opacity: 1
    }
}

.announcement-block-christmas span.a5 {
    left: calc(50% - 10rem);
    top: -3rem;
    background: radial-gradient(circle 10rem at center, #0ff 0, transparent 100%);
    animation-delay: 4s
}

.announcement-block-christmas .snowflakes > div {
    position: absolute;
    width: 10px;
    height: 10px;
    top: 0;
    background: #fff;
    border-radius: 50%;
    pointer-events: none
}

.announcement-block-christmas .snowflakes > div:nth-child(1) {
    opacity: .7571;
    transform: translate(11.2599vw, -10px) scale(.9636);
    animation: fall-1 5s -9s linear infinite
}

@media (prefers-reduced-motion) {
    .announcement-block-christmas .snowflakes > div:nth-child(1) {
        animation: none;
        transform: translate(11.4192vw, 3vh) scale(.9636)
    }
}

@keyframes fall-1 {
    75.342% {
        transform: translate(11.4192vw, 1.695195rem) scale(.9636)
    }
    to {
        transform: translate(11.33955vw, 2.25rem) scale(.9636)
    }
}

.announcement-block-christmas .snowflakes > div:nth-child(2) {
    opacity: .0135;
    transform: translate(27.4575vw, -10px) scale(.8759);
    animation: fall-2 2.5s -22s linear infinite
}

@media (prefers-reduced-motion) {
    .announcement-block-christmas .snowflakes > div:nth-child(2) {
        animation: none;
        transform: translate(26.6355vw, 7vh) scale(.8759)
    }
}

@keyframes fall-2 {
    32.718% {
        transform: translate(26.6355vw, .736155rem) scale(.8759)
    }
    to {
        transform: translate(27.0465vw, 2.25rem) scale(.8759)
    }
}

.announcement-block-christmas .snowflakes > div:nth-child(3) {
    opacity: .2539;
    transform: translate(66.9263vw, -10px) scale(.0763);
    animation: fall-3 6.75s -20s linear infinite
}

@media (prefers-reduced-motion) {
    .announcement-block-christmas .snowflakes > div:nth-child(3) {
        animation: none;
        transform: translate(67.0686vw, 8vh) scale(.0763)
    }
}

@keyframes fall-3 {
    68.995% {
        transform: translate(67.0686vw, 1.5523875rem) scale(.0763)
    }
    to {
        transform: translate(66.99745vw, 2.25rem) scale(.0763)
    }
}

.announcement-block-christmas .snowflakes > div:nth-child(4) {
    opacity: .2345;
    transform: translate(77.6833vw, -10px) scale(.0678);
    animation: fall-4 7.25s -7s linear infinite
}

@media (prefers-reduced-motion) {
    .announcement-block-christmas .snowflakes > div:nth-child(4) {
        animation: none;
        transform: translate(77.8466vw, 6vh) scale(.0678)
    }
}

@keyframes fall-4 {
    58.828% {
        transform: translate(77.8466vw, 1.32363rem) scale(.0678)
    }
    to {
        transform: translate(77.76495vw, 2.25rem) scale(.0678)
    }
}

.announcement-block-christmas .snowflakes > div:nth-child(5) {
    opacity: .6623;
    transform: translate(79.2493vw, -10px) scale(.2769);
    animation: fall-5 3.25s -4s linear infinite
}

@media (prefers-reduced-motion) {
    .announcement-block-christmas .snowflakes > div:nth-child(5) {
        animation: none;
        transform: translate(78.6586vw, 9vh) scale(.2769)
    }
}

@keyframes fall-5 {
    37.909% {
        transform: translate(78.6586vw, .8529525rem) scale(.2769)
    }
    to {
        transform: translate(78.95395vw, 2.25rem) scale(.2769)
    }
}

.announcement-block-christmas .snowflakes > div:nth-child(6) {
    opacity: .4831;
    transform: translate(41.3868vw, -10px) scale(.1521);
    animation: fall-6 2.5s -16s linear infinite
}

@media (prefers-reduced-motion) {
    .announcement-block-christmas .snowflakes > div:nth-child(6) {
        animation: none;
        transform: translate(41.528vw, 4vh) scale(.1521)
    }
}

@keyframes fall-6 {
    44.124% {
        transform: translate(41.528vw, .99279rem) scale(.1521)
    }
    to {
        transform: translate(41.4574vw, 2.25rem) scale(.1521)
    }
}

.announcement-block-christmas .snowflakes > div:nth-child(7) {
    opacity: .3128;
    transform: translate(35.0941vw, -10px) scale(.0751);
    animation: fall-7 5.75s -17s linear infinite
}

@media (prefers-reduced-motion) {
    .announcement-block-christmas .snowflakes > div:nth-child(7) {
        animation: none;
        transform: translate(34.7923vw, 7vh) scale(.0751)
    }
}

@keyframes fall-7 {
    50.663% {
        transform: translate(34.7923vw, 1.1399175rem) scale(.0751)
    }
    to {
        transform: translate(34.9432vw, 2.25rem) scale(.0751)
    }
}

.announcement-block-christmas .snowflakes > div:nth-child(8) {
    opacity: .5177;
    transform: translate(54.7034vw, -10px) scale(.5707);
    animation: fall-8 3.25s -10s linear infinite
}

@media (prefers-reduced-motion) {
    .announcement-block-christmas .snowflakes > div:nth-child(8) {
        animation: none;
        transform: translate(54.2963vw, 1vh) scale(.5707)
    }
}

@keyframes fall-8 {
    38.358% {
        transform: translate(54.2963vw, .863055rem) scale(.5707)
    }
    to {
        transform: translate(54.49985vw, 2.25rem) scale(.5707)
    }
}

.announcement-block-christmas .snowflakes > div:nth-child(9) {
    opacity: .175;
    transform: translate(25.6534vw, -10px) scale(.3786);
    animation: fall-9 7.5s -10s linear infinite
}

@media (prefers-reduced-motion) {
    .announcement-block-christmas .snowflakes > div:nth-child(9) {
        animation: none;
        transform: translate(26.1799vw, 10vh) scale(.3786)
    }
}

@keyframes fall-9 {
    78.79% {
        transform: translate(26.1799vw, 1.772775rem) scale(.3786)
    }
    to {
        transform: translate(25.91665vw, 2.25rem) scale(.3786)
    }
}

.announcement-block-christmas .snowflakes > div:nth-child(10) {
    opacity: .0532;
    transform: translate(92.5857vw, -10px) scale(.0517);
    animation: fall-10 3.25s -18s linear infinite
}

@media (prefers-reduced-motion) {
    .announcement-block-christmas .snowflakes > div:nth-child(10) {
        animation: none;
        transform: translate(92.8663vw, 0) scale(.0517)
    }
}

@keyframes fall-10 {
    34.918% {
        transform: translate(92.8663vw, .785655rem) scale(.0517)
    }
    to {
        transform: translate(92.726vw, 2.25rem) scale(.0517)
    }
}

.announcement-block-christmas .snowflakes > div:nth-child(11) {
    opacity: .4315;
    transform: translate(40.672vw, -10px) scale(.5518);
    animation: fall-11 2.75s -10s linear infinite
}

@media (prefers-reduced-motion) {
    .announcement-block-christmas .snowflakes > div:nth-child(11) {
        animation: none;
        transform: translate(40.1832vw, 9vh) scale(.5518)
    }
}

@keyframes fall-11 {
    71.805% {
        transform: translate(40.1832vw, 1.6156125rem) scale(.5518)
    }
    to {
        transform: translate(40.4276vw, 2.25rem) scale(.5518)
    }
}

.announcement-block-christmas .snowflakes > div:nth-child(12) {
    opacity: .6936;
    transform: translate(58.3761vw, -10px) scale(.0789);
    animation: fall-12 7s -16s linear infinite
}

@media (prefers-reduced-motion) {
    .announcement-block-christmas .snowflakes > div:nth-child(12) {
        animation: none;
        transform: translate(58.9393vw, 7vh) scale(.0789)
    }
}

@keyframes fall-12 {
    63.544% {
        transform: translate(58.9393vw, 1.42974rem) scale(.0789)
    }
    to {
        transform: translate(58.6577vw, 2.25rem) scale(.0789)
    }
}

.announcement-block-christmas .snowflakes > div:nth-child(13) {
    opacity: .3971;
    transform: translate(10.8912vw, -10px) scale(.9782);
    animation: fall-13 3s -1s linear infinite
}

@media (prefers-reduced-motion) {
    .announcement-block-christmas .snowflakes > div:nth-child(13) {
        animation: none;
        transform: translate(11.2629vw, 7vh) scale(.9782)
    }
}

@keyframes fall-13 {
    46.2% {
        transform: translate(11.2629vw, 1.0395rem) scale(.9782)
    }
    to {
        transform: translate(11.07705vw, 2.25rem) scale(.9782)
    }
}

.announcement-block-christmas .snowflakes > div:nth-child(14) {
    opacity: .0445;
    transform: translate(39.5519vw, -10px) scale(.2772);
    animation: fall-14 5s -7s linear infinite
}

@media (prefers-reduced-motion) {
    .announcement-block-christmas .snowflakes > div:nth-child(14) {
        animation: none;
        transform: translate(39.3963vw, 5vh) scale(.2772)
    }
}

@keyframes fall-14 {
    56.608% {
        transform: translate(39.3963vw, 1.27368rem) scale(.2772)
    }
    to {
        transform: translate(39.4741vw, 2.25rem) scale(.2772)
    }
}

.announcement-block-christmas .snowflakes > div:nth-child(15) {
    opacity: .5029;
    transform: translate(59.1977vw, -10px) scale(.4022);
    animation: fall-15 5.5s -4s linear infinite
}

@media (prefers-reduced-motion) {
    .announcement-block-christmas .snowflakes > div:nth-child(15) {
        animation: none;
        transform: translate(58.7816vw, 1vh) scale(.4022)
    }
}

@keyframes fall-15 {
    75.072% {
        transform: translate(58.7816vw, 1.68912rem) scale(.4022)
    }
    to {
        transform: translate(58.98965vw, 2.25rem) scale(.4022)
    }
}

.announcement-block-christmas .snowflakes > div:nth-child(16) {
    opacity: .4842;
    transform: translate(64.4398vw, -10px) scale(.2241);
    animation: fall-16 3.75s -29s linear infinite
}

@media (prefers-reduced-motion) {
    .announcement-block-christmas .snowflakes > div:nth-child(16) {
        animation: none;
        transform: translate(65.0924vw, 9vh) scale(.2241)
    }
}

@keyframes fall-16 {
    33.93% {
        transform: translate(65.0924vw, .763425rem) scale(.2241)
    }
    to {
        transform: translate(64.7661vw, 2.25rem) scale(.2241)
    }
}

.announcement-block-christmas .snowflakes > div:nth-child(17) {
    opacity: .5879;
    transform: translate(44.2329vw, -10px) scale(.2585);
    animation: fall-17 6.5s -16s linear infinite
}

@media (prefers-reduced-motion) {
    .announcement-block-christmas .snowflakes > div:nth-child(17) {
        animation: none;
        transform: translate(44.2218vw, 6vh) scale(.2585)
    }
}

@keyframes fall-17 {
    79.382% {
        transform: translate(44.2218vw, 1.786095rem) scale(.2585)
    }
    to {
        transform: translate(44.22735vw, 2.25rem) scale(.2585)
    }
}

.announcement-block-christmas .snowflakes > div:nth-child(18) {
    opacity: .8445;
    transform: translate(28.2989vw, -10px) scale(.8512);
    animation: fall-18 6.75s -16s linear infinite
}

@media (prefers-reduced-motion) {
    .announcement-block-christmas .snowflakes > div:nth-child(18) {
        animation: none;
        transform: translate(27.7746vw, 8vh) scale(.8512)
    }
}

@keyframes fall-18 {
    33.945% {
        transform: translate(27.7746vw, .7637625rem) scale(.8512)
    }
    to {
        transform: translate(28.03675vw, 2.25rem) scale(.8512)
    }
}

.announcement-block-christmas .snowflakes > div:nth-child(19) {
    opacity: .1202;
    transform: translate(22.6949vw, -10px) scale(.7087);
    animation: fall-19 2.5s -16s linear infinite
}

@media (prefers-reduced-motion) {
    .announcement-block-christmas .snowflakes > div:nth-child(19) {
        animation: none;
        transform: translate(22.3122vw, 5vh) scale(.7087)
    }
}

@keyframes fall-19 {
    72.516% {
        transform: translate(22.3122vw, 1.63161rem) scale(.7087)
    }
    to {
        transform: translate(22.50355vw, 2.25rem) scale(.7087)
    }
}

.announcement-block-christmas .snowflakes > div:nth-child(20) {
    opacity: .7013;
    transform: translate(96.0371vw, -10px) scale(.827);
    animation: fall-20 2.75s -9s linear infinite
}

@media (prefers-reduced-motion) {
    .announcement-block-christmas .snowflakes > div:nth-child(20) {
        animation: none;
        transform: translate(95.4331vw, 8vh) scale(.827)
    }
}

@keyframes fall-20 {
    36.863% {
        transform: translate(95.4331vw, .8294175rem) scale(.827)
    }
    to {
        transform: translate(95.7351vw, 2.25rem) scale(.827)
    }
}

.announcement-block-christmas .snowflakes > div:nth-child(21) {
    opacity: .2261;
    transform: translate(22.2367vw, -10px) scale(.02);
    animation: fall-21 2.75s -16s linear infinite
}

@media (prefers-reduced-motion) {
    .announcement-block-christmas .snowflakes > div:nth-child(21) {
        animation: none;
        transform: translate(21.8291vw, 3vh) scale(.02)
    }
}

@keyframes fall-21 {
    32.898% {
        transform: translate(21.8291vw, .740205rem) scale(.02)
    }
    to {
        transform: translate(22.0329vw, 2.25rem) scale(.02)
    }
}

.announcement-block-christmas .snowflakes > div:nth-child(22) {
    opacity: .4351;
    transform: translate(1.2646vw, -10px) scale(.1897);
    animation: fall-22 3s -22s linear infinite
}

@media (prefers-reduced-motion) {
    .announcement-block-christmas .snowflakes > div:nth-child(22) {
        animation: none;
        transform: translate(1.3357vw, 6vh) scale(.1897)
    }
}

@keyframes fall-22 {
    63.903% {
        transform: translate(1.3357vw, 1.4378175rem) scale(.1897)
    }
    to {
        transform: translate(1.30015vw, 2.25rem) scale(.1897)
    }
}

.announcement-block-christmas .snowflakes > div:nth-child(23) {
    opacity: .4945;
    transform: translate(62.7007vw, -10px) scale(.8345);
    animation: fall-23 7.25s -10s linear infinite
}

@media (prefers-reduced-motion) {
    .announcement-block-christmas .snowflakes > div:nth-child(23) {
        animation: none;
        transform: translate(61.944vw, 9vh) scale(.8345)
    }
}

@keyframes fall-23 {
    68.147% {
        transform: translate(61.944vw, 1.5333075rem) scale(.8345)
    }
    to {
        transform: translate(62.32235vw, 2.25rem) scale(.8345)
    }
}

.announcement-block-christmas .snowflakes > div:nth-child(24) {
    opacity: .8792;
    transform: translate(51.6351vw, -10px) scale(.7149);
    animation: fall-24 3s -13s linear infinite
}

@media (prefers-reduced-motion) {
    .announcement-block-christmas .snowflakes > div:nth-child(24) {
        animation: none;
        transform: translate(51.5453vw, 9vh) scale(.7149)
    }
}

@keyframes fall-24 {
    43.277% {
        transform: translate(51.5453vw, .9737325rem) scale(.7149)
    }
    to {
        transform: translate(51.5902vw, 2.25rem) scale(.7149)
    }
}

.announcement-block-christmas .snowflakes > div:nth-child(25) {
    opacity: .4306;
    transform: translate(60.1837vw, -10px) scale(.0698);
    animation: fall-25 3.75s -14s linear infinite
}

@media (prefers-reduced-motion) {
    .announcement-block-christmas .snowflakes > div:nth-child(25) {
        animation: none;
        transform: translate(59.9495vw, 1vh) scale(.0698)
    }
}

@keyframes fall-25 {
    37.441% {
        transform: translate(59.9495vw, .8424225rem) scale(.0698)
    }
    to {
        transform: translate(60.0666vw, 2.25rem) scale(.0698)
    }
}

.announcement-block-christmas .snowflakes > div:nth-child(26) {
    opacity: .8158;
    transform: translate(46.2673vw, -10px) scale(.0153);
    animation: fall-26 5.75s -14s linear infinite
}

@media (prefers-reduced-motion) {
    .announcement-block-christmas .snowflakes > div:nth-child(26) {
        animation: none;
        transform: translate(46.9301vw, 7vh) scale(.0153)
    }
}

@keyframes fall-26 {
    34.978% {
        transform: translate(46.9301vw, .787005rem) scale(.0153)
    }
    to {
        transform: translate(46.5987vw, 2.25rem) scale(.0153)
    }
}

.announcement-block-christmas .snowflakes > div:nth-child(27) {
    opacity: .3609;
    transform: translate(66.3915vw, -10px) scale(.6984);
    animation: fall-27 4.25s -3s linear infinite
}

@media (prefers-reduced-motion) {
    .announcement-block-christmas .snowflakes > div:nth-child(27) {
        animation: none;
        transform: translate(67.157vw, 6vh) scale(.6984)
    }
}

@keyframes fall-27 {
    36.468% {
        transform: translate(67.157vw, .82053rem) scale(.6984)
    }
    to {
        transform: translate(66.77425vw, 2.25rem) scale(.6984)
    }
}

.announcement-block-christmas .snowflakes > div:nth-child(28) {
    opacity: .6886;
    transform: translate(58.3628vw, -10px) scale(.9786);
    animation: fall-28 6.5s -23s linear infinite
}

@media (prefers-reduced-motion) {
    .announcement-block-christmas .snowflakes > div:nth-child(28) {
        animation: none;
        transform: translate(58.1683vw, 0) scale(.9786)
    }
}

@keyframes fall-28 {
    77.484% {
        transform: translate(58.1683vw, 1.74339rem) scale(.9786)
    }
    to {
        transform: translate(58.26555vw, 2.25rem) scale(.9786)
    }
}

.announcement-block-christmas .snowflakes > div:nth-child(29) {
    opacity: .1663;
    transform: translate(56.8324vw, -10px) scale(.2159);
    animation: fall-29 3.5s -20s linear infinite
}

@media (prefers-reduced-motion) {
    .announcement-block-christmas .snowflakes > div:nth-child(29) {
        animation: none;
        transform: translate(56.3107vw, 9vh) scale(.2159)
    }
}

@keyframes fall-29 {
    37.784% {
        transform: translate(56.3107vw, .85014rem) scale(.2159)
    }
    to {
        transform: translate(56.57155vw, 2.25rem) scale(.2159)
    }
}

.announcement-block-christmas .snowflakes > div:nth-child(30) {
    opacity: .8787;
    transform: translate(61.1122vw, -10px) scale(.269);
    animation: fall-30 6.75s -20s linear infinite
}

@media (prefers-reduced-motion) {
    .announcement-block-christmas .snowflakes > div:nth-child(30) {
        animation: none;
        transform: translate(60.7752vw, 6vh) scale(.269)
    }
}

@keyframes fall-30 {
    62.116% {
        transform: translate(60.7752vw, 1.39761rem) scale(.269)
    }
    to {
        transform: translate(60.9437vw, 2.25rem) scale(.269)
    }
}

.announcement-block-christmas .snowflakes > div:nth-child(31) {
    opacity: .0902;
    transform: translate(48.2409vw, -10px) scale(.479);
    animation: fall-31 6.75s -18s linear infinite
}

@media (prefers-reduced-motion) {
    .announcement-block-christmas .snowflakes > div:nth-child(31) {
        animation: none;
        transform: translate(47.6903vw, 8vh) scale(.479)
    }
}

@keyframes fall-31 {
    42.178% {
        transform: translate(47.6903vw, .949005rem) scale(.479)
    }
    to {
        transform: translate(47.9656vw, 2.25rem) scale(.479)
    }
}

.announcement-block-christmas .snowflakes > div:nth-child(32) {
    opacity: .2233;
    transform: translate(41.247vw, -10px) scale(.6255);
    animation: fall-32 3.5s -5s linear infinite
}

@media (prefers-reduced-motion) {
    .announcement-block-christmas .snowflakes > div:nth-child(32) {
        animation: none;
        transform: translate(40.4947vw, 1vh) scale(.6255)
    }
}

@keyframes fall-32 {
    43.51% {
        transform: translate(40.4947vw, .978975rem) scale(.6255)
    }
    to {
        transform: translate(40.87085vw, 2.25rem) scale(.6255)
    }
}

.announcement-block-christmas .snowflakes > div:nth-child(33) {
    opacity: .7372;
    transform: translate(63.354vw, -10px) scale(.0964);
    animation: fall-33 5.75s -17s linear infinite
}

@media (prefers-reduced-motion) {
    .announcement-block-christmas .snowflakes > div:nth-child(33) {
        animation: none;
        transform: translate(63.7487vw, 9vh) scale(.0964)
    }
}

@keyframes fall-33 {
    72.803% {
        transform: translate(63.7487vw, 1.6380675rem) scale(.0964)
    }
    to {
        transform: translate(63.55135vw, 2.25rem) scale(.0964)
    }
}

.announcement-block-christmas .snowflakes > div:nth-child(34) {
    opacity: .6437;
    transform: translate(85.1507vw, -10px) scale(.1186);
    animation: fall-34 4.75s -3s linear infinite
}

@media (prefers-reduced-motion) {
    .announcement-block-christmas .snowflakes > div:nth-child(34) {
        animation: none;
        transform: translate(85.5839vw, 8vh) scale(.1186)
    }
}

@keyframes fall-34 {
    73.618% {
        transform: translate(85.5839vw, 1.656405rem) scale(.1186)
    }
    to {
        transform: translate(85.3673vw, 2.25rem) scale(.1186)
    }
}

.announcement-block-christmas .snowflakes > div:nth-child(35) {
    opacity: .6094;
    transform: translate(79.3194vw, -10px) scale(.813);
    animation: fall-35 5.75s -19s linear infinite
}

@media (prefers-reduced-motion) {
    .announcement-block-christmas .snowflakes > div:nth-child(35) {
        animation: none;
        transform: translate(79.6504vw, 4vh) scale(.813)
    }
}

@keyframes fall-35 {
    34.464% {
        transform: translate(79.6504vw, .77544rem) scale(.813)
    }
    to {
        transform: translate(79.4849vw, 2.25rem) scale(.813)
    }
}

.announcement-block-christmas .snowflakes > div:nth-child(36) {
    opacity: .1898;
    transform: translate(35.2922vw, -10px) scale(.3559);
    animation: fall-36 3.5s -8s linear infinite
}

@media (prefers-reduced-motion) {
    .announcement-block-christmas .snowflakes > div:nth-child(36) {
        animation: none;
        transform: translate(34.6673vw, 1vh) scale(.3559)
    }
}

@keyframes fall-36 {
    71.72% {
        transform: translate(34.6673vw, 1.6137rem) scale(.3559)
    }
    to {
        transform: translate(34.97975vw, 2.25rem) scale(.3559)
    }
}

.announcement-block-christmas .snowflakes > div:nth-child(37) {
    opacity: .6699;
    transform: translate(19.7269vw, -10px) scale(.3746);
    animation: fall-37 5.75s -10s linear infinite
}

@media (prefers-reduced-motion) {
    .announcement-block-christmas .snowflakes > div:nth-child(37) {
        animation: none;
        transform: translate(19.6866vw, 1vh) scale(.3746)
    }
}

@keyframes fall-37 {
    72.444% {
        transform: translate(19.6866vw, 1.62999rem) scale(.3746)
    }
    to {
        transform: translate(19.70675vw, 2.25rem) scale(.3746)
    }
}

.announcement-block-christmas .snowflakes > div:nth-child(38) {
    opacity: .1477;
    transform: translate(29.651vw, -10px) scale(.5133);
    animation: fall-38 4.5s -14s linear infinite
}

@media (prefers-reduced-motion) {
    .announcement-block-christmas .snowflakes > div:nth-child(38) {
        animation: none;
        transform: translate(30.0201vw, 6vh) scale(.5133)
    }
}

@keyframes fall-38 {
    37.609% {
        transform: translate(30.0201vw, .8462025rem) scale(.5133)
    }
    to {
        transform: translate(29.83555vw, 2.25rem) scale(.5133)
    }
}

.announcement-block-christmas .snowflakes > div:nth-child(39) {
    opacity: .3715;
    transform: translate(32.8901vw, -10px) scale(.9708);
    animation: fall-39 4s -10s linear infinite
}

@media (prefers-reduced-motion) {
    .announcement-block-christmas .snowflakes > div:nth-child(39) {
        animation: none;
        transform: translate(32.2033vw, 1vh) scale(.9708)
    }
}

@keyframes fall-39 {
    77.739% {
        transform: translate(32.2033vw, 1.7491275rem) scale(.9708)
    }
    to {
        transform: translate(32.5467vw, 2.25rem) scale(.9708)
    }
}

.announcement-block-christmas .snowflakes > div:nth-child(40) {
    opacity: .9252;
    transform: translate(59.6433vw, -10px) scale(.7289);
    animation: fall-40 2.75s -29s linear infinite
}

@media (prefers-reduced-motion) {
    .announcement-block-christmas .snowflakes > div:nth-child(40) {
        animation: none;
        transform: translate(58.92vw, 3vh) scale(.7289)
    }
}

@keyframes fall-40 {
    65.49% {
        transform: translate(58.92vw, 1.473525rem) scale(.7289)
    }
    to {
        transform: translate(59.28165vw, 2.25rem) scale(.7289)
    }
}

.announcement-block-spring {
    display: block;
    position: fixed;
    order: -10;
    left: 0;
    right: 0;
    top: 0;
    height: 2.25rem;
    text-align: center;
    color: #fff;
    z-index: 6;
    overflow: hidden;
    background: linear-gradient(0deg, #cce7ff 0, #a0e1fd 100%);
    box-shadow: 0 0 5px #028615c2
}

.announcement-block-spring:after {
    content: ' ';
    position: absolute;
    left: 0;
    right: 0;
    top: 0;
    height: 2.25rem;
    z-index: 1;
    background: url(../images/content-public/ann/spring/spring-clouds.svg) 0 0;
    background-size: 1122px 36px;
    pointer-events: none;
    opacity: .5
}

.announcement-block-spring:before {
    content: ' ';
    position: absolute;
    left: 0;
    right: 0;
    top: 0;
    height: 2.25rem;
    background: url(../images/content-public/ann/spring/spring-clouds.svg);
    background-size: 2244px 72px;
    pointer-events: none
}

@keyframes bg-slide {
    from {
        transform: translateX(-50%);
        opacity: 0
    }
    50% {
        transform: translateX(0);
        opacity: 1
    }
    to {
        transform: translateX(50%);
        opacity: 0
    }
}

@keyframes bg-slide2 {
    from {
        transform: translateX(-50%);
        opacity: 0
    }
    50% {
        transform: translateX(0);
        opacity: 1
    }
    to {
        transform: translateX(50%);
        opacity: 0
    }
}

.announcement-block-spring a {
    position: absolute;
    left: 0;
    right: 0;
    top: 0;
    bottom: 0;
    color: #fff;
    font-size: 1.6rem;
    font-weight: 700;
    text-shadow: 0 1px 0 #028615, 1px 1px 0 #028615;
    z-index: 1;
    background: url(../images/content-public/ann/spring/spring.svg);
    background-size: 1122px 36px;
    text-transform: uppercase;
    display: flex;
    justify-content: center;
    gap: 8px;
    align-items: end
}

.announcement-block-spring a .announcement-link-text {
    backdrop-filter: blur(2px);
    display: inline-block;
    line-height: 31px
}

.announcement-block-spring a:hover {
    text-decoration: none;
    background: url(../images/content-public/ann/spring/spring.svg), rgba(255, 255, 255, .3);
    background-size: 1122px 36px
}

.announcement-block-summer {
    display: block;
    position: fixed;
    order: -10;
    left: 0;
    right: 0;
    top: 0;
    height: 2.25rem;
    text-align: center;
    color: #fff;
    z-index: 6;
    overflow: hidden;
    background: linear-gradient(0deg, #cce7ff 0, #a0e1fd 100%);
    box-shadow: 0 0 5px rgba(0, 24, 155, .76)
}

.announcement-block-summer:after {
    content: ' ';
    position: absolute;
    left: 0;
    right: 0;
    top: 0;
    height: 2.25rem;
    z-index: 1;
    background: url(../images/content-public/ann/summer/summer-clouds.svg) 0 0;
    background-size: 1122px 36px;
    pointer-events: none;
    opacity: .5
}

.announcement-block-summer:before {
    content: ' ';
    position: absolute;
    left: 0;
    right: 0;
    top: 0;
    height: 2.25rem;
    background: url(../images/content-public/ann/summer/summer-clouds.svg);
    background-size: 2244px 72px;
    pointer-events: none;
    visibility: hidden
}

@keyframes bg-slide {
    from {
        transform: translateX(-50%);
        opacity: 0
    }
    50% {
        transform: translateX(0);
        opacity: 1
    }
    to {
        transform: translateX(50%);
        opacity: 0
    }
}

@keyframes bg-slide2 {
    from {
        transform: translateX(-50%);
        opacity: 0
    }
    50% {
        transform: translateX(0);
        opacity: 1
    }
    to {
        transform: translateX(50%);
        opacity: 0
    }
}

.announcement-block-summer .beach-and-sea {
    position: absolute;
    left: 0;
    right: 0;
    top: 0;
    bottom: 0;
    color: #fff;
    font-size: 1.6rem;
    font-weight: 700;
    text-shadow: 0 1px 0 #2762f8, 1px 1px 0 #020d86;
    z-index: 1;
    text-transform: uppercase;
    background: linear-gradient(180deg, transparent 0, transparent 65%, #4f7bce 66%, #4dd9e3 100%)
}

.announcement-block-summer .beach-and-sea .a1 {
    position: absolute;
    left: 0;
    width: 50%;
    top: 0;
    bottom: 0;
    background: url(../images/content-public/ann/summer/summer.svg) 100% 0 no-repeat;
    background-size: 900px 36px;
    text-transform: uppercase
}

.announcement-block-summer .beach-and-sea .a2 {
    position: absolute;
    right: 0;
    width: 50%;
    top: 0;
    bottom: 0;
    background: url(../images/content-public/ann/summer/summer.svg) 0 0 no-repeat;
    background-size: 900px 36px;
    text-transform: uppercase;
    visibility: hidden
}

.announcement-block-summer .beach-and-sea .wave {
    position: absolute;
    left: 0;
    width: 16px;
    top: 20px;
    bottom: 0;
    background: url(../images/content-public/ann/summer/wave.svg) 0 0 no-repeat;
    scale: -.5 1 1;
    animation: wave-right 5s linear infinite;
    transform-origin: 50% 100%;
    visibility: hidden
}

@media (min-width: 768px) {
    .announcement-block-summer .beach-and-sea .wave {
        visibility: visible
    }
}

@media (prefers-reduced-motion) {
    .announcement-block-summer .beach-and-sea .wave {
        visibility: hidden
    }
}

@keyframes wave-right {
    from {
        opacity: 0;
        translate: -70px 0;
        scale: -.5 .5 1
    }
    25% {
        opacity: 1;
        scale: -1 1 1
    }
    70% {
        translate: -20px 0;
        scale: -1 1 1;
        rotate: -10deg;
        opacity: 1
    }
    to {
        translate: 10px 7px;
        scale: -1 1 1;
        rotate: 30deg;
        opacity: 0
    }
}

.announcement-block-summer .beach-and-sea .yacht {
    position: absolute;
    left: 32%;
    width: 24px;
    bottom: 0;
    height: 24px;
    background: url(../images/content-public/ann/summer/yacht.svg) 0 0 no-repeat;
    animation: surfer-right 300s linear infinite;
    transform-origin: 50% 100%;
    z-index: 0;
    visibility: hidden
}

@media (min-width: 768px) {
    .announcement-block-summer .beach-and-sea .yacht {
        visibility: visible
    }
}

@media (prefers-reduced-motion) {
    .announcement-block-summer .beach-and-sea .yacht {
        visibility: hidden
    }
}

@keyframes surfer-right {
    from {
        translate: 0 -3px;
        scale: 1 1 1
    }
    49% {
        translate: 30vw -8px;
        scale: .8 .8 1
    }
    50% {
        translate: 30vw -8px;
        scale: -.8 .8 1
    }
    to {
        translate: 0 0;
        scale: -1 1 1
    }
}

@media (min-width: 768px) {
    .announcement-block-summer .beach-and-sea .a1, .announcement-block-summer .beach-and-sea .a2 {
        width: 30%;
        visibility: visible
    }
}

.announcement-block-summer a {
    position: absolute;
    left: 0;
    right: 0;
    top: 0;
    bottom: 0;
    color: #fff;
    font-size: 1.5rem;
    line-height: 36px;
    font-weight: 700;
    text-shadow: 0 1px 0 #2762f8, 1px 1px 0 #020d86;
    z-index: 2;
    text-transform: uppercase;
    display: flex;
    justify-content: center;
    gap: 8px;
    align-items: end
}

.locale-pt-br .announcement-block-summer a, .locale-ru .announcement-block-summer a {
    font-size: 1.3rem;
    letter-spacing: -1px
}

@media (min-width: 450px) {
    .announcement-block-summer a {
        font-size: 1.9rem
    }

    .locale-pt-br .announcement-block-summer a, .locale-ru .announcement-block-summer a {
        font-size: 1.9rem;
        letter-spacing: 0
    }
}

.announcement-block-summer a:hover {
    text-decoration: none;
    background: rgba(255, 255, 255, .3)
}

.announcement-block-summer .announcement-link-text {
    backdrop-filter: blur(2px);
    display: inline-block;
    line-height: 31px
}

.announcement-block-autumn {
    display: block;
    position: fixed;
    order: -10;
    left: 0;
    right: 0;
    top: 0;
    height: 2.25rem;
    text-align: center;
    color: #fff;
    z-index: 6;
    overflow: hidden;
    background: linear-gradient(0deg, #fff3cc 0, #95f3fc 100%);
    box-shadow: 0 0 3px 0 #ad1968
}

.announcement-block-autumn:after {
    content: ' ';
    position: absolute;
    left: 0;
    right: 0;
    top: 0;
    height: 2.25rem;
    z-index: 1;
    background: url(../images/content-public/ann/autumn/autumn-clouds.svg) 0 0;
    background-size: 1122px 36px;
    pointer-events: none;
    opacity: .5
}

.announcement-block-autumn:before {
    content: ' ';
    position: absolute;
    left: 0;
    right: 0;
    top: 0;
    height: 2.25rem;
    background: url(../images/content-public/ann/autumn/autumn-clouds.svg);
    background-size: 2244px 72px;
    pointer-events: none
}

@keyframes bg-slide {
    from {
        transform: translateX(-50%);
        opacity: 0
    }
    50% {
        transform: translateX(0);
        opacity: 1
    }
    to {
        transform: translateX(50%);
        opacity: 0
    }
}

@keyframes bg-slide2 {
    from {
        transform: translateX(-50%);
        opacity: 0
    }
    50% {
        transform: translateX(0);
        opacity: 1
    }
    to {
        transform: translateX(50%);
        opacity: 0
    }
}

.announcement-block-autumn a {
    position: absolute;
    left: 0;
    right: 0;
    top: 0;
    bottom: 0;
    color: #fff;
    font-size: 1.75rem;
    font-weight: 700;
    font-family: Gabriela, serif;
    white-space: nowrap;
    text-shadow: 0 -1px 0 #ab125f, -1px 0 0 #ab125f, 0 2px 0 #8f12ab99, 2px 0 0 #8f12ab99, 2px 2px 1px #8f12ab55;
    z-index: 1;
    background: url(../images/content-public/ann/autumn/autumn.svg);
    background-size: 1122px 36px;
    display: flex;
    justify-content: center;
    gap: 8px;
    align-items: end
}

@media (min-width: 768px) {
    .announcement-block-autumn a {
        font-size: 2rem
    }
}

:lang(zh) .announcement-block-autumn a {
    font-family: "PT Sans", "Helvetica Neue", Arial, "PingFang SC", "microsoft yahei", "hiragino sans gb", sans-serif;
    font-size: 1.8rem
}

:lang(ja) .announcement-block-autumn a {
    font-family: "PT Sans", "Helvetica Neue", Tahoma, "游ゴシック Medium", "Yu Gothic Medium", YuGothicM, 游ゴシック体, YuGothic, "ヒラギノ角ゴ Pro", "Hiragino Kaku Gothic Pro", "Meiryo UI", メイリオ, Meiryo, sans-serif;
    font-size: 1.8rem
}

:lang(ko) .announcement-block-autumn a {
    font-family: KoreanParentheses, "PT Sans", "Apple SD Gothic Neo", "Malgun Gothic", Dotum, "Noto Sans CJK KR", sans-serif;
    font-size: 1.8rem
}

:lang(pt-br) .announcement-block-autumn a {
    font-size: 1.75rem
}

@media (min-width: 768px) {
    :lang(pt-br) .announcement-block-autumn a {
        font-size: 1.5rem
    }
}

:lang(ru) .announcement-block-autumn a, :lang(uk) .announcement-block-autumn a {
    font-size: 1.5rem;
    font-family: Gabriela, serif
}

@media (min-width: 768px) {
    :lang(ru) .announcement-block-autumn a, :lang(uk) .announcement-block-autumn a {
        font-size: 1.75rem
    }
}

.announcement-block-autumn a .announcement-link-text {
    backdrop-filter: blur(2px);
    display: inline-block;
    line-height: 33px
}

:lang(pt-br) .announcement-block-autumn a .announcement-link-text {
    line-height: 2rem
}

@media (min-width: 768px) {
    :lang(pt-br) .announcement-block-autumn a .announcement-link-text {
        line-height: 2rem
    }
}

.announcement-block-autumn a:hover {
    text-decoration: none;
    background: url(../images/content-public/ann/autumn/autumn.svg), rgba(255, 255, 255, .3);
    background-size: 1122px 36px
}

.banner-sidebar .banner-text {
    background: #fff;
    height: 205px;
    display: block;
    margin: 0 20px;
    padding: 21px 20px 20px;
    border-radius: 10px;
    font-size: 19px;
    line-height: 27px;
    position: absolute;
    top: 20px
}

.banner-sidebar .banner-text-ru, .banner-sidebar .banner-text-uk {
    font-size: 16px;
    line-height: 26px
}

.banner-content {
    max-width: 648px;
    margin: 3rem 0 2rem
}

.banner-content .title {
    margin-top: 0
}

.banner-content .title, .banner-content p {
    margin-bottom: 10px
}

.banner-content .btn {
    display: block
}

@media (min-width: 768px) {
    .banner-content .btn {
        display: inline-block
    }
}

.banner {
    padding: 1.5rem;
    position: relative;
    border: solid .5rem #eee
}

.banner-bg {
    padding: 2rem;
    position: relative
}

.banner-bg:before {
    content: " ";
    display: block;
    border-radius: 3px;
    background: #fff;
    position: absolute;
    top: .5rem;
    left: .5rem;
    right: .5rem;
    bottom: .5rem;
    z-index: 0
}

.banner-bg > * {
    position: relative;
    z-index: 1
}

.banner-bg.banner-striped {
    background: repeating-linear-gradient(45deg, #d12345, #d12345 10px, #fff 10px, #fff 20px);
    border-radius: 3px
}

.banner-bg.banner-night-mode {
    background: repeating-linear-gradient(45deg, #555, #555 10px, #333 10px, #333 20px);
    color: #eee
}

.banner-bg.banner-night-mode:before {
    background: #333
}

.banner-with-image {
    display: flex;
    gap: 1rem;
    justify-content: space-between;
    flex-direction: column
}

.banner-with-image .banner-image {
    text-align: center
}

@media (min-width: 768px) {
    .banner-with-image {
        flex-direction: row-reverse;
        flex-direction: row;
        gap: 2rem
    }

    .banner-with-image .banner-image {
        display: flex;
        justify-content: center;
        flex-direction: column
    }

    .banner-with-image .banner-image img {
        max-width: none
    }
}

.banner-discount {
    display: block;
    position: absolute;
    background: #fff;
    transform: rotateZ(0) scale(1) translate(15px, -15px);
    width: 120px;
    font-size: 28px;
    font-weight: 700;
    padding: 0;
    border: solid 4px #6b1f59;
    color: #6b1f59;
    z-index: 1;
    right: 0;
    top: 0
}

.prom:hover .banner-discount {
    transform: rotateZ(765deg) scale(1.3);
    right: -6px;
    top: 33px
}

.banner-discount {
    transition: all .5s
}

.banner-examples {
    padding-bottom: 40px;
    transition: padding-bottom .2s
}

:lang(es) .banner-examples, :lang(pl) .banner-examples, :lang(pt-br) .banner-examples {
    padding-bottom: 70px
}

.banner-examples .banner-examples-fade {
    opacity: 1;
    position: absolute;
    left: 15px;
    right: 15px;
    transform: translateY(0);
    transition: all .1s
}

.banner-examples .banner-examples-fade a {
    display: block;
    text-align: center
}

.banner-examples .banner-examples-text {
    max-height: 0;
    overflow: hidden;
    transition: max-height .2s
}

.banner-examples:hover {
    padding-bottom: 20px
}

.banner-examples:hover .banner-examples-fade {
    opacity: 0;
    transform: translateY(40px);
    pointer-events: none
}

.banner-examples:hover .banner-examples-text {
    max-height: 300px
}

.store-products {
    justify-content: space-around
}

@media (max-width: 768px) {
    .store-products {
        display: block
    }
}

.store-products .product-block {
    padding: 14px
}

.store-products .more-info {
    margin-top: 30px;
    text-align: center
}

.image3d-book-right {
    perspective: 1000px;
    position: relative;
    width: 250px;
    margin: 0 auto
}

.image3d-book-right .image3d-cover, .image3d-book-right:after, .image3d-book-right:before {
    transition: all .5s;
    border-left: solid 5px #b52845;
    border-top-left-radius: 4px;
    border-bottom-left-radius: 4px;
    transform: rotatey(-10deg) translateZ(25px)
}

.image3d-book-right.hover .image3d-cover, .image3d-book-right.hover:after, .image3d-book-right.hover:before, .image3d-book-right:hover .image3d-cover, .image3d-book-right:hover:after, .image3d-book-right:hover:before {
    transform: rotatey(-15deg) translateZ(40px)
}

.image3d-book-right .image3d-cover {
    position: relative;
    z-index: 2;
    max-width: none !important;
    border-top-right-radius: 2px;
    border-bottom-right-radius: 2px
}

.image3d-book-right:before {
    content: " ";
    position: absolute;
    top: 0;
    display: block;
    z-index: 2
}

.image3d-book-right:after {
    content: " ";
    position: absolute;
    top: 0;
    display: block;
    z-index: 1
}

.image3d-book-right:before {
    width: 250px;
    height: 368px;
    background: linear-gradient(to right, #fff 0, #fff 95%, #ccc 95.5%, #fff 96%, #ccc 96.5%, #fff 97%, #ccc 97.5%, #fff 98%, #ccc 98.5%, #fff 99%, #ccc 99.5%, #fff 100%);
    border-top: solid 1px #aaa;
    border-right: solid 1px #aaa;
    border-bottom: solid 1px #aaa;
    border-top-right-radius: 5px;
    border-bottom-right-radius: 5px;
    transform: rotatey(-10deg) translateZ(-20px) translatex(9px)
}

.image3d-book-right.hover:before, .image3d-book-right:hover:before {
    transform: rotatey(-15deg) translateZ(-20px) translatex(9px)
}

.image3d-book-right:after {
    width: 250px;
    height: 368px;
    background: #09132c;
    border-top-right-radius: 2px;
    border-bottom-right-radius: 2px;
    box-shadow: 10px 2px 20px -3px rgba(20, 0, 70, .3);
    transform: rotatey(-10deg) translateZ(-30px) translatex(12px)
}

.image3d-book-right.hover:after, .image3d-book-right:hover:after {
    box-shadow: 15px 2px 20px -3px rgba(20, 0, 70, .3);
    transform: rotatey(-15deg) translateZ(-30px) translatex(12px)
}

.image3d-course {
    perspective: 1000px;
    position: relative;
    margin: 0 auto;
    width: 300px
}

.image3d-course .image3d-cover, .image3d-course .image3d-side {
    transition: all .5s
}

.image3d-course .image3d-cover {
    transform: rotatey(10deg) translateZ(25px)
}

.image3d-course.hover .image3d-cover, .image3d-course:hover .image3d-cover {
    transform: rotatey(15deg) translateZ(40px)
}

.image3d-course .image3d-side {
    position: absolute;
    top: 0;
    display: block;
    z-index: 2;
    background: #6c1309 url(../images/refactoring/course/store-cover-side.png@1) no-repeat;
    width: 40px;
    height: 375px;
    transform: rotateY(105deg) translateZ(-26px) translatex(-28px)
}

.image3d-course.hover .image3d-side, .image3d-course:hover .image3d-side {
    transform: rotateY(111deg) translateZ(-32px) translatex(-52px)
}

.main-menu-lang {
    display: none;
    gap: .25rem
}

.main-menu-lang a {
    color: #444;
    cursor: pointer;
    font-size: 16px;
    line-height: 34px;
    padding: 15px 8px;
    vertical-align: middle;
    background: 0 0;
    border: none;
    border-radius: 0;
    box-shadow: none
}

@media (min-width: 992px) {
    .main-menu-lang {
        display: flex;
        padding: 0 0 0 4rem
    }
}

.tooltip-lang-suggest {
    font-size: 1rem;
    width: 260px;
    padding: 14px 0 !important;
    margin-top: -14px;
    z-index: 4
}

.modal-open .tooltip-lang-suggest {
    display: none
}

.tooltip-lang-suggest.show {
    opacity: 1
}

.tooltip-lang-suggest .tooltip-inner {
    max-width: none;
    background: #fff;
    color: #444;
    box-shadow: 0 4px 20px #0004;
    border: solid 1px #0004;
    border-top: none;
    padding: 1rem;
    border-radius: 10px;
    cursor: default;
    text-align: left
}

.tooltip-lang-suggest .tooltip-inner a {
    margin-top: .5rem
}

.tooltip-lang-suggest .arrow-custom {
    position: absolute;
    top: 0;
    left: calc(50%);
    width: 28px;
    height: 16px;
    overflow: hidden
}

.tooltip-lang-suggest .arrow-custom:before {
    content: " ";
    background: #fff;
    position: absolute;
    width: 28px;
    height: 28px;
    top: 5px;
    transform: rotate(45deg)
}

@media (min-width: 992px) {
    .tooltip-lang-suggest .arrow-custom:before {
        border: solid 1px #0002
    }
}

.navigation .navigation-container > .navigation-brand {
    padding: 0 10px 0 25px;
    max-width: 12.5rem;
    text-align: center
}

.navigation .navigation-container > .navigation-brand img {
    width: auto;
    height: 4rem
}

@media (max-width: 767.98px) {
    .nav-contact {
        display: none !important
    }
}

.sidebar .menu-brand img {
    width: 12.5rem;
    height: 15.125rem
}

.menu-refactoring-soon-ja .menu-tag {
    display: inline-block;
    line-height: 14px;
    position: absolute;
    bottom: -8px;
    left: 38px
}

.menu-fs15 > a {
    font-size: 15px !important
}

.menu-fs14 > a {
    font-size: 14px !important
}

.menu-fs18 > a {
    font-size: 18px !important
}

.menu-extra-margin > a {
    padding: .25rem 1.5rem .25rem 4rem !important
}

.menu-extra-margin > a:before {
    left: 2.8rem !important
}

.sidebar .locale-link[data-locale=pt-br] {
    font-size: 13px !important;
    letter-spacing: -.4px
}

.pattern-example .nav-tabs .nav-link {
    box-shadow: inset 0 -20px 10px -10px rgba(0, 0, 0, .05)
}

.pattern-example .nav-tabs .nav-link:focus, .pattern-example .nav-tabs .nav-link:hover {
    box-shadow: none
}

.pattern-example .nav-tabs .nav-item.show .nav-link, .pattern-example .nav-tabs .nav-link.active {
    box-shadow: none
}

.pattern-example .nav-tabs-bottom {
    border-top: solid 1px #dee2e6;
    border-bottom: 0
}

.pattern-example .nav-tabs-bottom .nav-link {
    margin-top: -1px;
    border-top-left-radius: 0;
    border-top-right-radius: 0;
    border-bottom-left-radius: .25rem;
    border-bottom-right-radius: .25rem;
    box-shadow: inset 0 20px 10px -10px rgba(0, 0, 0, .05)
}

.pattern-example .nav-tabs-bottom .nav-item.show .nav-link, .pattern-example .nav-tabs-bottom .nav-link.active {
    color: #495057;
    background-color: #fff;
    border-color: transparent #dee2e6 #dee2e6;
    box-shadow: none;
    border-left-width: 1px;
    border-right-width: 1px
}

.patterns-filter {
    margin: -24px 0 24px
}

@media (min-width: 768px) {
    .patterns-filter {
        margin: -32px 0 32px;
        font-size: 1.25rem
    }
}

.patterns-filter .filter {
    text-decoration: none;
    border-bottom: dashed 1px;
    cursor: pointer
}

.patterns-filter .filter:hover {
    border-bottom: solid 1px
}

.patterns-filter .filter.active {
    cursor: default;
    color: #212529;
    font-weight: 700;
    border-bottom: none
}

.behavioral-patterns-header, .creational-patterns-header, .structural-patterns-header {
    margin-bottom: 1.5rem;
    clear: both;
    padding-top: 2rem
}

.behavioral-patterns, .creational-patterns, .structural-patterns {
    overflow: hidden
}

.patterns-catalog .pattern-card {
    width: 49%;
    display: block;
    float: left;
    vertical-align: top;
    margin: 0
}

@media (max-width: 599px) {
    .patterns-catalog .behavioral-patterns-header, .patterns-catalog .creational-patterns-header, .patterns-catalog .structural-patterns-header {
        margin-bottom: 1.5rem
    }
}

@media (min-width: 600px) {
    .patterns-catalog {
        display: grid;
        grid-gap: 1.5rem;
        grid-template-columns:1fr 1fr 1fr 1fr
    }

    .patterns-catalog .behavioral-patterns-header, .patterns-catalog .creational-patterns-header, .patterns-catalog .structural-patterns-header {
        clear: none;
        padding-top: 0
    }

    .patterns-catalog .creational-patterns-header {
        grid-column: 1/3;
        grid-row: 1
    }

    .patterns-catalog .creational-patterns {
        grid-column: 1/3;
        grid-row: 2
    }

    .patterns-catalog .structural-patterns-header {
        grid-column: 3/5;
        grid-row: 1
    }

    .patterns-catalog .structural-patterns {
        grid-column: 3/5;
        grid-row: 2
    }

    .patterns-catalog .behavioral-patterns-header {
        grid-column: 1/5;
        grid-row: 3
    }

    .patterns-catalog .behavioral-patterns {
        grid-column: 1/5;
        grid-row: 4
    }

    .patterns-catalog .behavioral-patterns .pattern-card {
        width: 24%
    }
}

@media (min-width: 1366px) {
    .patterns-catalog .creational-patterns-header {
        grid-column: 1;
        grid-row: 1
    }

    .patterns-catalog .creational-patterns {
        grid-column: 1;
        grid-row: 2
    }

    .patterns-catalog .structural-patterns-header {
        grid-column: 2;
        grid-row: 1
    }

    .patterns-catalog .structural-patterns {
        grid-column: 2;
        grid-row: 2
    }

    .patterns-catalog .behavioral-patterns-header {
        grid-column: 3/5;
        grid-row: 1
    }

    .patterns-catalog .behavioral-patterns {
        grid-column: 3/5;
        grid-row: 2
    }

    .patterns-catalog .behavioral-patterns .pattern-card {
        width: 24%
    }
}

.pattern-card {
    display: block;
    border: solid 1px #f5f5f5;
    box-sizing: border-box;
    min-height: 202px;
    padding: 14px;
    margin: 1px
}

a.pattern-card {
    text-decoration: none
}

a.pattern-card:hover {
    text-decoration: none;
    border: solid 1px #ea6153
}

.pattern-image {
    display: block;
    width: 100%;
    height: 100px;
    text-align: center;
    vertical-align: middle
}

.pattern-image img {
    max-width: 100%;
    max-height: 100px
}

.pattern-aka, .pattern-name {
    display: block;
    color: #212529;
    text-align: center;
    line-height: 1.2
}

.pattern-name {
    font-weight: 700;
    margin-bottom: 5px
}

.pattern-aka {
    font-size: .75rem
}

.pattern-card-extended {
    display: block;
    box-sizing: border-box;
    border: solid 1px rgba(0, 0, 0, .125);
    padding: 14px;
    margin: 5px 0;
    width: 100%;
    min-width: 315px;
    overflow: hidden
}

.pattern-card-extended .pattern-image {
    display: block;
    width: 140px;
    height: auto;
    float: left
}

.pattern-card-extended .pattern-image img {
    width: 140px
}

.pattern-card-extended .pattern-aka, .pattern-card-extended .pattern-name {
    margin-left: 160px;
    text-align: left;
    word-break: break-word
}

.pattern-card-extended .pattern-name {
    font-size: 24px;
    margin-top: 30px
}

.pattern-card-extended .pattern-name.pattern-name-long {
    font-size: 20px;
    margin-top: 20px
}

.pattern-card-extended .pattern-name.with-aka {
    font-size: 22px;
    margin-top: 15px
}

.pattern-card-extended .pattern-name.with-aka.pattern-name-long {
    font-size: 20px;
    margin-top: 10px
}

.pattern-card-extended .pattern-aka {
    font-size: 16px
}

@media (min-width: 768px) {
    .pattern-card-extended {
        width: 50%
    }
}

@media (min-width: 992px) {
    .pattern-card-extended {
        width: 45%;
        margin: 0 0 15px 0
    }
}

@media (min-width: 1340px) {
    .pattern-card-extended {
        width: 32%
    }
}

a.pattern-card-extended {
    text-decoration: none
}

a.pattern-card-extended:hover {
    text-decoration: none;
    border: solid 1px #ea6153
}

.pattern-card-top {
    display: block;
    overflow: hidden;
    margin-bottom: 15px
}

.pattern-card-bottom {
    display: block;
    color: #444
}

.pattern-example-title-block {
    margin-bottom: 1.5rem
}

.pattern-example-title-block-image {
    display: none
}

.pattern-example-title-block-title {
    margin: 0 !important
}

.pattern-example-title-block {
    display: flex;
    gap: 1rem;
    align-items: center
}

.pattern-example-title-block-image {
    display: block
}

.pattern-example-brief {
    margin-bottom: 12px;
    clear: both
}

@media (min-width: 576px) {
    .pattern-card-example {
        width: 140px;
        float: left;
        margin-bottom: .5rem;
        margin-right: 20px
    }

    .pattern-example-brief {
        margin-bottom: 16px
    }
}

.sidebar-navigation {
    border: solid 2px #ecf0f1;
    padding: 30px
}

.sidebar-navigation .en-title {
    font-weight: 700;
    font-size: 2rem;
    line-height: 2rem;
    margin: -.75rem 0 .5rem
}

.sidebar-navigation .en-intro {
    margin: 1rem 0 0
}

.sidebar-navigation a {
    white-space: normal
}

.sidebar-navigation .en-dir, .sidebar-navigation .en-file, .sidebar-navigation .en-inside, .sidebar-navigation .en-intro {
    padding-left: 25px
}

.sidebar-navigation .fa {
    margin-left: -25px
}

.pattern-example .sidebar-navigation .fa-angle-right {
    transform: rotate(135deg)
}

.pattern-example .sidebar-navigation .en-inside > .en-inside {
    padding-left: 15px
}

.pattern-example .sidebar-navigation .en-inside {
    padding-left: 0
}

@media (min-width: 1200px) {
    .pattern-example.page .sidebar-navigation {
        display: none
    }
}

@media (max-width: 1199.98px) {
    .pattern-example .feature .sidebar-navigation {
        display: none
    }
}

@media (max-width: 991.98px) {
    .pattern-example-tabs {
        display: none
    }

    .pattern-example-tab-content .tab-pane {
        display: block !important
    }
}

@media (min-width: 992px) {
    .pattern-example .tab-pane {
        border-left: solid 1px #dee2e6;
        border-right: solid 1px #dee2e6;
        padding: 1rem 2rem
    }

    .pattern-example-tabs {
        margin-top: 3rem
    }
}

.pattern .vertical-align {
    display: flex;
    align-items: center
}

.pattern .applicability {
    padding-left: 28px
}

.pattern .applicability .applicability-problem {
    font-weight: 700;
    margin-bottom: 1.5rem
}

.pattern .applicability .applicability-solution {
    margin-bottom: 2rem;
    border-bottom: dotted 1px #eee
}

.pattern .applicability .applicability-solution > p:last-child {
    margin-bottom: 1.5rem
}

.pattern .applicability .applicability-solution:last-child {
    border-bottom: none
}

.pattern .applicability .applicability-solution:last-child > p:last-child {
    margin-bottom: 0
}

.pattern .applicability .fa {
    margin-left: -31px;
    font-size: 20px
}

.pattern .big-arrow, .pattern .big-bug {
    text-align: center;
    font-size: 30px
}

.pattern .big-arrow {
    padding-right: 0
}

.pattern .pros-cons ul {
    list-style: none;
    margin-bottom: 0;
    padding: 0 0 0 27px
}

.pattern .pros-cons ul li > .fa {
    margin-left: -24px
}

.pattern .fa-check {
    color: #45670d !important
}

.pattern .fa-times {
    color: #a00 !important
}

.structure-container {
    box-shadow: 0 0 20px 20px #fff;
    background: #fff;
    z-index: 5;
    position: relative
}

.structure-container h4 {
    border-top: solid 1px rgba(0, 0, 0, .125);
    padding-top: 1.5rem
}

@media (min-width: 1200px) {
    .structure-container {
        width: calc(100% + 340px)
    }

    .structure {
        position: relative;
        margin: 100px auto;
        width: 568px
    }

    .structure .struct-image {
        position: absolute;
        opacity: 1
    }

    .structure .struct-image .image {
        margin: 0
    }

    .structure ol {
        font-size: 14px;
        line-height: 20px;
        list-style: none;
        margin: 0;
        padding: 0;
        counter-reset: my-badass-counter
    }

    .structure ol li {
        position: absolute;
        background: #f5f5f5;
        opacity: .4;
        transition: opacity .5s;
        padding: 15px;
        margin: 0
    }

    .structure ol li.positionable-extension-positioned-element-focused, .structure ol li:hover {
        opacity: 1
    }

    .structure ol li p {
        margin: 20px 0 !important
    }

    .structure ol li p:first-child {
        margin-top: 0 !important
    }

    .structure ol li p:last-child {
        margin-bottom: 0 !important
    }

    .structure ol li:before {
        content: counter(my-badass-counter);
        counter-increment: my-badass-counter;
        position: absolute;
        left: -10px;
        margin-top: -9px;
        font-size: 40px;
        font-weight: 700;
        color: #ccc
    }
}

.prog-lang-link {
    display: inline-block;
    border: solid #eee 2px;
    background: 0 0 !important;
    border-radius: 10px;
    padding: 10px 5px
}

.prog-lang-link:hover {
    border-color: #e74c3c
}

.prog-lang-link img {
    width: 46px;
    height: 57px
}

@media (max-width: 720px),(min-width: 992px) and (max-width: 1030px),(min-width: 1200px) and (max-width: 1355px) {
    .implementations p {
        display: flex;
        align-content: center;
        flex-wrap: wrap;
        justify-content: space-around
    }

    .prog-lang-link {
        display: inline-block;
        margin: 0 0 5px 0
    }

    .prog-lang-link img {
        width: 70px;
        height: 70px
    }
}

.dp1-h {
    margin-top: 0 !important;
    text-transform: uppercase;
    text-align: center
}

.dp1-h-1 {
    font-size: 54px;
    line-height: 45px;
    color: #000;
    display: block
}

.dp1-h-2 {
    font-size: 31px;
    line-height: 54px;
    display: block
}

@media (min-width: 320px) {
    .dp1-h-1 {
        font-size: 80px;
        line-height: 59px;
        color: #000;
        display: block
    }

    .dp1-h-2 {
        font-size: 57px;
        line-height: 63px;
        display: block
    }
}

@media (min-width: 712px) {
    .dp1-h-1 {
        font-size: 5rem;
        line-height: 5rem
    }

    .dp1-h-2 {
        font-size: 4rem;
        line-height: 4rem
    }
}

.locale-es .dp1-h-1, .locale-fr .dp1-h-1, .locale-pt-br .dp1-h-1 {
    color: #000;
    display: block
}

.locale-es .dp-h-article, .locale-es .dp1-h-2, .locale-fr .dp-h-article, .locale-fr .dp1-h-2, .locale-pt-br .dp-h-article, .locale-pt-br .dp1-h-2 {
    display: block
}

@media (min-width: 320px) {
    .locale-es .dp1-h-1, .locale-fr .dp1-h-1, .locale-pt-br .dp1-h-1 {
        color: #000;
        display: inline
    }

    .locale-es .dp-h-article, .locale-es .dp1-h-2, .locale-fr .dp-h-article, .locale-fr .dp1-h-2, .locale-pt-br .dp-h-article, .locale-pt-br .dp1-h-2 {
        display: inline
    }
}

.locale-es .dp-h-article, .locale-es .dp1-h-1, .locale-es .dp1-h-2, .locale-pt-br .dp-h-article, .locale-pt-br .dp1-h-1, .locale-pt-br .dp1-h-2 {
    font-size: 54px;
    line-height: 45px
}

@media (min-width: 320px) {
    .locale-es .dp-h-article, .locale-es .dp1-h-1, .locale-es .dp1-h-2, .locale-pt-br .dp-h-article, .locale-pt-br .dp1-h-1, .locale-pt-br .dp1-h-2 {
        font-size: 80px;
        line-height: 59px
    }
}

@media (min-width: 712px) {
    .locale-es .dp-h-article, .locale-es .dp1-h-1, .locale-es .dp1-h-2, .locale-pt-br .dp-h-article, .locale-pt-br .dp1-h-1, .locale-pt-br .dp1-h-2 {
        font-size: 5rem;
        line-height: 5rem
    }
}

.locale-fr .dp-h-article, .locale-fr .dp1-h-1, .locale-fr .dp1-h-2 {
    font-size: 2rem;
    line-height: 2rem
}

@media (min-width: 576px) {
    .locale-fr .dp-h-article, .locale-fr .dp1-h-1, .locale-fr .dp1-h-2 {
        font-size: 4rem;
        line-height: 4rem
    }
}

.locale-ru .dp1-h-1, .locale-uk .dp1-h-1 {
    font-size: 54px;
    line-height: 54px
}

.locale-ru .dp1-h-2, .locale-uk .dp1-h-2 {
    font-size: 31px;
    line-height: 31px;
    display: block
}

@media (min-width: 370px) {
    .locale-ru .dp1-h-1, .locale-uk .dp1-h-1 {
        font-size: 65px;
        line-height: 45px
    }

    .locale-ru .dp1-h-2, .locale-uk .dp1-h-2 {
        font-size: 37px;
        line-height: 54px
    }
}

@media (min-width: 712px) {
    .locale-ru .dp1-h-1, .locale-ru .dp1-h-2, .locale-uk .dp1-h-1, .locale-uk .dp1-h-2 {
        font-size: 5rem;
        line-height: 5rem
    }
}

.locale-zh .dp1-h-1 {
    color: #000;
    display: block
}

.locale-zh .dp1-h-2 {
    display: block
}

.mob-image {
    text-align: center;
    margin: 0 0 1rem 0
}

@media (min-width: 712px) {
    .mob-image {
        display: none
    }
}

.dp-lang-main-page .dp1-h {
    text-align: center;
    margin-top: 0 !important
}

.dp-lang-main-page .dp-lang, .dp-lang-main-page .dp-lang-in {
    display: none
}

.dp-lang-main-page .dp-bg {
    display: none
}

.dp-lang-main-page .dp-the-catalog {
    display: none
}

.dp-lang-main-page .text .dp-h2 {
    text-align: center;
    font-size: 2rem;
    line-height: 2rem
}

.dp-lang-main-page .text .dp-h4 {
    text-align: center;
    font-size: 1.5rem;
    line-height: 2rem;
    border-bottom: solid 2px #eee
}

.dp-lang-main-page .text .dp-pattern-item {
    margin: 0 0 1.5rem;
    padding: 0 0 1.5rem;
    border-bottom: solid 1px #eee
}

.dp-lang-main-page .text .dp-pattern-title {
    margin: 0 0 .5rem 0;
    line-height: 1rem
}

.dp-lang-main-page .text .dp-pattern-title i {
    font-size: .8125rem;
    vertical-align: bottom;
    line-height: 1rem
}

.dp-lang-main-page .text .dp-pattern-title .dp-popularity {
    white-space: nowrap
}

.dp-lang-main-page .dp-pattern-aka {
    margin: -.5rem 0 .5rem
}

.dp-lang-main-page .text .dp-pattern-intent {
    margin: .5rem 0;
    font-size: .875rem;
    line-height: 1.5
}

.dp-lang-main-page .text .dp-pattern-links {
    clear: both
}

.dp-lang-main-page .text .dp-pattern-link {
    display: inline-block;
    text-decoration: none;
    line-height: 1.25rem
}

.dp-lang-main-page .text .dp-pattern-link a {
    text-decoration: none;
    font-weight: 700;
    color: #444
}

.dp-lang-main-page .text .dp-pattern-link i {
    text-decoration: none;
    font-weight: 700;
    color: #444
}

.dp-lang-main-page .text .dp-pattern-link span {
    text-decoration: none;
    font-weight: 700;
    color: #444;
    box-shadow: inset 0 -2px 0 #f29f97
}

.dp-lang-main-page .text .dp-pattern-link:hover span {
    color: #ea6153;
    box-shadow: inset 0 -2px 0 #ea6153
}

.dp-lang-main-page .text .dp-pattern-card {
    float: left;
    margin-right: 20px
}

.dp-lang-main-page .text .dp-pattern-card img {
    width: 105px
}

.dp-lang-main-page .text .dp-pattern-intent, .dp-lang-main-page .text .dp-pattern-title {
    margin-left: 125px
}

@media (min-width: 350px) {
    .dp-lang-main-page .text .dp-pattern-links {
        display: grid;
        grid-template-columns:auto auto;
        grid-template-rows:auto auto;
        grid-column-gap: 1rem;
        grid-row-gap: .5rem;
        grid-auto-flow: column
    }
}

@media (min-width: 560px) {
    .dp-lang-main-page .text .dp-pattern-links {
        clear: both;
        margin-left: 125px
    }
}

@media (min-width: 712px) {
    .dp-lang-main-page .illustration-container {
        position: relative;
        transform-origin: 0 0;
        height: 675px
    }

    .dp-lang-main-page .text .dp-bg {
        display: block;
        max-width: none;
        position: absolute;
        z-index: 0
    }

    .dp-lang-main-page .dp1-h {
        margin-top: 0 !important;
        text-align: center;
        font-size: 6rem;
        line-height: 6rem;
        position: absolute;
        left: 0;
        width: 960px
    }

    .locale-ru .dp-lang-main-page .dp1-h {
        font-size: 5rem;
        line-height: 5rem
    }

    .locale-uk .dp-lang-main-page .dp1-h {
        font-size: 5.5rem;
        line-height: 5rem
    }

    .dp-lang-main-page .dp-lang-in {
        display: block;
        font-size: 2rem;
        line-height: 2rem;
        text-transform: lowercase;
        text-shadow: 0 3px #fff, 0 -3px #fff, 3px 0 #fff, -3px 0 #fff, 3px 3px #fff, -3px 3px #fff, 3px -3px #fff, -3px -3px #fff
    }

    .dp-lang-main-page .dp-h-article {
        text-transform: lowercase;
        text-shadow: 0 3px #fff, 0 -3px #fff, 3px 0 #fff, -3px 0 #fff, 3px 3px #fff, -3px 3px #fff, 3px -3px #fff, -3px -3px #fff
    }

    .dp-lang-main-page .dp-lang {
        display: block;
        font-size: 6rem;
        line-height: 6rem;
        color: #000;
        text-shadow: 0 5px #fff, 0 -5px #fff, 5px 0 #fff, -5px 0 #fff, 5px 5px #fff, -5px 5px #fff, 5px -5px #fff, -5px -5px #fff, 0 3px #fff, 0 -3px #fff, 3px 0 #fff, -3px 0 #fff, 3px 3px #fff, -3px 3px #fff, 3px -3px #fff, -3px -3px #fff
    }

    .dp-lang-main-page .dp-the-catalog {
        display: inline
    }

    .dp-lang-main-page .text .dp-h2 {
        font-size: 3rem;
        line-height: 3rem;
        margin: 24px 0 48px;
        text-shadow: 0 3px #fff, 0 -3px #fff, 3px 0 #fff, -3px 0 #fff, 3px 3px #fff, -3px 3px #fff, 3px -3px #fff, -3px -3px #fff;
        position: relative;
        z-index: 1
    }

    .dp-lang-main-page .dp-double-cols {
        display: grid;
        grid-template-columns:50% 50%;
        grid-column-gap: 2rem;
        grid-template-rows:auto;
        grid-auto-flow: dense
    }

    .dp-lang-main-page .dp-double-cols {
        display: grid
    }

    .dp-lang-main-page .text .dp-creational-title {
        grid-column: 1
    }

    .dp-lang-main-page .text .dp-creational {
        grid-column: 1;
        margin-top: 0
    }

    .dp-lang-main-page .text .dp-structural-title {
        grid-column: 2;
        margin-top: 0
    }

    .dp-lang-main-page .text .dp-structural {
        grid-column: 2
    }

    .dp-lang-main-page .text .dp-pattern-links {
        margin-left: 0
    }
}

@media (min-width: 1200px) {
    .dp-lang-main-page .text .dp-pattern-links {
        margin-left: 0
    }
}

@media (min-width: 1300px) {
    .dp-lang-main-page .text .dp-pattern-links {
        margin-left: 125px
    }

    .locale-ru .dp-lang-main-page .text .dp-pattern-links, .locale-uk .dp-lang-main-page .text .dp-pattern-links {
        margin-left: 0
    }
}

.hr {
    margin: 50px 0;
    border-top: solid 1px #eee
}

@media (min-width: 768px) {
    .index-grid {
        display: grid;
        grid:1fr/1fr 1fr;
        column-gap: 2rem
    }
}

.author .signature br {
    display: inline
}

@media (min-width: 576px) {
    .author .signature {
        text-align: right
    }
}

@media (min-width: 1200px) and (max-width: 1460px) {
    .locale-fr .navigation .caption {
        display: none !important
    }
}

@keyframes border-animation {
    0% {
        border-color: #000
    }
    25% {
        border-color: #800
    }
    100% {
        border-color: #000
    }
}

.main-menu .russia-stop {
    display: none
}

@media (min-width: 992px) {
    .main-menu .russia-stop {
        display: block;
        left: 50px;
        top: -138px;
        width: 146px;
        color: #000;
        text-align: center;
        position: absolute;
        font-size: 16px;
        line-height: 18px;
        background-color: #fff;
        border: solid 8px #000;
        text-shadow: none;
        animation: border-animation 1s infinite
    }

    .main-menu .russia-stop:hover {
        transform: scale(1.1);
        background-color: #fff
    }

    .main-menu .russia-stop:active, .main-menu .russia-stop:focus {
        transform: scale(1.1);
        background-color: #fff
    }
}

.navigation .russia-stop {
    display: block;
    left: 0;
    width: 100%;
    color: #000;
    text-align: center;
    position: absolute;
    font-size: 1.25rem;
    line-height: 1.75rem;
    background-color: #fff;
    border: solid 8px #000;
    text-shadow: none;
    animation: border-animation 1s infinite
}

.navigation .russia-stop:hover {
    transform: scale(1.1);
    background-color: #fff
}

.navigation .russia-stop:active, .navigation .russia-stop:focus {
    transform: scale(1.1);
    background-color: #fff
}