@charset "UTF-8";
/*!
 * Bootstrap v4.0.0-beta (https://getbootstrap.com)
 * Copyright 2011-2017 The Bootstrap Authors
 * Copyright 2011-2017 Twitter, Inc.
 * Licensed under MIT (https://github.com/twbs/bootstrap/blob/master/LICENSE)
 */

@media print {
    *,
    :after,
    :before {
        box-shadow: none !important;
        text-shadow: none !important
    }
    a,
    a:visited {
        text-decoration: underline
    }
    abbr[title]:after {
        content: " (" attr(title) ")"
    }
    pre {
        white-space: pre-wrap !important
    }
    blockquote,
    pre {
        border: 1px solid #999;
        page-break-inside: avoid
    }
    thead {
        display: table-header-group
    }
    img,
    tr {
        page-break-inside: avoid
    }
    h2,
    h3,
    p {
        orphans: 3;
        widows: 3
    }
    h2,
    h3 {
        page-break-after: avoid
    }
    .navbar {
        display: none
    }
    .badge {
        border: 1px solid #000
    }
    .table {
        border-collapse: collapse !important
    }
    .table td,
    .table th {
        background-color: #fff !important
    }
    .table-bordered td,
    .table-bordered th {
        border: 1px solid #ddd !important
    }
}

html {
    -ms-overflow-style: scrollbar;
    -webkit-tap-highlight-color: transparent;
    box-sizing: border-box;
    line-height: 1.15
}

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

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

body {
    background-color: #fff;
    color: #212529;
    font-size: 1rem;
    font-weight: 400;
    line-height: 1.5
}

[tabindex="-1"]:focus {
    outline: none !important
}

hr {
    overflow: visible
}

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

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

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

address {
    font-style: normal;
    line-height: inherit
}

address,
dl,
ol,
ul {
    margin-bottom: 1rem
}

dl,
ol,
ul {
    margin-top: 0
}

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
}

dfn {
    font-style: italic
}

b,
strong {
    font-weight: bolder
}

small {
    font-size: 80%
}

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

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

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

a:not([href]):not([tabindex]):focus {
    outline: 0
}

code,
kbd,
pre,
samp {
    font-family: monospace, monospace
}

pre {
    overflow: auto
}

figure {
    margin: 0 0 1rem
}

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

[role=button],
a,
area,
button,
input,
label,
select,
summary,
textarea {
    touch-action: manipulation
}

caption {
    caption-side: bottom;
    color: #868e96;
    padding-bottom: .75rem;
    padding-top: .75rem
}

caption,
th {
    text-align: left
}

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

button:focus {
    outline: 1px dotted;
    outline: 5px auto -webkit-focus-ring-color
}

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

button,
input {
    overflow: visible
}

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

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

input[type=date],
input[type=datetime-local],
input[type=month],
input[type=time] {
    -webkit-appearance: listbox
}

textarea {
    resize: vertical
}

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

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

progress {
    vertical-align: baseline
}

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

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

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

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

output {
    display: inline-block
}

summary {
    display: list-item
}

template {
    display: none
}

[hidden] {
    display: none !important
}

.h1,
.h2,
.h3,
.h4,
.h5,
.h6,
h1,
h2,
h3,
h4,
h5,
h6 {
    color: inherit;
    font-family: inherit;
    font-weight: 500;
    line-height: 1.1;
    margin-bottom: .5rem
}

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

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

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

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

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

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

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

.display-1 {
    font-size: 6rem
}

.display-1,
.display-2 {
    font-weight: 300;
    line-height: 1.1
}

.display-2 {
    font-size: 5.5rem
}

.display-3 {
    font-size: 4.5rem
}

.display-3,
.display-4 {
    font-weight: 300;
    line-height: 1.1
}

.display-4 {
    font-size: 3.5rem
}

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

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

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

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

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

.list-inline-item:not(:last-child) {
    margin-right: 5px
}

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

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

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

.blockquote-footer:before {
    content: "— "
}

.img-fluid,
.img-thumbnail {
    height: auto;
    max-width: 100%
}

.img-thumbnail {
    background-color: #fff;
    border: 1px solid #ddd;
    border-radius: .25rem;
    padding: .25rem;
    transition: all .2s ease-in-out
}

.figure {
    display: inline-block
}

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

.figure-caption {
    color: #868e96;
    font-size: 90%
}

code,
kbd,
pre,
samp {
    font-family: Menlo, Monaco, Consolas, Liberation Mono, Courier New, monospace
}

code {
    background-color: #f8f9fa;
    border-radius: .25rem;
    color: #bd4147;
    font-size: 90%;
    padding: .2rem .4rem
}

a>code {
    background-color: inherit;
    color: inherit;
    padding: 0
}

kbd {
    background-color: #212529;
    border-radius: .2rem;
    color: #fff;
    font-size: 90%;
    padding: .2rem .4rem
}

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

pre {
    color: #212529;
    display: block;
    font-size: 90%;
    margin-bottom: 1rem;
    margin-top: 0
}

pre code {
    background-color: transparent;
    border-radius: 0;
    color: inherit;
    font-size: inherit;
    padding: 0
}

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

.container {
    margin-left: auto;
    margin-right: auto;
    padding-left: 15px;
    padding-right: 15px
}

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

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

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

@media (min-width:1200px) {
    .container {
        max-width: 1140px
    }
}

.container-fluid {
    margin-left: auto;
    margin-right: auto;
    padding-left: 15px;
    padding-right: 15px;
    width: 100%
}

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

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

.no-gutters>.col,
.no-gutters>[class*=col-] {
    padding-left: 0;
    padding-right: 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 {
    min-height: 1px;
    padding-left: 15px;
    padding-right: 15px;
    position: relative;
    width: 100%
}

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

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

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

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

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

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

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

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

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

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

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

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

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

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

.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
}

@media (min-width:576px) {
    .col-sm {
        flex-basis: 0;
        flex-grow: 1;
        max-width: 100%
    }
    .col-sm-auto {
        flex: 0 0 auto;
        max-width: none;
        width: auto
    }
    .col-sm-1 {
        flex: 0 0 8.333333%;
        max-width: 8.333333%
    }
    .col-sm-2 {
        flex: 0 0 16.666667%;
        max-width: 16.666667%
    }
    .col-sm-3 {
        flex: 0 0 25%;
        max-width: 25%
    }
    .col-sm-4 {
        flex: 0 0 33.333333%;
        max-width: 33.333333%
    }
    .col-sm-5 {
        flex: 0 0 41.666667%;
        max-width: 41.666667%
    }
    .col-sm-6 {
        flex: 0 0 50%;
        max-width: 50%
    }
    .col-sm-7 {
        flex: 0 0 58.333333%;
        max-width: 58.333333%
    }
    .col-sm-8 {
        flex: 0 0 66.666667%;
        max-width: 66.666667%
    }
    .col-sm-9 {
        flex: 0 0 75%;
        max-width: 75%
    }
    .col-sm-10 {
        flex: 0 0 83.333333%;
        max-width: 83.333333%
    }
    .col-sm-11 {
        flex: 0 0 91.666667%;
        max-width: 91.666667%
    }
    .col-sm-12 {
        flex: 0 0 100%;
        max-width: 100%
    }
    .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
    }
}

@media (min-width:768px) {
    .col-md {
        flex-basis: 0;
        flex-grow: 1;
        max-width: 100%
    }
    .col-md-auto {
        flex: 0 0 auto;
        max-width: none;
        width: auto
    }
    .col-md-1 {
        flex: 0 0 8.333333%;
        max-width: 8.333333%
    }
    .col-md-2 {
        flex: 0 0 16.666667%;
        max-width: 16.666667%
    }
    .col-md-3 {
        flex: 0 0 25%;
        max-width: 25%
    }
    .col-md-4 {
        flex: 0 0 33.333333%;
        max-width: 33.333333%
    }
    .col-md-5 {
        flex: 0 0 41.666667%;
        max-width: 41.666667%
    }
    .col-md-6 {
        flex: 0 0 50%;
        max-width: 50%
    }
    .col-md-7 {
        flex: 0 0 58.333333%;
        max-width: 58.333333%
    }
    .col-md-8 {
        flex: 0 0 66.666667%;
        max-width: 66.666667%
    }
    .col-md-9 {
        flex: 0 0 75%;
        max-width: 75%
    }
    .col-md-10 {
        flex: 0 0 83.333333%;
        max-width: 83.333333%
    }
    .col-md-11 {
        flex: 0 0 91.666667%;
        max-width: 91.666667%
    }
    .col-md-12 {
        flex: 0 0 100%;
        max-width: 100%
    }
    .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
    }
}

@media (min-width:992px) {
    .col-lg {
        flex-basis: 0;
        flex-grow: 1;
        max-width: 100%
    }
    .col-lg-auto {
        flex: 0 0 auto;
        max-width: none;
        width: auto
    }
    .col-lg-1 {
        flex: 0 0 8.333333%;
        max-width: 8.333333%
    }
    .col-lg-2 {
        flex: 0 0 16.666667%;
        max-width: 16.666667%
    }
    .col-lg-3 {
        flex: 0 0 25%;
        max-width: 25%
    }
    .col-lg-4 {
        flex: 0 0 33.333333%;
        max-width: 33.333333%
    }
    .col-lg-5 {
        flex: 0 0 41.666667%;
        max-width: 41.666667%
    }
    .col-lg-6 {
        flex: 0 0 50%;
        max-width: 50%
    }
    .col-lg-7 {
        flex: 0 0 58.333333%;
        max-width: 58.333333%
    }
    .col-lg-8 {
        flex: 0 0 66.666667%;
        max-width: 66.666667%
    }
    .col-lg-9 {
        flex: 0 0 75%;
        max-width: 75%
    }
    .col-lg-10 {
        flex: 0 0 83.333333%;
        max-width: 83.333333%
    }
    .col-lg-11 {
        flex: 0 0 91.666667%;
        max-width: 91.666667%
    }
    .col-lg-12 {
        flex: 0 0 100%;
        max-width: 100%
    }
    .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
    }
}

@media (min-width:1200px) {
    .col-xl {
        flex-basis: 0;
        flex-grow: 1;
        max-width: 100%
    }
    .col-xl-auto {
        flex: 0 0 auto;
        max-width: none;
        width: auto
    }
    .col-xl-1 {
        flex: 0 0 8.333333%;
        max-width: 8.333333%
    }
    .col-xl-2 {
        flex: 0 0 16.666667%;
        max-width: 16.666667%
    }
    .col-xl-3 {
        flex: 0 0 25%;
        max-width: 25%
    }
    .col-xl-4 {
        flex: 0 0 33.333333%;
        max-width: 33.333333%
    }
    .col-xl-5 {
        flex: 0 0 41.666667%;
        max-width: 41.666667%
    }
    .col-xl-6 {
        flex: 0 0 50%;
        max-width: 50%
    }
    .col-xl-7 {
        flex: 0 0 58.333333%;
        max-width: 58.333333%
    }
    .col-xl-8 {
        flex: 0 0 66.666667%;
        max-width: 66.666667%
    }
    .col-xl-9 {
        flex: 0 0 75%;
        max-width: 75%
    }
    .col-xl-10 {
        flex: 0 0 83.333333%;
        max-width: 83.333333%
    }
    .col-xl-11 {
        flex: 0 0 91.666667%;
        max-width: 91.666667%
    }
    .col-xl-12 {
        flex: 0 0 100%;
        max-width: 100%
    }
    .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
    }
}

.table {
    background-color: transparent;
    margin-bottom: 1rem;
    max-width: 100%;
    width: 100%
}

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

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

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

.table .table {
    background-color: #fff
}

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

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

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

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

.table-hover tbody tr:hover {
    background-color: rgba(0, 0, 0, .075)
}

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

.thead-inverse th {
    background-color: #212529;
    color: #fff
}

.thead-default th {
    background-color: #e9ecef;
    color: #495057
}

.table-inverse {
    background-color: #212529;
    color: #fff
}

.table-inverse td,
.table-inverse th,
.table-inverse thead th {
    border-color: #32383e
}

.table-inverse.table-bordered {
    border: 0
}

.table-inverse.table-striped tbody tr:nth-of-type(odd) {
    background-color: hsla(0, 0%, 100%, .05)
}

.table-inverse.table-hover tbody tr:hover {
    background-color: hsla(0, 0%, 100%, .075)
}

@media (max-width:991px) {
    .table-responsive {
        -ms-overflow-style: -ms-autohiding-scrollbar;
        display: block;
        overflow-x: auto;
        width: 100%
    }
    .table-responsive.table-bordered {
        border: 0
    }
}

.form-control {
    background-clip: padding-box;
    background-color: #fff;
    background-image: none;
    border: 1px solid rgba(0, 0, 0, .15);
    border-radius: .25rem;
    color: #495057;
    display: block;
    font-size: 1rem;
    line-height: 1.25;
    padding: .5rem .75rem;
    transition: border-color .15s ease-in-out, box-shadow .15s ease-in-out;
    width: 100%
}

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

.form-control:focus {
    background-color: #fff;
    border-color: #80bdff;
    color: #495057;
    outline: none
}

.form-control::-moz-placeholder {
    color: #868e96;
    opacity: 1
}

.form-control::placeholder {
    color: #868e96;
    opacity: 1
}

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

select.form-control:not([size]):not([multiple]) {
    height: calc(2.25rem + 2px)
}

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

.form-control-file,
.form-control-range {
    display: block
}

.col-form-label {
    margin-bottom: 0
}

.col-form-label,
.col-form-label-lg {
    padding-bottom: calc(.5rem - 2px);
    padding-top: calc(.5rem - 2px)
}

.col-form-label-lg {
    font-size: 1.25rem
}

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

.col-form-legend {
    font-size: 1rem
}

.col-form-legend,
.form-control-plaintext {
    margin-bottom: 0;
    padding-bottom: .5rem;
    padding-top: .5rem
}

.form-control-plaintext {
    border: solid transparent;
    border-width: 1px 0;
    line-height: 1.25
}

.form-control-plaintext.form-control-lg,
.form-control-plaintext.form-control-sm,
.input-group-lg>.form-control-plaintext.form-control,
.input-group-lg>.form-control-plaintext.input-group-addon,
.input-group-lg>.input-group-btn>.form-control-plaintext.btn,
.input-group-sm>.form-control-plaintext.form-control,
.input-group-sm>.form-control-plaintext.input-group-addon,
.input-group-sm>.input-group-btn>.form-control-plaintext.btn {
    padding-left: 0;
    padding-right: 0
}

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

.input-group-sm>.input-group-btn>select.btn:not([size]):not([multiple]),
.input-group-sm>select.form-control:not([size]):not([multiple]),
.input-group-sm>select.input-group-addon:not([size]):not([multiple]),
select.form-control-sm:not([size]):not([multiple]) {
    height: calc(1.8125rem + 2px)
}

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

.input-group-lg>.input-group-btn>select.btn:not([size]):not([multiple]),
.input-group-lg>select.form-control:not([size]):not([multiple]),
.input-group-lg>select.input-group-addon:not([size]):not([multiple]),
select.form-control-lg:not([size]):not([multiple]) {
    height: calc(2.3125rem + 2px)
}

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

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

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

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

.form-check {
    display: block;
    margin-bottom: .5rem;
    position: relative
}

.form-check.disabled .form-check-label {
    color: #868e96
}

.form-check-label {
    margin-bottom: 0;
    padding-left: 1.25rem
}

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

.form-check-input:only-child {
    position: static
}

.form-check-inline {
    display: inline-block
}

.form-check-inline .form-check-label {
    vertical-align: middle
}

.form-check-inline+.form-check-inline {
    margin-left: .75rem
}

.invalid-feedback {
    color: #dc3545;
    display: none;
    font-size: .875rem;
    margin-top: .25rem
}

.invalid-tooltip {
    background-color: rgba(220, 53, 69, .8);
    border-radius: .2rem;
    color: #fff;
    display: none;
    font-size: .875rem;
    line-height: 1;
    margin-top: .1rem;
    padding: .5rem;
    position: absolute;
    top: 100%;
    width: 250px;
    z-index: 5
}

.custom-select.is-valid,
.form-control.is-valid,
.was-validated .custom-select:valid,
.was-validated .form-control:valid {
    border-color: #28a745
}

.custom-select.is-valid:focus,
.form-control.is-valid:focus,
.was-validated .custom-select:valid:focus,
.was-validated .form-control:valid:focus {
    box-shadow: 0 0 0 .2rem rgba(40, 167, 69, .25)
}

.custom-select.is-valid~.invalid-feedback,
.custom-select.is-valid~.invalid-tooltip,
.form-control.is-valid~.invalid-feedback,
.form-control.is-valid~.invalid-tooltip,
.was-validated .custom-select:valid~.invalid-feedback,
.was-validated .custom-select:valid~.invalid-tooltip,
.was-validated .form-control:valid~.invalid-feedback,
.was-validated .form-control:valid~.invalid-tooltip {
    display: block
}

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

.custom-control-input.is-valid~.custom-control-indicator,
.was-validated .custom-control-input:valid~.custom-control-indicator {
    background-color: rgba(40, 167, 69, .25)
}

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

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

.custom-file-input.is-valid~.custom-file-control:before,
.was-validated .custom-file-input:valid~.custom-file-control:before {
    border-color: inherit
}

.custom-file-input.is-valid:focus,
.was-validated .custom-file-input:valid:focus {
    box-shadow: 0 0 0 .2rem rgba(40, 167, 69, .25)
}

.custom-select.is-invalid,
.form-control.is-invalid,
.was-validated .custom-select:invalid,
.was-validated .form-control:invalid {
    border-color: #dc3545
}

.custom-select.is-invalid:focus,
.form-control.is-invalid:focus,
.was-validated .custom-select:invalid:focus,
.was-validated .form-control:invalid:focus {
    box-shadow: 0 0 0 .2rem rgba(220, 53, 69, .25)
}

.custom-select.is-invalid~.invalid-feedback,
.custom-select.is-invalid~.invalid-tooltip,
.form-control.is-invalid~.invalid-feedback,
.form-control.is-invalid~.invalid-tooltip,
.was-validated .custom-select:invalid~.invalid-feedback,
.was-validated .custom-select:invalid~.invalid-tooltip,
.was-validated .form-control:invalid~.invalid-feedback,
.was-validated .form-control:invalid~.invalid-tooltip {
    display: block
}

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

.custom-control-input.is-invalid~.custom-control-indicator,
.was-validated .custom-control-input:invalid~.custom-control-indicator {
    background-color: rgba(220, 53, 69, .25)
}

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

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

.custom-file-input.is-invalid~.custom-file-control:before,
.was-validated .custom-file-input:invalid~.custom-file-control:before {
    border-color: inherit
}

.custom-file-input.is-invalid:focus,
.was-validated .custom-file-input:invalid:focus {
    box-shadow: 0 0 0 .2rem rgba(220, 53, 69, .25)
}

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

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

@media (min-width:576px) {
    .form-inline label {
        justify-content: center
    }
    .form-inline .form-group,
    .form-inline label {
        align-items: center;
        display: flex;
        margin-bottom: 0
    }
    .form-inline .form-group {
        flex: 0 0 auto;
        flex-flow: row wrap
    }
    .form-inline .form-control {
        display: inline-block;
        vertical-align: middle;
        width: auto
    }
    .form-inline .form-control-plaintext {
        display: inline-block
    }
    .form-inline .input-group {
        width: auto
    }
    .form-inline .form-control-label {
        margin-bottom: 0;
        vertical-align: middle
    }
    .form-inline .form-check {
        align-items: center;
        display: flex;
        justify-content: center;
        margin-bottom: 0;
        margin-top: 0;
        width: auto
    }
    .form-inline .form-check-label {
        padding-left: 0
    }
    .form-inline .form-check-input {
        margin-left: 0;
        margin-right: .25rem;
        margin-top: 0;
        position: relative
    }
    .form-inline .custom-control {
        align-items: center;
        display: flex;
        justify-content: center;
        padding-left: 0
    }
    .form-inline .custom-control-indicator {
        display: inline-block;
        margin-right: .25rem;
        position: static;
        vertical-align: text-bottom
    }
    .form-inline .has-feedback .form-control-feedback {
        top: 0
    }
}

.btn {
    border: 1px solid transparent;
    border-radius: .25rem;
    display: inline-block;
    font-size: 1rem;
    font-weight: 400;
    line-height: 1.25;
    padding: .5rem .75rem;
    text-align: center;
    transition: all .15s ease-in-out;
    -webkit-user-select: none;
    -moz-user-select: none;
    user-select: none;
    vertical-align: middle;
    white-space: nowrap
}

.btn:focus,
.btn:hover {
    text-decoration: none
}

.btn.focus,
.btn:focus {
    box-shadow: 0 0 0 3px rgba(0, 123, 255, .25);
    outline: 0
}

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

.btn.active,
.btn:active {
    background-image: none
}

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

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

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

.btn-primary.focus,
.btn-primary:focus {
    box-shadow: 0 0 0 3px rgba(0, 123, 255, .5)
}

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

.btn-primary.active,
.btn-primary:active,
.show>.btn-primary.dropdown-toggle {
    background-color: #0069d9;
    background-image: none;
    border-color: #0062cc
}

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

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

.btn-secondary.focus,
.btn-secondary:focus {
    box-shadow: 0 0 0 3px hsla(210, 7%, 56%, .5)
}

.btn-secondary.disabled,
.btn-secondary:disabled {
    background-color: #868e96;
    border-color: #868e96
}

.btn-secondary.active,
.btn-secondary:active,
.show>.btn-secondary.dropdown-toggle {
    background-color: #727b84;
    background-image: none;
    border-color: #6c757d
}

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

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

.btn-success.focus,
.btn-success:focus {
    box-shadow: 0 0 0 3px rgba(40, 167, 69, .5)
}

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

.btn-success.active,
.btn-success:active,
.show>.btn-success.dropdown-toggle {
    background-color: #218838;
    background-image: none;
    border-color: #1e7e34
}

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

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

.btn-info.focus,
.btn-info:focus {
    box-shadow: 0 0 0 3px rgba(23, 162, 184, .5)
}

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

.btn-info.active,
.btn-info:active,
.show>.btn-info.dropdown-toggle {
    background-color: #138496;
    background-image: none;
    border-color: #117a8b
}

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

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

.btn-warning.focus,
.btn-warning:focus {
    box-shadow: 0 0 0 3px rgba(255, 193, 7, .5)
}

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

.btn-warning.active,
.btn-warning:active,
.show>.btn-warning.dropdown-toggle {
    background-color: #e0a800;
    background-image: none;
    border-color: #d39e00
}

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

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

.btn-danger.focus,
.btn-danger:focus {
    box-shadow: 0 0 0 3px rgba(220, 53, 69, .5)
}

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

.btn-danger.active,
.btn-danger:active,
.show>.btn-danger.dropdown-toggle {
    background-color: #c82333;
    background-image: none;
    border-color: #bd2130
}

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

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

.btn-light.focus,
.btn-light:focus {
    box-shadow: 0 0 0 3px rgba(248, 249, 250, .5)
}

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

.btn-light.active,
.btn-light:active,
.show>.btn-light.dropdown-toggle {
    background-color: #e2e6ea;
    background-image: none;
    border-color: #dae0e5
}

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

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

.btn-dark.focus,
.btn-dark:focus {
    box-shadow: 0 0 0 3px rgba(52, 58, 64, .5)
}

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

.btn-dark.active,
.btn-dark:active,
.show>.btn-dark.dropdown-toggle {
    background-color: #23272b;
    background-image: none;
    border-color: #1d2124
}

.btn-outline-primary {
    background-color: transparent;
    background-image: none;
    border-color: #007bff;
    color: #007bff
}

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

.btn-outline-primary.focus,
.btn-outline-primary:focus {
    box-shadow: 0 0 0 3px rgba(0, 123, 255, .5)
}

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

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

.btn-outline-secondary {
    background-color: transparent;
    background-image: none;
    border-color: #868e96;
    color: #868e96
}

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

.btn-outline-secondary.focus,
.btn-outline-secondary:focus {
    box-shadow: 0 0 0 3px hsla(210, 7%, 56%, .5)
}

.btn-outline-secondary.disabled,
.btn-outline-secondary:disabled {
    background-color: transparent;
    color: #868e96
}

.btn-outline-secondary.active,
.btn-outline-secondary:active,
.show>.btn-outline-secondary.dropdown-toggle {
    background-color: #868e96;
    border-color: #868e96;
    color: #fff
}

.btn-outline-success {
    background-color: transparent;
    background-image: none;
    border-color: #28a745;
    color: #28a745
}

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

.btn-outline-success.focus,
.btn-outline-success:focus {
    box-shadow: 0 0 0 3px rgba(40, 167, 69, .5)
}

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

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

.btn-outline-info {
    background-color: transparent;
    background-image: none;
    border-color: #17a2b8;
    color: #17a2b8
}

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

.btn-outline-info.focus,
.btn-outline-info:focus {
    box-shadow: 0 0 0 3px rgba(23, 162, 184, .5)
}

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

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

.btn-outline-warning {
    background-color: transparent;
    background-image: none;
    border-color: #ffc107;
    color: #ffc107
}

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

.btn-outline-warning.focus,
.btn-outline-warning:focus {
    box-shadow: 0 0 0 3px rgba(255, 193, 7, .5)
}

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

.btn-outline-warning.active,
.btn-outline-warning:active,
.show>.btn-outline-warning.dropdown-toggle {
    background-color: #ffc107;
    border-color: #ffc107;
    color: #fff
}

.btn-outline-danger {
    background-color: transparent;
    background-image: none;
    border-color: #dc3545;
    color: #dc3545
}

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

.btn-outline-danger.focus,
.btn-outline-danger:focus {
    box-shadow: 0 0 0 3px rgba(220, 53, 69, .5)
}

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

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

.btn-outline-light {
    background-color: transparent;
    background-image: none;
    border-color: #f8f9fa;
    color: #f8f9fa
}

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

.btn-outline-light.focus,
.btn-outline-light:focus {
    box-shadow: 0 0 0 3px rgba(248, 249, 250, .5)
}

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

.btn-outline-light.active,
.btn-outline-light:active,
.show>.btn-outline-light.dropdown-toggle {
    background-color: #f8f9fa;
    border-color: #f8f9fa;
    color: #fff
}

.btn-outline-dark {
    background-color: transparent;
    background-image: none;
    border-color: #343a40;
    color: #343a40
}

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

.btn-outline-dark.focus,
.btn-outline-dark:focus {
    box-shadow: 0 0 0 3px rgba(52, 58, 64, .5)
}

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

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

.btn-link {
    border-radius: 0;
    color: #007bff;
    font-weight: 400
}

.btn-link,
.btn-link.active,
.btn-link:active,
.btn-link:disabled {
    background-color: transparent
}

.btn-link,
.btn-link:active,
.btn-link:focus {
    border-color: transparent;
    box-shadow: none
}

.btn-link:hover {
    border-color: transparent
}

.btn-link:focus,
.btn-link:hover {
    background-color: transparent;
    color: #0056b3;
    text-decoration: underline
}

.btn-link:disabled {
    color: #868e96
}

.btn-link:disabled:focus,
.btn-link:disabled:hover {
    text-decoration: none
}

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

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

.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 {
    opacity: 0;
    transition: opacity .15s linear
}

.fade.show {
    opacity: 1
}

.collapse {
    display: none
}

.collapse.show {
    display: block
}

tr.collapse.show {
    display: table-row
}

tbody.collapse.show {
    display: table-row-group
}

.collapsing {
    height: 0;
    overflow: hidden;
    transition: height .35s ease
}

.collapsing,
.dropdown,
.dropup {
    position: relative
}

.dropdown-toggle:after {
    border-left: .3em solid transparent;
    border-right: .3em solid transparent;
    border-top: .3em solid;
    content: "";
    display: inline-block;
    height: 0;
    margin-left: .255em;
    vertical-align: .255em;
    width: 0
}

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

.dropup .dropdown-menu {
    margin-bottom: .125rem;
    margin-top: 0
}

.dropup .dropdown-toggle:after {
    border-bottom: .3em solid;
    border-top: 0
}

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

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

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

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

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

.dropdown-item.disabled,
.dropdown-item:disabled {
    background-color: transparent;
    color: #868e96
}

.show>a {
    outline: 0
}

.dropdown-menu.show {
    display: block
}

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

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

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

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

.btn-group .btn+.btn,
.btn-group .btn+.btn-group,
.btn-group .btn-group+.btn,
.btn-group .btn-group+.btn-group,
.btn-group-vertical .btn+.btn,
.btn-group-vertical .btn+.btn-group,
.btn-group-vertical .btn-group+.btn,
.btn-group-vertical .btn-group+.btn-group {
    margin-left: -1px
}

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

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

.btn-group>.btn:not(:first-child):not(:last-child):not(.dropdown-toggle) {
    border-radius: 0
}

.btn-group>.btn:first-child {
    margin-left: 0
}

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

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

.btn-group>.btn-group {
    float: left
}

.btn-group>.btn-group:not(:first-child):not(:last-child)>.btn {
    border-radius: 0
}

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

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

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

.btn+.dropdown-toggle-split:after {
    margin-left: 0
}

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

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

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

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

.btn-group-vertical>.btn+.btn,
.btn-group-vertical>.btn+.btn-group,
.btn-group-vertical>.btn-group+.btn,
.btn-group-vertical>.btn-group+.btn-group {
    margin-left: 0;
    margin-top: -1px
}

.btn-group-vertical>.btn:not(:first-child):not(:last-child) {
    border-radius: 0
}

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

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

.btn-group-vertical>.btn-group:not(:first-child):not(:last-child)>.btn {
    border-radius: 0
}

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

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

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

.input-group {
    display: flex;
    position: relative;
    width: 100%
}

.input-group .form-control {
    flex: 1 1 auto;
    margin-bottom: 0;
    position: relative;
    width: 1%;
    z-index: 2
}

.input-group .form-control:active,
.input-group .form-control:focus,
.input-group .form-control:hover {
    z-index: 3
}

.input-group .form-control,
.input-group-addon,
.input-group-btn {
    align-items: center;
    display: flex
}

.input-group .form-control:not(:first-child):not(:last-child),
.input-group-addon:not(:first-child):not(:last-child),
.input-group-btn:not(:first-child):not(:last-child) {
    border-radius: 0
}

.input-group-addon,
.input-group-btn {
    vertical-align: middle;
    white-space: nowrap
}

.input-group-addon {
    background-color: #e9ecef;
    border: 1px solid rgba(0, 0, 0, .15);
    border-radius: .25rem;
    color: #495057;
    font-size: 1rem;
    font-weight: 400;
    line-height: 1.25;
    margin-bottom: 0;
    padding: .5rem .75rem;
    text-align: center
}

.input-group-addon.form-control-sm,
.input-group-sm>.input-group-addon,
.input-group-sm>.input-group-btn>.input-group-addon.btn {
    border-radius: .2rem;
    font-size: .875rem;
    padding: .25rem .5rem
}

.input-group-addon.form-control-lg,
.input-group-lg>.input-group-addon,
.input-group-lg>.input-group-btn>.input-group-addon.btn {
    border-radius: .3rem;
    font-size: 1.25rem;
    padding: .5rem 1rem
}

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

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

.input-group-addon:not(:last-child) {
    border-right: 0
}

.input-group .form-control:not(:first-child),
.input-group-addon:not(:first-child),
.input-group-btn:not(:first-child)>.btn,
.input-group-btn:not(:first-child)>.btn-group>.btn,
.input-group-btn:not(:first-child)>.dropdown-toggle,
.input-group-btn:not(:last-child)>.btn-group:not(:first-child)>.btn,
.input-group-btn:not(:last-child)>.btn:not(:first-child) {
    border-bottom-left-radius: 0;
    border-top-left-radius: 0
}

.form-control+.input-group-addon:not(:first-child) {
    border-left: 0
}

.input-group-btn {
    font-size: 0;
    white-space: nowrap
}

.input-group-btn,
.input-group-btn>.btn {
    position: relative
}

.input-group-btn>.btn+.btn {
    margin-left: -1px
}

.input-group-btn>.btn:active,
.input-group-btn>.btn:focus,
.input-group-btn>.btn:hover {
    z-index: 3
}

.input-group-btn:not(:last-child)>.btn,
.input-group-btn:not(:last-child)>.btn-group {
    margin-right: -1px
}

.input-group-btn:not(:first-child)>.btn,
.input-group-btn:not(:first-child)>.btn-group {
    margin-left: -1px;
    z-index: 2
}

.input-group-btn:not(:first-child)>.btn-group:active,
.input-group-btn:not(:first-child)>.btn-group:focus,
.input-group-btn:not(:first-child)>.btn-group:hover,
.input-group-btn:not(:first-child)>.btn:active,
.input-group-btn:not(:first-child)>.btn:focus,
.input-group-btn:not(:first-child)>.btn:hover {
    z-index: 3
}

.custom-control {
    display: inline-flex;
    margin-right: 1rem;
    min-height: 1.5rem;
    padding-left: 1.5rem;
    position: relative
}

.custom-control-input {
    opacity: 0;
    position: absolute;
    z-index: -1
}

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

.custom-control-input:focus~.custom-control-indicator {
    box-shadow: 0 0 0 1px #fff, 0 0 0 3px #007bff
}

.custom-control-input:active~.custom-control-indicator {
    background-color: #b3d7ff;
    color: #fff
}

.custom-control-input:disabled~.custom-control-indicator {
    background-color: #e9ecef
}

.custom-control-input:disabled~.custom-control-description {
    color: #868e96
}

.custom-control-indicator {
    background-color: #ddd;
    background-position: 50%;
    background-repeat: no-repeat;
    background-size: 50% 50%;
    display: block;
    height: 1rem;
    left: 0;
    pointer-events: none;
    position: absolute;
    top: .25rem;
    -webkit-user-select: none;
    -moz-user-select: none;
    user-select: none;
    width: 1rem
}

.custom-checkbox .custom-control-indicator {
    border-radius: .25rem
}

.custom-checkbox .custom-control-input:checked~.custom-control-indicator {
    background-image: url("data:image/svg+xml;charset=utf8,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 8 8'%3E%3Cpath fill='%23fff' d='M6.564.75l-3.59 3.612-1.538-1.55L0 4.26 2.974 7.25 8 2.193z'/%3E%3C/svg%3E")
}

.custom-checkbox .custom-control-input:indeterminate~.custom-control-indicator {
    background-color: #007bff;
    background-image: url("data:image/svg+xml;charset=utf8,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 4 4'%3E%3Cpath stroke='%23fff' d='M0 2h4'/%3E%3C/svg%3E")
}

.custom-radio .custom-control-indicator {
    border-radius: 50%
}

.custom-radio .custom-control-input:checked~.custom-control-indicator {
    background-image: url("data:image/svg+xml;charset=utf8,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='-4 -4 8 8'%3E%3Ccircle r='3' fill='%23fff'/%3E%3C/svg%3E")
}

.custom-controls-stacked {
    display: flex;
    flex-direction: column
}

.custom-controls-stacked .custom-control {
    margin-bottom: .25rem
}

.custom-controls-stacked .custom-control+.custom-control {
    margin-left: 0
}

.custom-select {
    -webkit-appearance: none;
    -moz-appearance: none;
    appearance: none;
    background: #fff url("data:image/svg+xml;charset=utf8,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 4 5'%3E%3Cpath fill='%23333' d='M2 0L0 2h4zm0 5L0 3h4z'/%3E%3C/svg%3E") no-repeat right .75rem center;
    background-size: 8px 10px;
    border: 1px solid rgba(0, 0, 0, .15);
    border-radius: .25rem;
    color: #495057;
    display: inline-block;
    height: calc(2.25rem + 2px);
    line-height: 1.25;
    max-width: 100%;
    padding: .375rem 1.75rem .375rem .75rem;
    vertical-align: middle
}

.custom-select:focus {
    border-color: #80bdff;
    outline: none
}

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

.custom-select:disabled {
    background-color: #e9ecef;
    color: #868e96
}

.custom-select::-ms-expand {
    opacity: 0
}

.custom-select-sm {
    font-size: 75%;
    height: calc(1.8125rem + 2px);
    padding-bottom: .375rem;
    padding-top: .375rem
}

.custom-file {
    display: inline-block;
    height: 2.5rem;
    margin-bottom: 0;
    max-width: 100%;
    position: relative
}

.custom-file-input {
    height: 2.5rem;
    margin: 0;
    max-width: 100%;
    min-width: 14rem;
    opacity: 0
}

.custom-file-control {
    background-color: #fff;
    border: 1px solid rgba(0, 0, 0, .15);
    border-radius: .25rem;
    color: #495057;
    height: 2.5rem;
    left: 0;
    line-height: 1.5;
    padding: .5rem 1rem;
    pointer-events: none;
    position: absolute;
    right: 0;
    top: 0;
    -webkit-user-select: none;
    -moz-user-select: none;
    user-select: none;
    z-index: 5
}

.custom-file-control:lang(en):empty:after {
    content: "Choose file..."
}

.custom-file-control:before {
    background-color: #e9ecef;
    border: 1px solid rgba(0, 0, 0, .15);
    border-radius: 0 .25rem .25rem 0;
    bottom: -1px;
    color: #495057;
    display: block;
    height: 2.5rem;
    line-height: 1.5;
    padding: .5rem 1rem;
    position: absolute;
    right: -1px;
    top: -1px;
    z-index: 6
}

.custom-file-control:lang(en):before {
    content: "Browse"
}

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

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

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

.nav-link.disabled {
    color: #868e96
}

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

.nav-tabs .nav-item {
    margin-bottom: -1px
}

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

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

.nav-tabs .nav-link.disabled {
    background-color: transparent;
    border-color: transparent;
    color: #868e96
}

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

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

.nav-pills .nav-link {
    border-radius: .25rem
}

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

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

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

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

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

.navbar {
    padding: .5rem 1rem;
    position: relative
}

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

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

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

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

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

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

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

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

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

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

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

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

@media (min-width:576px) {
    .navbar-expand-sm {
        flex-wrap: nowrap;
        justify-content: flex-start
    }
    .navbar-expand-sm,
    .navbar-expand-sm .navbar-nav {
        flex-direction: row
    }
    .navbar-expand-sm .navbar-nav .dropdown-menu {
        position: absolute
    }
    .navbar-expand-sm .navbar-nav .dropdown-menu-right {
        left: auto;
        right: 0
    }
    .navbar-expand-sm .navbar-nav .nav-link {
        padding-left: .5rem;
        padding-right: .5rem
    }
    .navbar-expand-sm>.container,
    .navbar-expand-sm>.container-fluid {
        flex-wrap: nowrap
    }
    .navbar-expand-sm .navbar-collapse {
        display: flex !important
    }
    .navbar-expand-sm .navbar-toggler {
        display: none
    }
}

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

@media (min-width:768px) {
    .navbar-expand-md {
        flex-wrap: nowrap;
        justify-content: flex-start
    }
    .navbar-expand-md,
    .navbar-expand-md .navbar-nav {
        flex-direction: row
    }
    .navbar-expand-md .navbar-nav .dropdown-menu {
        position: absolute
    }
    .navbar-expand-md .navbar-nav .dropdown-menu-right {
        left: auto;
        right: 0
    }
    .navbar-expand-md .navbar-nav .nav-link {
        padding-left: .5rem;
        padding-right: .5rem
    }
    .navbar-expand-md>.container,
    .navbar-expand-md>.container-fluid {
        flex-wrap: nowrap
    }
    .navbar-expand-md .navbar-collapse {
        display: flex !important
    }
    .navbar-expand-md .navbar-toggler {
        display: none
    }
}

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

@media (min-width:992px) {
    .navbar-expand-lg {
        flex-wrap: nowrap;
        justify-content: flex-start
    }
    .navbar-expand-lg,
    .navbar-expand-lg .navbar-nav {
        flex-direction: row
    }
    .navbar-expand-lg .navbar-nav .dropdown-menu {
        position: absolute
    }
    .navbar-expand-lg .navbar-nav .dropdown-menu-right {
        left: auto;
        right: 0
    }
    .navbar-expand-lg .navbar-nav .nav-link {
        padding-left: .5rem;
        padding-right: .5rem
    }
    .navbar-expand-lg>.container,
    .navbar-expand-lg>.container-fluid {
        flex-wrap: nowrap
    }
    .navbar-expand-lg .navbar-collapse {
        display: flex !important
    }
    .navbar-expand-lg .navbar-toggler {
        display: none
    }
}

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

@media (min-width:1200px) {
    .navbar-expand-xl {
        flex-wrap: nowrap;
        justify-content: flex-start
    }
    .navbar-expand-xl,
    .navbar-expand-xl .navbar-nav {
        flex-direction: row
    }
    .navbar-expand-xl .navbar-nav .dropdown-menu {
        position: absolute
    }
    .navbar-expand-xl .navbar-nav .dropdown-menu-right {
        left: auto;
        right: 0
    }
    .navbar-expand-xl .navbar-nav .nav-link {
        padding-left: .5rem;
        padding-right: .5rem
    }
    .navbar-expand-xl>.container,
    .navbar-expand-xl>.container-fluid {
        flex-wrap: nowrap
    }
    .navbar-expand-xl .navbar-collapse {
        display: flex !important
    }
    .navbar-expand-xl .navbar-toggler {
        display: none
    }
}

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

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

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

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

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

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

.navbar-expand>.container,
.navbar-expand>.container-fluid {
    flex-wrap: nowrap
}

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

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

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

.navbar-light .navbar-toggler-icon {
    background-image: url("data:image/svg+xml;charset=utf8,%3Csvg viewBox='0 0 30 30' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath stroke='rgba(0, 0, 0, 0.5)' stroke-width='2' stroke-linecap='round' stroke-miterlimit='10' d='M4 7h22M4 15h22M4 23h22'/%3E%3C/svg%3E")
}

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

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

.navbar-dark .navbar-nav .nav-link {
    color: hsla(0, 0%, 100%, .5)
}

.navbar-dark .navbar-nav .nav-link:focus,
.navbar-dark .navbar-nav .nav-link:hover {
    color: hsla(0, 0%, 100%, .75)
}

.navbar-dark .navbar-nav .nav-link.disabled {
    color: hsla(0, 0%, 100%, .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 {
    border-color: hsla(0, 0%, 100%, .1);
    color: hsla(0, 0%, 100%, .5)
}

.navbar-dark .navbar-toggler-icon {
    background-image: url("data:image/svg+xml;charset=utf8,%3Csvg viewBox='0 0 30 30' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath stroke='rgba(255, 255, 255, 0.5)' stroke-width='2' stroke-linecap='round' stroke-miterlimit='10' d='M4 7h22M4 15h22M4 23h22'/%3E%3C/svg%3E")
}

.navbar-dark .navbar-text {
    color: hsla(0, 0%, 100%, .5)
}

.card {
    word-wrap: break-word;
    background-clip: border-box;
    background-color: #fff;
    border: 1px solid rgba(0, 0, 0, .125);
    border-radius: .25rem;
    display: flex;
    flex-direction: column;
    min-width: 0;
    position: relative
}

.card-body {
    flex: 1 1 auto;
    padding: 1.25rem
}

.card-title {
    margin-bottom: .75rem
}

.card-subtitle {
    margin-top: -.375rem
}

.card-subtitle,
.card-text:last-child {
    margin-bottom: 0
}

.card-link:hover {
    text-decoration: none
}

.card-link+.card-link {
    margin-left: 1.25rem
}

.card>.list-group:first-child .list-group-item:first-child {
    border-top-left-radius: .25rem;
    border-top-right-radius: .25rem
}

.card>.list-group:last-child .list-group-item:last-child {
    border-bottom-left-radius: .25rem;
    border-bottom-right-radius: .25rem
}

.card-header {
    background-color: rgba(0, 0, 0, .03);
    border-bottom: 1px solid rgba(0, 0, 0, .125);
    margin-bottom: 0;
    padding: .75rem 1.25rem
}

.card-header:first-child {
    border-radius: calc(.25rem - 1px) calc(.25rem - 1px) 0 0
}

.card-footer {
    background-color: rgba(0, 0, 0, .03);
    border-top: 1px solid rgba(0, 0, 0, .125);
    padding: .75rem 1.25rem
}

.card-footer:last-child {
    border-radius: 0 0 calc(.25rem - 1px) calc(.25rem - 1px)
}

.card-header-tabs {
    border-bottom: 0;
    margin-bottom: -.75rem
}

.card-header-pills,
.card-header-tabs {
    margin-left: -.625rem;
    margin-right: -.625rem
}

.card-img-overlay {
    bottom: 0;
    left: 0;
    padding: 1.25rem;
    position: absolute;
    right: 0;
    top: 0
}

.card-img {
    border-radius: calc(.25rem - 1px);
    width: 100%
}

.card-img-top {
    border-top-left-radius: calc(.25rem - 1px);
    border-top-right-radius: calc(.25rem - 1px);
    width: 100%
}

.card-img-bottom {
    border-bottom-left-radius: calc(.25rem - 1px);
    border-bottom-right-radius: calc(.25rem - 1px);
    width: 100%
}

@media (min-width:576px) {
    .card-deck {
        display: flex;
        flex-flow: row wrap;
        margin-left: -15px;
        margin-right: -15px
    }
    .card-deck .card {
        display: flex;
        flex: 1 0 0%;
        flex-direction: column;
        margin-left: 15px;
        margin-right: 15px
    }
    .card-group {
        display: flex;
        flex-flow: row wrap
    }
    .card-group .card {
        flex: 1 0 0%
    }
    .card-group .card+.card {
        border-left: 0;
        margin-left: 0
    }
    .card-group .card:first-child {
        border-bottom-right-radius: 0;
        border-top-right-radius: 0
    }
    .card-group .card:first-child .card-img-top {
        border-top-right-radius: 0
    }
    .card-group .card:first-child .card-img-bottom {
        border-bottom-right-radius: 0
    }
    .card-group .card:last-child {
        border-bottom-left-radius: 0;
        border-top-left-radius: 0
    }
    .card-group .card:last-child .card-img-top {
        border-top-left-radius: 0
    }
    .card-group .card:last-child .card-img-bottom {
        border-bottom-left-radius: 0
    }
    .card-group .card:not(:first-child):not(:last-child),
    .card-group .card:not(:first-child):not(:last-child) .card-img-bottom,
    .card-group .card:not(:first-child):not(:last-child) .card-img-top {
        border-radius: 0
    }
}

.card-columns .card {
    margin-bottom: .75rem
}

@media (min-width:576px) {
    .card-columns {
        -moz-column-count: 3;
        column-count: 3;
        -moz-column-gap: 1.25rem;
        column-gap: 1.25rem
    }
    .card-columns .card {
        display: inline-block;
        width: 100%
    }
}

.breadcrumb {
    background-color: #e9ecef;
    border-radius: .25rem;
    list-style: none;
    margin-bottom: 1rem;
    padding: .75rem 1rem
}

.breadcrumb:after {
    clear: both;
    content: "";
    display: block
}

.breadcrumb-item {
    float: left
}

.breadcrumb-item+.breadcrumb-item:before {
    color: #868e96;
    content: "/";
    display: inline-block;
    padding-left: .5rem;
    padding-right: .5rem
}

.breadcrumb-item+.breadcrumb-item:hover:before {
    text-decoration: underline;
    text-decoration: none
}

.breadcrumb-item.active {
    color: #868e96
}

.pagination {
    border-radius: .25rem;
    display: flex;
    list-style: none;
    padding-left: 0
}

.page-item:first-child .page-link {
    border-bottom-left-radius: .25rem;
    border-top-left-radius: .25rem;
    margin-left: 0
}

.page-item:last-child .page-link {
    border-bottom-right-radius: .25rem;
    border-top-right-radius: .25rem
}

.page-item.active .page-link {
    background-color: #007bff;
    border-color: #007bff;
    color: #fff;
    z-index: 2
}

.page-item.disabled .page-link {
    background-color: #fff;
    border-color: #ddd;
    color: #868e96;
    pointer-events: none
}

.page-link {
    background-color: #fff;
    border: 1px solid #ddd;
    color: #007bff;
    display: block;
    line-height: 1.25;
    margin-left: -1px;
    padding: .5rem .75rem;
    position: relative
}

.page-link:focus,
.page-link:hover {
    background-color: #e9ecef;
    border-color: #ddd;
    color: #0056b3;
    text-decoration: none
}

.pagination-lg .page-link {
    font-size: 1.25rem;
    line-height: 1.5;
    padding: .75rem 1.5rem
}

.pagination-lg .page-item:first-child .page-link {
    border-bottom-left-radius: .3rem;
    border-top-left-radius: .3rem
}

.pagination-lg .page-item:last-child .page-link {
    border-bottom-right-radius: .3rem;
    border-top-right-radius: .3rem
}

.pagination-sm .page-link {
    font-size: .875rem;
    line-height: 1.5;
    padding: .25rem .5rem
}

.pagination-sm .page-item:first-child .page-link {
    border-bottom-left-radius: .2rem;
    border-top-left-radius: .2rem
}

.pagination-sm .page-item:last-child .page-link {
    border-bottom-right-radius: .2rem;
    border-top-right-radius: .2rem
}

.badge {
    border-radius: .25rem;
    color: #fff;
    display: inline-block;
    font-size: 75%;
    font-weight: 700;
    line-height: 1;
    padding: .25em .4em;
    text-align: center;
    vertical-align: baseline;
    white-space: nowrap
}

.badge:empty {
    display: none
}

.btn .badge {
    position: relative;
    top: -1px
}

.badge-pill {
    border-radius: 10rem;
    padding-left: .6em;
    padding-right: .6em
}

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

.badge-primary[href]:focus,
.badge-primary[href]:hover {
    background-color: #0062cc;
    color: #fff;
    text-decoration: none
}

.badge-secondary {
    background-color: #868e96;
    color: #fff
}

.badge-secondary[href]:focus,
.badge-secondary[href]:hover {
    background-color: #6c757d;
    color: #fff;
    text-decoration: none
}

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

.badge-success[href]:focus,
.badge-success[href]:hover {
    background-color: #1e7e34;
    color: #fff;
    text-decoration: none
}

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

.badge-info[href]:focus,
.badge-info[href]:hover {
    background-color: #117a8b;
    color: #fff;
    text-decoration: none
}

.badge-warning {
    background-color: #ffc107;
    color: #111
}

.badge-warning[href]:focus,
.badge-warning[href]:hover {
    background-color: #d39e00;
    color: #111;
    text-decoration: none
}

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

.badge-danger[href]:focus,
.badge-danger[href]:hover {
    background-color: #bd2130;
    color: #fff;
    text-decoration: none
}

.badge-light {
    background-color: #f8f9fa;
    color: #111
}

.badge-light[href]:focus,
.badge-light[href]:hover {
    background-color: #dae0e5;
    color: #111;
    text-decoration: none
}

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

.badge-dark[href]:focus,
.badge-dark[href]:hover {
    background-color: #1d2124;
    color: #fff;
    text-decoration: none
}

.jumbotron {
    background-color: #e9ecef;
    border-radius: .3rem;
    margin-bottom: 2rem;
    padding: 2rem 1rem
}

@media (min-width:576px) {
    .jumbotron {
        padding: 4rem 2rem
    }
}

.jumbotron-fluid {
    border-radius: 0;
    padding-left: 0;
    padding-right: 0
}

.alert {
    border: 1px solid transparent;
    border-radius: .25rem;
    margin-bottom: 1rem;
    padding: .75rem 1.25rem
}

.alert-heading {
    color: inherit
}

.alert-link {
    font-weight: 700
}

.alert-dismissible .close {
    color: inherit;
    padding: .75rem 1.25rem;
    position: relative;
    right: -1.25rem;
    top: -.75rem
}

.alert-primary {
    background-color: #cce5ff;
    border-color: #b8daff;
    color: #004085
}

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

.alert-primary .alert-link {
    color: #002752
}

.alert-secondary {
    background-color: #e7e8ea;
    border-color: #dddfe2;
    color: #464a4e
}

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

.alert-secondary .alert-link {
    color: #2e3133
}

.alert-success {
    background-color: #d4edda;
    border-color: #c3e6cb;
    color: #155724
}

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

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

.alert-info {
    background-color: #d1ecf1;
    border-color: #bee5eb;
    color: #0c5460
}

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

.alert-info .alert-link {
    color: #062c33
}

.alert-warning {
    background-color: #fff3cd;
    border-color: #ffeeba;
    color: #856404
}

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

.alert-warning .alert-link {
    color: #533f03
}

.alert-danger {
    background-color: #f8d7da;
    border-color: #f5c6cb;
    color: #721c24
}

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

.alert-danger .alert-link {
    color: #491217
}

.alert-light {
    background-color: #fefefe;
    border-color: #fdfdfe;
    color: #818182
}

.alert-light hr {
    border-top-color: #ececf6
}

.alert-light .alert-link {
    color: #686868
}

.alert-dark {
    background-color: #d6d8d9;
    border-color: #c6c8ca;
    color: #1b1e21
}

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

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

@keyframes progress-bar-stripes {
    0% {
        background-position: 1rem 0
    }
    to {
        background-position: 0 0
    }
}

.progress {
    background-color: #e9ecef;
    border-radius: .25rem;
    display: flex;
    font-size: .75rem;
    line-height: 1rem;
    overflow: hidden;
    text-align: center
}

.progress-bar {
    background-color: #007bff;
    color: #fff;
    height: 1rem;
    line-height: 1rem;
    transition: width .6s ease
}

.progress-bar-striped {
    background-image: linear-gradient(45deg, hsla(0, 0%, 100%, .15) 25%, transparent 0, transparent 50%, hsla(0, 0%, 100%, .15) 0, hsla(0, 0%, 100%, .15) 75%, transparent 0, transparent);
    background-size: 1rem 1rem
}

.progress-bar-animated {
    animation: progress-bar-stripes 1s linear infinite
}

.media {
    align-items: flex-start;
    display: flex
}

.media-body {
    flex: 1
}

.list-group {
    display: flex;
    flex-direction: column;
    margin-bottom: 0;
    padding-left: 0
}

.list-group-item-action {
    color: #495057;
    text-align: inherit;
    width: 100%
}

.list-group-item-action:focus,
.list-group-item-action:hover {
    background-color: #f8f9fa;
    color: #495057;
    text-decoration: none
}

.list-group-item-action:active {
    background-color: #e9ecef;
    color: #212529
}

.list-group-item {
    background-color: #fff;
    border: 1px solid rgba(0, 0, 0, .125);
    display: block;
    margin-bottom: -1px;
    padding: .75rem 1.25rem;
    position: relative
}

.list-group-item:first-child {
    border-top-left-radius: .25rem;
    border-top-right-radius: .25rem
}

.list-group-item:last-child {
    border-bottom-left-radius: .25rem;
    border-bottom-right-radius: .25rem;
    margin-bottom: 0
}

.list-group-item:focus,
.list-group-item:hover {
    text-decoration: none
}

.list-group-item.disabled,
.list-group-item:disabled {
    background-color: #fff;
    color: #868e96
}

.list-group-item.active {
    background-color: #007bff;
    border-color: #007bff;
    color: #fff;
    z-index: 2
}

.list-group-flush .list-group-item {
    border-left: 0;
    border-radius: 0;
    border-right: 0
}

.list-group-flush:first-child .list-group-item:first-child {
    border-top: 0
}

.list-group-flush:last-child .list-group-item:last-child {
    border-bottom: 0
}

.list-group-item-primary {
    background-color: #b8daff;
    color: #004085
}

a.list-group-item-primary,
button.list-group-item-primary {
    color: #004085
}

a.list-group-item-primary:focus,
a.list-group-item-primary:hover,
button.list-group-item-primary:focus,
button.list-group-item-primary:hover {
    background-color: #9fcdff;
    color: #004085
}

a.list-group-item-primary.active,
button.list-group-item-primary.active {
    background-color: #004085;
    border-color: #004085;
    color: #fff
}

.list-group-item-secondary {
    background-color: #dddfe2;
    color: #464a4e
}

a.list-group-item-secondary,
button.list-group-item-secondary {
    color: #464a4e
}

a.list-group-item-secondary:focus,
a.list-group-item-secondary:hover,
button.list-group-item-secondary:focus,
button.list-group-item-secondary:hover {
    background-color: #cfd2d6;
    color: #464a4e
}

a.list-group-item-secondary.active,
button.list-group-item-secondary.active {
    background-color: #464a4e;
    border-color: #464a4e;
    color: #fff
}

.list-group-item-success {
    background-color: #c3e6cb;
    color: #155724
}

a.list-group-item-success,
button.list-group-item-success {
    color: #155724
}

a.list-group-item-success:focus,
a.list-group-item-success:hover,
button.list-group-item-success:focus,
button.list-group-item-success:hover {
    background-color: #b1dfbb;
    color: #155724
}

a.list-group-item-success.active,
button.list-group-item-success.active {
    background-color: #155724;
    border-color: #155724;
    color: #fff
}

.list-group-item-info {
    background-color: #bee5eb;
    color: #0c5460
}

a.list-group-item-info,
button.list-group-item-info {
    color: #0c5460
}

a.list-group-item-info:focus,
a.list-group-item-info:hover,
button.list-group-item-info:focus,
button.list-group-item-info:hover {
    background-color: #abdde5;
    color: #0c5460
}

a.list-group-item-info.active,
button.list-group-item-info.active {
    background-color: #0c5460;
    border-color: #0c5460;
    color: #fff
}

.list-group-item-warning {
    background-color: #ffeeba;
    color: #856404
}

a.list-group-item-warning,
button.list-group-item-warning {
    color: #856404
}

a.list-group-item-warning:focus,
a.list-group-item-warning:hover,
button.list-group-item-warning:focus,
button.list-group-item-warning:hover {
    background-color: #ffe8a1;
    color: #856404
}

a.list-group-item-warning.active,
button.list-group-item-warning.active {
    background-color: #856404;
    border-color: #856404;
    color: #fff
}

.list-group-item-danger {
    background-color: #f5c6cb;
    color: #721c24
}

a.list-group-item-danger,
button.list-group-item-danger {
    color: #721c24
}

a.list-group-item-danger:focus,
a.list-group-item-danger:hover,
button.list-group-item-danger:focus,
button.list-group-item-danger:hover {
    background-color: #f1b0b7;
    color: #721c24
}

a.list-group-item-danger.active,
button.list-group-item-danger.active {
    background-color: #721c24;
    border-color: #721c24;
    color: #fff
}

.list-group-item-light {
    background-color: #fdfdfe;
    color: #818182
}

a.list-group-item-light,
button.list-group-item-light {
    color: #818182
}

a.list-group-item-light:focus,
a.list-group-item-light:hover,
button.list-group-item-light:focus,
button.list-group-item-light:hover {
    background-color: #ececf6;
    color: #818182
}

a.list-group-item-light.active,
button.list-group-item-light.active {
    background-color: #818182;
    border-color: #818182;
    color: #fff
}

.list-group-item-dark {
    background-color: #c6c8ca;
    color: #1b1e21
}

a.list-group-item-dark,
button.list-group-item-dark {
    color: #1b1e21
}

a.list-group-item-dark:focus,
a.list-group-item-dark:hover,
button.list-group-item-dark:focus,
button.list-group-item-dark:hover {
    background-color: #b9bbbe;
    color: #1b1e21
}

a.list-group-item-dark.active,
button.list-group-item-dark.active {
    background-color: #1b1e21;
    border-color: #1b1e21;
    color: #fff
}

.close {
    color: #000;
    float: right;
    font-size: 1.5rem;
    font-weight: 700;
    line-height: 1;
    opacity: .5;
    text-shadow: 0 1px 0 #fff
}

.close:focus,
.close:hover {
    color: #000;
    opacity: .75;
    text-decoration: none
}

button.close {
    -webkit-appearance: none;
    background: transparent;
    border: 0;
    padding: 0
}

.modal,
.modal-open {
    overflow: hidden
}

.modal {
    bottom: 0;
    display: none;
    left: 0;
    outline: 0;
    position: fixed;
    right: 0;
    top: 0;
    z-index: 1050
}

.modal.fade .modal-dialog {
    transform: translateY(-25%);
    transition: transform .3s ease-out
}

.modal.show .modal-dialog {
    transform: translate(0)
}

.modal-open .modal {
    overflow-x: hidden;
    overflow-y: auto
}

.modal-dialog {
    margin: 10px;
    position: relative;
    width: auto
}

.modal-content {
    background-clip: padding-box;
    background-color: #fff;
    border: 1px solid rgba(0, 0, 0, .2);
    border-radius: .3rem;
    display: flex;
    flex-direction: column;
    outline: 0;
    position: relative
}

.modal-backdrop {
    background-color: #000;
    bottom: 0;
    left: 0;
    position: fixed;
    right: 0;
    top: 0;
    z-index: 1040
}

.modal-backdrop.fade {
    opacity: 0
}

.modal-backdrop.show {
    opacity: .5
}

.modal-header {
    align-items: center;
    border-bottom: 1px solid #e9ecef;
    display: flex;
    justify-content: space-between;
    padding: 15px
}

.modal-title {
    line-height: 1.5;
    margin-bottom: 0
}

.modal-body {
    flex: 1 1 auto;
    padding: 15px;
    position: relative
}

.modal-footer {
    align-items: center;
    border-top: 1px solid #e9ecef;
    display: flex;
    justify-content: flex-end;
    padding: 15px
}

.modal-footer>:not(:first-child) {
    margin-left: .25rem
}

.modal-footer>:not(:last-child) {
    margin-right: .25rem
}

.modal-scrollbar-measure {
    height: 50px;
    overflow: scroll;
    position: absolute;
    top: -9999px;
    width: 50px
}

@media (min-width:576px) {
    .modal-dialog {
        margin: 30px auto;
        max-width: 500px
    }
    .modal-sm {
        max-width: 300px
    }
}

@media (min-width:992px) {
    .modal-lg {
        max-width: 800px
    }
}

.tooltip {
    word-wrap: break-word;
    display: block;
    font-family: -apple-system, BlinkMacSystemFont, Segoe UI, Roboto, Helvetica Neue, Arial, sans-serif;
    font-size: .875rem;
    font-style: normal;
    font-weight: 400;
    letter-spacing: normal;
    line-break: auto;
    line-height: 1.5;
    margin: 0;
    opacity: 0;
    position: absolute;
    text-align: left;
    text-align: start;
    text-decoration: none;
    text-shadow: none;
    text-transform: none;
    white-space: normal;
    word-break: normal;
    word-spacing: normal;
    z-index: 1070
}

.tooltip.show {
    opacity: .9
}

.tooltip .arrow {
    display: block;
    height: 5px;
    position: absolute;
    width: 5px
}

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

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

.tooltip.bs-tooltip-auto[x-placement^=top] .arrow:before,
.tooltip.bs-tooltip-top .arrow:before {
    border-top-color: #000;
    border-width: 5px 5px 0;
    content: "";
    margin-left: -3px
}

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

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

.tooltip.bs-tooltip-auto[x-placement^=right] .arrow:before,
.tooltip.bs-tooltip-right .arrow:before {
    border-right-color: #000;
    border-width: 5px 5px 5px 0;
    content: "";
    margin-top: -3px
}

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

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

.tooltip.bs-tooltip-auto[x-placement^=bottom] .arrow:before,
.tooltip.bs-tooltip-bottom .arrow:before {
    border-bottom-color: #000;
    border-width: 0 5px 5px;
    content: "";
    margin-left: -3px
}

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

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

.tooltip.bs-tooltip-auto[x-placement^=left] .arrow:before,
.tooltip.bs-tooltip-left .arrow:before {
    border-left-color: #000;
    border-width: 5px 0 5px 5px;
    content: "";
    margin-top: -3px;
    right: 0
}

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

.tooltip-inner {
    background-color: #000;
    border-radius: .25rem;
    color: #fff;
    max-width: 200px;
    padding: 3px 8px;
    text-align: center
}

.popover {
    word-wrap: break-word;
    background-clip: padding-box;
    background-color: #fff;
    border: 1px solid rgba(0, 0, 0, .2);
    border-radius: .3rem;
    font-family: -apple-system, BlinkMacSystemFont, Segoe UI, Roboto, Helvetica Neue, Arial, sans-serif;
    font-size: .875rem;
    font-style: normal;
    font-weight: 400;
    left: 0;
    letter-spacing: normal;
    line-break: auto;
    line-height: 1.5;
    max-width: 276px;
    padding: 1px;
    text-align: left;
    text-align: start;
    text-decoration: none;
    text-shadow: none;
    text-transform: none;
    top: 0;
    white-space: normal;
    word-break: normal;
    word-spacing: normal;
    z-index: 1060
}

.popover,
.popover .arrow {
    display: block;
    position: absolute
}

.popover .arrow {
    height: 5px;
    width: 10px
}

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

.popover .arrow:after,
.popover .arrow:before {
    border-width: 11px;
    content: ""
}

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

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

.popover.bs-popover-auto[x-placement^=top] .arrow:after,
.popover.bs-popover-auto[x-placement^=top] .arrow:before,
.popover.bs-popover-top .arrow:after,
.popover.bs-popover-top .arrow:before {
    border-bottom-width: 0
}

.popover.bs-popover-auto[x-placement^=top] .arrow:before,
.popover.bs-popover-top .arrow:before {
    border-top-color: rgba(0, 0, 0, .25);
    bottom: -11px;
    margin-left: -6px
}

.popover.bs-popover-auto[x-placement^=top] .arrow:after,
.popover.bs-popover-top .arrow:after {
    border-top-color: #fff;
    bottom: -10px;
    margin-left: -6px
}

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

.popover.bs-popover-auto[x-placement^=right] .arrow,
.popover.bs-popover-right .arrow {
    left: 0
}

.popover.bs-popover-auto[x-placement^=right] .arrow:after,
.popover.bs-popover-auto[x-placement^=right] .arrow:before,
.popover.bs-popover-right .arrow:after,
.popover.bs-popover-right .arrow:before {
    border-left-width: 0;
    margin-top: -8px
}

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

.popover.bs-popover-auto[x-placement^=right] .arrow:after,
.popover.bs-popover-right .arrow:after {
    border-right-color: #fff;
    left: -10px
}

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

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

.popover.bs-popover-auto[x-placement^=bottom] .arrow:after,
.popover.bs-popover-auto[x-placement^=bottom] .arrow:before,
.popover.bs-popover-bottom .arrow:after,
.popover.bs-popover-bottom .arrow:before {
    border-top-width: 0;
    margin-left: -7px
}

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

.popover.bs-popover-auto[x-placement^=bottom] .arrow:after,
.popover.bs-popover-bottom .arrow:after {
    border-bottom-color: #fff;
    top: -10px
}

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

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

.popover.bs-popover-auto[x-placement^=left] .arrow,
.popover.bs-popover-left .arrow {
    right: 0
}

.popover.bs-popover-auto[x-placement^=left] .arrow:after,
.popover.bs-popover-auto[x-placement^=left] .arrow:before,
.popover.bs-popover-left .arrow:after,
.popover.bs-popover-left .arrow:before {
    border-right-width: 0;
    margin-top: -8px
}

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

.popover.bs-popover-auto[x-placement^=left] .arrow:after,
.popover.bs-popover-left .arrow:after {
    border-left-color: #fff;
    right: -10px
}

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

.popover-header:empty {
    display: none
}

.popover-body {
    color: #212529;
    padding: 9px 14px
}

.carousel {
    position: relative
}

.carousel-inner {
    overflow: hidden;
    position: relative;
    width: 100%
}

.carousel-item {
    align-items: center;
    -webkit-backface-visibility: hidden;
    backface-visibility: hidden;
    display: none;
    perspective: 1000px;
    position: relative;
    transition: transform .6s ease;
    width: 100%
}

.carousel-item-next,
.carousel-item-prev,
.carousel-item.active {
    display: block
}

.carousel-item-next,
.carousel-item-prev {
    position: absolute;
    top: 0
}

.carousel-item-next.carousel-item-left,
.carousel-item-prev.carousel-item-right {
    transform: translateX(0)
}

@supports (transform-style:preserve-3d) {
    .carousel-item-next.carousel-item-left,
    .carousel-item-prev.carousel-item-right {
        transform: translateZ(0)
    }
}

.active.carousel-item-right,
.carousel-item-next {
    transform: translateX(100%)
}

@supports (transform-style:preserve-3d) {
    .active.carousel-item-right,
    .carousel-item-next {
        transform: translate3d(100%, 0, 0)
    }
}

.active.carousel-item-left,
.carousel-item-prev {
    transform: translateX(-100%)
}

@supports (transform-style:preserve-3d) {
    .active.carousel-item-left,
    .carousel-item-prev {
        transform: translate3d(-100%, 0, 0)
    }
}

.carousel-control-next,
.carousel-control-prev {
    align-items: center;
    bottom: 0;
    color: #fff;
    display: flex;
    justify-content: center;
    opacity: .5;
    position: absolute;
    text-align: center;
    top: 0;
    width: 15%
}

.carousel-control-next:focus,
.carousel-control-next:hover,
.carousel-control-prev:focus,
.carousel-control-prev:hover {
    color: #fff;
    opacity: .9;
    outline: 0;
    text-decoration: none
}

.carousel-control-prev {
    left: 0
}

.carousel-control-next {
    right: 0
}

.carousel-control-next-icon,
.carousel-control-prev-icon {
    background: transparent no-repeat 50%;
    background-size: 100% 100%;
    display: inline-block;
    height: 20px;
    width: 20px
}

.carousel-control-prev-icon {
    background-image: url("data:image/svg+xml;charset=utf8,%3Csvg xmlns='http://www.w3.org/2000/svg' fill='%23fff' viewBox='0 0 8 8'%3E%3Cpath d='M4 0l-4 4 4 4 1.5-1.5-2.5-2.5 2.5-2.5-1.5-1.5z'/%3E%3C/svg%3E")
}

.carousel-control-next-icon {
    background-image: url("data:image/svg+xml;charset=utf8,%3Csvg xmlns='http://www.w3.org/2000/svg' fill='%23fff' viewBox='0 0 8 8'%3E%3Cpath d='M1.5 0l-1.5 1.5 2.5 2.5-2.5 2.5 1.5 1.5 4-4-4-4z'/%3E%3C/svg%3E")
}

.carousel-indicators {
    bottom: 10px;
    display: flex;
    justify-content: center;
    left: 0;
    list-style: none;
    margin-left: 15%;
    margin-right: 15%;
    padding-left: 0;
    position: absolute;
    right: 0;
    z-index: 15
}

.carousel-indicators li {
    background-color: hsla(0, 0%, 100%, .5);
    flex: 0 1 auto;
    height: 3px;
    margin-left: 3px;
    margin-right: 3px;
    position: relative;
    text-indent: -999px;
    width: 30px
}

.carousel-indicators li:before {
    top: -10px
}

.carousel-indicators li:after,
.carousel-indicators li:before {
    content: "";
    display: inline-block;
    height: 10px;
    left: 0;
    position: absolute;
    width: 100%
}

.carousel-indicators li:after {
    bottom: -10px
}

.carousel-indicators .active {
    background-color: #fff
}

.carousel-caption {
    bottom: 20px;
    color: #fff;
    left: 15%;
    padding-bottom: 20px;
    padding-top: 20px;
    position: absolute;
    right: 15%;
    text-align: center;
    z-index: 10
}

.align-baseline {
    vertical-align: baseline !important
}

.align-top {
    vertical-align: top !important
}

.align-middle {
    vertical-align: middle !important
}

.align-bottom {
    vertical-align: bottom !important
}

.align-text-bottom {
    vertical-align: text-bottom !important
}

.align-text-top {
    vertical-align: text-top !important
}

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

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

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

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

.bg-success {
    background-color: #28a745 !important
}

a.bg-success:focus,
a.bg-success:hover {
    background-color: #1e7e34 !important
}

.bg-info {
    background-color: #17a2b8 !important
}

a.bg-info:focus,
a.bg-info:hover {
    background-color: #117a8b !important
}

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

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

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

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

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

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

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

a.bg-dark:focus,
a.bg-dark:hover {
    background-color: #1d2124 !important
}

.bg-white {
    background-color: #fff !important
}

.bg-transparent {
    background-color: transparent !important
}

.border {
    border: 1px solid #e9ecef !important
}

.border-0 {
    border: 0 !important
}

.border-top-0 {
    border-top: 0 !important
}

.border-right-0 {
    border-right: 0 !important
}

.border-bottom-0 {
    border-bottom: 0 !important
}

.border-left-0 {
    border-left: 0 !important
}

.border-primary {
    border-color: #007bff !important
}

.border-secondary {
    border-color: #868e96 !important
}

.border-success {
    border-color: #28a745 !important
}

.border-info {
    border-color: #17a2b8 !important
}

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

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

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

.border-dark {
    border-color: #343a40 !important
}

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

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

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

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

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

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

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

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

.rounded-0 {
    border-radius: 0
}

.clearfix:after {
    clear: both;
    content: "";
    display: block
}

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

.d-print-block {
    display: none !important
}

@media print {
    .d-print-block {
        display: block !important
    }
}

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

@media print {
    .d-print-inline {
        display: inline !important
    }
}

.d-print-inline-block {
    display: none !important
}

@media print {
    .d-print-inline-block {
        display: inline-block !important
    }
    .d-print-none {
        display: none !important
    }
}

.embed-responsive {
    display: block;
    overflow: hidden;
    padding: 0;
    position: relative;
    width: 100%
}

.embed-responsive:before {
    content: "";
    display: block
}

.embed-responsive .embed-responsive-item,
.embed-responsive embed,
.embed-responsive iframe,
.embed-responsive object,
.embed-responsive video {
    border: 0;
    bottom: 0;
    height: 100%;
    left: 0;
    position: absolute;
    top: 0;
    width: 100%
}

.embed-responsive-21by9:before {
    padding-top: 42.857143%
}

.embed-responsive-16by9:before {
    padding-top: 56.25%
}

.embed-responsive-4by3:before {
    padding-top: 75%
}

.embed-responsive-1by1:before {
    padding-top: 100%
}

.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
}

.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
    }
    .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
    }
    .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
    }
    .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
    }
    .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
    }
}

.fixed-top {
    top: 0
}

.fixed-bottom,
.fixed-top {
    left: 0;
    position: fixed;
    right: 0;
    z-index: 1030
}

.fixed-bottom {
    bottom: 0
}

@supports (position:sticky) {
    .sticky-top {
        position: sticky;
        top: 0;
        z-index: 1020
    }
}

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

.sr-only-focusable:active,
.sr-only-focusable:focus {
    clip: auto;
    -webkit-clip-path: none;
    clip-path: none;
    height: auto;
    overflow: visible;
    position: static;
    white-space: normal;
    width: auto
}

.w-25 {
    width: 25% !important
}

.w-50 {
    width: 50% !important
}

.w-75 {
    width: 75% !important
}

.w-100 {
    width: 100% !important
}

.h-25 {
    height: 25% !important
}

.h-50 {
    height: 50% !important
}

.h-75 {
    height: 75% !important
}

.h-100 {
    height: 100% !important
}

.mw-100 {
    max-width: 100% !important
}

.mh-100 {
    max-height: 100% !important
}

.m-0 {
    margin: 0 !important
}

.mt-0 {
    margin-top: 0 !important
}

.mr-0 {
    margin-right: 0 !important
}

.mb-0 {
    margin-bottom: 0 !important
}

.ml-0,
.mx-0 {
    margin-left: 0 !important
}

.mx-0 {
    margin-right: 0 !important
}

.my-0 {
    margin-bottom: 0 !important;
    margin-top: 0 !important
}

.m-1 {
    margin: .25rem !important
}

.mt-1 {
    margin-top: .25rem !important
}

.mr-1 {
    margin-right: .25rem !important
}

.mb-1 {
    margin-bottom: .25rem !important
}

.ml-1,
.mx-1 {
    margin-left: .25rem !important
}

.mx-1 {
    margin-right: .25rem !important
}

.my-1 {
    margin-bottom: .25rem !important;
    margin-top: .25rem !important
}

.m-2 {
    margin: .5rem !important
}

.mt-2 {
    margin-top: .5rem !important
}

.mr-2 {
    margin-right: .5rem !important
}

.mb-2 {
    margin-bottom: .5rem !important
}

.ml-2,
.mx-2 {
    margin-left: .5rem !important
}

.mx-2 {
    margin-right: .5rem !important
}

.my-2 {
    margin-bottom: .5rem !important;
    margin-top: .5rem !important
}

.m-3 {
    margin: 1rem !important
}

.mt-3 {
    margin-top: 1rem !important
}

.mr-3 {
    margin-right: 1rem !important
}

.mb-3 {
    margin-bottom: 1rem !important
}

.ml-3,
.mx-3 {
    margin-left: 1rem !important
}

.mx-3 {
    margin-right: 1rem !important
}

.my-3 {
    margin-bottom: 1rem !important;
    margin-top: 1rem !important
}

.m-4 {
    margin: 1.5rem !important
}

.mt-4 {
    margin-top: 1.5rem !important
}

.mr-4 {
    margin-right: 1.5rem !important
}

.mb-4 {
    margin-bottom: 1.5rem !important
}

.ml-4,
.mx-4 {
    margin-left: 1.5rem !important
}

.mx-4 {
    margin-right: 1.5rem !important
}

.my-4 {
    margin-bottom: 1.5rem !important;
    margin-top: 1.5rem !important
}

.m-5 {
    margin: 3rem !important
}

.mt-5 {
    margin-top: 3rem !important
}

.mr-5 {
    margin-right: 3rem !important
}

.mb-5 {
    margin-bottom: 3rem !important
}

.ml-5,
.mx-5 {
    margin-left: 3rem !important
}

.mx-5 {
    margin-right: 3rem !important
}

.my-5 {
    margin-bottom: 3rem !important;
    margin-top: 3rem !important
}

.p-0 {
    padding: 0 !important
}

.pt-0 {
    padding-top: 0 !important
}

.pr-0 {
    padding-right: 0 !important
}

.pb-0 {
    padding-bottom: 0 !important
}

.pl-0,
.px-0 {
    padding-left: 0 !important
}

.px-0 {
    padding-right: 0 !important
}

.py-0 {
    padding-bottom: 0 !important;
    padding-top: 0 !important
}

.p-1 {
    padding: .25rem !important
}

.pt-1 {
    padding-top: .25rem !important
}

.pr-1 {
    padding-right: .25rem !important
}

.pb-1 {
    padding-bottom: .25rem !important
}

.pl-1,
.px-1 {
    padding-left: .25rem !important
}

.px-1 {
    padding-right: .25rem !important
}

.py-1 {
    padding-bottom: .25rem !important;
    padding-top: .25rem !important
}

.p-2 {
    padding: .5rem !important
}

.pt-2 {
    padding-top: .5rem !important
}

.pr-2 {
    padding-right: .5rem !important
}

.pb-2 {
    padding-bottom: .5rem !important
}

.pl-2,
.px-2 {
    padding-left: .5rem !important
}

.px-2 {
    padding-right: .5rem !important
}

.py-2 {
    padding-bottom: .5rem !important;
    padding-top: .5rem !important
}

.p-3 {
    padding: 1rem !important
}

.pt-3 {
    padding-top: 1rem !important
}

.pr-3 {
    padding-right: 1rem !important
}

.pb-3 {
    padding-bottom: 1rem !important
}

.pl-3,
.px-3 {
    padding-left: 1rem !important
}

.px-3 {
    padding-right: 1rem !important
}

.py-3 {
    padding-bottom: 1rem !important;
    padding-top: 1rem !important
}

.p-4 {
    padding: 1.5rem !important
}

.pt-4 {
    padding-top: 1.5rem !important
}

.pr-4 {
    padding-right: 1.5rem !important
}

.pb-4 {
    padding-bottom: 1.5rem !important
}

.pl-4,
.px-4 {
    padding-left: 1.5rem !important
}

.px-4 {
    padding-right: 1.5rem !important
}

.py-4 {
    padding-bottom: 1.5rem !important;
    padding-top: 1.5rem !important
}

.p-5 {
    padding: 3rem !important
}

.pt-5 {
    padding-top: 3rem !important
}

.pr-5 {
    padding-right: 3rem !important
}

.pb-5 {
    padding-bottom: 3rem !important
}

.pl-5,
.px-5 {
    padding-left: 3rem !important
}

.px-5 {
    padding-right: 3rem !important
}

.py-5 {
    padding-bottom: 3rem !important;
    padding-top: 3rem !important
}

.m-auto {
    margin: auto !important
}

.mt-auto {
    margin-top: auto !important
}

.mr-auto {
    margin-right: auto !important
}

.mb-auto {
    margin-bottom: auto !important
}

.ml-auto,
.mx-auto {
    margin-left: auto !important
}

.mx-auto {
    margin-right: auto !important
}

.my-auto {
    margin-bottom: auto !important;
    margin-top: auto !important
}

@media (min-width:576px) {
    .m-sm-0 {
        margin: 0 !important
    }
    .mt-sm-0 {
        margin-top: 0 !important
    }
    .mr-sm-0 {
        margin-right: 0 !important
    }
    .mb-sm-0 {
        margin-bottom: 0 !important
    }
    .ml-sm-0,
    .mx-sm-0 {
        margin-left: 0 !important
    }
    .mx-sm-0 {
        margin-right: 0 !important
    }
    .my-sm-0 {
        margin-bottom: 0 !important;
        margin-top: 0 !important
    }
    .m-sm-1 {
        margin: .25rem !important
    }
    .mt-sm-1 {
        margin-top: .25rem !important
    }
    .mr-sm-1 {
        margin-right: .25rem !important
    }
    .mb-sm-1 {
        margin-bottom: .25rem !important
    }
    .ml-sm-1,
    .mx-sm-1 {
        margin-left: .25rem !important
    }
    .mx-sm-1 {
        margin-right: .25rem !important
    }
    .my-sm-1 {
        margin-bottom: .25rem !important;
        margin-top: .25rem !important
    }
    .m-sm-2 {
        margin: .5rem !important
    }
    .mt-sm-2 {
        margin-top: .5rem !important
    }
    .mr-sm-2 {
        margin-right: .5rem !important
    }
    .mb-sm-2 {
        margin-bottom: .5rem !important
    }
    .ml-sm-2,
    .mx-sm-2 {
        margin-left: .5rem !important
    }
    .mx-sm-2 {
        margin-right: .5rem !important
    }
    .my-sm-2 {
        margin-bottom: .5rem !important;
        margin-top: .5rem !important
    }
    .m-sm-3 {
        margin: 1rem !important
    }
    .mt-sm-3 {
        margin-top: 1rem !important
    }
    .mr-sm-3 {
        margin-right: 1rem !important
    }
    .mb-sm-3 {
        margin-bottom: 1rem !important
    }
    .ml-sm-3,
    .mx-sm-3 {
        margin-left: 1rem !important
    }
    .mx-sm-3 {
        margin-right: 1rem !important
    }
    .my-sm-3 {
        margin-bottom: 1rem !important;
        margin-top: 1rem !important
    }
    .m-sm-4 {
        margin: 1.5rem !important
    }
    .mt-sm-4 {
        margin-top: 1.5rem !important
    }
    .mr-sm-4 {
        margin-right: 1.5rem !important
    }
    .mb-sm-4 {
        margin-bottom: 1.5rem !important
    }
    .ml-sm-4,
    .mx-sm-4 {
        margin-left: 1.5rem !important
    }
    .mx-sm-4 {
        margin-right: 1.5rem !important
    }
    .my-sm-4 {
        margin-bottom: 1.5rem !important;
        margin-top: 1.5rem !important
    }
    .m-sm-5 {
        margin: 3rem !important
    }
    .mt-sm-5 {
        margin-top: 3rem !important
    }
    .mr-sm-5 {
        margin-right: 3rem !important
    }
    .mb-sm-5 {
        margin-bottom: 3rem !important
    }
    .ml-sm-5,
    .mx-sm-5 {
        margin-left: 3rem !important
    }
    .mx-sm-5 {
        margin-right: 3rem !important
    }
    .my-sm-5 {
        margin-bottom: 3rem !important;
        margin-top: 3rem !important
    }
    .p-sm-0 {
        padding: 0 !important
    }
    .pt-sm-0 {
        padding-top: 0 !important
    }
    .pr-sm-0 {
        padding-right: 0 !important
    }
    .pb-sm-0 {
        padding-bottom: 0 !important
    }
    .pl-sm-0,
    .px-sm-0 {
        padding-left: 0 !important
    }
    .px-sm-0 {
        padding-right: 0 !important
    }
    .py-sm-0 {
        padding-bottom: 0 !important;
        padding-top: 0 !important
    }
    .p-sm-1 {
        padding: .25rem !important
    }
    .pt-sm-1 {
        padding-top: .25rem !important
    }
    .pr-sm-1 {
        padding-right: .25rem !important
    }
    .pb-sm-1 {
        padding-bottom: .25rem !important
    }
    .pl-sm-1,
    .px-sm-1 {
        padding-left: .25rem !important
    }
    .px-sm-1 {
        padding-right: .25rem !important
    }
    .py-sm-1 {
        padding-bottom: .25rem !important;
        padding-top: .25rem !important
    }
    .p-sm-2 {
        padding: .5rem !important
    }
    .pt-sm-2 {
        padding-top: .5rem !important
    }
    .pr-sm-2 {
        padding-right: .5rem !important
    }
    .pb-sm-2 {
        padding-bottom: .5rem !important
    }
    .pl-sm-2,
    .px-sm-2 {
        padding-left: .5rem !important
    }
    .px-sm-2 {
        padding-right: .5rem !important
    }
    .py-sm-2 {
        padding-bottom: .5rem !important;
        padding-top: .5rem !important
    }
    .p-sm-3 {
        padding: 1rem !important
    }
    .pt-sm-3 {
        padding-top: 1rem !important
    }
    .pr-sm-3 {
        padding-right: 1rem !important
    }
    .pb-sm-3 {
        padding-bottom: 1rem !important
    }
    .pl-sm-3,
    .px-sm-3 {
        padding-left: 1rem !important
    }
    .px-sm-3 {
        padding-right: 1rem !important
    }
    .py-sm-3 {
        padding-bottom: 1rem !important;
        padding-top: 1rem !important
    }
    .p-sm-4 {
        padding: 1.5rem !important
    }
    .pt-sm-4 {
        padding-top: 1.5rem !important
    }
    .pr-sm-4 {
        padding-right: 1.5rem !important
    }
    .pb-sm-4 {
        padding-bottom: 1.5rem !important
    }
    .pl-sm-4,
    .px-sm-4 {
        padding-left: 1.5rem !important
    }
    .px-sm-4 {
        padding-right: 1.5rem !important
    }
    .py-sm-4 {
        padding-bottom: 1.5rem !important;
        padding-top: 1.5rem !important
    }
    .p-sm-5 {
        padding: 3rem !important
    }
    .pt-sm-5 {
        padding-top: 3rem !important
    }
    .pr-sm-5 {
        padding-right: 3rem !important
    }
    .pb-sm-5 {
        padding-bottom: 3rem !important
    }
    .pl-sm-5,
    .px-sm-5 {
        padding-left: 3rem !important
    }
    .px-sm-5 {
        padding-right: 3rem !important
    }
    .py-sm-5 {
        padding-bottom: 3rem !important;
        padding-top: 3rem !important
    }
    .m-sm-auto {
        margin: auto !important
    }
    .mt-sm-auto {
        margin-top: auto !important
    }
    .mr-sm-auto {
        margin-right: auto !important
    }
    .mb-sm-auto {
        margin-bottom: auto !important
    }
    .ml-sm-auto,
    .mx-sm-auto {
        margin-left: auto !important
    }
    .mx-sm-auto {
        margin-right: auto !important
    }
    .my-sm-auto {
        margin-bottom: auto !important;
        margin-top: auto !important
    }
}

@media (min-width:768px) {
    .m-md-0 {
        margin: 0 !important
    }
    .mt-md-0 {
        margin-top: 0 !important
    }
    .mr-md-0 {
        margin-right: 0 !important
    }
    .mb-md-0 {
        margin-bottom: 0 !important
    }
    .ml-md-0,
    .mx-md-0 {
        margin-left: 0 !important
    }
    .mx-md-0 {
        margin-right: 0 !important
    }
    .my-md-0 {
        margin-bottom: 0 !important;
        margin-top: 0 !important
    }
    .m-md-1 {
        margin: .25rem !important
    }
    .mt-md-1 {
        margin-top: .25rem !important
    }
    .mr-md-1 {
        margin-right: .25rem !important
    }
    .mb-md-1 {
        margin-bottom: .25rem !important
    }
    .ml-md-1,
    .mx-md-1 {
        margin-left: .25rem !important
    }
    .mx-md-1 {
        margin-right: .25rem !important
    }
    .my-md-1 {
        margin-bottom: .25rem !important;
        margin-top: .25rem !important
    }
    .m-md-2 {
        margin: .5rem !important
    }
    .mt-md-2 {
        margin-top: .5rem !important
    }
    .mr-md-2 {
        margin-right: .5rem !important
    }
    .mb-md-2 {
        margin-bottom: .5rem !important
    }
    .ml-md-2,
    .mx-md-2 {
        margin-left: .5rem !important
    }
    .mx-md-2 {
        margin-right: .5rem !important
    }
    .my-md-2 {
        margin-bottom: .5rem !important;
        margin-top: .5rem !important
    }
    .m-md-3 {
        margin: 1rem !important
    }
    .mt-md-3 {
        margin-top: 1rem !important
    }
    .mr-md-3 {
        margin-right: 1rem !important
    }
    .mb-md-3 {
        margin-bottom: 1rem !important
    }
    .ml-md-3,
    .mx-md-3 {
        margin-left: 1rem !important
    }
    .mx-md-3 {
        margin-right: 1rem !important
    }
    .my-md-3 {
        margin-bottom: 1rem !important;
        margin-top: 1rem !important
    }
    .m-md-4 {
        margin: 1.5rem !important
    }
    .mt-md-4 {
        margin-top: 1.5rem !important
    }
    .mr-md-4 {
        margin-right: 1.5rem !important
    }
    .mb-md-4 {
        margin-bottom: 1.5rem !important
    }
    .ml-md-4,
    .mx-md-4 {
        margin-left: 1.5rem !important
    }
    .mx-md-4 {
        margin-right: 1.5rem !important
    }
    .my-md-4 {
        margin-bottom: 1.5rem !important;
        margin-top: 1.5rem !important
    }
    .m-md-5 {
        margin: 3rem !important
    }
    .mt-md-5 {
        margin-top: 3rem !important
    }
    .mr-md-5 {
        margin-right: 3rem !important
    }
    .mb-md-5 {
        margin-bottom: 3rem !important
    }
    .ml-md-5,
    .mx-md-5 {
        margin-left: 3rem !important
    }
    .mx-md-5 {
        margin-right: 3rem !important
    }
    .my-md-5 {
        margin-bottom: 3rem !important;
        margin-top: 3rem !important
    }
    .p-md-0 {
        padding: 0 !important
    }
    .pt-md-0 {
        padding-top: 0 !important
    }
    .pr-md-0 {
        padding-right: 0 !important
    }
    .pb-md-0 {
        padding-bottom: 0 !important
    }
    .pl-md-0,
    .px-md-0 {
        padding-left: 0 !important
    }
    .px-md-0 {
        padding-right: 0 !important
    }
    .py-md-0 {
        padding-bottom: 0 !important;
        padding-top: 0 !important
    }
    .p-md-1 {
        padding: .25rem !important
    }
    .pt-md-1 {
        padding-top: .25rem !important
    }
    .pr-md-1 {
        padding-right: .25rem !important
    }
    .pb-md-1 {
        padding-bottom: .25rem !important
    }
    .pl-md-1,
    .px-md-1 {
        padding-left: .25rem !important
    }
    .px-md-1 {
        padding-right: .25rem !important
    }
    .py-md-1 {
        padding-bottom: .25rem !important;
        padding-top: .25rem !important
    }
    .p-md-2 {
        padding: .5rem !important
    }
    .pt-md-2 {
        padding-top: .5rem !important
    }
    .pr-md-2 {
        padding-right: .5rem !important
    }
    .pb-md-2 {
        padding-bottom: .5rem !important
    }
    .pl-md-2,
    .px-md-2 {
        padding-left: .5rem !important
    }
    .px-md-2 {
        padding-right: .5rem !important
    }
    .py-md-2 {
        padding-bottom: .5rem !important;
        padding-top: .5rem !important
    }
    .p-md-3 {
        padding: 1rem !important
    }
    .pt-md-3 {
        padding-top: 1rem !important
    }
    .pr-md-3 {
        padding-right: 1rem !important
    }
    .pb-md-3 {
        padding-bottom: 1rem !important
    }
    .pl-md-3,
    .px-md-3 {
        padding-left: 1rem !important
    }
    .px-md-3 {
        padding-right: 1rem !important
    }
    .py-md-3 {
        padding-bottom: 1rem !important;
        padding-top: 1rem !important
    }
    .p-md-4 {
        padding: 1.5rem !important
    }
    .pt-md-4 {
        padding-top: 1.5rem !important
    }
    .pr-md-4 {
        padding-right: 1.5rem !important
    }
    .pb-md-4 {
        padding-bottom: 1.5rem !important
    }
    .pl-md-4,
    .px-md-4 {
        padding-left: 1.5rem !important
    }
    .px-md-4 {
        padding-right: 1.5rem !important
    }
    .py-md-4 {
        padding-bottom: 1.5rem !important;
        padding-top: 1.5rem !important
    }
    .p-md-5 {
        padding: 3rem !important
    }
    .pt-md-5 {
        padding-top: 3rem !important
    }
    .pr-md-5 {
        padding-right: 3rem !important
    }
    .pb-md-5 {
        padding-bottom: 3rem !important
    }
    .pl-md-5,
    .px-md-5 {
        padding-left: 3rem !important
    }
    .px-md-5 {
        padding-right: 3rem !important
    }
    .py-md-5 {
        padding-bottom: 3rem !important;
        padding-top: 3rem !important
    }
    .m-md-auto {
        margin: auto !important
    }
    .mt-md-auto {
        margin-top: auto !important
    }
    .mr-md-auto {
        margin-right: auto !important
    }
    .mb-md-auto {
        margin-bottom: auto !important
    }
    .ml-md-auto,
    .mx-md-auto {
        margin-left: auto !important
    }
    .mx-md-auto {
        margin-right: auto !important
    }
    .my-md-auto {
        margin-bottom: auto !important;
        margin-top: auto !important
    }
}

@media (min-width:992px) {
    .m-lg-0 {
        margin: 0 !important
    }
    .mt-lg-0 {
        margin-top: 0 !important
    }
    .mr-lg-0 {
        margin-right: 0 !important
    }
    .mb-lg-0 {
        margin-bottom: 0 !important
    }
    .ml-lg-0,
    .mx-lg-0 {
        margin-left: 0 !important
    }
    .mx-lg-0 {
        margin-right: 0 !important
    }
    .my-lg-0 {
        margin-bottom: 0 !important;
        margin-top: 0 !important
    }
    .m-lg-1 {
        margin: .25rem !important
    }
    .mt-lg-1 {
        margin-top: .25rem !important
    }
    .mr-lg-1 {
        margin-right: .25rem !important
    }
    .mb-lg-1 {
        margin-bottom: .25rem !important
    }
    .ml-lg-1,
    .mx-lg-1 {
        margin-left: .25rem !important
    }
    .mx-lg-1 {
        margin-right: .25rem !important
    }
    .my-lg-1 {
        margin-bottom: .25rem !important;
        margin-top: .25rem !important
    }
    .m-lg-2 {
        margin: .5rem !important
    }
    .mt-lg-2 {
        margin-top: .5rem !important
    }
    .mr-lg-2 {
        margin-right: .5rem !important
    }
    .mb-lg-2 {
        margin-bottom: .5rem !important
    }
    .ml-lg-2,
    .mx-lg-2 {
        margin-left: .5rem !important
    }
    .mx-lg-2 {
        margin-right: .5rem !important
    }
    .my-lg-2 {
        margin-bottom: .5rem !important;
        margin-top: .5rem !important
    }
    .m-lg-3 {
        margin: 1rem !important
    }
    .mt-lg-3 {
        margin-top: 1rem !important
    }
    .mr-lg-3 {
        margin-right: 1rem !important
    }
    .mb-lg-3 {
        margin-bottom: 1rem !important
    }
    .ml-lg-3,
    .mx-lg-3 {
        margin-left: 1rem !important
    }
    .mx-lg-3 {
        margin-right: 1rem !important
    }
    .my-lg-3 {
        margin-bottom: 1rem !important;
        margin-top: 1rem !important
    }
    .m-lg-4 {
        margin: 1.5rem !important
    }
    .mt-lg-4 {
        margin-top: 1.5rem !important
    }
    .mr-lg-4 {
        margin-right: 1.5rem !important
    }
    .mb-lg-4 {
        margin-bottom: 1.5rem !important
    }
    .ml-lg-4,
    .mx-lg-4 {
        margin-left: 1.5rem !important
    }
    .mx-lg-4 {
        margin-right: 1.5rem !important
    }
    .my-lg-4 {
        margin-bottom: 1.5rem !important;
        margin-top: 1.5rem !important
    }
    .m-lg-5 {
        margin: 3rem !important
    }
    .mt-lg-5 {
        margin-top: 3rem !important
    }
    .mr-lg-5 {
        margin-right: 3rem !important
    }
    .mb-lg-5 {
        margin-bottom: 3rem !important
    }
    .ml-lg-5,
    .mx-lg-5 {
        margin-left: 3rem !important
    }
    .mx-lg-5 {
        margin-right: 3rem !important
    }
    .my-lg-5 {
        margin-bottom: 3rem !important;
        margin-top: 3rem !important
    }
    .p-lg-0 {
        padding: 0 !important
    }
    .pt-lg-0 {
        padding-top: 0 !important
    }
    .pr-lg-0 {
        padding-right: 0 !important
    }
    .pb-lg-0 {
        padding-bottom: 0 !important
    }
    .pl-lg-0,
    .px-lg-0 {
        padding-left: 0 !important
    }
    .px-lg-0 {
        padding-right: 0 !important
    }
    .py-lg-0 {
        padding-bottom: 0 !important;
        padding-top: 0 !important
    }
    .p-lg-1 {
        padding: .25rem !important
    }
    .pt-lg-1 {
        padding-top: .25rem !important
    }
    .pr-lg-1 {
        padding-right: .25rem !important
    }
    .pb-lg-1 {
        padding-bottom: .25rem !important
    }
    .pl-lg-1,
    .px-lg-1 {
        padding-left: .25rem !important
    }
    .px-lg-1 {
        padding-right: .25rem !important
    }
    .py-lg-1 {
        padding-bottom: .25rem !important;
        padding-top: .25rem !important
    }
    .p-lg-2 {
        padding: .5rem !important
    }
    .pt-lg-2 {
        padding-top: .5rem !important
    }
    .pr-lg-2 {
        padding-right: .5rem !important
    }
    .pb-lg-2 {
        padding-bottom: .5rem !important
    }
    .pl-lg-2,
    .px-lg-2 {
        padding-left: .5rem !important
    }
    .px-lg-2 {
        padding-right: .5rem !important
    }
    .py-lg-2 {
        padding-bottom: .5rem !important;
        padding-top: .5rem !important
    }
    .p-lg-3 {
        padding: 1rem !important
    }
    .pt-lg-3 {
        padding-top: 1rem !important
    }
    .pr-lg-3 {
        padding-right: 1rem !important
    }
    .pb-lg-3 {
        padding-bottom: 1rem !important
    }
    .pl-lg-3,
    .px-lg-3 {
        padding-left: 1rem !important
    }
    .px-lg-3 {
        padding-right: 1rem !important
    }
    .py-lg-3 {
        padding-bottom: 1rem !important;
        padding-top: 1rem !important
    }
    .p-lg-4 {
        padding: 1.5rem !important
    }
    .pt-lg-4 {
        padding-top: 1.5rem !important
    }
    .pr-lg-4 {
        padding-right: 1.5rem !important
    }
    .pb-lg-4 {
        padding-bottom: 1.5rem !important
    }
    .pl-lg-4,
    .px-lg-4 {
        padding-left: 1.5rem !important
    }
    .px-lg-4 {
        padding-right: 1.5rem !important
    }
    .py-lg-4 {
        padding-bottom: 1.5rem !important;
        padding-top: 1.5rem !important
    }
    .p-lg-5 {
        padding: 3rem !important
    }
    .pt-lg-5 {
        padding-top: 3rem !important
    }
    .pr-lg-5 {
        padding-right: 3rem !important
    }
    .pb-lg-5 {
        padding-bottom: 3rem !important
    }
    .pl-lg-5,
    .px-lg-5 {
        padding-left: 3rem !important
    }
    .px-lg-5 {
        padding-right: 3rem !important
    }
    .py-lg-5 {
        padding-bottom: 3rem !important;
        padding-top: 3rem !important
    }
    .m-lg-auto {
        margin: auto !important
    }
    .mt-lg-auto {
        margin-top: auto !important
    }
    .mr-lg-auto {
        margin-right: auto !important
    }
    .mb-lg-auto {
        margin-bottom: auto !important
    }
    .ml-lg-auto,
    .mx-lg-auto {
        margin-left: auto !important
    }
    .mx-lg-auto {
        margin-right: auto !important
    }
    .my-lg-auto {
        margin-bottom: auto !important;
        margin-top: auto !important
    }
}

@media (min-width:1200px) {
    .m-xl-0 {
        margin: 0 !important
    }
    .mt-xl-0 {
        margin-top: 0 !important
    }
    .mr-xl-0 {
        margin-right: 0 !important
    }
    .mb-xl-0 {
        margin-bottom: 0 !important
    }
    .ml-xl-0,
    .mx-xl-0 {
        margin-left: 0 !important
    }
    .mx-xl-0 {
        margin-right: 0 !important
    }
    .my-xl-0 {
        margin-bottom: 0 !important;
        margin-top: 0 !important
    }
    .m-xl-1 {
        margin: .25rem !important
    }
    .mt-xl-1 {
        margin-top: .25rem !important
    }
    .mr-xl-1 {
        margin-right: .25rem !important
    }
    .mb-xl-1 {
        margin-bottom: .25rem !important
    }
    .ml-xl-1,
    .mx-xl-1 {
        margin-left: .25rem !important
    }
    .mx-xl-1 {
        margin-right: .25rem !important
    }
    .my-xl-1 {
        margin-bottom: .25rem !important;
        margin-top: .25rem !important
    }
    .m-xl-2 {
        margin: .5rem !important
    }
    .mt-xl-2 {
        margin-top: .5rem !important
    }
    .mr-xl-2 {
        margin-right: .5rem !important
    }
    .mb-xl-2 {
        margin-bottom: .5rem !important
    }
    .ml-xl-2,
    .mx-xl-2 {
        margin-left: .5rem !important
    }
    .mx-xl-2 {
        margin-right: .5rem !important
    }
    .my-xl-2 {
        margin-bottom: .5rem !important;
        margin-top: .5rem !important
    }
    .m-xl-3 {
        margin: 1rem !important
    }
    .mt-xl-3 {
        margin-top: 1rem !important
    }
    .mr-xl-3 {
        margin-right: 1rem !important
    }
    .mb-xl-3 {
        margin-bottom: 1rem !important
    }
    .ml-xl-3,
    .mx-xl-3 {
        margin-left: 1rem !important
    }
    .mx-xl-3 {
        margin-right: 1rem !important
    }
    .my-xl-3 {
        margin-bottom: 1rem !important;
        margin-top: 1rem !important
    }
    .m-xl-4 {
        margin: 1.5rem !important
    }
    .mt-xl-4 {
        margin-top: 1.5rem !important
    }
    .mr-xl-4 {
        margin-right: 1.5rem !important
    }
    .mb-xl-4 {
        margin-bottom: 1.5rem !important
    }
    .ml-xl-4,
    .mx-xl-4 {
        margin-left: 1.5rem !important
    }
    .mx-xl-4 {
        margin-right: 1.5rem !important
    }
    .my-xl-4 {
        margin-bottom: 1.5rem !important;
        margin-top: 1.5rem !important
    }
    .m-xl-5 {
        margin: 3rem !important
    }
    .mt-xl-5 {
        margin-top: 3rem !important
    }
    .mr-xl-5 {
        margin-right: 3rem !important
    }
    .mb-xl-5 {
        margin-bottom: 3rem !important
    }
    .ml-xl-5,
    .mx-xl-5 {
        margin-left: 3rem !important
    }
    .mx-xl-5 {
        margin-right: 3rem !important
    }
    .my-xl-5 {
        margin-bottom: 3rem !important;
        margin-top: 3rem !important
    }
    .p-xl-0 {
        padding: 0 !important
    }
    .pt-xl-0 {
        padding-top: 0 !important
    }
    .pr-xl-0 {
        padding-right: 0 !important
    }
    .pb-xl-0 {
        padding-bottom: 0 !important
    }
    .pl-xl-0,
    .px-xl-0 {
        padding-left: 0 !important
    }
    .px-xl-0 {
        padding-right: 0 !important
    }
    .py-xl-0 {
        padding-bottom: 0 !important;
        padding-top: 0 !important
    }
    .p-xl-1 {
        padding: .25rem !important
    }
    .pt-xl-1 {
        padding-top: .25rem !important
    }
    .pr-xl-1 {
        padding-right: .25rem !important
    }
    .pb-xl-1 {
        padding-bottom: .25rem !important
    }
    .pl-xl-1,
    .px-xl-1 {
        padding-left: .25rem !important
    }
    .px-xl-1 {
        padding-right: .25rem !important
    }
    .py-xl-1 {
        padding-bottom: .25rem !important;
        padding-top: .25rem !important
    }
    .p-xl-2 {
        padding: .5rem !important
    }
    .pt-xl-2 {
        padding-top: .5rem !important
    }
    .pr-xl-2 {
        padding-right: .5rem !important
    }
    .pb-xl-2 {
        padding-bottom: .5rem !important
    }
    .pl-xl-2,
    .px-xl-2 {
        padding-left: .5rem !important
    }
    .px-xl-2 {
        padding-right: .5rem !important
    }
    .py-xl-2 {
        padding-bottom: .5rem !important;
        padding-top: .5rem !important
    }
    .p-xl-3 {
        padding: 1rem !important
    }
    .pt-xl-3 {
        padding-top: 1rem !important
    }
    .pr-xl-3 {
        padding-right: 1rem !important
    }
    .pb-xl-3 {
        padding-bottom: 1rem !important
    }
    .pl-xl-3,
    .px-xl-3 {
        padding-left: 1rem !important
    }
    .px-xl-3 {
        padding-right: 1rem !important
    }
    .py-xl-3 {
        padding-bottom: 1rem !important;
        padding-top: 1rem !important
    }
    .p-xl-4 {
        padding: 1.5rem !important
    }
    .pt-xl-4 {
        padding-top: 1.5rem !important
    }
    .pr-xl-4 {
        padding-right: 1.5rem !important
    }
    .pb-xl-4 {
        padding-bottom: 1.5rem !important
    }
    .pl-xl-4,
    .px-xl-4 {
        padding-left: 1.5rem !important
    }
    .px-xl-4 {
        padding-right: 1.5rem !important
    }
    .py-xl-4 {
        padding-bottom: 1.5rem !important;
        padding-top: 1.5rem !important
    }
    .p-xl-5 {
        padding: 3rem !important
    }
    .pt-xl-5 {
        padding-top: 3rem !important
    }
    .pr-xl-5 {
        padding-right: 3rem !important
    }
    .pb-xl-5 {
        padding-bottom: 3rem !important
    }
    .pl-xl-5,
    .px-xl-5 {
        padding-left: 3rem !important
    }
    .px-xl-5 {
        padding-right: 3rem !important
    }
    .py-xl-5 {
        padding-bottom: 3rem !important;
        padding-top: 3rem !important
    }
    .m-xl-auto {
        margin: auto !important
    }
    .mt-xl-auto {
        margin-top: auto !important
    }
    .mr-xl-auto {
        margin-right: auto !important
    }
    .mb-xl-auto {
        margin-bottom: auto !important
    }
    .ml-xl-auto,
    .mx-xl-auto {
        margin-left: auto !important
    }
    .mx-xl-auto {
        margin-right: auto !important
    }
    .my-xl-auto {
        margin-bottom: auto !important;
        margin-top: auto !important
    }
}

.text-justify {
    text-align: justify !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-normal {
    font-weight: 400
}

.font-weight-bold {
    font-weight: 700
}

.font-italic {
    font-style: italic
}

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

.text-primary {
    color: #007bff !important
}

a.text-primary:focus,
a.text-primary:hover {
    color: #0062cc !important
}

.text-secondary {
    color: #868e96 !important
}

a.text-secondary:focus,
a.text-secondary:hover {
    color: #6c757d !important
}

.text-success {
    color: #28a745 !important
}

a.text-success:focus,
a.text-success:hover {
    color: #1e7e34 !important
}

.text-info {
    color: #17a2b8 !important
}

a.text-info:focus,
a.text-info:hover {
    color: #117a8b !important
}

.text-warning {
    color: #ffc107 !important
}

a.text-warning:focus,
a.text-warning:hover {
    color: #d39e00 !important
}

.text-danger {
    color: #dc3545 !important
}

a.text-danger:focus,
a.text-danger:hover {
    color: #bd2130 !important
}

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

a.text-light:focus,
a.text-light:hover {
    color: #dae0e5 !important
}

.text-dark {
    color: #343a40 !important
}

a.text-dark:focus,
a.text-dark:hover {
    color: #1d2124 !important
}

.text-muted {
    color: #868e96 !important
}

.text-hide {
    background-color: transparent;
    border: 0;
    color: transparent;
    font: 0/0 a;
    text-shadow: none
}

.visible {
    visibility: visible !important
}

.invisible {
    visibility: hidden !important
}

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

audio,
canvas,
video {
    display: inline-block
}

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

[hidden],
template {
    display: none
}

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

body {
    margin: 0
}

a {
    background: transparent
}

a:focus {
    outline: thin dotted
}

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

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

.strong,
b,
strong {
    font-weight: 700
}

.em,
dfn,
em {
    font-style: italic
}

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

pre {
    margin: 0
}

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

pre {
    white-space: pre-wrap
}

q {
    quotes: "“" "”" "‘" "’"
}

q:after,
q:before {
    content: "";
    content: none
}

.small,
small,
sub,
sup {
    font-size: 75%
}

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

sup {
    top: -.5em
}

sub {
    bottom: -.25em
}

dl,
menu,
ol,
ul {
    margin: 1em 0
}

dd {
    margin: 0
}

menu {
    padding: 0 0 0 40px
}

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

nav ol,
nav ul {
    list-style: none;
    list-style-image: none
}

img {
    border: 0
}

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

figure {
    margin: 0
}

fieldset {
    border: 1px solid silver;
    margin: 0 2px;
    padding: .35em .625em .75em
}

legend {
    border: 0;
    padding: 0
}

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

button,
input {
    line-height: normal
}

button,
select {
    text-transform: none
}

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

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

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

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

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

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

textarea {
    overflow: auto;
    vertical-align: top
}

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

* {
    box-sizing: border-box
}

.image-replacement,
.ir {
    overflow: hidden;
    text-indent: 100%;
    white-space: nowrap
}

.cf,
.clearfix {
    zoom: 1
}

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

.cf:after,
.clearfix:after {
    clear: both
}

span.amp {
    font-family: Baskerville, Goudy Old Style, Palatino, Book Antiqua, serif !important;
    font-style: italic
}

body {
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
    position: relative;
    scroll-behavior: smooth
}

body.menu-open {
    height: 100vh;
    overflow-y: hidden
}

body,
html {
    overflow-x: hidden
}

body {
    width: 100%
}

.cover {
    background-position: 50%;
    background-repeat: no-repeat;
    background-size: cover
}

.object-cover {
    -o-object-fit: cover;
    object-fit: cover;
    -o-object-position: center;
    object-position: center
}

.container {
    max-width: 1200px;
    padding: 0 30px;
    position: relative;
    width: 100%
}

.container--sm {
    max-width: 820px
}

.container--md {
    max-width: 1090px
}

.container--lg {
    max-width: 1400px
}

.container--no-mobile-padding {
    padding: 0
}

@media screen and (min-width:992px) {
    .container--no-mobile-padding {
        padding: 0 30px
    }
}

.site-overlay {
    background-color: #000;
    height: 100%;
    left: 0;
    opacity: 0;
    pointer-events: none;
    position: fixed;
    top: 0;
    transition: .3s;
    width: 100%;
    z-index: 15
}

.site-overlay.active {
    opacity: .4
}

.text-dropshadow {
    text-shadow: 0 6px 6px rgba(0, 0, 0, .2)
}

.section {
    padding: rem-calc(80px 0 40px 0)
}

@media screen and (min-width:1024px) {
    .section {
        padding: rem-calc(95px 0)
    }
}

.full-bg .section+.section {
    padding-top: 20px
}

@media screen and (min-width:1024px) {
    .full-bg .section+.section {
        padding-top: 50px
    }
}

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

img {
    max-width: 100%
}

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

@media screen and (min-width:992px) {
    .js-hidden {
        opacity: 0;
        transform: translateY(30px);
        transition: transform .9s ease, opacity .9s ease;
        will-change: transform
    }
    .js-hidden.js-visible {
        opacity: 1;
        transform: translateY(0)
    }
}

a:focus {
    outline: 0
}

.hidden {
    display: none !important
}

.fade-in {
    opacity: 1 !important;
    transition: all .3s ease-in-out;
    visibility: visible !important;
    z-index: 2 !important
}

.fade-out {
    opacity: 0 !important;
    visibility: hidden !important;
    z-index: -1 !important
}

.object-fit {
    position: relative
}

.object-fit img {
    -o-object-fit: cover;
    object-fit: cover;
    -o-object-position: center;
    object-position: center
}

.object-fit img,
.overlay {
    height: 100%;
    left: 0;
    position: absolute;
    top: 0;
    width: 100%
}

.full-height {
    height: 100%
}

@media screen and (max-width:768px) {
    .cta-wrap {
        justify-content: center
    }
}

.white-text * {
    color: #fff
}

.loader {
    text-align: center
}

.flex-align-center {
    align-items: center;
    display: flex
}

.flex-wrap {
    justify-content: space-between
}

.flex,
.flex-wrap {
    display: flex
}

@media screen and (min-width:768px) {
    .flex-md {
        display: flex
    }
}

.row-reverse {
    flex-flow: row-reverse
}

@media (max-width:768px) {
    .row-reverse {
        flex-flow: column
    }
}

.grid-wrap {
    display: grid
}

.grid-wrap.grid-2 {
    grid-template-columns: 50% 50%;
    height: 100%
}

@font-face {
    font-family: Langdon;
    src: url(../../fonts/langdon/langdon.eot) format("embedded-opentype"), url(../../fonts/langdon/langdon.ttf) format("truetype"), url(../../fonts/langdon/langdon.woff) format("woff"), url(../../fonts/langdon/langdon.woff2) format("woff2"), url(../../fonts/langdon/langdon.svg) format("svg")
}

@font-face {
    font-family: Baskerville;
    src: url(../../fonts/baskerville/baskerville.eot) format("embedded-opentype"), url(../../fonts/baskerville/baskerville.ttf) format("truetype"), url(../../fonts/baskerville/baskerville.woff) format("woff"), url(../../fonts/baskerville/baskerville.woff2) format("woff2"), url(../../fonts/baskerville/baskerville.svg) format("svg")
}

@font-face {
    font-family: Montserrat-Medium;
    src: url(../../fonts/montserrat/montserrat-medium.eot) format("embedded-opentype"), url(../../fonts/montserrat/montserrat-medium.ttf) format("truetype"), url(../../fonts/montserrat/montserrat-medium.woff) format("woff"), url(../../fonts/montserrat/montserrat-medium.woff2) format("woff2"), url(../../fonts/montserrat/montserrat-medium.svg) format("svg")
}

@font-face {
    font-family: Montserrat-Regular;
    src: url(../../fonts/montserrat/montserrat-regular.eot) format("embedded-opentype"), url(../../fonts/montserrat/montserrat-regular.ttf) format("truetype"), url(../../fonts/montserrat/montserrat-regular.woff) format("woff"), url(../../fonts/montserrat/montserrat-regular.woff2) format("woff2"), url(../../fonts/montserrat/montserrat-regular.svg) format("svg")
}

@font-face {
    font-family: Montserrat-Light;
    src: url(../../fonts/montserrat/montserrat-light.eot) format("embedded-opentype"), url(../../fonts/montserrat/montserrat-light.ttf) format("truetype"), url(../../fonts/montserrat/montserrat-light.woff) format("woff"), url(../../fonts/montserrat/montserrat-light.woff2) format("woff2"), url(../../fonts/montserrat/montserrat-light.svg) format("svg")
}

h1 {
    font-family: Langdon;
    font-size: 66px;
    font-weight: 400;
    letter-spacing: 6.6px;
    line-height: 70px
}

@media screen and (min-width:1024px) {
    h1 {
        font-size: 80px;
        letter-spacing: 8px;
        line-height: 90px
    }
}

@media screen and (min-width:1200px) {
    h1 {
        font-size: 96px;
        letter-spacing: 9.6px;
        line-height: 107px
    }
}

h2 {
    font-family: Langdon;
    font-size: 40px;
    font-weight: 400;
    letter-spacing: 4px;
    line-height: 55px;
    text-transform: uppercase
}

@media screen and (min-width:768px) {
    h2 {
        font-size: 62px;
        letter-spacing: 6.2px;
        line-height: 60px
    }
}

h3 {
    font-size: 42px;
    letter-spacing: 4.4px;
    line-height: 54px
}

h3,
h4 {
    font-family: Langdon;
    font-weight: 400;
    text-transform: uppercase
}

h4 {
    font-size: 26px;
    letter-spacing: 2.8px;
    line-height: 28px
}

h5 {
    font-family: Baskerville;
    letter-spacing: 1.8px;
    line-height: 27.5px
}

h5,
h6 {
    font-size: 16px;
    margin: 0;
    text-transform: uppercase
}

h6 {
    font-family: Langdon;
    letter-spacing: 3.2px;
    line-height: 20px
}

p {
    font-family: Montserrat-Medium;
    font-size: 16px;
    font-weight: 500;
    letter-spacing: 1.8px;
    line-height: 24px
}

@media print {
    * {
        background: transparent !important;
        color: #000 !important;
        filter: none !important;
        -ms-filter: none !important;
        text-shadow: none !important
    }
    a,
    a:visited {
        color: #444 !important;
        text-decoration: underline
    }
    a:after,
    a:visited:after {
        content: " (" attr(href) ")"
    }
    a abbr[title]:after,
    a:visited abbr[title]:after {
        content: " (" attr(title) ")"
    }
    .ir a:after,
    a[href^="#"]:after,
    a[href^="javascript:"]:after {
        content: ""
    }
    blockquote,
    pre {
        border: 1px solid #999;
        page-break-inside: avoid
    }
    thead {
        display: table-header-group
    }
    img,
    tr {
        page-break-inside: avoid
    }
    img {
        max-width: 100% !important
    }
    @page {
        margin: .5cm
    }
    h2,
    h3,
    p {
        orphans: 3;
        widows: 3
    }
    h2,
    h3 {
        page-break-after: avoid
    }
    .page-navigation,
    .respond-form,
    .sidebar,
    .wp-prev-next,
    nav {
        display: none
    }
}

.button--outline {
    display: block;
    font-family: Baskerville;
    font-size: 16px;
    height: 50px;
    letter-spacing: 1.8px;
    padding: 13px 0;
    text-align: center;
    text-transform: uppercase;
    transition: .3s;
    width: 200px
}

.button--outline--white {
    border: 2px solid #fff;
    color: #fff
}

.button--outline--white:hover {
    background-color: #fff;
    color: #002855;
    text-decoration: none
}

.button--outline--red {
    border: 2px solid #af272f;
    color: #af272f
}

.button--outline--red:hover {
    background-color: #af272f;
    color: #fff;
    text-decoration: none
}

.button--border-style {
    display: inline-block;
    font-family: Langdon;
    font-size: 26px;
    font-weight: 400;
    letter-spacing: 2.8px;
    line-height: 28px;
    text-transform: uppercase;
    transition: .3s
}

.button--border-style:before {
    margin-bottom: 4px
}

.button--border-style:after,
.button--border-style:before {
    background-color: transparent;
    content: "";
    display: block;
    height: 7px
}

.button--border-style:after {
    margin-top: 2px
}

.button--border-style.edge:after {
    margin-top: 7px
}

.button--border-style.edge a:after,
.button--border-style.edge a:before,
.button--border-style.edge p:after,
.button--border-style.edge p:before {
    top: 1px
}

.button--border-style:hover a,
.button--border-style:hover p {
    color: transparent;
    text-decoration: none
}

.button--blue a,
.button--blue p {
    color: #002855;
    position: relative;
    transition: .3s
}

.button--blue a:after,
.button--blue p:after {
    right: -25px
}

.button--blue a:after,
.button--blue a:before,
.button--blue p:after,
.button--blue p:before {
    background-image: url(../../images/graphics/blue-star.svg);
    background-position: 50%;
    background-repeat: no-repeat;
    content: "";
    display: block;
    height: 20px;
    opacity: 0;
    position: absolute;
    top: 0;
    transition: .3s;
    width: 20px
}

.button--blue a:before,
.button--blue p:before {
    left: -25px
}

@media (pointer:fine) {
    .button--blue a,
    .button--blue p {
        -webkit-text-stroke: 1px transparent
    }
}

.button--blue:after,
.button--blue:before {
    border-bottom: 2px solid #002855;
    border-top: 2px solid #002855
}

@media (pointer:fine) {
    .button--blue:hover a,
    .button--blue:hover p {
        -webkit-text-stroke: 1px #002855
    }
    .button--blue:hover a:after,
    .button--blue:hover a:before,
    .button--blue:hover p:after,
    .button--blue:hover p:before {
        opacity: 1
    }
}

.button--white a,
.button--white p {
    color: #fff;
    position: relative;
    transition: .3s
}

.button--white a:after,
.button--white p:after {
    right: -25px
}

.button--white a:after,
.button--white a:before,
.button--white p:after,
.button--white p:before {
    background-image: url(../../images/graphics/white-star.svg);
    background-position: 50%;
    background-repeat: no-repeat;
    content: "";
    display: block;
    height: 20px;
    opacity: 0;
    position: absolute;
    top: 0;
    transition: .3s;
    width: 20px
}

.button--white a:before,
.button--white p:before {
    left: -25px
}

@media (pointer:fine) {
    .button--white a,
    .button--white p {
        -webkit-text-stroke: 1px transparent
    }
}

.button--white:after,
.button--white:before {
    border-bottom: 2px solid #fff;
    border-top: 2px solid #fff
}

@media (pointer:fine) {
    .button--white:hover a,
    .button--white:hover p {
        -webkit-text-stroke: 1px #fff
    }
    .button--white:hover a:after,
    .button--white:hover a:before,
    .button--white:hover p:after,
    .button--white:hover p:before {
        opacity: 1
    }
}

.button--red a,
.button--red p {
    color: #af272f;
    position: relative;
    transition: .3s
}

.button--red a:after,
.button--red p:after {
    right: -25px
}

.button--red a:after,
.button--red a:before,
.button--red p:after,
.button--red p:before {
    background-image: url(../../images/graphics/red-star.svg);
    background-position: 50%;
    background-repeat: no-repeat;
    content: "";
    display: block;
    height: 20px;
    opacity: 0;
    position: absolute;
    top: 0;
    transition: .3s;
    width: 20px
}

.button--red a:before,
.button--red p:before {
    left: -25px
}

@media (pointer:fine) {
    .button--red a,
    .button--red p {
        -webkit-text-stroke: 1px transparent
    }
}

.button--red:after,
.button--red:before {
    border-bottom: 2px solid #af272f;
    border-top: 2px solid #af272f
}

@media (pointer:fine) {
    .button--red:hover a,
    .button--red:hover p {
        -webkit-text-stroke: 1px #af272f
    }
    .button--red:hover a:after,
    .button--red:hover a:before,
    .button--red:hover p:after,
    .button--red:hover p:before {
        opacity: 1
    }
}

.header {
    background-color: rgba(138, 161, 177, .8);
    height: 98px;
    position: fixed;
    transition: .3s;
    width: 100%;
    z-index: 20
}

@media screen and (min-width:768px) {
    .header {
        height: 150px
    }
}

@media screen and (min-width:1200px) {
    .header {
        height: 150px
    }
}

.header.shrink {
    -webkit-backdrop-filter: blur(10px);
    backdrop-filter: blur(10px);
    height: 98px
}

.header.shrink .header__logo img {
    height: 98px
}

.header.fill {
    background-color: #002855
}

.header.fill .btn {
    background-color: #fff
}

.header.fill .btn a {
    color: #af272f
}

.header.fill .header__logo__main {
    opacity: 0
}

.header.fill .header__logo__white {
    opacity: 1
}

.header__logo {
    position: relative
}

.header__logo img {
    height: 100px;
    transition: .3s;
    width: auto
}

@media screen and (min-width:768px) {
    .header__logo img {
        height: 120px
    }
}

@media screen and (min-width:1200px) {
    .header__logo img {
        height: 140px
    }
}

.header__logo__main {
    opacity: 1;
    position: relative;
    transition: .3s;
    z-index: 2
}

.header__logo__white {
    left: 0;
    opacity: 0;
    position: absolute;
    top: 0;
    z-index: 1
}

.header__nav ul {
    align-items: center;
    display: flex
}

.header__nav ul li {
    display: none
}

@media screen and (min-width:768px) {
    .header__nav ul li {
        display: block;
        margin-left: 20px
    }
}

@media screen and (min-width:992px) {
    .header__nav ul li {
        margin-left: 35px;
        padding-top: 6px
    }
}

@media screen and (min-width:1200px) {
    .header__nav ul li {
        margin-left: 60px
    }
}

.header__nav ul li.current-menu-item a:after {
    width: 100%
}

.header__nav ul li a {
    color: #fff;
    font-family: Langdon;
    font-size: 14px;
    font-weight: 400;
    letter-spacing: 2.2px;
    line-height: 20px;
    text-decoration: none;
    text-transform: uppercase;
    transition: .3s
}

@media screen and (min-width:992px) {
    .header__nav ul li a {
        font-size: 20px;
        letter-spacing: 3.2px
    }
}

.header__nav ul li a:after {
    background: #fff;
    content: "";
    display: block;
    height: 2px;
    opacity: 1;
    transition: width .3s;
    width: 0
}

.header__nav ul li a:hover {
    text-decoration: none
}

.header__nav ul li a:hover:after {
    width: 100%
}

.header__nav ul li.btn {
    background-color: #002855;
    display: block;
    padding: 13px 10px 10px;
    transition: .3s
}

.header__nav ul li.btn:hover {
    background-color: #fff
}

.header__nav ul li.btn:hover a {
    color: #af272f
}

.header__nav ul li.btn a:after {
    content: none
}

.header__nav-toggle {
    cursor: pointer;
    height: 30px;
    margin-left: 20px;
    position: relative;
    width: 53px;
    z-index: 10
}

@media screen and (min-width:992px) {
    .header__nav-toggle {
        margin-left: 30px
    }
}

@media screen and (min-width:1200px) {
    .header__nav-toggle {
        margin-left: 50px
    }
}

.header__nav-toggle__wrapper {
    height: 30px;
    position: absolute;
    width: 40px
}

.header__nav-toggle span {
    background: #fff;
    display: block;
    height: 2px;
    opacity: 1;
    position: absolute;
    transform: rotate(0deg);
    transition: .25s ease-in-out;
    width: 50%
}

.header__nav-toggle span:nth-child(2n) {
    border-radius: 0 1px 1px 0;
    left: 50%
}

.header__nav-toggle span:nth-child(odd) {
    border-radius: 1px 0 0 1px;
    left: 0
}

.header__nav-toggle span:first-child,
.header__nav-toggle span:nth-child(2) {
    top: 0
}

.header__nav-toggle span:nth-child(3),
.header__nav-toggle span:nth-child(4) {
    top: 14px
}

.header__nav-toggle span:nth-child(5),
.header__nav-toggle span:nth-child(6) {
    top: 28px
}

.header__nav-toggle.open span:first-child,
.header__nav-toggle.open span:nth-child(6) {
    transform: rotate(45deg)
}

.header__nav-toggle.open span:nth-child(2),
.header__nav-toggle.open span:nth-child(5) {
    transform: rotate(-45deg)
}

.header__nav-toggle.open span:first-child {
    left: 5px;
    top: 7px
}

.header__nav-toggle.open span:nth-child(2) {
    left: calc(50% - 5px);
    top: 7px
}

.header__nav-toggle.open span:nth-child(3) {
    left: -50%;
    opacity: 0
}

.header__nav-toggle.open span:nth-child(4) {
    left: 100%;
    opacity: 0
}

.header__nav-toggle.open span:nth-child(5) {
    left: 4px;
    top: 18px
}

.header__nav-toggle.open span:nth-child(6) {
    left: calc(50% - 4px);
    top: 18px
}

.footer {
    background-color: #8aa1b1;
    padding: 60px 0 0;
    position: relative
}

@media screen and (min-width:768px) {
    .footer {
        padding: 60px 0 70px
    }
}

@media screen and (min-width:1200px) {
    .footer {
        padding: 80px 0 90px
    }
}

.footer a,
.footer h4,
.footer p {
    color: #002855
}

.footer .back-to-top {
    cursor: pointer;
    position: absolute;
    right: 30px;
    top: 0;
    transition: .5s;
    width: 80px
}

@media screen and (min-width:768px) {
    .footer .back-to-top {
        transform: rotate(180deg)
    }
}

@media screen and (min-width:1200px) {
    .footer .back-to-top {
        width: 112px
    }
}

.footer .back-to-top:hover {
    transform: rotate(0)
}

.footer__logo img {
    height: 80px;
    width: auto
}

@media screen and (min-width:992px) {
    .footer__logo img {
        height: 120px
    }
}

.footer__newsletter {
    margin: 60px 0 50px;
    width: 100%
}

@media screen and (min-width:768px) {
    .footer__newsletter {
        margin: 0 0 50px
    }
}

@media screen and (min-width:992px) {
    .footer__newsletter {
        margin: 0;
        width: 220px
    }
}

.footer__newsletter h4 {
    font-size: 20px;
    letter-spacing: 1px;
    line-height: 22px;
    margin-bottom: 15px
}

.footer__newsletter .selectric-js-selectric {
    height: 50px;
    margin-bottom: 15px
}

.footer__newsletter .selectric-js-selectric .selectric {
    border: 2px solid #002855;
    height: 50px;
    min-width: unset;
    width: 220px
}

.footer__newsletter .selectric-js-selectric .selectric .button {
    height: 47px;
    right: 15px
}

.footer__newsletter .selectric-js-selectric .selectric-items {
    border: 1px solid #002855;
    top: 100%
}

.footer__newsletter .selectric-js-selectric .selectric-items li {
    border: 1px solid #002855;
    font-size: 16px
}

.footer__newsletter .selectric-js-selectric .selectric .label {
    color: #002855;
    font-family: Langdon;
    font-size: 16px;
    height: 47px;
    letter-spacing: 0;
    line-height: 16px;
    padding: 17px 15px 15px;
    text-transform: uppercase
}

.footer__newsletter .selectric-js-selectric .selectric:after {
    content: none
}

.footer__newsletter input {
    margin-bottom: 12px;
    text-transform: uppercase
}

@media screen and (min-width:992px) {
    .footer__newsletter input {
        margin-bottom: 17px
    }
}

.footer__newsletter input.error {
    border: 2px solid #af272f
}

.footer__newsletter p {
    font-size: 9px;
    line-height: 20px;
    margin-bottom: 15px
}

@media screen and (min-width:992px) {
    .footer__newsletter p {
        margin-bottom: 20px
    }
}

.footer__newsletter .button {
    cursor: pointer
}

.footer__newsletter .button p {
    font-family: Langdon;
    font-size: 20px;
    font-weight: 400;
    letter-spacing: 2.8px;
    line-height: 20px;
    margin: 0;
    text-transform: uppercase
}

@media screen and (min-width:992px) {
    .footer__newsletter .button p {
        font-size: 26px;
        line-height: 28px
    }
    .footer__nav {
        padding-left: 20px
    }
}

@media screen and (min-width:1024px) {
    .footer__nav {
        padding-left: 50px
    }
}

.footer__nav h4 {
    font-size: 20px;
    letter-spacing: 1px;
    line-height: 22px;
    margin-bottom: 15px
}

.footer__nav ul {
    -moz-column-count: 2;
    column-count: 2
}

@media screen and (min-width:768px) {
    .footer__nav ul {
        -moz-column-count: 3;
        column-count: 3
    }
}

@media screen and (min-width:992px) {
    .footer__nav ul {
        -moz-column-count: 2;
        column-count: 2;
        max-width: 300px
    }
}

.footer__nav ul li {
    margin-bottom: 10px
}

@media screen and (min-width:992px) {
    .footer__nav ul li {
        margin-bottom: 20px
    }
}

.footer__nav ul li a {
    color: #002855;
    display: inline-block;
    font-family: Langdon;
    font-size: 16px;
    font-weight: 400;
    letter-spacing: .8px;
    line-height: 22px;
    text-transform: uppercase;
    transition: .3s
}

.footer__nav ul li a:after {
    background: #fff;
    content: "";
    display: block;
    height: 2px;
    opacity: 1;
    transition: width .3s;
    width: 0
}

.footer__nav ul li a:hover {
    color: #fff;
    text-decoration: none
}

.footer__nav ul li a:hover:after {
    width: 100%
}

.footer__social {
    display: none
}

@media screen and (min-width:768px) {
    .footer__social {
        display: block
    }
}

.footer__social h4 {
    font-size: 20px;
    letter-spacing: 1px;
    line-height: 22px;
    margin-bottom: 15px
}

.footer__social ul {
    -moz-column-count: 2;
    column-count: 2
}

.footer__social ul li {
    margin-bottom: 10px;
    width: 100%
}

@media screen and (min-width:992px) {
    .footer__social ul li {
        margin-bottom: 20px
    }
}

.footer__social ul li img {
    height: auto;
    margin-right: 10px;
    width: 17px
}

.footer__social ul li a {
    color: #002855;
    font-family: Langdon;
    font-size: 16px;
    font-weight: 400;
    letter-spacing: .8px;
    line-height: 22px;
    text-transform: uppercase;
    transition: .3s
}

.footer__social ul li a:after {
    background: #fff;
    content: "";
    display: block;
    height: 2px;
    opacity: 1;
    transition: width .3s;
    width: 0
}

.footer__social ul li a:hover {
    color: #fff;
    text-decoration: none
}

.footer__social ul li a:hover:after {
    width: 100%
}

.footer__bottom-row {
    border-top: 1px solid #002855;
    display: none;
    margin-top: 30px;
    padding-top: 30px
}

@media screen and (min-width:768px) {
    .footer__bottom-row {
        display: block
    }
}

@media screen and (min-width:992px) {
    .footer__bottom-row {
        margin-top: 50px
    }
}

.footer__bottom-row p {
    font-family: Baskerville;
    font-size: 14px;
    letter-spacing: .7px;
    margin: 0;
    text-align: center;
    width: 100%
}

@media screen and (min-width:768px) {
    .footer__bottom-row p {
        text-align: initial;
        width: auto
    }
}

.footer__bottom-row ul {
    align-items: center;
    display: flex;
    margin: 0
}

.footer__bottom-row ul li {
    border-right: 1px solid #002855;
    padding: 0 10px
}

.footer__bottom-row ul li:last-of-type {
    border-right: none
}

.footer__bottom-row ul li a {
    font-family: Baskerville;
    font-size: 14px;
    letter-spacing: .7px;
    transition: .3s
}

.footer__bottom-row ul li a:after {
    background: #fff;
    content: "";
    display: block;
    height: 2px;
    opacity: 1;
    transition: width .3s;
    width: 0
}

.footer__bottom-row ul li a:hover {
    color: #fff;
    text-decoration: none
}

.footer__bottom-row ul li a:hover:after {
    width: 100%
}

.footer__bottom-mobile {
    background-color: #002855;
    display: block;
    padding: 30px 0
}

@media screen and (min-width:768px) {
    .footer__bottom-mobile {
        display: none
    }
}

.footer__bottom-mobile h2 {
    color: #fff;
    font-size: 32px;
    letter-spacing: 1.6px;
    line-height: 34px;
    margin-bottom: 30px
}

.footer__bottom-mobile p {
    margin: 0
}

.footer__bottom-mobile p,
.footer__bottom-mobile p a {
    color: #fff;
    font-family: Baskerville;
    font-size: 12px;
    letter-spacing: .7px
}

.footer__bottom-mobile__social {
    display: flex;
    justify-content: center;
    margin-bottom: 30px
}

.footer__bottom-mobile__social li img {
    height: 26px;
    margin: 0 10px;
    width: auto
}

.footer__bottom-mobile .menu-footer-bottom-menu-container ul {
    display: flex;
    justify-content: center;
    margin: 10px 0
}

.footer__bottom-mobile .menu-footer-bottom-menu-container ul li {
    border-right: 1px solid hsla(0, 0%, 100%, .5);
    padding: 0 5px
}

.footer__bottom-mobile .menu-footer-bottom-menu-container ul li:last-of-type {
    border-right: none
}

.footer__bottom-mobile .menu-footer-bottom-menu-container ul li a {
    color: #fff;
    font-family: Baskerville;
    font-size: 12px;
    letter-spacing: .7px
}

.footer__accessibility {
    bottom: 30px;
    position: fixed;
    right: 30px
}

input {
    background-color: transparent;
    border: 2px solid #002855;
    border-radius: 0;
    color: #002855;
    font-family: Langdon;
    font-size: 16px;
    height: 50px;
    padding-left: 15px;
    width: 100%
}

input::-webkit-input-placeholder {
    color: #002855;
    font-family: Langdon;
    font-size: 16px
}

input:-moz-placeholder,
input::-moz-placeholder {
    color: #002855;
    font-family: Langdon;
    font-size: 16px
}

input:-ms-input-placeholder {
    color: #002855;
    font-family: Langdon;
    font-size: 16px
}

.main-navigation {
    background-color: #002855;
    display: none;
    height: 100vh;
    opacity: 0;
    padding-top: 150px;
    pointer-events: none;
    position: fixed;
    top: 0;
    transition: .5s;
    visibility: hidden;
    width: 100vw;
    z-index: 15
}

.main-navigation.active {
    opacity: 1;
    pointer-events: auto;
    visibility: visible
}

.main-navigation.active .main-navigation__nav {
    opacity: 1;
    transform: translateY(0)
}

.main-navigation.active .outlined-text {
    transform: rotate(180deg) translateX(0)
}

.main-navigation .outlined-text {
    display: none;
    left: -40px;
    position: absolute;
    transform: rotate(180deg) translateX(300px);
    transition: .4s
}

@media screen and (min-width:576px) {
    .main-navigation .outlined-text {
        display: block;
        width: 150px
    }
}

@media screen and (min-width:768px) {
    .main-navigation .outlined-text {
        width: 200px
    }
}

@media screen and (min-width:992px) {
    .main-navigation .outlined-text {
        width: 270px
    }
}

@media screen and (min-width:1200px) {
    .main-navigation .outlined-text {
        width: 370px
    }
}

.main-navigation__nav {
    -ms-overflow-style: none;
    height: calc(100vh - 150px);
    opacity: 0;
    overflow: scroll;
    scrollbar-width: none;
    transform: translateY(100px);
    transition: .3s;
    transition-delay: .3s
}

.main-navigation__nav::-webkit-scrollbar {
    display: none
}

.main-navigation__nav ul {
    align-items: center;
    display: flex;
    flex-direction: column;
    margin: 0
}

.main-navigation__nav ul.desktop {
    display: none
}

@media screen and (min-width:768px) {
    .main-navigation__nav ul.desktop {
        display: flex;
        height: 100%;
        justify-content: space-between;
        padding-bottom: 50px
    }
}

.main-navigation__nav ul.mobile {
    display: flex
}

@media screen and (min-width:768px) {
    .main-navigation__nav ul.mobile {
        display: none
    }
}

.main-navigation__nav ul li {
    display: inline-flex;
    margin-bottom: 15px;
    text-align: center
}

@media screen and (min-width:576px) {
    .main-navigation__nav ul li {
        margin-bottom: 30px
    }
}

@media screen and (min-width:768px) {
    .main-navigation__nav ul li {
        margin-bottom: 0
    }
}

.main-navigation__nav ul li:last-of-type {
    padding-bottom: 50px
}

.main-navigation__nav ul li.current-menu-item a {
    -webkit-text-stroke: 1px #fff;
    color: transparent
}

.main-navigation__nav ul li a {
    color: #fff;
    font-family: Langdon;
    font-size: 30px;
    font-weight: 400;
    letter-spacing: 3px;
    line-height: 30px;
    text-decoration: none;
    text-transform: uppercase;
    transition: .3s
}

@media screen and (min-width:576px) {
    .main-navigation__nav ul li a {
        font-size: 40px;
        letter-spacing: 3.2px;
        line-height: 40px
    }
}

@media screen and (min-width:768px) {
    .main-navigation__nav ul li a {
        font-size: 50px;
        letter-spacing: 4.2px;
        line-height: 50px
    }
}

@media screen and (min-width:1024px) {
    .main-navigation__nav ul li a {
        font-size: 62px;
        letter-spacing: 6.2px;
        line-height: 60px;
        padding: 20px
    }
    .main-navigation__nav ul li a.edge {
        padding: 20px
    }
}

.main-navigation__nav ul li a:hover {
    -webkit-text-stroke: 1px #fff;
    background-color: #af272f;
    color: transparent
}

.selectric-js-selectric {
    height: 62px
}

.selectric-js-selectric .selectric {
    background: transparent;
    border: none;
    min-width: 200px
}

@media only screen and (min-width:1440px) {
    .selectric-js-selectric .selectric {
        min-width: 260px
    }
}

.selectric-js-selectric .selectric-items {
    top: calc(100% + 20px)
}

.selectric-js-selectric .selectric:after {
    background-color: transparent;
    border-bottom: 2px solid #002855;
    border-top: 2px solid #002855;
    content: "";
    display: block;
    height: 7px
}

.selectric-js-selectric .selectric .label {
    background: transparent;
    border: none;
    color: #002855;
    font-family: Langdon;
    font-size: 55px;
    font-weight: 400;
    height: 70px;
    letter-spacing: 2.5px;
    line-height: 70px;
    margin: 0;
    text-transform: uppercase
}

.selectric-js-selectric .selectric .button {
    background-color: transparent;
    background-image: url(../../images/icons/arrow-blue.svg);
    background-position: 100%;
    background-repeat: no-repeat;
    height: 62px;
    transform: rotate(0);
    transition: .3s;
    width: 17px
}

.selectric-js-selectric .selectric .button:after {
    display: none
}

.selectric-js-selectric .selectric .button.active {
    transform: rotate(180deg)
}

.selectric-js-selectric .selectric-items .selectric-group {
    padding-bottom: 7px
}

.selectric-js-selectric .selectric-items li {
    background-color: #8aa1b1;
    border-bottom: 1px solid #fff;
    color: #fff;
    font-family: Langdon;
    font-size: 26px;
    font-weight: 400;
    line-height: 26px;
    padding: 15px 15px 12px;
    text-transform: uppercase
}

.selectric-js-selectric .selectric-items li.disabled {
    display: none
}

.selectric-js-selectric .selectric-items li:hover {
    background: rgba(0, 40, 85, .05);
    color: #002855
}

.selectric-js-selectric .selectric-items li.selected {
    background: rgba(0, 40, 85, .15);
    color: #002855
}

.selectric-js-selectric .selectric-items li.selectric-group-label {
    background: transparent;
    border-top: 1px solid rgba(27, 68, 156, .122);
    color: #002855;
    font-size: 14px;
    font-size: 13px;
    font-weight: 500;
    letter-spacing: 1px;
    padding: 15px 12px 7px;
    text-transform: uppercase
}

.selectric-js-selectric .selectric-items li.selectric-group-label:hover {
    background: transparent
}

.selectric-js-selectric-transparent {
    height: 25px
}

@media only screen and (min-width:992px) {
    .selectric-js-selectric-transparent {
        height: 45px
    }
}

.selectric-js-selectric-transparent .selectric {
    background: transparent;
    border: none;
    display: inline-block
}

.selectric-js-selectric-transparent .selectric .label {
    border: none;
    color: #002855;
    font-size: 18px;
    font-weight: 800;
    height: 25px;
    letter-spacing: .024em;
    line-height: 25px;
    line-height: 23px;
    margin-left: 0;
    margin-right: 25px;
    text-decoration: underline;
    text-transform: uppercase
}

@media only screen and (min-width:992px) {
    .selectric-js-selectric-transparent .selectric .label {
        font-size: 32px;
        height: 45px;
        line-height: 42px;
        line-height: 45px;
        margin-right: 45px
    }
}

.selectric-js-selectric-transparent .selectric .button {
    background-color: transparent;
    background-position: 50% 40%;
    background-repeat: no-repeat;
    background-size: 11px 7px;
    height: 25px;
    width: 25px
}

@media only screen and (min-width:992px) {
    .selectric-js-selectric-transparent .selectric .button {
        background-position: 50% 45%;
        background-size: 13px 10px;
        height: 45px;
        width: 45px
    }
}

.selectric-js-selectric-transparent .selectric .button:after {
    display: none
}

.selectric-js-selectric-transparent .selectric-items li {
    color: #002855;
    font-size: 20px;
    font-weight: 400;
    padding: 12px 15px
}

.selectric-js-selectric-transparent .selectric-items li.disabled {
    display: none
}

.selectric-js-selectric-transparent .selectric-items li:hover {
    background: rgba(0, 40, 85, .05);
    color: #002855
}

.selectric-js-selectric-transparent .selectric-items li.selected {
    background: rgba(0, 40, 85, .15);
    color: #002855
}

.popup-container {
    background-color: rgba(0, 0, 0, .8);
    display: none;
    height: 100vh;
    left: 0;
    position: fixed;
    top: 0;
    width: 100vw;
    z-index: 30
}

.popup-container img {
    cursor: pointer;
    height: 30px;
    position: absolute;
    right: 20px;
    top: 20px;
    transform: rotate(45deg)
}

@media screen and (min-width:768px) {
    .popup-container img {
        height: 60px
    }
}

.popup-container iframe {
    background: #fff;
    height: 600px;
    left: 50%;
    position: absolute;
    top: 50%;
    transform: translate(-50%, -50%);
    width: 600px
}

.popup-container .thank-you-popup {
    background-color: #002855;
    left: 50%;
    padding: 50px 50px 40px;
    position: fixed;
    top: 50%;
    transform: translate(-50%, -50%);
    z-index: 30
}

.popup-container .thank-you-popup h3 {
    color: #fff;
    margin: 0
}

.popup-container .thank-you-popup img {
    cursor: pointer;
    position: absolute;
    right: 20px;
    top: 20px;
    transform: rotate(45deg)
}

.popup-container .thank-you-popup.active {
    display: block
}

.popup-container .popup {
    background: #002855;
    left: 50%;
    overflow: scroll;
    padding: 30px;
    position: absolute;
    text-align: center;
    top: 50%;
    transform: translate(-50%, -50%);
    width: 90%
}

@media screen and (min-width:768px) {
    .popup-container .popup {
        padding: 50px;
        width: 50%
    }
}

.popup-container .popup h3,
.popup-container .popup p {
    color: #fff;
    margin-bottom: 30px
}

.popup-container .popup a {
    background-color: #fff;
    color: #af272f;
    display: block;
    font-family: Langdon;
    font-size: 24px;
    font-weight: 400;
    height: 60px;
    letter-spacing: 2.8px;
    margin: 0 auto;
    padding: 13px 0;
    text-align: center;
    text-transform: uppercase;
    transition: .3s;
    width: 240px
}

.popup-container .popup a:last-of-type {
    margin-bottom: 0
}

.popup-container .popup a:hover {
    background-color: #af272f;
    color: #fff;
    text-decoration: none
}

.contact-form {
    background-color: #fff;
    background-image: url(../../images/backgrounds/concrete-tile-v4.png);
    padding: 90px 0
}

.contact-form h2 {
    color: #002855;
    margin-bottom: 70px
}

.contact-form h3 {
    color: #002855
}

.contact-form input {
    border: 2px solid #002855;
    font-family: Montserrat-Medium;
    font-size: 18px;
    height: 63px;
    letter-spacing: 1.8px;
    margin-bottom: 43px
}

.contact-form select,
.contact-form textarea {
    margin-bottom: 43px;
    width: 100%
}

.contact-form textarea {
    background-color: transparent;
    border: 2px solid #002855;
    color: #002855;
    font-family: Montserrat-Medium;
    font-size: 18px;
    letter-spacing: 1.8px;
    min-height: 200px;
    padding: 15px
}

.contact-form .selectric-js-selectric {
    margin-bottom: 43px
}

.contact-form .selectric-js-selectric .selectric {
    border: 2px solid #002855;
    height: 63px
}

.contact-form .selectric-js-selectric .selectric .button {
    right: 15px
}

.contact-form .selectric-js-selectric .selectric-items {
    top: 100%
}

.contact-form .selectric-js-selectric .selectric .label {
    font-family: Montserrat-Medium;
    font-size: 18px;
    letter-spacing: 1.8px;
    line-height: 18px;
    padding: 20px 15px;
    text-transform: none
}

.contact-form .selectric-js-selectric .selectric:after {
    content: none
}

.contact-form label {
    color: #002855;
    font-family: Montserrat-Medium;
    font-size: 16px;
    font-weight: 500;
    letter-spacing: 1.8px;
    line-height: 24px
}

.contact-form label .error {
    color: #af272f;
    display: none;
    font-size: 12px
}

.contact-form label .error.active {
    display: inline-block
}

.contact-form .url-field-wrapper {
    left: -9999px;
    position: absolute
}

.contact-form .button {
    cursor: pointer
}

.contact-form .button p {
    font-family: Langdon;
    font-size: 26px;
    font-weight: 400;
    letter-spacing: 2.8px;
    line-height: 28px;
    margin: 0;
    text-transform: uppercase
}

.content-image {
    padding: 70px 0 0
}

@media screen and (min-width:576px) {
    .content-image {
        padding: 100px 0
    }
}

.content-image #ot-reservation-widget .ot-dtp-picker {
    margin: 0
}

.content-image #ot-reservation-widget .ot-dtp-picker,
.content-image #ot-reservation-widget .ot-title {
    -webkit-text-size-adjust: 100%;
    -moz-text-size-adjust: 100%;
    text-size-adjust: 100%;
    font-family: BrandonText, -apple-system, BlinkMacSystemFont, Segoe UI, Roboto, Helvetica, Arial, sans-serif, Apple Color Emoji, Segoe UI Emoji, Segoe UI Symbol;
    font-size: 16px;
    letter-spacing: 0;
    line-height: 20px
}

.content-image.no-padding {
    padding-bottom: 0
}

.content-image.reverse {
    padding: 0 0 70px
}

@media screen and (min-width:768px) {
    .content-image.reverse {
        padding: 145px 0 150px
    }
}

.content-image.reverse .content-image__mobile-img {
    margin: 0 0 70px
}

.content-image.large h2 {
    font-size: 50px;
    left: 5px;
    line-height: 56px
}

@media screen and (min-width:576px) {
    .content-image.large h2 {
        font-size: 80px;
        letter-spacing: 8px;
        line-height: 86px
    }
}

.content-image.blue {
    background-color: #002855
}

.content-image.blue h2,
.content-image.blue h5,
.content-image.blue li,
.content-image.blue p {
    color: #fff
}

.content-image.blue h2:after {
    background-image: url(../../images/graphics/four-stars-horizontal.svg)
}

.content-image.white {
    background-color: #fff;
    background-image: url(../../images/backgrounds/concrete-tile-v4.png)
}

.content-image.white h2,
.content-image.white h5,
.content-image.white li,
.content-image.white p {
    color: #002855
}

.content-image.white h2:after {
    background-image: url(../../images/graphics/four-stars-horizontal-blue.svg)
}

.content-image.light_blue,
.content-image.white .content-image__img.drop_shadow:after {
    background-color: #8aa1b1
}

.content-image.light_blue h2,
.content-image.light_blue h5,
.content-image.light_blue li,
.content-image.light_blue p {
    color: #002855
}

.content-image.light_blue h2:after {
    background-image: url(../../images/graphics/four-stars-horizontal-blue.svg)
}

.content-image.light_blue .content-image__img.drop_shadow:after {
    background-color: #002855
}

.content-image h2 {
    font-size: 48px;
    letter-spacing: 4.8px;
    line-height: 58px;
    margin-bottom: 80px;
    position: relative
}

.content-image h2:after {
    background-repeat: no-repeat;
    bottom: -50px;
    content: "";
    display: block;
    height: 28px;
    left: 0;
    position: absolute;
    width: 134px
}

.content-image h5 {
    margin-bottom: 34px
}

.content-image p {
    margin-bottom: 40px
}

.content-image p a {
    text-decoration: underline
}

.content-image ul {
    margin: 0 0 40px
}

.content-image ul li {
    font-family: Montserrat-Medium;
    font-size: 16px;
    font-weight: 500;
    letter-spacing: 1.8px;
    line-height: 24px;
    margin-bottom: 10px;
    padding-left: 40px;
    position: relative
}

.content-image ul li:before {
    background-image: url(../../images/graphics/blue-star.svg);
    background-repeat: no-repeat;
    content: "";
    display: block;
    height: 20px;
    left: 0;
    position: absolute;
    top: 5px;
    width: 20px
}

.content-image .swiper {
    margin-top: 70px;
    padding-right: 0
}

@media screen and (min-width:768px) {
    .content-image .swiper {
        margin-top: 0;
        padding-right: 50px
    }
}

@media screen and (min-width:1400px) {
    .content-image .swiper {
        padding-right: 0
    }
}

.content-image .swiper-button-prev {
    height: 35px;
    left: 15px;
    top: 520px;
    width: 35px
}

@media screen and (min-width:576px) {
    .content-image .swiper-button-prev {
        top: 630px
    }
}

@media screen and (min-width:768px) {
    .content-image .swiper-button-prev {
        bottom: unset;
        height: 54px;
        left: -60px;
        top: 50%;
        transform: translateY(-50%);
        width: 54px
    }
}

.content-image .swiper-button-prev:after {
    content: none
}

.content-image .swiper-button-prev img {
    height: 100%;
    width: 100%
}

.content-image .swiper-button-next {
    height: 35px;
    right: 15px;
    top: 520px;
    width: 35px
}

@media screen and (min-width:576px) {
    .content-image .swiper-button-next {
        top: 630px
    }
}

@media screen and (min-width:768px) {
    .content-image .swiper-button-next {
        height: 54px;
        right: 0;
        top: 50%;
        transform: translateY(-50%);
        width: 54px
    }
}

@media screen and (min-width:1400px) {
    .content-image .swiper-button-next {
        right: -60px
    }
}

.content-image .swiper-button-next:after {
    content: none
}

.content-image .swiper-button-next img {
    height: 100%;
    width: 100%
}

@media screen and (min-width:768px) {
    .content-image .swiper-slide {
        padding-top: 20px
    }
}

.content-image .swiper-slide img {
    height: 400px;
    position: relative;
    width: 100%;
    z-index: 20
}

@media screen and (min-width:576px) {
    .content-image .swiper-slide img {
        height: 520px
    }
}

@media screen and (min-width:768px) {
    .content-image .swiper-slide img,
    .content-image .swiper-slide:after {
        height: calc(100% - 40px);
        width: calc(100% - 20px)
    }
    .content-image .swiper-slide:after {
        background-color: #8aa1b1;
        content: "";
        display: block;
        left: 0;
        position: absolute;
        top: 0;
        transform: translate(20px, -20px);
        z-index: 0
    }
}

@media screen and (min-width:1400px) {
    .content-image .swiper-slide:after {
        width: 100%
    }
}

.content-image .swiper-slide-caption {
    background: #fff;
    background-image: url(../../images/backgrounds/concrete-tile-v4.png);
    display: block;
    margin: 35px auto 0;
    text-align: center
}

@media screen and (min-width:768px) {
    .content-image .swiper-slide-caption {
        margin: 10px 0 0;
        text-align: left
    }
}

.content-image .swiper-slide-count {
    left: 70px;
    margin: 0;
    position: absolute;
    top: 490px;
    z-index: 10
}

@media screen and (min-width:576px) {
    .content-image .swiper-slide-count {
        top: 611px
    }
}

@media screen and (min-width:768px) {
    .content-image .swiper-slide-count {
        bottom: 6px;
        left: 15px;
        top: unset
    }
}

.content-image .swiper-slide-count .counter {
    display: inline-block;
    width: 13px
}

.content-image__mobile-img {
    display: block;
    height: auto;
    margin-top: 70px;
    max-height: 500px;
    width: 100%
}

@media screen and (min-width:768px) {
    .content-image__mobile-img {
        display: none
    }
}

.content-image__img {
    display: none;
    height: auto;
    position: relative;
    width: 100%
}

@media screen and (min-width:768px) {
    .content-image__img {
        display: block
    }
}

.content-image__img img {
    width: 100%
}

@media screen and (min-width:768px) {
    .content-image__img.background_image:before {
        background-image: url(../../images/graphics/four-stars-vertical.svg);
        background-repeat: no-repeat;
        content: "";
        display: block;
        height: 85px;
        left: -27px;
        position: absolute;
        top: 0;
        width: 15px
    }
}

.content-image__img.drop_shadow:after {
    content: "";
    display: block;
    height: 100%;
    left: 0;
    position: absolute;
    top: 0;
    transform: translate(20px, -20px);
    width: 100%;
    z-index: 0
}

.content-image__img--foreground {
    position: relative;
    z-index: 10
}

.content-image__img--background {
    display: none;
    left: 0;
    position: absolute;
    transform: translate(46px, -40px);
    z-index: 1
}

@media screen and (min-width:768px) {
    .content-image__img--background {
        display: inline-flex
    }
}

.content-image__selector {
    margin-bottom: 30px;
    padding-top: 20px
}

.content-image__selector h4 {
    color: #af272f;
    cursor: pointer;
    display: inline-block;
    position: relative;
    width: 220px
}

.content-image__selector h4.active:before {
    transform: rotate(0)
}

.content-image__selector h4:after {
    background-color: transparent;
    border-bottom: 2px solid #af272f;
    border-top: 2px solid #af272f;
    content: "";
    display: block;
    height: 7px
}

.content-image__selector h4:before {
    background-image: url(../../images/icons/arrow-red.svg);
    background-repeat: no-repeat;
    content: "";
    display: block;
    height: 18px;
    position: absolute;
    right: 0;
    top: 2px;
    transform: rotate(180deg);
    transition: .3s;
    width: 15px
}

.content-image__selector ul {
    display: none;
    margin: 0
}

.content-image__selector ul li {
    background-color: #002855;
    border-bottom: 1px solid #99e0ff;
    cursor: pointer;
    margin-bottom: 0;
    padding: 0;
    text-align: center;
    transition: .3s;
    width: 220px
}

.content-image__selector ul li:before {
    content: none
}

.content-image__selector ul li:hover {
    background-color: #8aa1b1
}

.content-image__selector ul li:hover a {
    color: #fff
}

.content-image__selector ul li a {
    color: #fff;
    display: block;
    font-family: Langdon;
    font-size: 18px;
    font-weight: 400;
    letter-spacing: 1.8px;
    line-height: 16px;
    margin: 0;
    padding: 18px 0;
    text-decoration: none;
    text-transform: uppercase;
    width: 100%
}

.content-image .button {
    display: block;
    width: -moz-fit-content;
    width: fit-content
}

.content-image .button--secondary {
    margin-top: 30px
}

.content-background-image {
    padding: 100px 0;
    position: relative
}

.content-background-image img {
    height: 100%;
    left: 0;
    position: absolute;
    top: 0;
    width: 100%
}

.content-background-image h2 {
    color: #fff;
    font-size: 50px;
    letter-spacing: 5px;
    line-height: 56px;
    margin-bottom: 100px;
    position: relative;
    z-index: 10
}

@media screen and (min-width:576px) {
    .content-background-image h2 {
        font-size: 80px;
        letter-spacing: 8px;
        line-height: 86px
    }
}

.content-background-image h2:after {
    background-image: url(../../images/graphics/four-stars-horizontal.svg);
    background-repeat: no-repeat;
    bottom: -50px;
    content: "";
    display: block;
    height: 28px;
    left: 0;
    position: absolute;
    width: 134px
}

.content-background-image p {
    color: #fff;
    margin-bottom: 40px
}

.content-background-image .button,
.content-background-image p {
    position: relative;
    z-index: 10
}

.cta-image {
    padding: 30px 0;
    position: relative
}

@media screen and (min-width:768px) {
    .cta-image {
        padding: 100px 0
    }
}

.cta-image.red {
    background-color: #af272f
}

.cta-image.blue {
    background-color: #002855
}

.cta-image .outlined-text {
    display: none;
    height: 500px;
    left: -35px;
    position: absolute;
    top: 50%;
    transform: translateY(-50%);
    width: auto;
    z-index: 10
}

@media screen and (min-width:768px) {
    .cta-image .outlined-text {
        display: block
    }
}

@media screen and (min-width:1024px) {
    .cta-image .outlined-text {
        height: 700px
    }
}

@media screen and (min-width:1200px) {
    .cta-image .outlined-text {
        height: 800px
    }
}

.cta-image__img {
    height: 400px;
    position: relative
}

@media screen and (min-width:768px) {
    .cta-image__img {
        height: 550px
    }
}

.cta-image__img .overlay {
    background-color: #000;
    height: 100%;
    left: 0;
    opacity: .5;
    position: absolute;
    top: 0;
    width: 100%;
    z-index: 5
}

@media (pointer:fine) {
    .cta-image__img:hover h2 {
        transform: translateY(0) !important
    }
    .cta-image__img:hover .button,
    .cta-image__img:hover p {
        opacity: 1
    }
}

@media screen and (min-width:1200px) {
    .cta-image__img:after {
        background-image: url(../../images/graphics/four-stars-vertical.svg);
        background-repeat: no-repeat;
        content: "";
        display: block;
        height: 85px;
        position: absolute;
        right: -27px;
        top: 0;
        width: 15px
    }
}

.cta-image__img h2 {
    color: #fff;
    font-size: 50px;
    letter-spacing: 5px;
    line-height: 56px;
    max-width: 770px;
    padding: 0 30px;
    position: relative;
    text-align: center;
    width: 100%;
    z-index: 10
}

@media screen and (min-width:576px) {
    .cta-image__img h2 {
        font-size: 66px;
        letter-spacing: 6.6px;
        line-height: 70px;
        padding: 0 50px
    }
}

@media screen and (min-width:768px) {
    .cta-image__img h2 {
        font-size: 96px;
        letter-spacing: 9.6px;
        line-height: 107px
    }
}

@media (pointer:fine) {
    .cta-image__img h2 {
        transition: .3s
    }
}

@media (pointer:coarse) {
    .cta-image__img h2 {
        transform: translateY(0) !important
    }
}

.cta-image__img p {
    color: #fff;
    font-size: 14px;
    max-width: 600px;
    padding: 0 20px;
    position: relative;
    text-align: center;
    z-index: 10
}

@media screen and (min-width:576px) {
    .cta-image__img p {
        font-size: 16px;
        padding: 0
    }
}

@media (pointer:fine) {
    .cta-image__img p {
        opacity: 0;
        transition: .3s
    }
}

.cta-image__img .button {
    margin-top: 30px;
    position: relative;
    text-align: center;
    width: 200px;
    z-index: 10
}

@media screen and (min-width:576px) {
    .cta-image__img .button {
        margin-top: 50px
    }
}

@media (pointer:fine) {
    .cta-image__img .button {
        opacity: 0;
        transition: .3s
    }
}

.cta-image__img img {
    height: 100%;
    left: 0;
    position: absolute;
    top: 0;
    width: 100%;
    z-index: 1
}

.cta-full-width-image {
    height: 390px;
    position: relative;
    width: 100%
}

@media screen and (min-width:768px) {
    .cta-full-width-image {
        height: 450px
    }
}

.cta-full-width-image .overlay {
    background-color: #000;
    opacity: .5;
    z-index: 5
}

.cta-full-width-image .overlay,
.cta-full-width-image img {
    height: 100%;
    left: 0;
    position: absolute;
    top: 0;
    width: 100%
}

.cta-full-width-image h2 {
    color: #fff;
    font-size: 66px;
    letter-spacing: 6.6px;
    line-height: 70px;
    margin-bottom: 40px;
    position: relative;
    text-align: center;
    z-index: 10
}

@media screen and (min-width:768px) {
    .cta-full-width-image h2 {
        font-size: 96px;
        letter-spacing: 9.6px;
        line-height: 107px;
        margin-bottom: 70px
    }
}

.cta-full-width-image .button {
    position: relative;
    z-index: 10
}

.gallery {
    background-color: #af272f;
    padding: 60px 0
}

@media screen and (min-width:992px) {
    .gallery {
        padding: 80px 0
    }
}

.gallery__container {
    padding-left: 30px
}

@media screen and (min-width:1200px) {
    .gallery__container {
        padding-left: calc(50vw - 570px)
    }
}

.gallery .swiper-slide {
    height: 310px;
    width: 310px
}

@media screen and (min-width:992px) {
    .gallery .swiper-slide {
        height: 480px;
        width: 480px
    }
}

.gallery .swiper-slide img {
    height: 100%;
    width: 100%
}

.gallery .swiper-button-next {
    height: 46px;
    left: 0;
    margin-top: 30px;
    position: relative;
    top: 0;
    width: 46px
}

.gallery .swiper-button-next:after {
    content: none
}

.gallery .swiper-button-prev {
    height: 46px;
    left: 0;
    margin-right: 15px;
    margin-top: 30px;
    position: relative;
    top: 0;
    width: 46px
}

.gallery .swiper-button-prev:after {
    content: none
}

.hero {
    height: 600px;
    position: relative;
    width: 100%
}

@media screen and (min-width:768px) {
    .hero {
        height: 700px
    }
}

@media screen and (min-width:1200px) {
    .hero {
        height: 900px
    }
}

.hero .outlined-text {
    -webkit-text-stroke: 3px #fff;
    bottom: -120px;
    color: transparent;
    font-family: Langdon;
    font-size: 195px;
    height: 350px;
    left: 0;
    line-height: 400px;
    margin: 0;
    position: absolute;
    text-transform: uppercase;
    z-index: 10
}

.hero .outlined-text.edge {
    bottom: -80px
}

@media screen and (min-width:576px) {
    .hero .outlined-text {
        bottom: -80px;
        font-size: 250px
    }
    .hero .outlined-text.edge {
        bottom: -60px
    }
}

@media screen and (min-width:768px) {
    .hero .outlined-text {
        -webkit-text-stroke: 4px #fff;
        bottom: -50px;
        font-size: 350px;
        left: -20px
    }
    .hero .outlined-text.edge {
        bottom: -20px
    }
}

@media screen and (min-width:1200px) {
    .hero .outlined-text {
        bottom: 0;
        font-size: 500px;
        height: 400px;
        line-height: 500px
    }
    .hero .outlined-text.edge {
        bottom: 30px
    }
}

.hero h1 {
    color: #fff;
    padding: 0 50px;
    position: absolute;
    text-align: center;
    text-transform: uppercase;
    width: 100%
}

.hero--small {
    height: 350px
}

@media screen and (min-width:768px) {
    .hero--small {
        height: 500px
    }
}

.hero--medium {
    height: 350px
}

@media screen and (min-width:768px) {
    .hero--medium {
        height: 450px
    }
}

@media screen and (min-width:1200px) {
    .hero--medium {
        height: 550px
    }
}

.hero img {
    height: 100%;
    width: 100%
}

.menus-module {
    background-color: #fff;
    background-image: url(../../images/backgrounds/concrete-tile-v4.png);
    height: auto
}

@media screen and (min-width:768px) {
    .menus-module {
        height: 760px
    }
}

.menus-module.active {
    display: block
}

.menus-module__images {
    background-image: url(../../images/backgrounds/menus-bg.png);
    height: 610px;
    order: 2;
    position: relative;
    width: 100%
}

@media screen and (min-width:768px) {
    .menus-module__images {
        height: 100%;
        order: 1;
        width: 50%
    }
}

.menus-module__images--foreground {
    height: 80%;
    max-width: 470px;
    position: relative;
    width: 80%;
    z-index: 10
}

.menus-module__images--background {
    height: 80%;
    max-width: 470px;
    position: absolute;
    transform: translate(5%, -5%);
    width: 80%;
    z-index: 1
}

.menus-module__content {
    order: 1;
    padding: 0 30px 140px;
    position: relative;
    width: 100%
}

@media screen and (min-width:768px) {
    .menus-module__content {
        order: 2;
        padding: 0 30px;
        width: 50%
    }
}

.menus-module__content__graphic {
    height: 70px;
    position: absolute;
    right: 30px;
    top: 50px;
    width: 70px
}

@media screen and (min-width:768px) {
    .menus-module__content__graphic {
        height: 113px;
        right: 90px;
        width: 113px
    }
}

@media screen and (min-width:1200px) {
    .menus-module__content__graphic {
        top: 110px
    }
}

.menus-module__content__wrapper {
    box-sizing: content-box;
    max-width: 410px;
    padding: 100px 0 0;
    width: 100%
}

.menus-module__content__wrapper h2 {
    color: #002855;
    margin-bottom: 60px;
    position: relative
}

@media screen and (min-width:768px) {
    .menus-module__content__wrapper h2 {
        margin-bottom: 30px
    }
}

.menus-module__content__wrapper h2:after {
    background-image: url(../../images/graphics/four-stars-horizontal-blue.svg);
    background-repeat: no-repeat;
    bottom: -35px;
    content: "";
    display: block;
    height: 28px;
    left: 0;
    position: absolute;
    width: 134px
}

@media screen and (min-width:768px) {
    .menus-module__content__wrapper h2:after {
        content: none
    }
}

.menus-module__content__wrapper h5 {
    color: #002855;
    margin-bottom: 30px;
    max-width: 300px
}

.menus-module__content__wrapper p {
    color: #002855;
    margin-bottom: 40px
}

.menus-module__content__selector h4 {
    color: #af272f;
    cursor: pointer;
    display: inline-block;
    position: relative;
    width: 220px
}

.menus-module__content__selector h4.active:before {
    transform: rotate(0)
}

.menus-module__content__selector h4:after {
    background-color: transparent;
    border-bottom: 2px solid #af272f;
    border-top: 2px solid #af272f;
    content: "";
    display: block;
    height: 7px
}

.menus-module__content__selector h4:before {
    background-image: url(../../images/icons/arrow-red.svg);
    background-repeat: no-repeat;
    content: "";
    display: block;
    height: 18px;
    position: absolute;
    right: 0;
    top: 2px;
    transform: rotate(180deg);
    transition: .3s;
    width: 15px
}

.menus-module__content__selector ul {
    display: none;
    margin: 0
}

.menus-module__content__selector ul li {
    background-color: #002855;
    border-bottom: 1px solid #99e0ff;
    cursor: pointer;
    padding: 0;
    text-align: center;
    transition: .3s;
    width: 220px
}

.menus-module__content__selector ul li:hover {
    background-color: #8aa1b1
}

.menus-module__content__selector ul li:hover a {
    color: #fff
}

.menus-module__content__selector ul li a {
    color: #fff;
    display: block;
    font-family: Langdon;
    font-size: 18px;
    font-weight: 400;
    letter-spacing: 1.8px;
    line-height: 16px;
    margin: 0;
    padding: 18px 0;
    text-decoration: none;
    text-transform: uppercase;
    width: 100%
}

.locations-module {
    background-color: #8aa1b1;
    padding: 80px 0
}

@media screen and (min-width:768px) {
    .locations-module {
        padding: 150px 0 100px
    }
}

.locations-module__content {
    margin-bottom: 50px;
    padding-left: 30px;
    width: 100%
}

@media screen and (min-width:768px) {
    .locations-module__content {
        margin-bottom: 0;
        width: 50%
    }
}

@media screen and (min-width:1200px) {
    .locations-module__content {
        padding-left: calc(50vw - 570px)
    }
}

.locations-module__content h2 {
    color: #002855;
    margin-bottom: 60px;
    position: relative
}

@media screen and (min-width:768px) {
    .locations-module__content h2 {
        margin-bottom: 38px
    }
}

.locations-module__content h2:after {
    background-image: url(../../images/graphics/four-stars-horizontal-blue.svg);
    background-repeat: no-repeat;
    bottom: -35px;
    content: "";
    display: block;
    height: 28px;
    left: 0;
    position: absolute;
    width: 134px
}

@media screen and (min-width:768px) {
    .locations-module__content h2:after {
        content: none
    }
}

.locations-module__content h5 {
    color: #002855;
    margin-bottom: 40px
}

.locations-module__content p {
    color: #002855;
    margin-bottom: 50px;
    max-width: 360px
}

.locations-module__content a {
    color: #fff;
    display: block;
    font-family: Langdon;
    font-size: 35px;
    font-weight: 400;
    letter-spacing: 3.5px;
    line-height: 40px;
    margin-bottom: 20px;
    text-transform: uppercase;
    transition: .3s
}

@media screen and (min-width:768px) {
    .locations-module__content a {
        color: #002855;
        font-size: 42px;
        letter-spacing: 4.4px;
        line-height: 54px
    }
}

.locations-module__content a:before {
    background-image: url(../../images/icons/arrow-white-right.svg);
    background-repeat: no-repeat;
    content: "";
    display: block;
    height: 15px;
    left: -25px;
    opacity: 0;
    position: absolute;
    top: 15px;
    transition: .3s;
    width: 16px
}

.locations-module__content a:last-of-type {
    margin-bottom: 0
}

.locations-module__content a:hover {
    -webkit-text-stroke: 1px #002855;
    color: transparent;
    text-decoration: none
}

.locations-module__content a:hover:before {
    opacity: 1
}

.locations-module__content__locations {
    display: none
}

@media screen and (min-width:768px) {
    .locations-module__content__locations {
        display: block
    }
}

.locations-module__image {
    position: relative;
    width: 100%
}

@media screen and (min-width:768px) {
    .locations-module__image {
        width: 50%
    }
}

.locations-module__image .button {
    margin: 80px auto 0
}

@media screen and (min-width:768px) {
    .locations-module__image .button {
        left: 50%;
        margin-top: 0;
        position: absolute;
        top: -90px;
        transform: translateX(-50%)
    }
}

.locations-module__image:before {
    background-image: url(../../images/graphics/four-stars-horizontal.svg);
    background-repeat: no-repeat;
    content: "";
    display: block;
    height: 28px;
    left: 50%;
    position: absolute;
    top: 30px;
    transform: translateX(-50%);
    width: 134px
}

.locations-module__image img {
    height: 600px;
    width: 100%
}

@media screen and (min-width:768px) {
    .locations-module__image img {
        height: 700px
    }
}

.locations-module__image__border {
    border-bottom: 2px solid #fff;
    border-left: 2px solid #fff;
    border-right: 2px solid #fff;
    height: 520px;
    left: 50%;
    position: absolute;
    top: 44px;
    transform: translateX(-50%);
    width: 90%
}

@media screen and (min-width:768px) {
    .locations-module__image__border {
        height: 620px
    }
}

.locations-module__image__border .border-top-left {
    background: #fff;
    height: 2px;
    left: 0;
    position: absolute;
    top: 0;
    width: calc(50% - 80px)
}

.locations-module__image__border .border-top-right {
    background: #fff;
    height: 2px;
    position: absolute;
    right: 0;
    top: 0;
    width: calc(50% - 80px)
}

.locations-module .swiper {
    display: block;
    padding-right: 30px
}

@media screen and (min-width:768px) {
    .locations-module .swiper {
        display: none
    }
}

.locations-module .swiper-slide {
    text-align: center
}

.locations-module .swiper-slide a:hover {
    -webkit-text-stroke: 0 #fff;
    color: #002855;
    text-decoration: none
}

.locations-module .swiper .swiper-button-next {
    height: 31px;
    margin-top: 0;
    position: absolute;
    right: 30px;
    top: 0;
    width: 31px
}

.locations-module .swiper .swiper-button-next:after {
    content: none
}

.locations-module .swiper .swiper-button-prev {
    height: 31px;
    left: 0;
    margin-right: 15px;
    margin-top: 0;
    position: absolute;
    top: 0;
    width: 31px
}

.locations-module .swiper .swiper-button-prev:after {
    content: none
}

.locations__grid {
    padding-bottom: 70px
}

.locations__grid--module {
    padding-top: 70px
}

@media screen and (min-width:768px) {
    .locations__grid--module {
        padding-top: 100px
    }
}

.locations__grid h2 {
    color: #fff;
    font-size: 66px;
    letter-spacing: 6.6px;
    line-height: 70px;
    margin-bottom: 100px;
    position: relative
}

@media screen and (min-width:768px) {
    .locations__grid h2 {
        font-size: 96px;
        letter-spacing: 9.6px;
        line-height: 107px;
        margin-bottom: 130px
    }
}

.locations__grid h2:after {
    background-image: url(../../images/graphics/four-stars-horizontal.svg);
    background-repeat: no-repeat;
    bottom: -25px;
    content: "";
    display: block;
    height: 28px;
    left: 0;
    position: absolute;
    width: 134px
}

.locations__grid .location__card {
    height: 100%;
    padding-bottom: 54px
}

.locations__grid .location__card h3 {
    color: #fff;
    font-size: 42px;
    margin-bottom: 20px;
    padding-bottom: 370px
}

@media screen and (min-width:768px) {
    .locations__grid .location__card h3 {
        padding-bottom: 0
    }
}

@media screen and (min-width:1200px) {
    .locations__grid .location__card h3 {
        font-size: 48px
    }
}

.locations__grid .location__card__img {
    height: 350px;
    left: -15px;
    overflow: hidden;
    position: absolute;
    top: 70px;
    width: 100vw
}

@media screen and (min-width:768px) {
    .locations__grid .location__card__img {
        left: 0;
        margin-bottom: 25px;
        position: relative;
        top: 0;
        width: 100%
    }
}

.locations__grid .location__card__img img {
    height: 100%;
    transform: scale(1);
    transition: .3s;
    width: 100%
}

.locations__grid .location__card__img:hover img {
    transform: scale(1.05)
}

.locations__grid .location__card__content {
    height: 100%
}

.locations__grid .location__card h5 {
    color: #fff;
    margin-bottom: 25px
}

.locations__grid .location__card p {
    color: #fff;
    font-family: Montserrat-Light;
    letter-spacing: 1.3px;
    line-height: 26px;
    margin: 0 0 40px
}

.locations__grid .location__card__ctas a {
    margin-bottom: 25px
}

.locations__grid .location__card__ctas a:last-of-type {
    margin-bottom: 0
}

.locations__grid .horizontal-line .line {
    background-color: #fff;
    height: 1px;
    width: 100%
}

.locations__grid .horizontal-line img {
    height: 30px;
    margin-left: 20px
}

.locations-slider {
    background-color: #fff;
    background-image: url(../../images/backgrounds/concrete-tile-v4.png);
    padding: 80px 0;
    position: relative
}

@media screen and (min-width:992px) {
    .locations-slider {
        padding: 100px 0 115px
    }
}

.locations-slider h2 {
    color: #002855;
    font-size: 50px;
    letter-spacing: 5px;
    line-height: 56px;
    margin-bottom: 100px;
    position: relative;
    width: 360px
}

@media screen and (min-width:576px) {
    .locations-slider h2 {
        font-size: 80px;
        letter-spacing: 8px;
        line-height: 86px
    }
}

@media screen and (min-width:992px) {
    .locations-slider h2 {
        margin-bottom: 120px
    }
}

.locations-slider h2:after {
    background-image: url(../../images/graphics/four-stars-horizontal-blue.svg);
    background-repeat: no-repeat;
    bottom: -50px;
    content: "";
    display: block;
    height: 28px;
    left: 0;
    position: absolute;
    width: 134px
}

@media screen and (min-width:992px) {
    .locations-slider h2:after {
        bottom: -50px
    }
}

.locations-slider__container {
    padding-left: 30px
}

@media screen and (min-width:1200px) {
    .locations-slider__container {
        padding-left: calc(50vw - 570px)
    }
}

.locations-slider .swiper {
    margin-bottom: 65px
}

.locations-slider .swiper-slide {
    width: 310px
}

@media screen and (min-width:992px) {
    .locations-slider .swiper-slide {
        width: 480px
    }
}

.locations-slider .swiper-slide a,
.locations-slider .swiper-slide a:hover {
    text-decoration: none
}

.locations-slider .swiper-slide h3 {
    color: #002855;
    text-decoration: none
}

.locations-slider .swiper-slide h3:hover {
    text-decoration: none
}

.locations-slider .swiper-slide__img {
    height: 310px;
    overflow: hidden;
    width: 100%
}

@media screen and (min-width:992px) {
    .locations-slider .swiper-slide__img {
        height: 480px
    }
}

.locations-slider .swiper-slide__img img {
    height: 100%;
    transform: scale(1);
    transition: .3s;
    width: 100%
}

.locations-slider .swiper-slide__img:hover img {
    transform: scale(1.05)
}

.locations-slider--nav {
    margin-bottom: 50px
}

@media screen and (min-width:992px) {
    .locations-slider--nav {
        margin-bottom: 100px
    }
}

.locations-slider .swiper-button-next {
    height: 46px;
    left: 0;
    margin-top: 0;
    position: relative;
    top: 0;
    width: 46px
}

.locations-slider .swiper-button-next:after {
    content: none
}

.locations-slider .swiper-button-prev {
    height: 46px;
    left: 0;
    margin-right: 30px;
    margin-top: 0;
    position: relative;
    top: 0;
    width: 46px
}

.locations-slider .swiper-button-prev:after {
    content: none
}

.locations-slider .button {
    margin-bottom: 50px
}

@media screen and (min-width:992px) {
    .locations-slider .button {
        margin-bottom: 100px
    }
}

.locations-slider__horizontal-line .line {
    background-color: #002855;
    height: 2px;
    width: calc(100% - 150px)
}

.instagram img {
    height: 150px;
    width: 33.33%
}

.instagram img:nth-of-type(7) {
    display: none
}

@media screen and (min-width:768px) {
    .instagram img:nth-of-type(7) {
        display: block
    }
}

.instagram img:nth-of-type(8),
.instagram img:nth-of-type(9) {
    display: none
}

@media screen and (min-width:992px) {
    .instagram img:nth-of-type(8),
    .instagram img:nth-of-type(9) {
        display: block
    }
}

@media screen and (min-width:576px) {
    .instagram img {
        height: 200px
    }
}

@media screen and (min-width:768px) {
    .instagram img {
        height: 290px;
        width: 25%
    }
}

@media screen and (min-width:992px) {
    .instagram img {
        width: 20%
    }
}

.instagram__cta {
    background-color: #002855;
    cursor: pointer;
    height: auto;
    padding: 25px 0;
    text-align: center;
    width: 100%
}

@media screen and (min-width:768px) {
    .instagram__cta {
        height: 290px;
        padding: 0;
        width: 25%
    }
}

@media screen and (min-width:992px) {
    .instagram__cta {
        width: 20%
    }
}

.instagram__cta img {
    height: 32px;
    margin: 0 15px 0 0;
    width: 32px
}

@media screen and (min-width:768px) {
    .instagram__cta img {
        margin: 0 0 30px
    }
}

.instagram__cta h3 {
    color: #fff;
    display: none;
    font-size: 40px;
    letter-spacing: 0;
    line-height: 40px;
    margin-bottom: 20px;
    width: 200px
}

@media screen and (min-width:768px) {
    .instagram__cta h3 {
        display: block
    }
}

.instagram__cta a {
    color: #fff;
    font-family: Langdon;
    font-size: 20px;
    letter-spacing: 2px;
    line-height: 20px;
    margin: 0;
    text-decoration: underline;
    text-transform: uppercase
}

@media screen and (min-width:768px) {
    .instagram__cta a {
        font-size: 16px;
        letter-spacing: 3.2px;
        line-height: 20px
    }
}

.instagram__cta a:hover {
    text-decoration: none
}

.outlined-title {
    background-color: #fff;
    background-image: url(../../images/backgrounds/concrete-tile-v4.png);
    position: relative
}

.outlined-title h1 {
    -webkit-text-stroke: 3px #002855;
    color: transparent;
    font-family: Langdon;
    font-size: 139px;
    left: -1%;
    letter-spacing: -2px;
    line-height: 122px;
    margin: 0;
    position: relative;
    text-transform: uppercase;
    top: -18px;
    width: 102%;
    z-index: 10
}

.outlined-title h1.edge {
    top: -30px
}

.outlined-title h1.no-padding {
    padding-right: 0
}

@media screen and (min-width:576px) {
    .outlined-title h1 {
        font-size: 200px;
        line-height: 170px;
        top: -25px
    }
    .outlined-title h1.edge {
        top: -40px
    }
}

@media screen and (min-width:768px) {
    .outlined-title h1 {
        padding-right: 100px
    }
}

@media screen and (min-width:992px) {
    .outlined-title h1 {
        -webkit-text-stroke: 4px #002855;
        font-size: 260px;
        letter-spacing: -5px;
        line-height: 220px;
        top: -30px
    }
    .outlined-title h1.edge {
        top: -50px
    }
}

@media screen and (min-width:1200px) {
    .outlined-title h1 {
        font-size: 290px;
        line-height: 250px;
        top: -40px
    }
    .outlined-title h1.edge {
        top: -60px
    }
}

@media screen and (min-width:1400px) {
    .outlined-title h1 {
        font-size: 390px;
        line-height: 327px
    }
    .outlined-title h1.edge {
        top: -75px
    }
}

.outlined-title h1.centered {
    text-align: center
}

.outlined-title__amso-logo {
    bottom: -50px;
    display: none;
    height: 210px;
    position: absolute;
    right: -100px;
    width: auto
}

@media screen and (min-width:768px) {
    .outlined-title__amso-logo {
        display: block
    }
}

@media screen and (min-width:992px) {
    .outlined-title__amso-logo {
        height: 250px
    }
}

@media screen and (min-width:1200px) {
    .outlined-title__amso-logo {
        bottom: -100px;
        height: 300px;
        right: -150px
    }
}

@media screen and (min-width:1400px) {
    .outlined-title__amso-logo {
        bottom: -150px;
        height: 360px;
        right: -250px
    }
}

.private-rooms {
    background-color: #fff;
    background-image: url(../../images/backgrounds/concrete-tile-v4.png);
    padding: 70px 0 0
}

@media screen and (min-width:576px) {
    .private-rooms {
        padding: 70px 0 80px
    }
}

@media screen and (min-width:768px) {
    .private-rooms {
        padding: 0 0 40px
    }
}

.private-rooms__header {
    margin-bottom: 50px
}

.private-rooms__header h2 {
    color: #002855;
    margin-bottom: 60px;
    position: relative
}

.private-rooms__header h2:after {
    background-image: url(../../images/graphics/four-stars-horizontal-blue.svg);
    background-repeat: no-repeat;
    bottom: -50px;
    content: "";
    display: block;
    height: 28px;
    left: 0;
    position: absolute;
    width: 134px
}

.private-rooms__header a {
    display: none
}

@media screen and (min-width:768px) {
    .private-rooms__header a {
        display: inline-block
    }
}

.private-rooms .private-room-card {
    margin-bottom: 50px
}

@media screen and (min-width:576px) {
    .private-rooms .private-room-card {
        margin-bottom: 70px
    }
}

@media screen and (min-width:768px) {
    .private-rooms .private-room-card {
        margin-bottom: 88px
    }
}

.private-rooms .private-room-card h3 {
    color: #002855;
    margin-bottom: 20px;
    padding-bottom: 0
}

.private-rooms .private-room-card__img {
    height: 350px;
    left: -30px;
    overflow: hidden;
    position: relative;
    width: 100vw
}

@media screen and (min-width:768px) {
    .private-rooms .private-room-card__img {
        left: unset;
        margin-bottom: 25px;
        width: 100%
    }
}

.private-rooms .private-room-card__img img {
    height: 100%;
    transform: scale(1);
    transition: .3s;
    width: 100%
}

.private-rooms .private-room-card__img:hover img {
    transform: scale(1.05)
}

.private-rooms .private-room-card ul {
    margin: 20px 0 0
}

@media screen and (min-width:768px) {
    .private-rooms .private-room-card ul {
        margin: 0
    }
}

.private-rooms .private-room-card ul li {
    margin-bottom: 12px
}

.private-rooms .private-room-card ul li img {
    height: 20px;
    margin-right: 10px;
    width: auto
}

.private-rooms .private-room-card ul li p {
    color: #002855;
    margin-bottom: 0
}

.private-rooms .mobile-pdf {
    display: flex;
    padding-bottom: 40px
}

@media screen and (min-width:768px) {
    .private-rooms .mobile-pdf {
        display: none
    }
}

.team {
    background-color: #002855;
    padding: 90px 0
}

@media screen and (min-width:768px) {
    .team {
        padding: 100px 0
    }
}

.team h2 {
    color: #fff;
    font-size: 66px;
    letter-spacing: 6.6px;
    line-height: 70px;
    margin-bottom: 100px;
    position: relative
}

@media screen and (min-width:768px) {
    .team h2 {
        font-size: 96px;
        letter-spacing: 9.6px;
        line-height: 107px;
        margin-bottom: 100px
    }
}

.team h2:after {
    background-image: url(../../images/graphics/four-stars-horizontal.svg);
    background-repeat: no-repeat;
    bottom: -25px;
    content: "";
    display: block;
    height: 28px;
    left: 0;
    position: absolute;
    width: 134px
}

.team .team__card {
    cursor: pointer;
    margin-bottom: 50px
}

.team .team__card h4 {
    color: #fff;
    margin-bottom: 8px;
    transition: .3s
}

.team .team__card h4:hover {
    opacity: .6
}

.team .team__card h5 {
    color: #fff;
    margin-bottom: 20px;
    padding-bottom: 0
}

.team .team__card__img {
    height: 350px;
    left: -30px;
    overflow: hidden;
    position: relative;
    width: 100vw
}

@media screen and (min-width:768px) {
    .team .team__card__img {
        left: unset;
        margin-bottom: 25px;
        width: 100%
    }
}

.team .team__card__img img {
    height: 100%;
    transform: scale(1);
    transition: .3s;
    width: 100%
}

.team .team__card__img:hover img {
    transform: scale(1.05)
}

.team .team__card p {
    color: #fff
}

.team .button {
    margin-top: 0
}

@media screen and (min-width:768px) {
    .team .button {
        margin-top: 30px
    }
}

.team-bios {
    background-color: #000;
    display: none;
    height: 100vh;
    left: 0;
    position: fixed;
    top: 0;
    width: 100vw;
    z-index: 30
}

.team-bios.active {
    display: block
}

.team-bios img {
    cursor: pointer;
    height: 30px;
    position: absolute;
    right: 20px;
    top: 20px;
    transform: rotate(45deg)
}

@media screen and (min-width:768px) {
    .team-bios img {
        height: 60px
    }
}

.team-bios__popup {
    background: #002855;
    display: none;
    height: 80%;
    left: 50%;
    overflow: scroll;
    padding: 30px;
    position: absolute;
    top: 50%;
    transform: translate(-50%, -50%);
    width: 90%
}

@media screen and (min-width:768px) {
    .team-bios__popup {
        padding: 50px;
        width: 60%
    }
}

.team-bios__popup.active {
    display: block
}

.team-bios__popup p {
    color: #fff
}

.team-bios__popup p:last-of-type {
    margin-bottom: 0
}

.testimonials {
    background-color: #fff;
    background-image: url(../../images/backgrounds/concrete-tile-v4.png);
    padding: 100px 0 0;
    position: relative
}

@media screen and (min-width:992px) {
    .testimonials {
        padding: 170px 0 200px
    }
}

.testimonials__img {
    display: none;
    height: 530px;
    position: absolute;
    right: 0;
    top: -90px;
    width: 530px
}

@media screen and (min-width:1200px) {
    .testimonials__img {
        display: block
    }
}

.testimonials h2 {
    color: #002855;
    font-size: 50px;
    letter-spacing: 5px;
    line-height: 56px;
    margin-bottom: 120px;
    position: relative
}

@media screen and (min-width:576px) {
    .testimonials h2 {
        font-size: 96px;
        letter-spacing: 9.6px;
        line-height: 107px
    }
}

.testimonials h2:after {
    background-image: url(../../images/graphics/four-stars-horizontal-blue.svg);
    background-repeat: no-repeat;
    bottom: -50px;
    content: "";
    display: block;
    height: 28px;
    left: 0;
    position: absolute;
    width: 134px
}

.testimonials__amso-logo {
    bottom: -150px;
    display: none;
    height: 410px;
    left: -300px;
    position: absolute
}

@media screen and (min-width:992px) {
    .testimonials__amso-logo {
        display: block
    }
}

.testimonials .testimonial-block {
    margin-bottom: 100px;
    position: relative
}

@media screen and (min-width:992px) {
    .testimonials .testimonial-block--left {
        padding-right: 50px
    }
}

@media screen and (min-width:1200px) {
    .testimonials .testimonial-block--left {
        padding-right: 85px
    }
}

.testimonials .testimonial-block--left:nth-of-type(2) {
    background-color: #8aa1b1
}

.testimonials .testimonial-block--left:nth-of-type(2):after {
    background-color: #8aa1b1;
    content: "";
    height: calc(100% + 60px);
    left: -30px;
    position: absolute;
    top: -30px;
    width: calc(100% + 60px)
}

@media screen and (min-width:992px) {
    .testimonials .testimonial-block--left:nth-of-type(2) {
        background-color: transparent
    }
    .testimonials .testimonial-block--left:nth-of-type(2):after {
        content: none
    }
    .testimonials .testimonial-block--right {
        padding-left: 50px
    }
}

@media screen and (min-width:1200px) {
    .testimonials .testimonial-block--right {
        padding-left: 85px;
        transform: translateY(200px)
    }
}

.testimonials .testimonial-block--right:nth-of-type(2) {
    background-color: #002855;
    margin-bottom: 30px
}

.testimonials .testimonial-block--right:nth-of-type(2):after {
    background-color: #002855;
    content: "";
    height: calc(100% + 60px);
    left: -30px;
    position: absolute;
    top: -30px;
    width: calc(100% + 60px)
}

.testimonials .testimonial-block--right:nth-of-type(2) h5,
.testimonials .testimonial-block--right:nth-of-type(2) p {
    color: #fff
}

@media screen and (min-width:992px) {
    .testimonials .testimonial-block--right:nth-of-type(2) {
        background-color: transparent;
        margin-bottom: 100px
    }
    .testimonials .testimonial-block--right:nth-of-type(2) h5,
    .testimonials .testimonial-block--right:nth-of-type(2) p {
        color: #002855
    }
    .testimonials .testimonial-block--right:nth-of-type(2):after {
        content: none
    }
}

.testimonials .testimonial-block h5 {
    color: #002855;
    margin-bottom: 40px;
    position: relative;
    z-index: 10
}

.testimonials .testimonial-block p {
    color: #002855;
    margin-bottom: 20px;
    position: relative;
    z-index: 10
}

.testimonials .testimonial-block p:last-of-type {
    margin-bottom: 0;
    margin-top: 50px
}

.testimonials .button {
    left: 50%;
    padding: 30px 0;
    position: relative;
    transform: translateX(-50%)
}

@media screen and (min-width:992px) {
    .testimonials .button {
        bottom: 50px;
        padding: 0;
        position: absolute
    }
}

.virtual-tour {
    background-color: #002855;
    padding: 30px
}

@media screen and (min-width:992px) {
    .virtual-tour {
        padding: 100px 30px 150px
    }
}

.virtual-tour__video {
    max-width: 930px;
    width: 100%
}

.virtual-tour__video iframe {
    background-color: #fff;
    height: 300px;
    width: 100%
}

@media screen and (min-width:992px) {
    .virtual-tour__video iframe {
        height: 555px
    }
}

.virtual-tour__video h5 {
    color: #fff
}

.location-main-content {
    background-color: #fff;
    background-image: url(../../images/backgrounds/concrete-tile-v4.png);
    padding: 180px 0 0;
    position: relative
}

@media screen and (min-width:576px) {
    .location-main-content {
        padding: 230px 0 0
    }
}

@media screen and (min-width:768px) {
    .location-main-content {
        padding: 240px 0 90px
    }
}

@media screen and (min-width:992px) {
    .location-main-content {
        padding: 250px 0 90px
    }
}

@media screen and (min-width:1200px) {
    .location-main-content {
        padding: 350px 0 90px
    }
}

.location-main-content h2 {
    color: #002855;
    margin-bottom: 60px;
    position: relative
}

.location-main-content h2:after {
    background-image: url(../../images/graphics/four-stars-horizontal-blue.svg);
    background-repeat: no-repeat;
    content: "";
    display: block;
    height: 28px;
    left: 0;
    position: absolute;
    width: 134px
}

.location-main-content h5 {
    color: #002855;
    margin-bottom: 30px
}

.location-main-content__social {
    margin-bottom: 45px
}

.location-main-content__social img {
    height: 30px;
    margin-right: 15px;
    opacity: 1;
    transition: .3s;
    width: auto
}

.location-main-content__social img:hover {
    opacity: .6
}

.location-main-content p {
    color: #002855;
    margin-bottom: 30px;
    width: 100%
}

@media screen and (min-width:992px) {
    .location-main-content p {
        max-width: 490px
    }
}

.location-main-content .button--border-style {
    margin-bottom: 50px
}

.location-main-content .button--outline {
    margin-bottom: 25px
}

.location-main-content .button--outline:last-of-type {
    margin-bottom: 0
}

.location-main-content iframe {
    left: -15px;
    position: relative;
    top: -15px
}

.location-main-content #ot-reservation-widget {
    left: -14px;
    position: relative;
    top: -14px;
    width: 210px
}

.location-main-content #ot-reservation-widget .ot-button {
    color: #fff
}

.location-main-content__feature-image {
    height: 350px;
    margin-bottom: 50px;
    position: relative;
    width: 100%;
    z-index: 10
}

@media screen and (min-width:768px) {
    .location-main-content__feature-image {
        height: 450px
    }
}

@media screen and (min-width:992px) {
    .location-main-content__feature-image {
        width: 450px
    }
}

.location-main-content__offset-image {
    display: none;
    height: 370px;
    position: absolute;
    right: 0;
    top: -150px;
    width: 370px;
    z-index: 10
}

@media screen and (min-width:992px) {
    .location-main-content__offset-image {
        display: block
    }
}

@media screen and (min-width:1024px) {
    .location-main-content__offset-image {
        height: 470px;
        width: 470px
    }
}

@media screen and (min-width:1400px) {
    .location-main-content__offset-image {
        height: 570px;
        width: 570px
    }
}

.location-main-content__amso-logo {
    display: none;
    height: 250px;
    left: 50%;
    position: absolute;
    top: 240px;
    width: auto
}

@media screen and (min-width:992px) {
    .location-main-content__amso-logo {
        display: block;
        left: 40%;
        top: 300px
    }
}

@media screen and (min-width:1200px) {
    .location-main-content__amso-logo {
        height: 362px;
        left: 50%;
        top: 250px
    }
}

.location-main-content__opening-times {
    background-color: #8aa1b1;
    margin-top: 80px;
    padding: 30px 0;
    position: relative;
    z-index: 10
}

.location-main-content__opening-times:after {
    background-color: #8aa1b1;
    content: "";
    display: block;
    height: 100%;
    left: -30px;
    position: absolute;
    top: 0;
    width: 100vw;
    z-index: -1
}

@media screen and (min-width:992px) {
    .location-main-content__opening-times {
        margin-top: 260px;
        padding: 30px
    }
    .location-main-content__opening-times:after {
        content: none
    }
}

.location-main-content__opening-times__wrapper {
    border: 2px solid #002855;
    padding: 50px
}

@media screen and (min-width:992px) {
    .location-main-content__opening-times__wrapper {
        padding: 90px 50px 120px 70px
    }
}

.location-main-content__opening-times__wrapper .opening-time {
    margin-bottom: 20px
}

.location-main-content__opening-times__wrapper .opening-time h5 {
    display: inline-block;
    margin: 0
}

.location-main-content__opening-times__wrapper .opening-time p {
    display: inline-block;
    font-family: Montserrat-Light;
    margin: 0;
    width: auto
}

.location-main-content .outlined-text--top {
    -webkit-text-stroke: 3px #002855;
    color: transparent;
    font-family: Langdon;
    font-size: 200px;
    left: 0;
    line-height: 250px;
    margin: 0;
    position: absolute;
    text-transform: uppercase;
    top: -60px;
    z-index: 10
}

@media screen and (min-width:576px) {
    .location-main-content .outlined-text--top {
        -webkit-text-stroke: 4px #002855;
        font-size: 290px;
        left: -40px;
        top: -30px
    }
}

@media screen and (min-width:1200px) {
    .location-main-content .outlined-text--top {
        font-size: 396px;
        line-height: 327px;
        top: -40px
    }
}

.location-main-content .outlined-text--bottom {
    -webkit-text-stroke: 4px #af272f;
    bottom: 10px;
    color: transparent;
    display: none;
    font-family: Langdon;
    font-size: 400px;
    height: 400px;
    line-height: 500px;
    margin: 0;
    position: absolute;
    right: -50px;
    z-index: 0
}

@media screen and (min-width:992px) {
    .location-main-content .outlined-text--bottom {
        display: block
    }
}

@media screen and (min-width:1200px) {
    .location-main-content .outlined-text--bottom {
        font-size: 515px
    }
}

.location-map {
    background-color: #fff;
    background-image: url(../../images/backgrounds/concrete-tile-v4.png);
    height: 400px;
    width: 100%
}

@media screen and (min-width:768px) {
    .location-map {
        height: 582px
    }
}

.location-map .map {
    height: 400px;
    width: 100%
}

@media screen and (min-width:768px) {
    .location-map .map {
        height: 582px
    }
}

.location-map .container {
    max-width: 1300px;
    padding: 0
}

@media screen and (min-width:768px) {
    .location-map .container {
        padding: 0 30px
    }
}

.location-online-ordering {
    background-color: #002855;
    overflow: hidden;
    padding: 0;
    position: relative
}

@media screen and (min-width:768px) {
    .location-online-ordering {
        padding: 50px 0
    }
}

@media screen and (min-width:992px) {
    .location-online-ordering {
        padding: 120px 0 160px
    }
}

.location-online-ordering .container {
    padding: 0
}

@media screen and (min-width:768px) {
    .location-online-ordering .container {
        padding: 0 30px
    }
}

.location-online-ordering__amso-logo {
    bottom: -100px;
    display: none;
    height: 400px;
    position: absolute;
    right: -150px;
    width: auto
}

@media screen and (min-width:992px) {
    .location-online-ordering__amso-logo {
        display: block
    }
}

.location-online-ordering__img {
    height: 550px;
    position: relative
}

.location-online-ordering__img .overlay {
    background-color: #000;
    height: 100%;
    left: 0;
    opacity: .5;
    position: absolute;
    top: 0;
    width: 100%;
    z-index: 5
}

@media screen and (min-width:1200px) {
    .location-online-ordering__img:after {
        background-image: url(../../images/graphics/four-stars-vertical.svg);
        background-repeat: no-repeat;
        content: "";
        display: block;
        height: 85px;
        left: -27px;
        position: absolute;
        top: 0;
        width: 15px
    }
}

.location-online-ordering__img h2 {
    color: #fff;
    font-size: 62px;
    letter-spacing: 6.2px;
    line-height: 70px;
    margin-bottom: 50px;
    max-width: 770px;
    padding: 0 30px;
    position: relative;
    text-align: center;
    width: 100%;
    z-index: 10
}

@media screen and (min-width:768px) {
    .location-online-ordering__img h2 {
        font-size: 96px;
        letter-spacing: 9.6px;
        line-height: 107px
    }
}

.location-online-ordering__img .button {
    position: relative;
    text-align: center;
    width: 200px;
    z-index: 10
}

.location-online-ordering__img img {
    height: 100%;
    left: 0;
    position: absolute;
    top: 0;
    width: 100%;
    z-index: 1
}

.single-whats-on-intro {
    background-color: #fff;
    background-image: url(../../images/backgrounds/concrete-tile-v4.png);
    padding: 435px 0 180px;
    position: relative
}

.single-whats-on-intro h2 {
    color: #002855;
    margin-bottom: 120px;
    max-width: 470px;
    position: relative;
    width: 100%
}

.single-whats-on-intro h2:after {
    background-image: url(../../images/graphics/four-stars-horizontal-blue.svg);
    background-repeat: no-repeat;
    bottom: -50px;
    content: "";
    display: block;
    height: 28px;
    left: 0;
    position: absolute;
    width: 134px
}

.single-whats-on-intro p {
    color: #002855;
    margin-bottom: 30px;
    max-width: 470px;
    width: 100%
}

.single-whats-on-intro p:last-of-type {
    margin-bottom: 50px
}

.single-whats-on-intro__amso-logo {
    bottom: 150px;
    position: absolute;
    right: -200px
}

.single-whats-on-intro__image {
    height: 510px;
    position: relative;
    width: 510px
}

.single-whats-on-intro__image img {
    height: 100%;
    position: relative;
    width: 100%;
    z-index: 10
}

.single-whats-on-intro__image:after {
    background-color: #8aa1b1;
    content: "";
    display: block;
    height: 100%;
    left: 0;
    position: absolute;
    top: 0;
    transform: translate(20px, -20px);
    width: 100%;
    z-index: 0
}

.single-whats-on-gallery {
    background-color: #af272f;
    padding: 80px 0 100px
}

.single-whats-on-gallery .swiper {
    padding-right: 200px
}

.single-whats-on-gallery .swiper-wrapper {
    padding-left: calc(50vw - 570px)
}

.single-whats-on-gallery .swiper-slide {
    height: 580px;
    width: 580px
}

.single-whats-on-gallery .swiper-slide img {
    height: 100%;
    width: 100%
}

.single-whats-on-gallery .swiper-button-next {
    height: 46px;
    left: 0;
    margin-top: 30px;
    position: relative;
    top: 0;
    width: 46px
}

.single-whats-on-gallery .swiper-button-next:after {
    content: none
}

.single-whats-on-gallery .swiper-button-prev {
    height: 46px;
    left: 0;
    margin-right: 15px;
    margin-top: 30px;
    position: relative;
    top: 0;
    width: 46px
}

.single-whats-on-gallery .swiper-button-prev:after {
    content: none
}

.locations,
.locations-intro {
    background-color: #002855
}

.locations-intro {
    padding-bottom: 50px;
    padding-top: 190px;
    position: relative
}

@media screen and (min-width:576px) {
    .locations-intro {
        padding-top: 220px
    }
}

@media screen and (min-width:992px) {
    .locations-intro {
        padding-top: 112px
    }
}

.locations-intro .outlined-text {
    -webkit-text-stroke: 3px #fff;
    color: transparent;
    font-family: Langdon;
    font-size: 200px;
    left: 0;
    line-height: 250px;
    margin: 0;
    position: absolute;
    text-transform: uppercase;
    top: -60px;
    z-index: 10
}

.locations-intro .outlined-text.edge {
    top: -80px
}

@media screen and (min-width:576px) {
    .locations-intro .outlined-text {
        -webkit-text-stroke: 4px #fff;
        font-size: 290px;
        left: -40px;
        top: -35px
    }
    .locations-intro .outlined-text.edge {
        top: -60px
    }
}

@media screen and (min-width:1200px) {
    .locations-intro .outlined-text {
        font-size: 320px;
        top: -25px
    }
    .locations-intro .outlined-text.edge {
        top: -90px
    }
}

@media screen and (min-width:1400px) {
    .locations-intro .outlined-text {
        font-size: 396px;
        line-height: 327px;
        top: -40px
    }
    .locations-intro .outlined-text.edge {
        top: -80px
    }
}

.locations-intro h1 {
    color: #fff;
    margin-bottom: 80px;
    padding-left: 30px;
    padding-right: 30px;
    position: relative;
    text-transform: uppercase
}

@media screen and (min-width:992px) {
    .locations-intro h1 {
        margin-bottom: 0
    }
}

@media screen and (min-width:1200px) {
    .locations-intro h1 {
        padding-left: calc(50vw - 570px)
    }
}

.locations-intro h1:after {
    background-image: url(../../images/graphics/four-stars-horizontal.svg);
    background-repeat: no-repeat;
    content: "";
    display: block;
    height: 28px;
    left: 30px;
    position: absolute;
    width: 134px
}

@media screen and (min-width:1200px) {
    .locations-intro h1:after {
        left: calc(50vw - 570px)
    }
}

.locations-intro img {
    display: none;
    height: 470px;
    width: 470px
}

@media screen and (min-width:992px) {
    .locations-intro img {
        display: block
    }
}

@media screen and (min-width:1200px) {
    .locations-intro img {
        height: 570px;
        width: 570px
    }
}

.locations__filter {
    display: none;
    margin-bottom: 30px
}

@media screen and (min-width:992px) {
    .locations__filter {
        transform: translateY(-80px)
    }
}

.locations__filter h5 {
    color: #fff;
    margin-bottom: 25px
}

.locations__filter__selector {
    margin-bottom: 30px
}

.locations__filter__selector h4 {
    color: #fff;
    font-size: 45px;
    letter-spacing: 1.6px;
    line-height: 55px;
    margin: 0 70px 0 0;
    position: relative;
    width: 220px
}

@media screen and (min-width:576px) {
    .locations__filter__selector h4 {
        width: auto
    }
}

@media screen and (min-width:992px) {
    .locations__filter__selector h4 {
        font-size: 55px;
        letter-spacing: 2px;
        line-height: 55px
    }
}

.locations__filter__selector h4:after {
    background-color: transparent;
    border-bottom: 2px solid #fff;
    border-top: 2px solid #fff;
    content: "";
    display: block;
    height: 7px
}

.locations__filter__selector h4:before {
    background-image: url(../../images/icons/arrow-white.svg);
    background-repeat: no-repeat;
    background-size: contain;
    content: "";
    display: block;
    height: 30px;
    position: absolute;
    right: 0;
    top: 9px;
    width: 25px
}

@media screen and (min-width:576px) {
    .locations__filter__selector h4:before {
        right: -35px
    }
}

.locations__filter__selector .button {
    background-color: #fff;
    color: #af272f;
    font-family: Langdon;
    font-size: 32px;
    height: 45px;
    letter-spacing: 1.4px;
    margin-top: 20px;
    text-align: center;
    text-transform: uppercase;
    width: 143px
}

@media screen and (min-width:576px) {
    .locations__filter__selector .button {
        margin-top: 0
    }
}

.locations__filter p {
    border-bottom: 1px solid #fff;
    color: #fff;
    display: inline-block;
    font-family: Baskerville;
    font-size: 12px;
    letter-spacing: 1.4px;
    margin-left: 20px;
    position: relative;
    text-transform: uppercase
}

.locations__filter p:before {
    background-image: url(../../images/icons/geo-icon.svg);
    background-repeat: no-repeat;
    background-size: contain;
    content: "";
    height: 12px;
    left: -20px;
    position: absolute;
    top: 5px;
    width: 12px
}

.menu {
    background-color: #fff;
    background-image: url(../../images/backgrounds/concrete-tile-v4.png);
    padding: 46px 0 60px
}

@media screen and (min-width:992px) {
    .menu {
        padding-bottom: 120px
    }
}

.menu.has-sticky-menu-filter .menu__filter-panel {
    position: fixed;
    top: 150px
}

.menu.has-sticky-menu-filter--bottom .menu__filter-panel {
    bottom: 0;
    position: absolute;
    top: unset
}

.menu__locations {
    margin-bottom: 30px;
    z-index: 3
}

.overflow-hidden .menu__locations {
    z-index: 2
}

@media screen and (min-width:992px) {
    .menu__locations {
        margin-bottom: 80px
    }
}

.menu__locations label {
    color: #002855;
    font-family: Baskerville;
    font-size: 16px;
    letter-spacing: 1.8px;
    line-height: 27.5px;
    text-transform: uppercase
}

.menu__filter-popup {
    margin-bottom: 35px;
    width: 100%;
    z-index: 3
}

.menu__filter-popup .close-filter,
.menu__filter-popup .open-filter {
    background-color: #002855;
    background-repeat: no-repeat;
    background-size: cover;
    padding: 5px 30px;
    position: relative;
    text-align: center;
    width: 100%;
    z-index: 2
}

.menu__filter-popup .close-filter span,
.menu__filter-popup .open-filter span {
    color: #fff;
    font-family: Montserrat-Regular;
    font-size: 15px;
    font-weight: 500;
    letter-spacing: .3em;
    line-height: 28px;
    text-transform: uppercase
}

.menu__filter-popup .close-filter span:after,
.menu__filter-popup .open-filter span:after {
    background-image: url(../../images/icons/close-white.svg);
    content: "";
    display: inline-block;
    height: 16px;
    margin-left: 10px;
    position: relative;
    top: 1px;
    width: 15px
}

.menu__filter-popup .open-filter {
    left: 0;
    position: absolute;
    top: 0;
    width: 100%
}

.has-sticky-menu-filter .menu__filter-popup .open-filter {
    background-color: #002855;
    position: fixed;
    top: 98px
}

.menu__filter-popup .close-filter span:after {
    top: 3px;
    transform: rotate(45deg)
}

@media only screen and (max-width:991px) {
    .menu__filter-popup .filter-popup {
        background-color: #002855;
        height: 100vh;
        left: 0;
        opacity: 0;
        overflow: auto;
        position: fixed;
        top: 0;
        visibility: hidden;
        width: 100vw;
        z-index: 20
    }
    .menu__filter-popup .filter-popup.is-active {
        opacity: 1;
        visibility: visible
    }
}

@media screen and (min-width:992px) {
    .menu__filter-popup .filter-popup {
        opacity: 1;
        visibility: visible
    }
}

.menu__filter-popup .filter-popup .close-filter {
    margin-bottom: 45px;
    margin-top: 98px
}

.menu__filter-menu-cats {
    align-items: flex-start;
    display: flex;
    flex-direction: column;
    padding: 0 30px
}

.menu__filter-menu-cats span {
    color: #fff;
    display: inline-block;
    font-family: Langdon;
    font-size: 28px;
    font-weight: 400;
    letter-spacing: 3px;
    line-height: 30px;
    text-transform: uppercase;
    transform: translateX(0);
    transition: all .3s ease
}

.menu__filter-menu-cats ul {
    display: none;
    margin: 0 0 20px
}

.menu__filter-menu-cats ul.open {
    display: block
}

.menu__filter-menu-cats ul li {
    color: #fff;
    cursor: pointer;
    font-family: Langdon;
    font-size: 18px;
    letter-spacing: 3.6px;
    opacity: .6;
    text-transform: uppercase;
    transition: .3s
}

.menu__filter-menu-cats ul li.active {
    opacity: 1
}

.menu__filter-menu-cats .cat {
    display: inline-block;
    line-height: 16px;
    margin-bottom: 22px;
    opacity: .75;
    position: relative;
    transition: opacity .3s ease
}

.menu__filter-menu-cats .cat.is-active {
    opacity: 1
}

@media screen and (min-width:992px) {
    .menu__filter-menu-cats .cat:hover,
    .menu__filter-menu-cats .cat:hover:after,
    .menu__filter-menu-cats .cat:hover:before {
        opacity: 1
    }
}

.menu__filter-panel {
    background: #002855;
    flex: 0 0 299px;
    margin-right: 10px;
    padding-bottom: 20px;
    width: 300px
}

@media screen and (min-width:1200px) {
    .menu__filter-panel {
        flex: 0 0 351px;
        width: 360px
    }
}

.menu__filter-panel__wrapper {
    display: none
}

@media screen and (min-width:992px) {
    .menu__filter-panel__wrapper {
        display: block;
        height: 100%;
        left: 15px;
        position: absolute
    }
}

.menu__filter-panel .label {
    border-bottom: 1px solid #fff;
    letter-spacing: .3em;
    margin-bottom: 30px;
    padding: 20px 30px
}

.menu__filter-panel .label p {
    color: #fff;
    font-size: 15px;
    font-weight: 500;
    text-transform: uppercase
}

.menu__items-container {
    padding-top: 44px
}

@media screen and (min-width:992px) {
    .menu__items-container {
        padding-top: 0
    }
}

.menu__items {
    flex: 1;
    min-height: 100vh;
    padding: 0
}

.menu__loading {
    animation: spin 2s linear infinite;
    background-position: 50%;
    background-repeat: no-repeat;
    background-size: 60px 60px;
    height: 60px;
    margin: 0 auto;
    opacity: 0;
    position: absolute;
    transition: opacity .3s ease, visibility .3s ease;
    visibility: hidden;
    width: calc(100% - 60px)
}

.menu-items .menu__loading {
    transform: translateY(30px)
}

.menu__loading.is-active {
    opacity: 1;
    visibility: visible
}

.menu .menu-cat__top {
    padding: 0 30px
}

@media screen and (min-width:992px) {
    .menu .menu-cat__top {
        padding: 0 50px
    }
}

.menu .menu-cat__top .button {
    min-width: 120px
}

.menu .menu-cat__title {
    color: #002855
}

@media screen and (min-width:992px) {
    .menu .menu-cat__title {
        font-size: 45px;
        letter-spacing: 2.2px
    }
}

.menu .menu-cat__title.mb {
    margin-bottom: 44px
}

.menu .menu-cat__pdf-button {
    min-width: 225px
}

@media only screen and (max-width:991px) {
    .menu .menu-cat__pdf-button {
        padding: 13px 14px 12px
    }
}

.menu .menu-subcat {
    padding: 30px
}

@media screen and (min-width:992px) {
    .menu .menu-subcat {
        padding: 50px
    }
}

.menu .menu-subcat--disclaimer {
    background-color: #af272f
}

.menu .menu-subcat--disclaimer p {
    color: #fff
}

.menu .menu-subcat--disclaimer a {
    background-color: #fff;
    color: #002855;
    display: block;
    font-family: Langdon;
    font-size: 24px;
    font-weight: 400;
    height: 60px;
    letter-spacing: 2.8px;
    margin-top: 30px;
    padding: 13px 0;
    text-align: center;
    text-transform: uppercase;
    transition: .3s;
    width: 240px
}

.menu .menu-subcat--disclaimer a:hover {
    background-color: #002855;
    color: #fff;
    text-decoration: none
}

.menu .menu-subcat--uber-eats {
    background-color: #002855;
    padding: 90px 50px
}

.menu .menu-subcat--uber-eats h4 {
    color: #fff;
    margin-bottom: 42px
}

.menu .menu-subcat--uber-eats p {
    color: #fff;
    margin-bottom: 60px;
    padding-bottom: 20px;
    position: relative
}

.menu .menu-subcat--uber-eats p:before {
    background-color: #fff;
    bottom: 0;
    content: "";
    display: block;
    height: 2px;
    position: absolute;
    width: 100%
}

.menu .menu-subcat--uber-eats p:after {
    background-color: #002855;
    background-image: url(../../images/graphics/four-stars-horizontal.svg);
    background-position: 50%;
    background-repeat: no-repeat;
    background-size: 80%;
    bottom: -13px;
    content: "";
    display: block;
    height: 30px;
    position: absolute;
    right: 40px;
    width: 120px
}

.menu .menu-subcat--uber-eats a {
    background-color: #fff;
    color: #af272f;
    display: block;
    font-family: Langdon;
    font-size: 24px;
    font-weight: 400;
    height: 60px;
    letter-spacing: 2.8px;
    margin-bottom: 20px;
    padding: 13px 0;
    text-align: center;
    text-transform: uppercase;
    transition: .3s;
    width: 240px
}

.menu .menu-subcat--uber-eats a:last-of-type {
    margin-bottom: 0
}

.menu .menu-subcat--uber-eats a:hover {
    background-color: #af272f;
    color: #fff;
    text-decoration: none
}

.menu .menu-subcat.light_blue {
    background-color: #8aa1b1
}

.menu .menu-subcat.light_blue .menu-item__description,
.menu .menu-subcat.light_blue .menu-item__extras li span,
.menu .menu-subcat.light_blue .menu-item__price,
.menu .menu-subcat.light_blue .menu-item__title,
.menu .menu-subcat.light_blue .menu-subcat__description,
.menu .menu-subcat.light_blue .menu-subcat__title {
    color: #002855
}

.menu .menu-subcat.light_blue .menu-item__top {
    border-bottom: 1px solid rgba(0, 40, 85, .5)
}

.menu .menu-subcat.light_blue .menu-subcat__items {
    border-top: 2px solid #002855
}

.menu .menu-subcat.light_blue .menu-subcat__items:after {
    background-color: #8aa1b1;
    background-image: url(../../images/graphics/four-stars-horizontal-blue.svg);
    background-position: 50%;
    background-repeat: no-repeat;
    background-size: 80%;
    content: "";
    display: block;
    height: 30px;
    position: absolute;
    right: 40px;
    top: -17px;
    width: 120px
}

.menu .menu-subcat.blue {
    background-color: #002855
}

.menu .menu-subcat.blue .menu-item__description,
.menu .menu-subcat.blue .menu-item__extras li span,
.menu .menu-subcat.blue .menu-item__price,
.menu .menu-subcat.blue .menu-item__title,
.menu .menu-subcat.blue .menu-subcat__description,
.menu .menu-subcat.blue .menu-subcat__title {
    color: #fff
}

.menu .menu-subcat.blue .menu-item__top {
    border-bottom: 1px solid hsla(0, 0%, 100%, .5)
}

.menu .menu-subcat.blue .menu-subcat__items {
    border-top: 2px solid #fff
}

.menu .menu-subcat.blue .menu-subcat__items:after {
    background-color: #002855;
    background-image: url(../../images/graphics/four-stars-horizontal.svg);
    background-position: 50%;
    background-repeat: no-repeat;
    background-size: 80%;
    content: "";
    display: block;
    height: 30px;
    position: absolute;
    right: 40px;
    top: -17px;
    width: 120px
}

.menu .menu-subcat.white .menu-subcat__title {
    color: #af272f
}

.menu .menu-subcat.white .menu-item__description,
.menu .menu-subcat.white .menu-item__extras li span,
.menu .menu-subcat.white .menu-item__price,
.menu .menu-subcat.white .menu-item__title,
.menu .menu-subcat.white .menu-subcat__description {
    color: #002855
}

.menu .menu-subcat.white .menu-item__top {
    border-bottom: 1px solid rgba(0, 40, 85, .5)
}

.menu .menu-subcat.white .menu-subcat__items {
    border-top: 2px solid #af272f
}

.menu .menu-subcat.white .menu-subcat__items:after {
    background-image: url(../../images/graphics/four-stars-horizontal-red.svg);
    background-position: 50%;
    background-repeat: no-repeat;
    background-size: 80%;
    content: "";
    display: block;
    height: 30px;
    position: absolute;
    right: 40px;
    top: -17px;
    width: 120px
}

.menu .menu-subcat.white .menu-subcat__items:before {
    background-color: #fff;
    background-image: url(../../images/backgrounds/concrete-tile-v4.png);
    content: "";
    height: 30px;
    position: absolute;
    right: 40px;
    top: -17px;
    width: 120px
}

.menu .menu-subcat__description {
    color: #002855;
    margin-bottom: 0;
    margin-top: 44px
}

.menu .menu-subcat__description a {
    color: inherit;
    text-decoration: underline
}

@media screen and (min-width:992px) {
    .menu .menu-subcat__title {
        font-size: 28px;
        letter-spacing: .8px;
        line-height: 36px
    }
}

.menu .menu-subcat__items {
    margin-top: 20px;
    padding-top: 30px;
    position: relative
}

@media screen and (min-width:992px) {
    .menu .menu-subcat__items {
        margin-top: 25px;
        padding-top: 40px
    }
}

@media screen and (min-width:1200px) {
    .menu .menu-subcat__items {
        display: flex;
        flex-wrap: wrap
    }
    .menu .menu-subcat__image {
        flex: 0 0 50%;
        max-width: 50%
    }
    .menu .menu-subcat__image.is-even {
        padding-left: 15px
    }
}

@media only screen and (min-width:1440px) {
    .menu .menu-subcat__image.is-even {
        padding-left: 35px
    }
}

@media screen and (min-width:1200px) {
    .menu .menu-subcat__image.is-odd {
        padding-right: 15px
    }
}

@media only screen and (min-width:1440px) {
    .menu .menu-subcat__image.is-odd {
        padding-right: 35px
    }
}

.menu .menu-subcat__image img {
    display: block;
    margin-bottom: 18px;
    max-height: 250px;
    -o-object-fit: cover;
    object-fit: cover;
    width: 100%
}

.menu .menu-subcat__image p {
    font-size: 15px;
    font-weight: 700;
    letter-spacing: .2em;
    line-height: 17px;
    text-transform: uppercase
}

.menu .menu-subcat.has-border {
    margin: 0 -5px 40px;
    padding: 20px 15px;
    position: relative
}

@media screen and (min-width:992px) {
    .menu .menu-subcat.has-border {
        margin: 0 -44px 60px;
        padding: 30px 44px 10px
    }
}

.menu .menu-subcat.has-border:before {
    content: "";
    height: calc(100% + 14px);
    left: -7px;
    pointer-events: none;
    position: absolute;
    top: -7px;
    width: calc(100% + 14px)
}

.menu .menu-subcat.has-border .border-corner {
    height: 22px;
    position: absolute;
    width: 22px
}

.menu .menu-subcat.has-border .border-corner--top-left {
    left: -9px;
    top: -9px
}

.menu .menu-subcat.has-border .border-corner--top-right {
    right: -9px;
    top: -9px;
    transform: rotate(90deg)
}

.menu .menu-subcat.has-border .border-corner--bottom-right {
    bottom: -9px;
    right: -9px;
    transform: rotate(180deg)
}

.menu .menu-subcat.has-border .border-corner--bottom-left {
    bottom: -9px;
    left: -9px;
    transform: rotate(270deg)
}

.menu .menu-item {
    margin-bottom: 27px
}

@media screen and (min-width:992px) {
    .menu .menu-item {
        margin-bottom: 35px
    }
}

@media screen and (min-width:1200px) {
    .menu .menu-item {
        flex: 0 0 50%;
        max-width: 50%
    }
    .menu .menu-item:nth-child(odd) .menu-item__inner {
        padding-right: 30px
    }
}

@media only screen and (min-width:1440px) {
    .menu .menu-item:nth-child(odd) .menu-item__inner {
        padding-right: 30px
    }
}

@media screen and (min-width:1200px) {
    .menu .menu-item:nth-child(2n) .menu-item__inner {
        padding-left: 30px
    }
}

@media only screen and (min-width:1440px) {
    .menu .menu-item:nth-child(2n) .menu-item__inner {
        padding-left: 30px
    }
}

.menu .menu-item__top {
    margin-bottom: 20px;
    padding-bottom: 12px;
    position: relative
}

.menu .menu-item__top:after {
    background-repeat: repeat-x;
    bottom: 0;
    content: "";
    display: block;
    height: 3px;
    left: 0;
    position: absolute;
    width: 100%
}

.menu .menu-item__title {
    font-style: italic;
    text-transform: uppercase;
    width: 70%
}

.menu .menu-item__price,
.menu .menu-item__title {
    color: #002855;
    display: inline-block;
    font-family: Baskerville;
    font-size: 16px;
    letter-spacing: 1.8px;
    line-height: 27.5px;
    vertical-align: top
}

.menu .menu-item__price {
    opacity: 0;
    text-align: right
}

.menu .menu-item__tags {
    color: #002855;
    font-family: Montserrat-Light;
    font-size: 13px;
    font-weight: 500;
    letter-spacing: 3.9px;
    line-height: 17px;
    margin: 0 0 13px;
    opacity: .8;
    text-transform: uppercase
}

.menu .menu-item__description {
    color: #002855;
    font-size: 14px;
    opacity: .8
}

.menu .menu-item__extras-title {
    font-size: 15px;
    font-weight: 700;
    letter-spacing: .2em;
    line-height: 17px;
    margin-bottom: 9px;
    text-transform: uppercase
}

.menu .menu-item__extras {
    list-style: none;
    margin: 0;
    opacity: .8;
    padding: 0
}

.menu .menu-item__extras li {
    align-items: flex-start;
    display: flex;
    justify-content: space-between;
    list-style-type: none
}

.menu .menu-item__extras li span {
    font-family: Montserrat-Medium;
    font-size: 14px;
    font-weight: 500;
    letter-spacing: 1.8px;
    line-height: 24px;
    margin-bottom: 5px
}

.menu .menu-item__extras li span.price {
    font-family: Baskerville;
    font-size: 14px;
    letter-spacing: 1.8px;
    line-height: 27.5px;
    opacity: 0
}

.whats-on {
    background-color: #002855;
    padding: 290px 0 50px;
    position: relative
}

@media screen and (min-width:576px) {
    .whats-on {
        padding: 210px 0 50px
    }
}

@media screen and (min-width:768px) {
    .whats-on {
        padding: 310px 0 50px
    }
}

@media screen and (min-width:992px) {
    .whats-on {
        padding: 410px 0 50px
    }
}

.whats-on .outlined-text {
    -webkit-text-stroke: 3px #fff;
    color: transparent;
    font-family: Langdon;
    font-size: 150px;
    left: 0;
    line-height: 150px;
    margin: 0;
    position: absolute;
    text-align: center;
    text-transform: uppercase;
    top: -28px;
    z-index: 10
}

.whats-on .outlined-text.edge {
    top: -40px
}

@media screen and (min-width:576px) {
    .whats-on .outlined-text {
        -webkit-text-stroke: 4px #fff;
        font-size: 155px;
        left: -20px;
        letter-spacing: 0;
        line-height: 250px;
        text-align: left;
        top: -75px
    }
    .whats-on .outlined-text.edge {
        top: -88px
    }
}

@media screen and (min-width:768px) {
    .whats-on .outlined-text {
        font-size: 210px;
        top: -55px
    }
    .whats-on .outlined-text.edge {
        top: -77px
    }
}

@media screen and (min-width:992px) {
    .whats-on .outlined-text {
        font-size: 265px;
        top: -40px
    }
    .whats-on .outlined-text.edge {
        top: -62px
    }
}

@media screen and (min-width:1200px) {
    .whats-on .outlined-text {
        font-size: 320px;
        line-height: 327px;
        top: -60px
    }
    .whats-on .outlined-text.edge {
        top: -90px
    }
}

@media screen and (min-width:1400px) {
    .whats-on .outlined-text {
        font-size: 375px;
        line-height: 327px;
        top: -40px
    }
    .whats-on .outlined-text.edge {
        top: -75px
    }
}

.whats-on__amso-logo {
    display: none;
    height: 220px;
    position: absolute;
    right: -40px;
    top: 200px;
    width: auto
}

@media screen and (min-width:576px) {
    .whats-on__amso-logo {
        display: block
    }
}

@media screen and (min-width:768px) {
    .whats-on__amso-logo {
        height: 320px;
        right: -200px
    }
}

@media screen and (min-width:992px) {
    .whats-on__amso-logo {
        height: 360px;
        right: -300px;
        top: 300px
    }
}

.whats-on__filter-container {
    z-index: 2
}

.whats-on__graphic {
    display: none;
    left: 50%;
    position: absolute;
    top: 50%;
    transform: translate(-50%, -50%)
}

.whats-on__graphic img {
    height: 250px;
    width: auto
}

@media screen and (min-width:992px) {
    .whats-on__graphic img {
        height: 354px
    }
}

.whats-on__selector {
    margin-bottom: 100px
}

.whats-on__selector h5 {
    color: #fff;
    margin-bottom: 40px
}

.whats-on__selector h4 {
    color: #fff;
    cursor: pointer;
    display: inline-block;
    line-height: 34px;
    position: relative;
    width: 220px
}

.whats-on__selector h4.active:before {
    transform: rotate(180deg)
}

.whats-on__selector h4:after {
    background-color: transparent;
    border-bottom: 2px solid #fff;
    border-top: 2px solid #fff;
    content: "";
    display: block;
    height: 7px
}

.whats-on__selector h4:before {
    background-image: url(../../images/icons/arrow-white.svg);
    background-repeat: no-repeat;
    content: "";
    display: block;
    height: 18px;
    position: absolute;
    right: 0;
    top: 6px;
    transform: rotate(0);
    transition: .3s;
    width: 15px
}

.whats-on__selector ul {
    display: none;
    margin: 0;
    position: absolute
}

.whats-on__selector ul li {
    background-color: #8aa1b1;
    border-bottom: 1px solid #002855;
    cursor: pointer;
    margin-bottom: 0;
    padding: 0;
    text-align: center;
    transition: .3s;
    width: 220px
}

.whats-on__selector ul li:before {
    content: none
}

.whats-on__selector ul li:hover {
    background-color: #fff
}

.whats-on__selector ul li:hover p {
    color: #002855
}

.whats-on__selector ul li p {
    color: #fff;
    display: block;
    font-family: Langdon;
    font-size: 18px;
    font-weight: 400;
    letter-spacing: 1.8px;
    line-height: 16px;
    margin: 0;
    padding: 18px 0;
    text-decoration: none;
    text-transform: uppercase;
    width: 100%
}

.whats-on__grid .whats-on-card {
    margin-bottom: 80px
}

.whats-on__grid .whats-on-card h4 {
    color: #fff;
    margin-bottom: 20px;
    padding-bottom: 410px
}

@media screen and (min-width:768px) {
    .whats-on__grid .whats-on-card h4 {
        padding-bottom: 0
    }
}

.whats-on__grid .whats-on-card__img {
    height: 350px;
    left: -15px;
    overflow: hidden;
    position: absolute;
    top: 70px;
    width: 100vw
}

@media screen and (min-width:768px) {
    .whats-on__grid .whats-on-card__img {
        left: 0;
        margin-bottom: 50px;
        position: relative;
        top: 0;
        width: 100%
    }
}

.whats-on__grid .whats-on-card__img img {
    height: 100%;
    transform: scale(1);
    transition: .3s;
    width: 100%
}

.whats-on__grid .whats-on-card__img:hover img {
    transform: scale(1.05)
}

.selectric-wrapper {
    cursor: pointer;
    position: relative
}

.selectric-responsive {
    width: 100%
}

.selectric {
    background: #f8f8f8;
    border: 1px solid #ddd;
    border-radius: 0;
    overflow: hidden;
    position: relative
}

.selectric .label {
    color: #444;
    font-size: 12px;
    margin: 0 38px 0 10px;
    overflow: hidden;
    text-overflow: ellipsis;
    -webkit-user-select: none;
    -moz-user-select: none;
    user-select: none;
    white-space: nowrap
}

.selectric .button,
.selectric .label {
    display: block;
    height: 38px;
    line-height: 38px
}

.selectric .button {
    background-color: #f8f8f8;
    color: #bbb;
    font: 0/0 a;
    *font: 20px/38px Lucida Sans Unicode, Arial Unicode MS, Arial;
    position: absolute;
    right: 0;
    text-align: center;
    top: 0;
    width: 38px
}

.selectric .button:after {
    border: 4px solid transparent;
    border-bottom: none;
    border-top-color: #bbb;
    bottom: 0;
    content: " ";
    height: 0;
    left: 0;
    margin: auto;
    position: absolute;
    right: 0;
    top: 0;
    width: 0
}

.selectric-focus .selectric {
    border-color: #aaa
}

.selectric-hover .selectric {
    border-color: #c4c4c4
}

.selectric-hover .selectric .button {
    color: #a2a2a2
}

.selectric-hover .selectric .button:after {
    border-top-color: #a2a2a2
}

.selectric-open {
    z-index: 9999
}

.selectric-open .selectric {
    border-color: #c4c4c4
}

.selectric-open .selectric-items {
    display: block
}

.selectric-disabled {
    cursor: default;
    filter: alpha(opacity=50);
    opacity: .5;
    -webkit-user-select: none;
    -moz-user-select: none;
    user-select: none
}

.selectric-hide-select {
    height: 0;
    overflow: hidden;
    position: relative;
    width: 0
}

.selectric-hide-select select {
    left: -100%;
    position: absolute
}

.selectric-hide-select.selectric-is-native {
    height: 100%;
    position: absolute;
    width: 100%;
    z-index: 10
}

.selectric-hide-select.selectric-is-native select {
    border: none;
    box-sizing: border-box;
    height: 100%;
    left: 0;
    opacity: 0;
    position: absolute;
    right: 0;
    top: 0;
    width: 100%;
    z-index: 1
}

.selectric-input {
    clip: rect(0, 0, 0, 0) !important;
    background: none !important;
    border: none !important;
    *font: 0/0 a !important;
    height: 1px !important;
    left: 0 !important;
    margin: 0 !important;
    outline: none !important;
    overflow: hidden !important;
    padding: 0 !important;
    position: absolute !important;
    top: 0 !important;
    width: 1px !important
}

.selectric-temp-show {
    display: block !important;
    position: absolute !important;
    visibility: hidden !important
}

.selectric-items {
    background: #f8f8f8;
    border: 1px solid #c4c4c4;
    box-shadow: 0 0 10px -6px;
    display: none;
    left: 0;
    position: absolute;
    top: 100%;
    z-index: -1
}

.selectric-items .selectric-scroll {
    height: 100%;
    overflow: auto
}

.selectric-above .selectric-items {
    bottom: 100%;
    top: auto
}

.selectric-items li,
.selectric-items ul {
    font-size: 12px;
    line-height: 20px;
    list-style: none;
    margin: 0;
    min-height: 20px;
    padding: 0
}

.selectric-items li {
    color: #666;
    cursor: pointer;
    display: block;
    padding: 10px
}

.selectric-items li.selected {
    background: #e0e0e0;
    color: #444
}

.selectric-items li.highlighted {
    background: #d0d0d0;
    color: #444
}

.selectric-items li:hover {
    background: #d5d5d5;
    color: #444
}

.selectric-items .disabled {
    background: none !important;
    color: #666 !important;
    cursor: default !important;
    filter: alpha(opacity=50);
    opacity: .5;
    -webkit-user-select: none;
    -moz-user-select: none;
    user-select: none
}

.selectric-items .selectric-group .selectric-group-label {
    background: none;
    color: #444;
    cursor: default;
    font-weight: 700;
    padding-left: 10px;
    -webkit-user-select: none;
    -moz-user-select: none;
    user-select: none
}

.selectric-items .selectric-group.disabled li {
    filter: alpha(opacity=100);
    opacity: 1
}

.selectric-items .selectric-group li {
    padding-left: 25px
}

/*# sourceMappingURL=style.min.css.map */