@charset "UTF-8";
/*!
 * Bootstrap v4.3.1 (https://getbootstrap.com/)
 * Copyright 2011-2019 The Bootstrap Authors
 * Copyright 2011-2019 Twitter, Inc.
 * Licensed under MIT (https://github.com/twbs/bootstrap/blob/master/LICENSE)
 */
:root {
  --blue: #007bff;
  --indigo: #6610f2;
  --purple: #6f42c1;
  --pink: #e83e8c;
  --red: #dc3545;
  --orange: #fd7e14;
  --yellow: #ffc107;
  --green: #28a745;
  --teal: #20c997;
  --cyan: #17a2b8;
  --white: #fff;
  --gray: #6c757d;
  --gray-dark: #343a40;
  --primary: #007bff;
  --secondary: #6c757d;
  --success: #28a745;
  --info: #17a2b8;
  --warning: #ffc107;
  --danger: #dc3545;
  --light: #f8f9fa;
  --dark: #343a40;
  --breakpoint-xs: 0;
  --breakpoint-sm: 576px;
  --breakpoint-md: 768px;
  --breakpoint-lg: 992px;
  --breakpoint-xl: 1200px;
  --font-family-sans-serif: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "Helvetica Neue", Arial, "Noto Sans", sans-serif, "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol", "Noto Color Emoji";
  --font-family-monospace: SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace;
}

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

html {
  font-family: sans-serif;
  line-height: 1.15;
  -webkit-text-size-adjust: 100%;
  -webkit-tap-highlight-color: rgba(0, 0, 0, 0);
}

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

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

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

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

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

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

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

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

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

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

dt {
  font-weight: 700;
}

dd {
  margin-bottom: 0.5rem;
  margin-left: 0;
}

blockquote {
  margin: 0 0 1rem;
}

b,
strong {
  font-weight: bolder;
}

small {
  font-size: 80%;
}

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

sub {
  bottom: -0.25em;
}

sup {
  top: -0.5em;
}

a {
  color: #007bff;
  text-decoration: none;
  background-color: transparent;
}
a:hover {
  color: rgb(0, 86.1, 178.5);
  text-decoration: underline;
}

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

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

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

figure {
  margin: 0 0 1rem;
}

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

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

table {
  border-collapse: collapse;
}

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

th {
  text-align: inherit;
}

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

button {
  border-radius: 0;
}

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

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

button,
input {
  overflow: visible;
}

button,
select {
  text-transform: none;
}

select {
  word-wrap: normal;
}

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

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

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

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

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

textarea {
  overflow: auto;
  resize: vertical;
}

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

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

progress {
  vertical-align: baseline;
}

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

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

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

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

output {
  display: inline-block;
}

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

template {
  display: none;
}

[hidden] {
  display: none !important;
}

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

.figure {
  display: inline-block;
}

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

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

code {
  font-size: 87.5%;
  color: #e83e8c;
  word-break: break-word;
}
a > code {
  color: inherit;
}

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

pre {
  display: block;
  font-size: 87.5%;
  color: #212529;
}
pre code {
  font-size: inherit;
  color: inherit;
  word-break: normal;
}

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

.container {
  width: 100%;
  padding-right: 15px;
  padding-left: 15px;
  margin-right: auto;
  margin-left: auto;
}
@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 {
  width: 100%;
  padding-right: 15px;
  padding-left: 15px;
  margin-right: auto;
  margin-left: auto;
}

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

.order-first {
  order: -1;
}

.order-last {
  order: 13;
}

.order-0 {
  order: 0;
}

.order-1 {
  order: 1;
}

.order-2 {
  order: 2;
}

.order-3 {
  order: 3;
}

.order-4 {
  order: 4;
}

.order-5 {
  order: 5;
}

.order-6 {
  order: 6;
}

.order-7 {
  order: 7;
}

.order-8 {
  order: 8;
}

.order-9 {
  order: 9;
}

.order-10 {
  order: 10;
}

.order-11 {
  order: 11;
}

.order-12 {
  order: 12;
}

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

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

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

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

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

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

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

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

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

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

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

@media (min-width: 576px) {
  .col-sm {
    flex-basis: 0;
    flex-grow: 1;
    max-width: 100%;
  }
  .col-sm-auto {
    flex: 0 0 auto;
    width: auto;
    max-width: 100%;
  }
  .col-sm-1 {
    flex: 0 0 8.3333333333%;
    max-width: 8.3333333333%;
  }
  .col-sm-2 {
    flex: 0 0 16.6666666667%;
    max-width: 16.6666666667%;
  }
  .col-sm-3 {
    flex: 0 0 25%;
    max-width: 25%;
  }
  .col-sm-4 {
    flex: 0 0 33.3333333333%;
    max-width: 33.3333333333%;
  }
  .col-sm-5 {
    flex: 0 0 41.6666666667%;
    max-width: 41.6666666667%;
  }
  .col-sm-6 {
    flex: 0 0 50%;
    max-width: 50%;
  }
  .col-sm-7 {
    flex: 0 0 58.3333333333%;
    max-width: 58.3333333333%;
  }
  .col-sm-8 {
    flex: 0 0 66.6666666667%;
    max-width: 66.6666666667%;
  }
  .col-sm-9 {
    flex: 0 0 75%;
    max-width: 75%;
  }
  .col-sm-10 {
    flex: 0 0 83.3333333333%;
    max-width: 83.3333333333%;
  }
  .col-sm-11 {
    flex: 0 0 91.6666666667%;
    max-width: 91.6666666667%;
  }
  .col-sm-12 {
    flex: 0 0 100%;
    max-width: 100%;
  }
  .order-sm-first {
    order: -1;
  }
  .order-sm-last {
    order: 13;
  }
  .order-sm-0 {
    order: 0;
  }
  .order-sm-1 {
    order: 1;
  }
  .order-sm-2 {
    order: 2;
  }
  .order-sm-3 {
    order: 3;
  }
  .order-sm-4 {
    order: 4;
  }
  .order-sm-5 {
    order: 5;
  }
  .order-sm-6 {
    order: 6;
  }
  .order-sm-7 {
    order: 7;
  }
  .order-sm-8 {
    order: 8;
  }
  .order-sm-9 {
    order: 9;
  }
  .order-sm-10 {
    order: 10;
  }
  .order-sm-11 {
    order: 11;
  }
  .order-sm-12 {
    order: 12;
  }
  .offset-sm-0 {
    margin-left: 0;
  }
  .offset-sm-1 {
    margin-left: 8.3333333333%;
  }
  .offset-sm-2 {
    margin-left: 16.6666666667%;
  }
  .offset-sm-3 {
    margin-left: 25%;
  }
  .offset-sm-4 {
    margin-left: 33.3333333333%;
  }
  .offset-sm-5 {
    margin-left: 41.6666666667%;
  }
  .offset-sm-6 {
    margin-left: 50%;
  }
  .offset-sm-7 {
    margin-left: 58.3333333333%;
  }
  .offset-sm-8 {
    margin-left: 66.6666666667%;
  }
  .offset-sm-9 {
    margin-left: 75%;
  }
  .offset-sm-10 {
    margin-left: 83.3333333333%;
  }
  .offset-sm-11 {
    margin-left: 91.6666666667%;
  }
}
@media (min-width: 768px) {
  .col-md {
    flex-basis: 0;
    flex-grow: 1;
    max-width: 100%;
  }
  .col-md-auto {
    flex: 0 0 auto;
    width: auto;
    max-width: 100%;
  }
  .col-md-1 {
    flex: 0 0 8.3333333333%;
    max-width: 8.3333333333%;
  }
  .col-md-2 {
    flex: 0 0 16.6666666667%;
    max-width: 16.6666666667%;
  }
  .col-md-3 {
    flex: 0 0 25%;
    max-width: 25%;
  }
  .col-md-4 {
    flex: 0 0 33.3333333333%;
    max-width: 33.3333333333%;
  }
  .col-md-5 {
    flex: 0 0 41.6666666667%;
    max-width: 41.6666666667%;
  }
  .col-md-6 {
    flex: 0 0 50%;
    max-width: 50%;
  }
  .col-md-7 {
    flex: 0 0 58.3333333333%;
    max-width: 58.3333333333%;
  }
  .col-md-8 {
    flex: 0 0 66.6666666667%;
    max-width: 66.6666666667%;
  }
  .col-md-9 {
    flex: 0 0 75%;
    max-width: 75%;
  }
  .col-md-10 {
    flex: 0 0 83.3333333333%;
    max-width: 83.3333333333%;
  }
  .col-md-11 {
    flex: 0 0 91.6666666667%;
    max-width: 91.6666666667%;
  }
  .col-md-12 {
    flex: 0 0 100%;
    max-width: 100%;
  }
  .order-md-first {
    order: -1;
  }
  .order-md-last {
    order: 13;
  }
  .order-md-0 {
    order: 0;
  }
  .order-md-1 {
    order: 1;
  }
  .order-md-2 {
    order: 2;
  }
  .order-md-3 {
    order: 3;
  }
  .order-md-4 {
    order: 4;
  }
  .order-md-5 {
    order: 5;
  }
  .order-md-6 {
    order: 6;
  }
  .order-md-7 {
    order: 7;
  }
  .order-md-8 {
    order: 8;
  }
  .order-md-9 {
    order: 9;
  }
  .order-md-10 {
    order: 10;
  }
  .order-md-11 {
    order: 11;
  }
  .order-md-12 {
    order: 12;
  }
  .offset-md-0 {
    margin-left: 0;
  }
  .offset-md-1 {
    margin-left: 8.3333333333%;
  }
  .offset-md-2 {
    margin-left: 16.6666666667%;
  }
  .offset-md-3 {
    margin-left: 25%;
  }
  .offset-md-4 {
    margin-left: 33.3333333333%;
  }
  .offset-md-5 {
    margin-left: 41.6666666667%;
  }
  .offset-md-6 {
    margin-left: 50%;
  }
  .offset-md-7 {
    margin-left: 58.3333333333%;
  }
  .offset-md-8 {
    margin-left: 66.6666666667%;
  }
  .offset-md-9 {
    margin-left: 75%;
  }
  .offset-md-10 {
    margin-left: 83.3333333333%;
  }
  .offset-md-11 {
    margin-left: 91.6666666667%;
  }
}
@media (min-width: 992px) {
  .col-lg {
    flex-basis: 0;
    flex-grow: 1;
    max-width: 100%;
  }
  .col-lg-auto {
    flex: 0 0 auto;
    width: auto;
    max-width: 100%;
  }
  .col-lg-1 {
    flex: 0 0 8.3333333333%;
    max-width: 8.3333333333%;
  }
  .col-lg-2 {
    flex: 0 0 16.6666666667%;
    max-width: 16.6666666667%;
  }
  .col-lg-3 {
    flex: 0 0 25%;
    max-width: 25%;
  }
  .col-lg-4 {
    flex: 0 0 33.3333333333%;
    max-width: 33.3333333333%;
  }
  .col-lg-5 {
    flex: 0 0 41.6666666667%;
    max-width: 41.6666666667%;
  }
  .col-lg-6 {
    flex: 0 0 50%;
    max-width: 50%;
  }
  .col-lg-7 {
    flex: 0 0 58.3333333333%;
    max-width: 58.3333333333%;
  }
  .col-lg-8 {
    flex: 0 0 66.6666666667%;
    max-width: 66.6666666667%;
  }
  .col-lg-9 {
    flex: 0 0 75%;
    max-width: 75%;
  }
  .col-lg-10 {
    flex: 0 0 83.3333333333%;
    max-width: 83.3333333333%;
  }
  .col-lg-11 {
    flex: 0 0 91.6666666667%;
    max-width: 91.6666666667%;
  }
  .col-lg-12 {
    flex: 0 0 100%;
    max-width: 100%;
  }
  .order-lg-first {
    order: -1;
  }
  .order-lg-last {
    order: 13;
  }
  .order-lg-0 {
    order: 0;
  }
  .order-lg-1 {
    order: 1;
  }
  .order-lg-2 {
    order: 2;
  }
  .order-lg-3 {
    order: 3;
  }
  .order-lg-4 {
    order: 4;
  }
  .order-lg-5 {
    order: 5;
  }
  .order-lg-6 {
    order: 6;
  }
  .order-lg-7 {
    order: 7;
  }
  .order-lg-8 {
    order: 8;
  }
  .order-lg-9 {
    order: 9;
  }
  .order-lg-10 {
    order: 10;
  }
  .order-lg-11 {
    order: 11;
  }
  .order-lg-12 {
    order: 12;
  }
  .offset-lg-0 {
    margin-left: 0;
  }
  .offset-lg-1 {
    margin-left: 8.3333333333%;
  }
  .offset-lg-2 {
    margin-left: 16.6666666667%;
  }
  .offset-lg-3 {
    margin-left: 25%;
  }
  .offset-lg-4 {
    margin-left: 33.3333333333%;
  }
  .offset-lg-5 {
    margin-left: 41.6666666667%;
  }
  .offset-lg-6 {
    margin-left: 50%;
  }
  .offset-lg-7 {
    margin-left: 58.3333333333%;
  }
  .offset-lg-8 {
    margin-left: 66.6666666667%;
  }
  .offset-lg-9 {
    margin-left: 75%;
  }
  .offset-lg-10 {
    margin-left: 83.3333333333%;
  }
  .offset-lg-11 {
    margin-left: 91.6666666667%;
  }
}
@media (min-width: 1200px) {
  .col-xl {
    flex-basis: 0;
    flex-grow: 1;
    max-width: 100%;
  }
  .col-xl-auto {
    flex: 0 0 auto;
    width: auto;
    max-width: 100%;
  }
  .col-xl-1 {
    flex: 0 0 8.3333333333%;
    max-width: 8.3333333333%;
  }
  .col-xl-2 {
    flex: 0 0 16.6666666667%;
    max-width: 16.6666666667%;
  }
  .col-xl-3 {
    flex: 0 0 25%;
    max-width: 25%;
  }
  .col-xl-4 {
    flex: 0 0 33.3333333333%;
    max-width: 33.3333333333%;
  }
  .col-xl-5 {
    flex: 0 0 41.6666666667%;
    max-width: 41.6666666667%;
  }
  .col-xl-6 {
    flex: 0 0 50%;
    max-width: 50%;
  }
  .col-xl-7 {
    flex: 0 0 58.3333333333%;
    max-width: 58.3333333333%;
  }
  .col-xl-8 {
    flex: 0 0 66.6666666667%;
    max-width: 66.6666666667%;
  }
  .col-xl-9 {
    flex: 0 0 75%;
    max-width: 75%;
  }
  .col-xl-10 {
    flex: 0 0 83.3333333333%;
    max-width: 83.3333333333%;
  }
  .col-xl-11 {
    flex: 0 0 91.6666666667%;
    max-width: 91.6666666667%;
  }
  .col-xl-12 {
    flex: 0 0 100%;
    max-width: 100%;
  }
  .order-xl-first {
    order: -1;
  }
  .order-xl-last {
    order: 13;
  }
  .order-xl-0 {
    order: 0;
  }
  .order-xl-1 {
    order: 1;
  }
  .order-xl-2 {
    order: 2;
  }
  .order-xl-3 {
    order: 3;
  }
  .order-xl-4 {
    order: 4;
  }
  .order-xl-5 {
    order: 5;
  }
  .order-xl-6 {
    order: 6;
  }
  .order-xl-7 {
    order: 7;
  }
  .order-xl-8 {
    order: 8;
  }
  .order-xl-9 {
    order: 9;
  }
  .order-xl-10 {
    order: 10;
  }
  .order-xl-11 {
    order: 11;
  }
  .order-xl-12 {
    order: 12;
  }
  .offset-xl-0 {
    margin-left: 0;
  }
  .offset-xl-1 {
    margin-left: 8.3333333333%;
  }
  .offset-xl-2 {
    margin-left: 16.6666666667%;
  }
  .offset-xl-3 {
    margin-left: 25%;
  }
  .offset-xl-4 {
    margin-left: 33.3333333333%;
  }
  .offset-xl-5 {
    margin-left: 41.6666666667%;
  }
  .offset-xl-6 {
    margin-left: 50%;
  }
  .offset-xl-7 {
    margin-left: 58.3333333333%;
  }
  .offset-xl-8 {
    margin-left: 66.6666666667%;
  }
  .offset-xl-9 {
    margin-left: 75%;
  }
  .offset-xl-10 {
    margin-left: 83.3333333333%;
  }
  .offset-xl-11 {
    margin-left: 91.6666666667%;
  }
}
.table {
  width: 100%;
  margin-bottom: 1rem;
  color: #212529;
}
.table th,
.table td {
  padding: 0.75rem;
  vertical-align: top;
  border-top: 1px solid #dee2e6;
}
.table thead th {
  vertical-align: bottom;
  border-bottom: 2px solid #dee2e6;
}
.table tbody + tbody {
  border-top: 2px solid #dee2e6;
}

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

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

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

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

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

.table-primary,
.table-primary > th,
.table-primary > td {
  background-color: rgb(183.6, 218.04, 255);
}
.table-primary th,
.table-primary td,
.table-primary thead th,
.table-primary tbody + tbody {
  border-color: rgb(122.4, 186.36, 255);
}

.table-hover .table-primary:hover {
  background-color: rgb(158.1, 204.84, 255);
}
.table-hover .table-primary:hover > td,
.table-hover .table-primary:hover > th {
  background-color: rgb(158.1, 204.84, 255);
}

.table-secondary,
.table-secondary > th,
.table-secondary > td {
  background-color: rgb(213.84, 216.36, 218.6);
}
.table-secondary th,
.table-secondary td,
.table-secondary thead th,
.table-secondary tbody + tbody {
  border-color: rgb(178.56, 183.24, 187.4);
}

.table-hover .table-secondary:hover {
  background-color: rgb(200.3075090253, 203.6560288809, 206.6324909747);
}
.table-hover .table-secondary:hover > td,
.table-hover .table-secondary:hover > th {
  background-color: rgb(200.3075090253, 203.6560288809, 206.6324909747);
}

.table-success,
.table-success > th,
.table-success > td {
  background-color: rgb(194.8, 230.36, 202.92);
}
.table-success th,
.table-success td,
.table-success thead th,
.table-success tbody + tbody {
  border-color: rgb(143.2, 209.24, 158.28);
}

.table-hover .table-success:hover {
  background-color: rgb(176.7059405941, 222.9540594059, 187.2665346535);
}
.table-hover .table-success:hover > td,
.table-hover .table-success:hover > th {
  background-color: rgb(176.7059405941, 222.9540594059, 187.2665346535);
}

.table-info,
.table-info > th,
.table-info > td {
  background-color: rgb(190.04, 228.96, 235.12);
}
.table-info th,
.table-info td,
.table-info thead th,
.table-info tbody + tbody {
  border-color: rgb(134.36, 206.64, 218.08);
}

.table-hover .table-info:hover {
  background-color: rgb(170.5152475248, 221.1332673267, 229.1447524752);
}
.table-hover .table-info:hover > td,
.table-hover .table-info:hover > th {
  background-color: rgb(170.5152475248, 221.1332673267, 229.1447524752);
}

.table-warning,
.table-warning > th,
.table-warning > td {
  background-color: rgb(255, 237.64, 185.56);
}
.table-warning th,
.table-warning td,
.table-warning thead th,
.table-warning tbody + tbody {
  border-color: rgb(255, 222.76, 126.04);
}

.table-hover .table-warning:hover {
  background-color: rgb(255, 231.265, 160.06);
}
.table-hover .table-warning:hover > td,
.table-hover .table-warning:hover > th {
  background-color: rgb(255, 231.265, 160.06);
}

.table-danger,
.table-danger > th,
.table-danger > td {
  background-color: rgb(245.2, 198.44, 202.92);
}
.table-danger th,
.table-danger td,
.table-danger thead th,
.table-danger tbody + tbody {
  border-color: rgb(236.8, 149.96, 158.28);
}

.table-hover .table-danger:hover {
  background-color: rgb(241.4341772152, 176.7058227848, 182.9073417722);
}
.table-hover .table-danger:hover > td,
.table-hover .table-danger:hover > th {
  background-color: rgb(241.4341772152, 176.7058227848, 182.9073417722);
}

.table-light,
.table-light > th,
.table-light > td {
  background-color: rgb(253.04, 253.32, 253.6);
}
.table-light th,
.table-light td,
.table-light thead th,
.table-light tbody + tbody {
  border-color: rgb(251.36, 251.88, 252.4);
}

.table-hover .table-light:hover {
  background-color: rgb(238.165, 240.57, 242.975);
}
.table-hover .table-light:hover > td,
.table-hover .table-light:hover > th {
  background-color: rgb(238.165, 240.57, 242.975);
}

.table-dark,
.table-dark > th,
.table-dark > td {
  background-color: rgb(198.16, 199.84, 201.52);
}
.table-dark th,
.table-dark td,
.table-dark thead th,
.table-dark tbody + tbody {
  border-color: rgb(149.44, 152.56, 155.68);
}

.table-hover .table-dark:hover {
  background-color: rgb(185.0216751269, 187.09, 189.1583248731);
}
.table-hover .table-dark:hover > td,
.table-hover .table-dark:hover > th {
  background-color: rgb(185.0216751269, 187.09, 189.1583248731);
}

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

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

.table .thead-dark th {
  color: #fff;
  background-color: #343a40;
  border-color: rgb(69.1465517241, 77.125, 85.1034482759);
}
.table .thead-light th {
  color: #495057;
  background-color: #e9ecef;
  border-color: #dee2e6;
}

.table-dark {
  color: #fff;
  background-color: #343a40;
}
.table-dark th,
.table-dark td,
.table-dark thead th {
  border-color: rgb(69.1465517241, 77.125, 85.1034482759);
}
.table-dark.table-bordered {
  border: 0;
}
.table-dark.table-striped tbody tr:nth-of-type(odd) {
  background-color: rgba(255, 255, 255, 0.05);
}
.table-dark.table-hover tbody tr:hover {
  color: #fff;
  background-color: rgba(255, 255, 255, 0.075);
}

@media (max-width: 575.98px) {
  .table-responsive-sm {
    display: block;
    width: 100%;
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
  }
  .table-responsive-sm > .table-bordered {
    border: 0;
  }
}
@media (max-width: 767.98px) {
  .table-responsive-md {
    display: block;
    width: 100%;
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
  }
  .table-responsive-md > .table-bordered {
    border: 0;
  }
}
@media (max-width: 991.98px) {
  .table-responsive-lg {
    display: block;
    width: 100%;
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
  }
  .table-responsive-lg > .table-bordered {
    border: 0;
  }
}
@media (max-width: 1199.98px) {
  .table-responsive-xl {
    display: block;
    width: 100%;
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
  }
  .table-responsive-xl > .table-bordered {
    border: 0;
  }
}
.table-responsive {
  display: block;
  width: 100%;
  overflow-x: auto;
  -webkit-overflow-scrolling: touch;
}
.table-responsive > .table-bordered {
  border: 0;
}

.form-control {
  display: block;
  width: 100%;
  height: calc(1.5em + 0.75rem + 2px);
  padding: 0.375rem 0.75rem;
  font-size: 1rem;
  font-weight: 400;
  line-height: 1.5;
  color: #495057;
  background-color: #fff;
  background-clip: padding-box;
  border: 1px solid #ced4da;
  border-radius: 0.25rem;
  transition: border-color 0.15s ease-in-out, box-shadow 0.15s ease-in-out;
}
@media (prefers-reduced-motion: reduce) {
  .form-control {
    transition: none;
  }
}
.form-control::-ms-expand {
  background-color: transparent;
  border: 0;
}
.form-control:focus {
  color: #495057;
  background-color: #fff;
  border-color: rgb(127.5, 189, 255);
  outline: 0;
  box-shadow: 0 0 0 0.2rem rgba(0, 123, 255, 0.25);
}
.form-control::placeholder {
  color: #6c757d;
  opacity: 1;
}
.form-control:disabled, .form-control[readonly] {
  background-color: #e9ecef;
  opacity: 1;
}

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

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

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

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

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

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

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

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

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

textarea.form-control {
  height: auto;
}

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

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

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

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

.form-check-input {
  position: absolute;
  margin-top: 0.3rem;
  margin-left: -1.25rem;
}
.form-check-input:disabled ~ .form-check-label {
  color: #6c757d;
}

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

.form-check-inline {
  display: inline-flex;
  align-items: center;
  padding-left: 0;
  margin-right: 0.75rem;
}
.form-check-inline .form-check-input {
  position: static;
  margin-top: 0;
  margin-right: 0.3125rem;
  margin-left: 0;
}

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

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

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

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

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

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

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

.was-validated .custom-control-input:valid ~ .custom-control-label, .custom-control-input.is-valid ~ .custom-control-label {
  color: #28a745;
}
.was-validated .custom-control-input:valid ~ .custom-control-label::before, .custom-control-input.is-valid ~ .custom-control-label::before {
  border-color: #28a745;
}
.was-validated .custom-control-input:valid ~ .valid-feedback,
.was-validated .custom-control-input:valid ~ .valid-tooltip, .custom-control-input.is-valid ~ .valid-feedback,
.custom-control-input.is-valid ~ .valid-tooltip {
  display: block;
}
.was-validated .custom-control-input:valid:checked ~ .custom-control-label::before, .custom-control-input.is-valid:checked ~ .custom-control-label::before {
  border-color: rgb(51.6956521739, 206.3043478261, 87);
  background-color: rgb(51.6956521739, 206.3043478261, 87);
}
.was-validated .custom-control-input:valid:focus ~ .custom-control-label::before, .custom-control-input.is-valid:focus ~ .custom-control-label::before {
  box-shadow: 0 0 0 0.2rem rgba(40, 167, 69, 0.25);
}
.was-validated .custom-control-input:valid:focus:not(:checked) ~ .custom-control-label::before, .custom-control-input.is-valid:focus:not(:checked) ~ .custom-control-label::before {
  border-color: #28a745;
}

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

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

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

.was-validated .form-control:invalid, .form-control.is-invalid {
  border-color: #dc3545;
  padding-right: calc(1.5em + 0.75rem);
  background-image: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' fill='%23dc3545' viewBox='-2 -2 7 7'%3e%3cpath stroke='%23dc3545' d='M0 0l3 3m0-3L0 3'/%3e%3ccircle r='.5'/%3e%3ccircle cx='3' r='.5'/%3e%3ccircle cy='3' r='.5'/%3e%3ccircle cx='3' cy='3' r='.5'/%3e%3c/svg%3E");
  background-repeat: no-repeat;
  background-position: center right calc(0.375em + 0.1875rem);
  background-size: calc(0.75em + 0.375rem) calc(0.75em + 0.375rem);
}
.was-validated .form-control:invalid:focus, .form-control.is-invalid:focus {
  border-color: #dc3545;
  box-shadow: 0 0 0 0.2rem rgba(220, 53, 69, 0.25);
}
.was-validated .form-control:invalid ~ .invalid-feedback,
.was-validated .form-control:invalid ~ .invalid-tooltip, .form-control.is-invalid ~ .invalid-feedback,
.form-control.is-invalid ~ .invalid-tooltip {
  display: block;
}

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

.was-validated .custom-select:invalid, .custom-select.is-invalid {
  border-color: #dc3545;
  padding-right: calc((1em + 0.75rem) * 3 / 4 + 1.75rem);
  background: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 4 5'%3e%3cpath fill='%23343a40' d='M2 0L0 2h4zm0 5L0 3h4z'/%3e%3c/svg%3e") no-repeat right 0.75rem center/8px 10px, url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' fill='%23dc3545' viewBox='-2 -2 7 7'%3e%3cpath stroke='%23dc3545' d='M0 0l3 3m0-3L0 3'/%3e%3ccircle r='.5'/%3e%3ccircle cx='3' r='.5'/%3e%3ccircle cy='3' r='.5'/%3e%3ccircle cx='3' cy='3' r='.5'/%3e%3c/svg%3E") #fff no-repeat center right 1.75rem/calc(0.75em + 0.375rem) calc(0.75em + 0.375rem);
}
.was-validated .custom-select:invalid:focus, .custom-select.is-invalid:focus {
  border-color: #dc3545;
  box-shadow: 0 0 0 0.2rem rgba(220, 53, 69, 0.25);
}
.was-validated .custom-select:invalid ~ .invalid-feedback,
.was-validated .custom-select:invalid ~ .invalid-tooltip, .custom-select.is-invalid ~ .invalid-feedback,
.custom-select.is-invalid ~ .invalid-tooltip {
  display: block;
}

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

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

.was-validated .custom-control-input:invalid ~ .custom-control-label, .custom-control-input.is-invalid ~ .custom-control-label {
  color: #dc3545;
}
.was-validated .custom-control-input:invalid ~ .custom-control-label::before, .custom-control-input.is-invalid ~ .custom-control-label::before {
  border-color: #dc3545;
}
.was-validated .custom-control-input:invalid ~ .invalid-feedback,
.was-validated .custom-control-input:invalid ~ .invalid-tooltip, .custom-control-input.is-invalid ~ .invalid-feedback,
.custom-control-input.is-invalid ~ .invalid-tooltip {
  display: block;
}
.was-validated .custom-control-input:invalid:checked ~ .custom-control-label::before, .custom-control-input.is-invalid:checked ~ .custom-control-label::before {
  border-color: rgb(227.5316455696, 96.4683544304, 109.0253164557);
  background-color: rgb(227.5316455696, 96.4683544304, 109.0253164557);
}
.was-validated .custom-control-input:invalid:focus ~ .custom-control-label::before, .custom-control-input.is-invalid:focus ~ .custom-control-label::before {
  box-shadow: 0 0 0 0.2rem rgba(220, 53, 69, 0.25);
}
.was-validated .custom-control-input:invalid:focus:not(:checked) ~ .custom-control-label::before, .custom-control-input.is-invalid:focus:not(:checked) ~ .custom-control-label::before {
  border-color: #dc3545;
}

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

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

.btn {
  display: inline-block;
  font-weight: 400;
  color: #212529;
  text-align: center;
  vertical-align: middle;
  user-select: none;
  background-color: transparent;
  border: 1px solid transparent;
  padding: 0.375rem 0.75rem;
  font-size: 1rem;
  line-height: 1.5;
  border-radius: 0.25rem;
  transition: color 0.15s ease-in-out, background-color 0.15s ease-in-out, border-color 0.15s ease-in-out, box-shadow 0.15s ease-in-out;
}
@media (prefers-reduced-motion: reduce) {
  .btn {
    transition: none;
  }
}
.btn:hover {
  color: #212529;
  text-decoration: none;
}
.btn:focus, .btn.focus {
  outline: 0;
  box-shadow: 0 0 0 0.2rem rgba(0, 123, 255, 0.25);
}
.btn.disabled, .btn:disabled {
  opacity: 0.65;
}
a.btn.disabled,
fieldset:disabled a.btn {
  pointer-events: none;
}

.btn-primary {
  color: #fff;
  background-color: #007bff;
  border-color: #007bff;
}
.btn-primary:hover {
  color: #fff;
  background-color: rgb(0, 104.55, 216.75);
  border-color: rgb(0, 98.4, 204);
}
.btn-primary:focus, .btn-primary.focus {
  box-shadow: 0 0 0 0.2rem rgba(38.25, 142.8, 255, 0.5);
}
.btn-primary.disabled, .btn-primary:disabled {
  color: #fff;
  background-color: #007bff;
  border-color: #007bff;
}
.btn-primary:not(:disabled):not(.disabled):active, .btn-primary:not(:disabled):not(.disabled).active, .show > .btn-primary.dropdown-toggle {
  color: #fff;
  background-color: rgb(0, 98.4, 204);
  border-color: rgb(0, 92.25, 191.25);
}
.btn-primary:not(:disabled):not(.disabled):active:focus, .btn-primary:not(:disabled):not(.disabled).active:focus, .show > .btn-primary.dropdown-toggle:focus {
  box-shadow: 0 0 0 0.2rem rgba(38.25, 142.8, 255, 0.5);
}

.btn-secondary {
  color: #fff;
  background-color: #6c757d;
  border-color: #6c757d;
}
.btn-secondary:hover {
  color: #fff;
  background-color: rgb(90.2703862661, 97.7929184549, 104.4796137339);
  border-color: rgb(84.3605150215, 91.3905579399, 97.6394849785);
}
.btn-secondary:focus, .btn-secondary.focus {
  box-shadow: 0 0 0 0.2rem rgba(130.05, 137.7, 144.5, 0.5);
}
.btn-secondary.disabled, .btn-secondary:disabled {
  color: #fff;
  background-color: #6c757d;
  border-color: #6c757d;
}
.btn-secondary:not(:disabled):not(.disabled):active, .btn-secondary:not(:disabled):not(.disabled).active, .show > .btn-secondary.dropdown-toggle {
  color: #fff;
  background-color: rgb(84.3605150215, 91.3905579399, 97.6394849785);
  border-color: rgb(78.4506437768, 84.9881974249, 90.7993562232);
}
.btn-secondary:not(:disabled):not(.disabled):active:focus, .btn-secondary:not(:disabled):not(.disabled).active:focus, .show > .btn-secondary.dropdown-toggle:focus {
  box-shadow: 0 0 0 0.2rem rgba(130.05, 137.7, 144.5, 0.5);
}

.btn-success {
  color: #fff;
  background-color: #28a745;
  border-color: #28a745;
}
.btn-success:hover {
  color: #fff;
  background-color: rgb(32.6086956522, 136.1413043478, 56.25);
  border-color: rgb(30.1449275362, 125.8550724638, 52);
}
.btn-success:focus, .btn-success.focus {
  box-shadow: 0 0 0 0.2rem rgba(72.25, 180.2, 96.9, 0.5);
}
.btn-success.disabled, .btn-success:disabled {
  color: #fff;
  background-color: #28a745;
  border-color: #28a745;
}
.btn-success:not(:disabled):not(.disabled):active, .btn-success:not(:disabled):not(.disabled).active, .show > .btn-success.dropdown-toggle {
  color: #fff;
  background-color: rgb(30.1449275362, 125.8550724638, 52);
  border-color: rgb(27.6811594203, 115.5688405797, 47.75);
}
.btn-success:not(:disabled):not(.disabled):active:focus, .btn-success:not(:disabled):not(.disabled).active:focus, .show > .btn-success.dropdown-toggle:focus {
  box-shadow: 0 0 0 0.2rem rgba(72.25, 180.2, 96.9, 0.5);
}

.btn-info {
  color: #fff;
  background-color: #17a2b8;
  border-color: #17a2b8;
}
.btn-info:hover {
  color: #fff;
  background-color: rgb(18.75, 132.0652173913, 150);
  border-color: rgb(17.3333333333, 122.0869565217, 138.6666666667);
}
.btn-info:focus, .btn-info.focus {
  box-shadow: 0 0 0 0.2rem rgba(57.8, 175.95, 194.65, 0.5);
}
.btn-info.disabled, .btn-info:disabled {
  color: #fff;
  background-color: #17a2b8;
  border-color: #17a2b8;
}
.btn-info:not(:disabled):not(.disabled):active, .btn-info:not(:disabled):not(.disabled).active, .show > .btn-info.dropdown-toggle {
  color: #fff;
  background-color: rgb(17.3333333333, 122.0869565217, 138.6666666667);
  border-color: rgb(15.9166666667, 112.1086956522, 127.3333333333);
}
.btn-info:not(:disabled):not(.disabled):active:focus, .btn-info:not(:disabled):not(.disabled).active:focus, .show > .btn-info.dropdown-toggle:focus {
  box-shadow: 0 0 0 0.2rem rgba(57.8, 175.95, 194.65, 0.5);
}

.btn-warning {
  color: #212529;
  background-color: #ffc107;
  border-color: #ffc107;
}
.btn-warning:hover {
  color: #212529;
  background-color: rgb(223.75, 167.8125, 0);
  border-color: rgb(211, 158.25, 0);
}
.btn-warning:focus, .btn-warning.focus {
  box-shadow: 0 0 0 0.2rem rgba(221.7, 169.6, 12.1, 0.5);
}
.btn-warning.disabled, .btn-warning:disabled {
  color: #212529;
  background-color: #ffc107;
  border-color: #ffc107;
}
.btn-warning:not(:disabled):not(.disabled):active, .btn-warning:not(:disabled):not(.disabled).active, .show > .btn-warning.dropdown-toggle {
  color: #212529;
  background-color: rgb(211, 158.25, 0);
  border-color: rgb(198.25, 148.6875, 0);
}
.btn-warning:not(:disabled):not(.disabled):active:focus, .btn-warning:not(:disabled):not(.disabled).active:focus, .show > .btn-warning.dropdown-toggle:focus {
  box-shadow: 0 0 0 0.2rem rgba(221.7, 169.6, 12.1, 0.5);
}

.btn-danger {
  color: #fff;
  background-color: #dc3545;
  border-color: #dc3545;
}
.btn-danger:hover {
  color: #fff;
  background-color: rgb(200.082278481, 34.667721519, 50.5158227848);
  border-color: rgb(189.2151898734, 32.7848101266, 47.7721518987);
}
.btn-danger:focus, .btn-danger.focus {
  box-shadow: 0 0 0 0.2rem rgba(225.25, 83.3, 96.9, 0.5);
}
.btn-danger.disabled, .btn-danger:disabled {
  color: #fff;
  background-color: #dc3545;
  border-color: #dc3545;
}
.btn-danger:not(:disabled):not(.disabled):active, .btn-danger:not(:disabled):not(.disabled).active, .show > .btn-danger.dropdown-toggle {
  color: #fff;
  background-color: rgb(189.2151898734, 32.7848101266, 47.7721518987);
  border-color: rgb(178.3481012658, 30.9018987342, 45.0284810127);
}
.btn-danger:not(:disabled):not(.disabled):active:focus, .btn-danger:not(:disabled):not(.disabled).active:focus, .show > .btn-danger.dropdown-toggle:focus {
  box-shadow: 0 0 0 0.2rem rgba(225.25, 83.3, 96.9, 0.5);
}

.btn-light {
  color: #212529;
  background-color: #f8f9fa;
  border-color: #f8f9fa;
}
.btn-light:hover {
  color: #212529;
  background-color: rgb(225.6875, 229.875, 234.0625);
  border-color: rgb(218.25, 223.5, 228.75);
}
.btn-light:focus, .btn-light.focus {
  box-shadow: 0 0 0 0.2rem rgba(215.75, 217.2, 218.65, 0.5);
}
.btn-light.disabled, .btn-light:disabled {
  color: #212529;
  background-color: #f8f9fa;
  border-color: #f8f9fa;
}
.btn-light:not(:disabled):not(.disabled):active, .btn-light:not(:disabled):not(.disabled).active, .show > .btn-light.dropdown-toggle {
  color: #212529;
  background-color: rgb(218.25, 223.5, 228.75);
  border-color: rgb(210.8125, 217.125, 223.4375);
}
.btn-light:not(:disabled):not(.disabled):active:focus, .btn-light:not(:disabled):not(.disabled).active:focus, .show > .btn-light.dropdown-toggle:focus {
  box-shadow: 0 0 0 0.2rem rgba(215.75, 217.2, 218.65, 0.5);
}

.btn-dark {
  color: #fff;
  background-color: #343a40;
  border-color: #343a40;
}
.btn-dark:hover {
  color: #fff;
  background-color: rgb(34.8534482759, 38.875, 42.8965517241);
  border-color: rgb(29.1379310345, 32.5, 35.8620689655);
}
.btn-dark:focus, .btn-dark.focus {
  box-shadow: 0 0 0 0.2rem rgba(82.45, 87.55, 92.65, 0.5);
}
.btn-dark.disabled, .btn-dark:disabled {
  color: #fff;
  background-color: #343a40;
  border-color: #343a40;
}
.btn-dark:not(:disabled):not(.disabled):active, .btn-dark:not(:disabled):not(.disabled).active, .show > .btn-dark.dropdown-toggle {
  color: #fff;
  background-color: rgb(29.1379310345, 32.5, 35.8620689655);
  border-color: rgb(23.4224137931, 26.125, 28.8275862069);
}
.btn-dark:not(:disabled):not(.disabled):active:focus, .btn-dark:not(:disabled):not(.disabled).active:focus, .show > .btn-dark.dropdown-toggle:focus {
  box-shadow: 0 0 0 0.2rem rgba(82.45, 87.55, 92.65, 0.5);
}

.btn-outline-primary {
  color: #007bff;
  border-color: #007bff;
}
.btn-outline-primary:hover {
  color: #fff;
  background-color: #007bff;
  border-color: #007bff;
}
.btn-outline-primary:focus, .btn-outline-primary.focus {
  box-shadow: 0 0 0 0.2rem rgba(0, 123, 255, 0.5);
}
.btn-outline-primary.disabled, .btn-outline-primary:disabled {
  color: #007bff;
  background-color: transparent;
}
.btn-outline-primary:not(:disabled):not(.disabled):active, .btn-outline-primary:not(:disabled):not(.disabled).active, .show > .btn-outline-primary.dropdown-toggle {
  color: #fff;
  background-color: #007bff;
  border-color: #007bff;
}
.btn-outline-primary:not(:disabled):not(.disabled):active:focus, .btn-outline-primary:not(:disabled):not(.disabled).active:focus, .show > .btn-outline-primary.dropdown-toggle:focus {
  box-shadow: 0 0 0 0.2rem rgba(0, 123, 255, 0.5);
}

.btn-outline-secondary {
  color: #6c757d;
  border-color: #6c757d;
}
.btn-outline-secondary:hover {
  color: #fff;
  background-color: #6c757d;
  border-color: #6c757d;
}
.btn-outline-secondary:focus, .btn-outline-secondary.focus {
  box-shadow: 0 0 0 0.2rem rgba(108, 117, 125, 0.5);
}
.btn-outline-secondary.disabled, .btn-outline-secondary:disabled {
  color: #6c757d;
  background-color: transparent;
}
.btn-outline-secondary:not(:disabled):not(.disabled):active, .btn-outline-secondary:not(:disabled):not(.disabled).active, .show > .btn-outline-secondary.dropdown-toggle {
  color: #fff;
  background-color: #6c757d;
  border-color: #6c757d;
}
.btn-outline-secondary:not(:disabled):not(.disabled):active:focus, .btn-outline-secondary:not(:disabled):not(.disabled).active:focus, .show > .btn-outline-secondary.dropdown-toggle:focus {
  box-shadow: 0 0 0 0.2rem rgba(108, 117, 125, 0.5);
}

.btn-outline-success {
  color: #28a745;
  border-color: #28a745;
}
.btn-outline-success:hover {
  color: #fff;
  background-color: #28a745;
  border-color: #28a745;
}
.btn-outline-success:focus, .btn-outline-success.focus {
  box-shadow: 0 0 0 0.2rem rgba(40, 167, 69, 0.5);
}
.btn-outline-success.disabled, .btn-outline-success:disabled {
  color: #28a745;
  background-color: transparent;
}
.btn-outline-success:not(:disabled):not(.disabled):active, .btn-outline-success:not(:disabled):not(.disabled).active, .show > .btn-outline-success.dropdown-toggle {
  color: #fff;
  background-color: #28a745;
  border-color: #28a745;
}
.btn-outline-success:not(:disabled):not(.disabled):active:focus, .btn-outline-success:not(:disabled):not(.disabled).active:focus, .show > .btn-outline-success.dropdown-toggle:focus {
  box-shadow: 0 0 0 0.2rem rgba(40, 167, 69, 0.5);
}

.btn-outline-info {
  color: #17a2b8;
  border-color: #17a2b8;
}
.btn-outline-info:hover {
  color: #fff;
  background-color: #17a2b8;
  border-color: #17a2b8;
}
.btn-outline-info:focus, .btn-outline-info.focus {
  box-shadow: 0 0 0 0.2rem rgba(23, 162, 184, 0.5);
}
.btn-outline-info.disabled, .btn-outline-info:disabled {
  color: #17a2b8;
  background-color: transparent;
}
.btn-outline-info:not(:disabled):not(.disabled):active, .btn-outline-info:not(:disabled):not(.disabled).active, .show > .btn-outline-info.dropdown-toggle {
  color: #fff;
  background-color: #17a2b8;
  border-color: #17a2b8;
}
.btn-outline-info:not(:disabled):not(.disabled):active:focus, .btn-outline-info:not(:disabled):not(.disabled).active:focus, .show > .btn-outline-info.dropdown-toggle:focus {
  box-shadow: 0 0 0 0.2rem rgba(23, 162, 184, 0.5);
}

.btn-outline-warning {
  color: #ffc107;
  border-color: #ffc107;
}
.btn-outline-warning:hover {
  color: #212529;
  background-color: #ffc107;
  border-color: #ffc107;
}
.btn-outline-warning:focus, .btn-outline-warning.focus {
  box-shadow: 0 0 0 0.2rem rgba(255, 193, 7, 0.5);
}
.btn-outline-warning.disabled, .btn-outline-warning:disabled {
  color: #ffc107;
  background-color: transparent;
}
.btn-outline-warning:not(:disabled):not(.disabled):active, .btn-outline-warning:not(:disabled):not(.disabled).active, .show > .btn-outline-warning.dropdown-toggle {
  color: #212529;
  background-color: #ffc107;
  border-color: #ffc107;
}
.btn-outline-warning:not(:disabled):not(.disabled):active:focus, .btn-outline-warning:not(:disabled):not(.disabled).active:focus, .show > .btn-outline-warning.dropdown-toggle:focus {
  box-shadow: 0 0 0 0.2rem rgba(255, 193, 7, 0.5);
}

.btn-outline-danger {
  color: #dc3545;
  border-color: #dc3545;
}
.btn-outline-danger:hover {
  color: #fff;
  background-color: #dc3545;
  border-color: #dc3545;
}
.btn-outline-danger:focus, .btn-outline-danger.focus {
  box-shadow: 0 0 0 0.2rem rgba(220, 53, 69, 0.5);
}
.btn-outline-danger.disabled, .btn-outline-danger:disabled {
  color: #dc3545;
  background-color: transparent;
}
.btn-outline-danger:not(:disabled):not(.disabled):active, .btn-outline-danger:not(:disabled):not(.disabled).active, .show > .btn-outline-danger.dropdown-toggle {
  color: #fff;
  background-color: #dc3545;
  border-color: #dc3545;
}
.btn-outline-danger:not(:disabled):not(.disabled):active:focus, .btn-outline-danger:not(:disabled):not(.disabled).active:focus, .show > .btn-outline-danger.dropdown-toggle:focus {
  box-shadow: 0 0 0 0.2rem rgba(220, 53, 69, 0.5);
}

.btn-outline-light {
  color: #f8f9fa;
  border-color: #f8f9fa;
}
.btn-outline-light:hover {
  color: #212529;
  background-color: #f8f9fa;
  border-color: #f8f9fa;
}
.btn-outline-light:focus, .btn-outline-light.focus {
  box-shadow: 0 0 0 0.2rem rgba(248, 249, 250, 0.5);
}
.btn-outline-light.disabled, .btn-outline-light:disabled {
  color: #f8f9fa;
  background-color: transparent;
}
.btn-outline-light:not(:disabled):not(.disabled):active, .btn-outline-light:not(:disabled):not(.disabled).active, .show > .btn-outline-light.dropdown-toggle {
  color: #212529;
  background-color: #f8f9fa;
  border-color: #f8f9fa;
}
.btn-outline-light:not(:disabled):not(.disabled):active:focus, .btn-outline-light:not(:disabled):not(.disabled).active:focus, .show > .btn-outline-light.dropdown-toggle:focus {
  box-shadow: 0 0 0 0.2rem rgba(248, 249, 250, 0.5);
}

.btn-outline-dark {
  color: #343a40;
  border-color: #343a40;
}
.btn-outline-dark:hover {
  color: #fff;
  background-color: #343a40;
  border-color: #343a40;
}
.btn-outline-dark:focus, .btn-outline-dark.focus {
  box-shadow: 0 0 0 0.2rem rgba(52, 58, 64, 0.5);
}
.btn-outline-dark.disabled, .btn-outline-dark:disabled {
  color: #343a40;
  background-color: transparent;
}
.btn-outline-dark:not(:disabled):not(.disabled):active, .btn-outline-dark:not(:disabled):not(.disabled).active, .show > .btn-outline-dark.dropdown-toggle {
  color: #fff;
  background-color: #343a40;
  border-color: #343a40;
}
.btn-outline-dark:not(:disabled):not(.disabled):active:focus, .btn-outline-dark:not(:disabled):not(.disabled).active:focus, .show > .btn-outline-dark.dropdown-toggle:focus {
  box-shadow: 0 0 0 0.2rem rgba(52, 58, 64, 0.5);
}

.btn-link {
  font-weight: 400;
  color: #007bff;
  text-decoration: none;
}
.btn-link:hover {
  color: rgb(0, 86.1, 178.5);
  text-decoration: underline;
}
.btn-link:focus, .btn-link.focus {
  text-decoration: underline;
  box-shadow: none;
}
.btn-link:disabled, .btn-link.disabled {
  color: #6c757d;
  pointer-events: none;
}

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

.btn-sm, .btn-group-sm > .btn {
  padding: 0.25rem 0.5rem;
  font-size: 0.875rem;
  line-height: 1.5;
  border-radius: 0.2rem;
}

.btn-block {
  display: block;
  width: 100%;
}
.btn-block + .btn-block {
  margin-top: 0.5rem;
}

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

.fade {
  transition: opacity 0.15s linear;
}
@media (prefers-reduced-motion: reduce) {
  .fade {
    transition: none;
  }
}
.fade:not(.show) {
  opacity: 0;
}

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

.collapsing {
  position: relative;
  height: 0;
  overflow: hidden;
  transition: height 0.35s ease;
}
@media (prefers-reduced-motion: reduce) {
  .collapsing {
    transition: none;
  }
}

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

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

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

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

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

@media (min-width: 576px) {
  .dropdown-menu-sm-left {
    right: auto;
    left: 0;
  }
  .dropdown-menu-sm-right {
    right: 0;
    left: auto;
  }
}
@media (min-width: 768px) {
  .dropdown-menu-md-left {
    right: auto;
    left: 0;
  }
  .dropdown-menu-md-right {
    right: 0;
    left: auto;
  }
}
@media (min-width: 992px) {
  .dropdown-menu-lg-left {
    right: auto;
    left: 0;
  }
  .dropdown-menu-lg-right {
    right: 0;
    left: auto;
  }
}
@media (min-width: 1200px) {
  .dropdown-menu-xl-left {
    right: auto;
    left: 0;
  }
  .dropdown-menu-xl-right {
    right: 0;
    left: auto;
  }
}
.dropup .dropdown-menu {
  top: auto;
  bottom: 100%;
  margin-top: 0;
  margin-bottom: 0.125rem;
}
.dropup .dropdown-toggle::after {
  display: inline-block;
  margin-left: 0.255em;
  vertical-align: 0.255em;
  content: "";
  border-top: 0;
  border-right: 0.3em solid transparent;
  border-bottom: 0.3em solid;
  border-left: 0.3em solid transparent;
}
.dropup .dropdown-toggle:empty::after {
  margin-left: 0;
}

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

.dropleft .dropdown-menu {
  top: 0;
  right: 100%;
  left: auto;
  margin-top: 0;
  margin-right: 0.125rem;
}
.dropleft .dropdown-toggle::after {
  display: inline-block;
  margin-left: 0.255em;
  vertical-align: 0.255em;
  content: "";
}
.dropleft .dropdown-toggle::after {
  display: none;
}
.dropleft .dropdown-toggle::before {
  display: inline-block;
  margin-right: 0.255em;
  vertical-align: 0.255em;
  content: "";
  border-top: 0.3em solid transparent;
  border-right: 0.3em solid;
  border-bottom: 0.3em solid transparent;
}
.dropleft .dropdown-toggle:empty::after {
  margin-left: 0;
}
.dropleft .dropdown-toggle::before {
  vertical-align: 0;
}

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

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

.dropdown-item {
  display: block;
  width: 100%;
  padding: 0.25rem 1.5rem;
  clear: both;
  font-weight: 400;
  color: #212529;
  text-align: inherit;
  white-space: nowrap;
  background-color: transparent;
  border: 0;
}
.dropdown-item:hover, .dropdown-item:focus {
  color: rgb(21.6283783784, 24.25, 26.8716216216);
  text-decoration: none;
  background-color: #f8f9fa;
}
.dropdown-item.active, .dropdown-item:active {
  color: #fff;
  text-decoration: none;
  background-color: #007bff;
}
.dropdown-item.disabled, .dropdown-item:disabled {
  color: #6c757d;
  pointer-events: none;
  background-color: transparent;
}

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

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

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

.btn-group,
.btn-group-vertical {
  position: relative;
  display: inline-flex;
  vertical-align: middle;
}
.btn-group > .btn,
.btn-group-vertical > .btn {
  position: relative;
  flex: 1 1 auto;
}
.btn-group > .btn:hover,
.btn-group-vertical > .btn:hover {
  z-index: 1;
}
.btn-group > .btn:focus, .btn-group > .btn:active, .btn-group > .btn.active,
.btn-group-vertical > .btn:focus,
.btn-group-vertical > .btn:active,
.btn-group-vertical > .btn.active {
  z-index: 1;
}

.btn-toolbar {
  display: flex;
  flex-wrap: wrap;
  justify-content: flex-start;
}
.btn-toolbar .input-group {
  width: auto;
}

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

.dropdown-toggle-split {
  padding-right: 0.5625rem;
  padding-left: 0.5625rem;
}
.dropdown-toggle-split::after, .dropup .dropdown-toggle-split::after, .dropright .dropdown-toggle-split::after {
  margin-left: 0;
}
.dropleft .dropdown-toggle-split::before {
  margin-right: 0;
}

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

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

.btn-group-vertical {
  flex-direction: column;
  align-items: flex-start;
  justify-content: center;
}
.btn-group-vertical > .btn,
.btn-group-vertical > .btn-group {
  width: 100%;
}
.btn-group-vertical > .btn:not(:first-child),
.btn-group-vertical > .btn-group:not(:first-child) {
  margin-top: -1px;
}
.btn-group-vertical > .btn:not(:last-child):not(.dropdown-toggle),
.btn-group-vertical > .btn-group:not(:last-child) > .btn {
  border-bottom-right-radius: 0;
  border-bottom-left-radius: 0;
}
.btn-group-vertical > .btn:not(:first-child),
.btn-group-vertical > .btn-group:not(:first-child) > .btn {
  border-top-left-radius: 0;
  border-top-right-radius: 0;
}

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

.input-group {
  position: relative;
  display: flex;
  flex-wrap: wrap;
  align-items: stretch;
  width: 100%;
}
.input-group > .form-control,
.input-group > .form-control-plaintext,
.input-group > .custom-select,
.input-group > .custom-file {
  position: relative;
  flex: 1 1 auto;
  width: 1%;
  margin-bottom: 0;
}
.input-group > .form-control + .form-control,
.input-group > .form-control + .custom-select,
.input-group > .form-control + .custom-file,
.input-group > .form-control-plaintext + .form-control,
.input-group > .form-control-plaintext + .custom-select,
.input-group > .form-control-plaintext + .custom-file,
.input-group > .custom-select + .form-control,
.input-group > .custom-select + .custom-select,
.input-group > .custom-select + .custom-file,
.input-group > .custom-file + .form-control,
.input-group > .custom-file + .custom-select,
.input-group > .custom-file + .custom-file {
  margin-left: -1px;
}
.input-group > .form-control:focus,
.input-group > .custom-select:focus,
.input-group > .custom-file .custom-file-input:focus ~ .custom-file-label {
  z-index: 3;
}
.input-group > .custom-file .custom-file-input:focus {
  z-index: 4;
}
.input-group > .form-control:not(:last-child),
.input-group > .custom-select:not(:last-child) {
  border-top-right-radius: 0;
  border-bottom-right-radius: 0;
}
.input-group > .form-control:not(:first-child),
.input-group > .custom-select:not(:first-child) {
  border-top-left-radius: 0;
  border-bottom-left-radius: 0;
}
.input-group > .custom-file {
  display: flex;
  align-items: center;
}
.input-group > .custom-file:not(:last-child) .custom-file-label, .input-group > .custom-file:not(:last-child) .custom-file-label::after {
  border-top-right-radius: 0;
  border-bottom-right-radius: 0;
}
.input-group > .custom-file:not(:first-child) .custom-file-label {
  border-top-left-radius: 0;
  border-bottom-left-radius: 0;
}

.input-group-prepend,
.input-group-append {
  display: flex;
}
.input-group-prepend .btn,
.input-group-append .btn {
  position: relative;
  z-index: 2;
}
.input-group-prepend .btn:focus,
.input-group-append .btn:focus {
  z-index: 3;
}
.input-group-prepend .btn + .btn,
.input-group-prepend .btn + .input-group-text,
.input-group-prepend .input-group-text + .input-group-text,
.input-group-prepend .input-group-text + .btn,
.input-group-append .btn + .btn,
.input-group-append .btn + .input-group-text,
.input-group-append .input-group-text + .input-group-text,
.input-group-append .input-group-text + .btn {
  margin-left: -1px;
}

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

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

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

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

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

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

.input-group-sm > .form-control,
.input-group-sm > .custom-select,
.input-group-sm > .input-group-prepend > .input-group-text,
.input-group-sm > .input-group-append > .input-group-text,
.input-group-sm > .input-group-prepend > .btn,
.input-group-sm > .input-group-append > .btn {
  padding: 0.25rem 0.5rem;
  font-size: 0.875rem;
  line-height: 1.5;
  border-radius: 0.2rem;
}

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

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

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

.custom-control {
  position: relative;
  display: block;
  min-height: 1.5rem;
  padding-left: 1.5rem;
}

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

.custom-control-input {
  position: absolute;
  z-index: -1;
  opacity: 0;
}
.custom-control-input:checked ~ .custom-control-label::before {
  color: #fff;
  border-color: #007bff;
  background-color: #007bff;
}
.custom-control-input:focus ~ .custom-control-label::before {
  box-shadow: 0 0 0 0.2rem rgba(0, 123, 255, 0.25);
}
.custom-control-input:focus:not(:checked) ~ .custom-control-label::before {
  border-color: rgb(127.5, 189, 255);
}
.custom-control-input:not(:disabled):active ~ .custom-control-label::before {
  color: #fff;
  background-color: rgb(178.5, 215.4, 255);
  border-color: rgb(178.5, 215.4, 255);
}
.custom-control-input:disabled ~ .custom-control-label {
  color: #6c757d;
}
.custom-control-input:disabled ~ .custom-control-label::before {
  background-color: #e9ecef;
}

.custom-control-label {
  position: relative;
  margin-bottom: 0;
  vertical-align: top;
}
.custom-control-label::before {
  position: absolute;
  top: 0.25rem;
  left: -1.5rem;
  display: block;
  width: 1rem;
  height: 1rem;
  pointer-events: none;
  content: "";
  background-color: #fff;
  border: #adb5bd solid 1px;
}
.custom-control-label::after {
  position: absolute;
  top: 0.25rem;
  left: -1.5rem;
  display: block;
  width: 1rem;
  height: 1rem;
  content: "";
  background: no-repeat 50%/50% 50%;
}

.custom-checkbox .custom-control-label::before {
  border-radius: 0.25rem;
}
.custom-checkbox .custom-control-input:checked ~ .custom-control-label::after {
  background-image: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' 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-label::before {
  border-color: #007bff;
  background-color: #007bff;
}
.custom-checkbox .custom-control-input:indeterminate ~ .custom-control-label::after {
  background-image: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 4 4'%3e%3cpath stroke='%23fff' d='M0 2h4'/%3e%3c/svg%3e");
}
.custom-checkbox .custom-control-input:disabled:checked ~ .custom-control-label::before {
  background-color: rgba(0, 123, 255, 0.5);
}
.custom-checkbox .custom-control-input:disabled:indeterminate ~ .custom-control-label::before {
  background-color: rgba(0, 123, 255, 0.5);
}

.custom-radio .custom-control-label::before {
  border-radius: 50%;
}
.custom-radio .custom-control-input:checked ~ .custom-control-label::after {
  background-image: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='-4 -4 8 8'%3e%3ccircle r='3' fill='%23fff'/%3e%3c/svg%3e");
}
.custom-radio .custom-control-input:disabled:checked ~ .custom-control-label::before {
  background-color: rgba(0, 123, 255, 0.5);
}

.custom-switch {
  padding-left: 2.25rem;
}
.custom-switch .custom-control-label::before {
  left: -2.25rem;
  width: 1.75rem;
  pointer-events: all;
  border-radius: 0.5rem;
}
.custom-switch .custom-control-label::after {
  top: calc(0.25rem + 2px);
  left: calc(-2.25rem + 2px);
  width: calc(1rem - 4px);
  height: calc(1rem - 4px);
  background-color: #adb5bd;
  border-radius: 0.5rem;
  transition: transform 0.15s ease-in-out, background-color 0.15s ease-in-out, border-color 0.15s ease-in-out, box-shadow 0.15s ease-in-out;
}
@media (prefers-reduced-motion: reduce) {
  .custom-switch .custom-control-label::after {
    transition: none;
  }
}
.custom-switch .custom-control-input:checked ~ .custom-control-label::after {
  background-color: #fff;
  transform: translateX(0.75rem);
}
.custom-switch .custom-control-input:disabled:checked ~ .custom-control-label::before {
  background-color: rgba(0, 123, 255, 0.5);
}

.custom-select {
  display: inline-block;
  width: 100%;
  height: calc(1.5em + 0.75rem + 2px);
  padding: 0.375rem 1.75rem 0.375rem 0.75rem;
  font-size: 1rem;
  font-weight: 400;
  line-height: 1.5;
  color: #495057;
  vertical-align: middle;
  background: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 4 5'%3e%3cpath fill='%23343a40' d='M2 0L0 2h4zm0 5L0 3h4z'/%3e%3c/svg%3e") no-repeat right 0.75rem center/8px 10px;
  background-color: #fff;
  border: 1px solid #ced4da;
  border-radius: 0.25rem;
  appearance: none;
}
.custom-select:focus {
  border-color: rgb(127.5, 189, 255);
  outline: 0;
  box-shadow: 0 0 0 0.2rem rgba(0, 123, 255, 0.25);
}
.custom-select:focus::-ms-value {
  color: #495057;
  background-color: #fff;
}
.custom-select[multiple], .custom-select[size]:not([size="1"]) {
  height: auto;
  padding-right: 0.75rem;
  background-image: none;
}
.custom-select:disabled {
  color: #6c757d;
  background-color: #e9ecef;
}
.custom-select::-ms-expand {
  display: none;
}

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

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

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

.custom-file-input {
  position: relative;
  z-index: 2;
  width: 100%;
  height: calc(1.5em + 0.75rem + 2px);
  margin: 0;
  opacity: 0;
}
.custom-file-input:focus ~ .custom-file-label {
  border-color: rgb(127.5, 189, 255);
  box-shadow: 0 0 0 0.2rem rgba(0, 123, 255, 0.25);
}
.custom-file-input:disabled ~ .custom-file-label {
  background-color: #e9ecef;
}
.custom-file-input:lang(en) ~ .custom-file-label::after {
  content: "Browse";
}
.custom-file-input ~ .custom-file-label[data-browse]::after {
  content: attr(data-browse);
}

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

.custom-range {
  width: 100%;
  height: calc(1rem + 0.4rem);
  padding: 0;
  background-color: transparent;
  appearance: none;
}
.custom-range:focus {
  outline: none;
}
.custom-range:focus::-webkit-slider-thumb {
  box-shadow: 0 0 0 1px #fff, 0 0 0 0.2rem rgba(0, 123, 255, 0.25);
}
.custom-range:focus::-moz-range-thumb {
  box-shadow: 0 0 0 1px #fff, 0 0 0 0.2rem rgba(0, 123, 255, 0.25);
}
.custom-range:focus::-ms-thumb {
  box-shadow: 0 0 0 1px #fff, 0 0 0 0.2rem rgba(0, 123, 255, 0.25);
}
.custom-range::-moz-focus-outer {
  border: 0;
}
.custom-range::-webkit-slider-thumb {
  width: 1rem;
  height: 1rem;
  margin-top: -0.25rem;
  background-color: #007bff;
  border: 0;
  border-radius: 1rem;
  transition: background-color 0.15s ease-in-out, border-color 0.15s ease-in-out, box-shadow 0.15s ease-in-out;
}
@media (prefers-reduced-motion: reduce) {
  .custom-range::-webkit-slider-thumb {
    transition: none;
  }
}
.custom-range::-webkit-slider-thumb {
  appearance: none;
}
.custom-range::-webkit-slider-thumb:active {
  background-color: rgb(178.5, 215.4, 255);
}
.custom-range::-webkit-slider-runnable-track {
  width: 100%;
  height: 0.5rem;
  color: transparent;
  cursor: pointer;
  background-color: #dee2e6;
  border-color: transparent;
  border-radius: 1rem;
}
.custom-range::-moz-range-thumb {
  width: 1rem;
  height: 1rem;
  background-color: #007bff;
  border: 0;
  border-radius: 1rem;
  transition: background-color 0.15s ease-in-out, border-color 0.15s ease-in-out, box-shadow 0.15s ease-in-out;
}
@media (prefers-reduced-motion: reduce) {
  .custom-range::-moz-range-thumb {
    transition: none;
  }
}
.custom-range::-moz-range-thumb {
  appearance: none;
}
.custom-range::-moz-range-thumb:active {
  background-color: rgb(178.5, 215.4, 255);
}
.custom-range::-moz-range-track {
  width: 100%;
  height: 0.5rem;
  color: transparent;
  cursor: pointer;
  background-color: #dee2e6;
  border-color: transparent;
  border-radius: 1rem;
}
.custom-range::-ms-thumb {
  width: 1rem;
  height: 1rem;
  margin-top: 0;
  margin-right: 0.2rem;
  margin-left: 0.2rem;
  background-color: #007bff;
  border: 0;
  border-radius: 1rem;
  transition: background-color 0.15s ease-in-out, border-color 0.15s ease-in-out, box-shadow 0.15s ease-in-out;
}
@media (prefers-reduced-motion: reduce) {
  .custom-range::-ms-thumb {
    transition: none;
  }
}
.custom-range::-ms-thumb {
  appearance: none;
}
.custom-range::-ms-thumb:active {
  background-color: rgb(178.5, 215.4, 255);
}
.custom-range::-ms-track {
  width: 100%;
  height: 0.5rem;
  color: transparent;
  cursor: pointer;
  background-color: transparent;
  border-color: transparent;
  border-width: 0.5rem;
}
.custom-range::-ms-fill-lower {
  background-color: #dee2e6;
  border-radius: 1rem;
}
.custom-range::-ms-fill-upper {
  margin-right: 15px;
  background-color: #dee2e6;
  border-radius: 1rem;
}
.custom-range:disabled::-webkit-slider-thumb {
  background-color: #adb5bd;
}
.custom-range:disabled::-webkit-slider-runnable-track {
  cursor: default;
}
.custom-range:disabled::-moz-range-thumb {
  background-color: #adb5bd;
}
.custom-range:disabled::-moz-range-track {
  cursor: default;
}
.custom-range:disabled::-ms-thumb {
  background-color: #adb5bd;
}

.custom-control-label::before,
.custom-file-label,
.custom-select {
  transition: background-color 0.15s ease-in-out, border-color 0.15s ease-in-out, box-shadow 0.15s ease-in-out;
}
@media (prefers-reduced-motion: reduce) {
  .custom-control-label::before,
  .custom-file-label,
  .custom-select {
    transition: none;
  }
}

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

.nav-link {
  display: block;
  padding: 0.5rem 1rem;
}
.nav-link:hover, .nav-link:focus {
  text-decoration: none;
}
.nav-link.disabled {
  color: #6c757d;
  pointer-events: none;
  cursor: default;
}

.nav-tabs {
  border-bottom: 1px solid #dee2e6;
}
.nav-tabs .nav-item {
  margin-bottom: -1px;
}
.nav-tabs .nav-link {
  border: 1px solid transparent;
  border-top-left-radius: 0.25rem;
  border-top-right-radius: 0.25rem;
}
.nav-tabs .nav-link:hover, .nav-tabs .nav-link:focus {
  border-color: #e9ecef #e9ecef #dee2e6;
}
.nav-tabs .nav-link.disabled {
  color: #6c757d;
  background-color: transparent;
  border-color: transparent;
}
.nav-tabs .nav-link.active,
.nav-tabs .nav-item.show .nav-link {
  color: #495057;
  background-color: #fff;
  border-color: #dee2e6 #dee2e6 #fff;
}
.nav-tabs .dropdown-menu {
  margin-top: -1px;
  border-top-left-radius: 0;
  border-top-right-radius: 0;
}

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

.nav-fill .nav-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 {
  position: relative;
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: space-between;
  padding: 0.5rem 1rem;
}
.navbar > .container,
.navbar > .container-fluid {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: space-between;
}

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

.navbar-nav {
  display: flex;
  flex-direction: column;
  padding-left: 0;
  margin-bottom: 0;
  list-style: none;
}
.navbar-nav .nav-link {
  padding-right: 0;
  padding-left: 0;
}
.navbar-nav .dropdown-menu {
  position: static;
  float: none;
}

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

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

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

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

@media (max-width: 575.98px) {
  .navbar-expand-sm > .container,
  .navbar-expand-sm > .container-fluid {
    padding-right: 0;
    padding-left: 0;
  }
}
@media (min-width: 576px) {
  .navbar-expand-sm {
    flex-flow: row nowrap;
    justify-content: flex-start;
  }
  .navbar-expand-sm .navbar-nav {
    flex-direction: row;
  }
  .navbar-expand-sm .navbar-nav .dropdown-menu {
    position: absolute;
  }
  .navbar-expand-sm .navbar-nav .nav-link {
    padding-right: 0.5rem;
    padding-left: 0.5rem;
  }
  .navbar-expand-sm > .container,
  .navbar-expand-sm > .container-fluid {
    flex-wrap: nowrap;
  }
  .navbar-expand-sm .navbar-collapse {
    display: flex !important;
    flex-basis: auto;
  }
  .navbar-expand-sm .navbar-toggler {
    display: none;
  }
}
@media (max-width: 767.98px) {
  .navbar-expand-md > .container,
  .navbar-expand-md > .container-fluid {
    padding-right: 0;
    padding-left: 0;
  }
}
@media (min-width: 768px) {
  .navbar-expand-md {
    flex-flow: row nowrap;
    justify-content: flex-start;
  }
  .navbar-expand-md .navbar-nav {
    flex-direction: row;
  }
  .navbar-expand-md .navbar-nav .dropdown-menu {
    position: absolute;
  }
  .navbar-expand-md .navbar-nav .nav-link {
    padding-right: 0.5rem;
    padding-left: 0.5rem;
  }
  .navbar-expand-md > .container,
  .navbar-expand-md > .container-fluid {
    flex-wrap: nowrap;
  }
  .navbar-expand-md .navbar-collapse {
    display: flex !important;
    flex-basis: auto;
  }
  .navbar-expand-md .navbar-toggler {
    display: none;
  }
}
@media (max-width: 991.98px) {
  .navbar-expand-lg > .container,
  .navbar-expand-lg > .container-fluid {
    padding-right: 0;
    padding-left: 0;
  }
}
@media (min-width: 992px) {
  .navbar-expand-lg {
    flex-flow: row nowrap;
    justify-content: flex-start;
  }
  .navbar-expand-lg .navbar-nav {
    flex-direction: row;
  }
  .navbar-expand-lg .navbar-nav .dropdown-menu {
    position: absolute;
  }
  .navbar-expand-lg .navbar-nav .nav-link {
    padding-right: 0.5rem;
    padding-left: 0.5rem;
  }
  .navbar-expand-lg > .container,
  .navbar-expand-lg > .container-fluid {
    flex-wrap: nowrap;
  }
  .navbar-expand-lg .navbar-collapse {
    display: flex !important;
    flex-basis: auto;
  }
  .navbar-expand-lg .navbar-toggler {
    display: none;
  }
}
@media (max-width: 1199.98px) {
  .navbar-expand-xl > .container,
  .navbar-expand-xl > .container-fluid {
    padding-right: 0;
    padding-left: 0;
  }
}
@media (min-width: 1200px) {
  .navbar-expand-xl {
    flex-flow: row nowrap;
    justify-content: flex-start;
  }
  .navbar-expand-xl .navbar-nav {
    flex-direction: row;
  }
  .navbar-expand-xl .navbar-nav .dropdown-menu {
    position: absolute;
  }
  .navbar-expand-xl .navbar-nav .nav-link {
    padding-right: 0.5rem;
    padding-left: 0.5rem;
  }
  .navbar-expand-xl > .container,
  .navbar-expand-xl > .container-fluid {
    flex-wrap: nowrap;
  }
  .navbar-expand-xl .navbar-collapse {
    display: flex !important;
    flex-basis: auto;
  }
  .navbar-expand-xl .navbar-toggler {
    display: none;
  }
}
.navbar-expand > .container,
.navbar-expand > .container-fluid {
  padding-right: 0;
  padding-left: 0;
}
.navbar-expand {
  flex-flow: row nowrap;
  justify-content: flex-start;
}
.navbar-expand .navbar-nav {
  flex-direction: row;
}
.navbar-expand .navbar-nav .dropdown-menu {
  position: absolute;
}
.navbar-expand .navbar-nav .nav-link {
  padding-right: 0.5rem;
  padding-left: 0.5rem;
}
.navbar-expand > .container,
.navbar-expand > .container-fluid {
  flex-wrap: nowrap;
}
.navbar-expand .navbar-collapse {
  display: flex !important;
  flex-basis: auto;
}
.navbar-expand .navbar-toggler {
  display: none;
}

.navbar-light .navbar-brand {
  color: rgba(0, 0, 0, 0.9);
}
.navbar-light .navbar-brand:hover, .navbar-light .navbar-brand:focus {
  color: rgba(0, 0, 0, 0.9);
}
.navbar-light .navbar-nav .nav-link {
  color: rgba(0, 0, 0, 0.5);
}
.navbar-light .navbar-nav .nav-link:hover, .navbar-light .navbar-nav .nav-link:focus {
  color: rgba(0, 0, 0, 0.7);
}
.navbar-light .navbar-nav .nav-link.disabled {
  color: rgba(0, 0, 0, 0.3);
}
.navbar-light .navbar-nav .show > .nav-link,
.navbar-light .navbar-nav .active > .nav-link,
.navbar-light .navbar-nav .nav-link.show,
.navbar-light .navbar-nav .nav-link.active {
  color: rgba(0, 0, 0, 0.9);
}
.navbar-light .navbar-toggler {
  color: rgba(0, 0, 0, 0.5);
  border-color: rgba(0, 0, 0, 0.1);
}
.navbar-light .navbar-toggler-icon {
  background-image: url("data:image/svg+xml,%3csvg 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, 0.5);
}
.navbar-light .navbar-text a {
  color: rgba(0, 0, 0, 0.9);
}
.navbar-light .navbar-text a:hover, .navbar-light .navbar-text a:focus {
  color: rgba(0, 0, 0, 0.9);
}

.navbar-dark .navbar-brand {
  color: #fff;
}
.navbar-dark .navbar-brand:hover, .navbar-dark .navbar-brand:focus {
  color: #fff;
}
.navbar-dark .navbar-nav .nav-link {
  color: rgba(255, 255, 255, 0.5);
}
.navbar-dark .navbar-nav .nav-link:hover, .navbar-dark .navbar-nav .nav-link:focus {
  color: rgba(255, 255, 255, 0.75);
}
.navbar-dark .navbar-nav .nav-link.disabled {
  color: rgba(255, 255, 255, 0.25);
}
.navbar-dark .navbar-nav .show > .nav-link,
.navbar-dark .navbar-nav .active > .nav-link,
.navbar-dark .navbar-nav .nav-link.show,
.navbar-dark .navbar-nav .nav-link.active {
  color: #fff;
}
.navbar-dark .navbar-toggler {
  color: rgba(255, 255, 255, 0.5);
  border-color: rgba(255, 255, 255, 0.1);
}
.navbar-dark .navbar-toggler-icon {
  background-image: url("data:image/svg+xml,%3csvg 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: rgba(255, 255, 255, 0.5);
}
.navbar-dark .navbar-text a {
  color: #fff;
}
.navbar-dark .navbar-text a:hover, .navbar-dark .navbar-text a:focus {
  color: #fff;
}

.card {
  position: relative;
  display: flex;
  flex-direction: column;
  min-width: 0;
  word-wrap: break-word;
  background-color: #fff;
  background-clip: border-box;
  border: 1px solid rgba(0, 0, 0, 0.125);
  border-radius: 0.25rem;
}
.card > hr {
  margin-right: 0;
  margin-left: 0;
}
.card > .list-group:first-child .list-group-item:first-child {
  border-top-left-radius: 0.25rem;
  border-top-right-radius: 0.25rem;
}
.card > .list-group:last-child .list-group-item:last-child {
  border-bottom-right-radius: 0.25rem;
  border-bottom-left-radius: 0.25rem;
}

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

.card-title {
  margin-bottom: 0.75rem;
}

.card-subtitle {
  margin-top: -0.375rem;
  margin-bottom: 0;
}

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

.card-link:hover {
  text-decoration: none;
}
.card-link + .card-link {
  margin-left: 1.25rem;
}

.card-header {
  padding: 0.75rem 1.25rem;
  margin-bottom: 0;
  background-color: rgba(0, 0, 0, 0.03);
  border-bottom: 1px solid rgba(0, 0, 0, 0.125);
}
.card-header:first-child {
  border-radius: calc(0.25rem - 1px) calc(0.25rem - 1px) 0 0;
}
.card-header + .list-group .list-group-item:first-child {
  border-top: 0;
}

.card-footer {
  padding: 0.75rem 1.25rem;
  background-color: rgba(0, 0, 0, 0.03);
  border-top: 1px solid rgba(0, 0, 0, 0.125);
}
.card-footer:last-child {
  border-radius: 0 0 calc(0.25rem - 1px) calc(0.25rem - 1px);
}

.card-header-tabs {
  margin-right: -0.625rem;
  margin-bottom: -0.75rem;
  margin-left: -0.625rem;
  border-bottom: 0;
}

.card-header-pills {
  margin-right: -0.625rem;
  margin-left: -0.625rem;
}

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

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

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

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

.card-deck {
  display: flex;
  flex-direction: column;
}
.card-deck .card {
  margin-bottom: 15px;
}
@media (min-width: 576px) {
  .card-deck {
    flex-flow: row wrap;
    margin-right: -15px;
    margin-left: -15px;
  }
  .card-deck .card {
    display: flex;
    flex: 1 0 0%;
    flex-direction: column;
    margin-right: 15px;
    margin-bottom: 0;
    margin-left: 15px;
  }
}

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

.card-columns .card {
  margin-bottom: 0.75rem;
}
@media (min-width: 576px) {
  .card-columns {
    column-count: 3;
    column-gap: 1.25rem;
    orphans: 1;
    widows: 1;
  }
  .card-columns .card {
    display: inline-block;
    width: 100%;
  }
}

.accordion > .card {
  overflow: hidden;
}
.accordion > .card:not(:first-of-type) .card-header:first-child {
  border-radius: 0;
}
.accordion > .card:not(:first-of-type):not(:last-of-type) {
  border-bottom: 0;
  border-radius: 0;
}
.accordion > .card:first-of-type {
  border-bottom: 0;
  border-bottom-right-radius: 0;
  border-bottom-left-radius: 0;
}
.accordion > .card:last-of-type {
  border-top-left-radius: 0;
  border-top-right-radius: 0;
}
.accordion > .card .card-header {
  margin-bottom: -1px;
}

.breadcrumb {
  display: flex;
  flex-wrap: wrap;
  padding: 0.75rem 1rem;
  margin-bottom: 1rem;
  list-style: none;
  background-color: #e9ecef;
  border-radius: 0.25rem;
}

.breadcrumb-item + .breadcrumb-item {
  padding-left: 0.5rem;
}
.breadcrumb-item + .breadcrumb-item::before {
  display: inline-block;
  padding-right: 0.5rem;
  color: #6c757d;
  content: "/";
}
.breadcrumb-item + .breadcrumb-item:hover::before {
  text-decoration: underline;
}
.breadcrumb-item + .breadcrumb-item:hover::before {
  text-decoration: none;
}
.breadcrumb-item.active {
  color: #6c757d;
}

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

.page-link {
  position: relative;
  display: block;
  padding: 0.5rem 0.75rem;
  margin-left: -1px;
  line-height: 1.25;
  color: #007bff;
  background-color: #fff;
  border: 1px solid #dee2e6;
}
.page-link:hover {
  z-index: 2;
  color: rgb(0, 86.1, 178.5);
  text-decoration: none;
  background-color: #e9ecef;
  border-color: #dee2e6;
}
.page-link:focus {
  z-index: 2;
  outline: 0;
  box-shadow: 0 0 0 0.2rem rgba(0, 123, 255, 0.25);
}

.page-item:first-child .page-link {
  margin-left: 0;
  border-top-left-radius: 0.25rem;
  border-bottom-left-radius: 0.25rem;
}
.page-item:last-child .page-link {
  border-top-right-radius: 0.25rem;
  border-bottom-right-radius: 0.25rem;
}
.page-item.active .page-link {
  z-index: 1;
  color: #fff;
  background-color: #007bff;
  border-color: #007bff;
}
.page-item.disabled .page-link {
  color: #6c757d;
  pointer-events: none;
  cursor: auto;
  background-color: #fff;
  border-color: #dee2e6;
}

.pagination-lg .page-link {
  padding: 0.75rem 1.5rem;
  font-size: 1.25rem;
  line-height: 1.5;
}
.pagination-lg .page-item:first-child .page-link {
  border-top-left-radius: 0.3rem;
  border-bottom-left-radius: 0.3rem;
}
.pagination-lg .page-item:last-child .page-link {
  border-top-right-radius: 0.3rem;
  border-bottom-right-radius: 0.3rem;
}

.pagination-sm .page-link {
  padding: 0.25rem 0.5rem;
  font-size: 0.875rem;
  line-height: 1.5;
}
.pagination-sm .page-item:first-child .page-link {
  border-top-left-radius: 0.2rem;
  border-bottom-left-radius: 0.2rem;
}
.pagination-sm .page-item:last-child .page-link {
  border-top-right-radius: 0.2rem;
  border-bottom-right-radius: 0.2rem;
}

.badge {
  display: inline-block;
  padding: 0.25em 0.4em;
  font-size: 75%;
  font-weight: 700;
  line-height: 1;
  text-align: center;
  white-space: nowrap;
  vertical-align: baseline;
  border-radius: 0.25rem;
  transition: color 0.15s ease-in-out, background-color 0.15s ease-in-out, border-color 0.15s ease-in-out, box-shadow 0.15s ease-in-out;
}
@media (prefers-reduced-motion: reduce) {
  .badge {
    transition: none;
  }
}
a.badge:hover, a.badge:focus {
  text-decoration: none;
}

.badge:empty {
  display: none;
}

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

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

.badge-primary {
  color: #fff;
  background-color: #007bff;
}
a.badge-primary:hover, a.badge-primary:focus {
  color: #fff;
  background-color: rgb(0, 98.4, 204);
}
a.badge-primary:focus, a.badge-primary.focus {
  outline: 0;
  box-shadow: 0 0 0 0.2rem rgba(0, 123, 255, 0.5);
}

.badge-secondary {
  color: #fff;
  background-color: #6c757d;
}
a.badge-secondary:hover, a.badge-secondary:focus {
  color: #fff;
  background-color: rgb(84.3605150215, 91.3905579399, 97.6394849785);
}
a.badge-secondary:focus, a.badge-secondary.focus {
  outline: 0;
  box-shadow: 0 0 0 0.2rem rgba(108, 117, 125, 0.5);
}

.badge-success {
  color: #fff;
  background-color: #28a745;
}
a.badge-success:hover, a.badge-success:focus {
  color: #fff;
  background-color: rgb(30.1449275362, 125.8550724638, 52);
}
a.badge-success:focus, a.badge-success.focus {
  outline: 0;
  box-shadow: 0 0 0 0.2rem rgba(40, 167, 69, 0.5);
}

.badge-info {
  color: #fff;
  background-color: #17a2b8;
}
a.badge-info:hover, a.badge-info:focus {
  color: #fff;
  background-color: rgb(17.3333333333, 122.0869565217, 138.6666666667);
}
a.badge-info:focus, a.badge-info.focus {
  outline: 0;
  box-shadow: 0 0 0 0.2rem rgba(23, 162, 184, 0.5);
}

.badge-warning {
  color: #212529;
  background-color: #ffc107;
}
a.badge-warning:hover, a.badge-warning:focus {
  color: #212529;
  background-color: rgb(211, 158.25, 0);
}
a.badge-warning:focus, a.badge-warning.focus {
  outline: 0;
  box-shadow: 0 0 0 0.2rem rgba(255, 193, 7, 0.5);
}

.badge-danger {
  color: #fff;
  background-color: #dc3545;
}
a.badge-danger:hover, a.badge-danger:focus {
  color: #fff;
  background-color: rgb(189.2151898734, 32.7848101266, 47.7721518987);
}
a.badge-danger:focus, a.badge-danger.focus {
  outline: 0;
  box-shadow: 0 0 0 0.2rem rgba(220, 53, 69, 0.5);
}

.badge-light {
  color: #212529;
  background-color: #f8f9fa;
}
a.badge-light:hover, a.badge-light:focus {
  color: #212529;
  background-color: rgb(218.25, 223.5, 228.75);
}
a.badge-light:focus, a.badge-light.focus {
  outline: 0;
  box-shadow: 0 0 0 0.2rem rgba(248, 249, 250, 0.5);
}

.badge-dark {
  color: #fff;
  background-color: #343a40;
}
a.badge-dark:hover, a.badge-dark:focus {
  color: #fff;
  background-color: rgb(29.1379310345, 32.5, 35.8620689655);
}
a.badge-dark:focus, a.badge-dark.focus {
  outline: 0;
  box-shadow: 0 0 0 0.2rem rgba(52, 58, 64, 0.5);
}

.jumbotron {
  padding: 2rem 1rem;
  margin-bottom: 2rem;
  background-color: #e9ecef;
  border-radius: 0.3rem;
}
@media (min-width: 576px) {
  .jumbotron {
    padding: 4rem 2rem;
  }
}

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

.alert {
  position: relative;
  padding: 0.75rem 1.25rem;
  margin-bottom: 1rem;
  border: 1px solid transparent;
  border-radius: 0.25rem;
}

.alert-heading {
  color: inherit;
}

.alert-link {
  font-weight: 700;
}

.alert-dismissible {
  padding-right: 4rem;
}
.alert-dismissible .close {
  position: absolute;
  top: 0;
  right: 0;
  padding: 0.75rem 1.25rem;
  color: inherit;
}

.alert-primary {
  color: rgb(0, 63.96, 132.6);
  background-color: rgb(204, 228.6, 255);
  border-color: rgb(183.6, 218.04, 255);
}
.alert-primary hr {
  border-top-color: rgb(158.1, 204.84, 255);
}
.alert-primary .alert-link {
  color: rgb(0, 39.36, 81.6);
}

.alert-secondary {
  color: rgb(56.16, 60.84, 65);
  background-color: rgb(225.6, 227.4, 229);
  border-color: rgb(213.84, 216.36, 218.6);
}
.alert-secondary hr {
  border-top-color: rgb(200.3075090253, 203.6560288809, 206.6324909747);
}
.alert-secondary .alert-link {
  color: rgb(32.5205150215, 35.2305579399, 37.6394849785);
}

.alert-success {
  color: rgb(20.8, 86.84, 35.88);
  background-color: rgb(212, 237.4, 217.8);
  border-color: rgb(194.8, 230.36, 202.92);
}
.alert-success hr {
  border-top-color: rgb(176.7059405941, 222.9540594059, 187.2665346535);
}
.alert-success .alert-link {
  color: rgb(10.9449275362, 45.6950724638, 18.88);
}

.alert-info {
  color: rgb(11.96, 84.24, 95.68);
  background-color: rgb(208.6, 236.4, 240.8);
  border-color: rgb(190.04, 228.96, 235.12);
}
.alert-info hr {
  border-top-color: rgb(170.5152475248, 221.1332673267, 229.1447524752);
}
.alert-info .alert-link {
  color: rgb(6.2933333333, 44.3269565217, 50.3466666667);
}

.alert-warning {
  color: rgb(132.6, 100.36, 3.64);
  background-color: rgb(255, 242.6, 205.4);
  border-color: rgb(255, 237.64, 185.56);
}
.alert-warning hr {
  border-top-color: rgb(255, 231.265, 160.06);
}
.alert-warning .alert-link {
  color: rgb(82.9625954198, 62.7912977099, 2.2774045802);
}

.alert-danger {
  color: rgb(114.4, 27.56, 35.88);
  background-color: rgb(248, 214.6, 217.8);
  border-color: rgb(245.2, 198.44, 202.92);
}
.alert-danger hr {
  border-top-color: rgb(241.4341772152, 176.7058227848, 182.9073417722);
}
.alert-danger .alert-link {
  color: rgb(73.3010989011, 17.6589010989, 22.9898901099);
}

.alert-light {
  color: rgb(128.96, 129.48, 130);
  background-color: rgb(253.6, 253.8, 254);
  border-color: rgb(253.04, 253.32, 253.6);
}
.alert-light hr {
  border-top-color: rgb(238.165, 240.57, 242.975);
}
.alert-light .alert-link {
  color: rgb(103.5492351816, 103.98, 104.4107648184);
}

.alert-dark {
  color: rgb(27.04, 30.16, 33.28);
  background-color: rgb(214.4, 215.6, 216.8);
  border-color: rgb(198.16, 199.84, 201.52);
}
.alert-dark hr {
  border-top-color: rgb(185.0216751269, 187.09, 189.1583248731);
}
.alert-dark .alert-link {
  color: rgb(4.1779310345, 4.66, 5.1420689655);
}

@keyframes progress-bar-stripes {
  from {
    background-position: 1rem 0;
  }
  to {
    background-position: 0 0;
  }
}
.progress {
  display: flex;
  height: 1rem;
  overflow: hidden;
  font-size: 0.75rem;
  background-color: #e9ecef;
  border-radius: 0.25rem;
}

.progress-bar {
  display: flex;
  flex-direction: column;
  justify-content: center;
  color: #fff;
  text-align: center;
  white-space: nowrap;
  background-color: #007bff;
  transition: width 0.6s ease;
}
@media (prefers-reduced-motion: reduce) {
  .progress-bar {
    transition: none;
  }
}

.progress-bar-striped {
  background-image: linear-gradient(45deg, rgba(255, 255, 255, 0.15) 25%, transparent 25%, transparent 50%, rgba(255, 255, 255, 0.15) 50%, rgba(255, 255, 255, 0.15) 75%, transparent 75%, transparent);
  background-size: 1rem 1rem;
}

.progress-bar-animated {
  animation: progress-bar-stripes 1s linear infinite;
}
@media (prefers-reduced-motion: reduce) {
  .progress-bar-animated {
    animation: none;
  }
}

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

.media-body {
  flex: 1;
}

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

.list-group-item-action {
  width: 100%;
  color: #495057;
  text-align: inherit;
}
.list-group-item-action:hover, .list-group-item-action:focus {
  z-index: 1;
  color: #495057;
  text-decoration: none;
  background-color: #f8f9fa;
}
.list-group-item-action:active {
  color: #212529;
  background-color: #e9ecef;
}

.list-group-item {
  position: relative;
  display: block;
  padding: 0.75rem 1.25rem;
  margin-bottom: -1px;
  background-color: #fff;
  border: 1px solid rgba(0, 0, 0, 0.125);
}
.list-group-item:first-child {
  border-top-left-radius: 0.25rem;
  border-top-right-radius: 0.25rem;
}
.list-group-item:last-child {
  margin-bottom: 0;
  border-bottom-right-radius: 0.25rem;
  border-bottom-left-radius: 0.25rem;
}
.list-group-item.disabled, .list-group-item:disabled {
  color: #6c757d;
  pointer-events: none;
  background-color: #fff;
}
.list-group-item.active {
  z-index: 2;
  color: #fff;
  background-color: #007bff;
  border-color: #007bff;
}

.list-group-horizontal {
  flex-direction: row;
}
.list-group-horizontal .list-group-item {
  margin-right: -1px;
  margin-bottom: 0;
}
.list-group-horizontal .list-group-item:first-child {
  border-top-left-radius: 0.25rem;
  border-bottom-left-radius: 0.25rem;
  border-top-right-radius: 0;
}
.list-group-horizontal .list-group-item:last-child {
  margin-right: 0;
  border-top-right-radius: 0.25rem;
  border-bottom-right-radius: 0.25rem;
  border-bottom-left-radius: 0;
}

@media (min-width: 576px) {
  .list-group-horizontal-sm {
    flex-direction: row;
  }
  .list-group-horizontal-sm .list-group-item {
    margin-right: -1px;
    margin-bottom: 0;
  }
  .list-group-horizontal-sm .list-group-item:first-child {
    border-top-left-radius: 0.25rem;
    border-bottom-left-radius: 0.25rem;
    border-top-right-radius: 0;
  }
  .list-group-horizontal-sm .list-group-item:last-child {
    margin-right: 0;
    border-top-right-radius: 0.25rem;
    border-bottom-right-radius: 0.25rem;
    border-bottom-left-radius: 0;
  }
}
@media (min-width: 768px) {
  .list-group-horizontal-md {
    flex-direction: row;
  }
  .list-group-horizontal-md .list-group-item {
    margin-right: -1px;
    margin-bottom: 0;
  }
  .list-group-horizontal-md .list-group-item:first-child {
    border-top-left-radius: 0.25rem;
    border-bottom-left-radius: 0.25rem;
    border-top-right-radius: 0;
  }
  .list-group-horizontal-md .list-group-item:last-child {
    margin-right: 0;
    border-top-right-radius: 0.25rem;
    border-bottom-right-radius: 0.25rem;
    border-bottom-left-radius: 0;
  }
}
@media (min-width: 992px) {
  .list-group-horizontal-lg {
    flex-direction: row;
  }
  .list-group-horizontal-lg .list-group-item {
    margin-right: -1px;
    margin-bottom: 0;
  }
  .list-group-horizontal-lg .list-group-item:first-child {
    border-top-left-radius: 0.25rem;
    border-bottom-left-radius: 0.25rem;
    border-top-right-radius: 0;
  }
  .list-group-horizontal-lg .list-group-item:last-child {
    margin-right: 0;
    border-top-right-radius: 0.25rem;
    border-bottom-right-radius: 0.25rem;
    border-bottom-left-radius: 0;
  }
}
@media (min-width: 1200px) {
  .list-group-horizontal-xl {
    flex-direction: row;
  }
  .list-group-horizontal-xl .list-group-item {
    margin-right: -1px;
    margin-bottom: 0;
  }
  .list-group-horizontal-xl .list-group-item:first-child {
    border-top-left-radius: 0.25rem;
    border-bottom-left-radius: 0.25rem;
    border-top-right-radius: 0;
  }
  .list-group-horizontal-xl .list-group-item:last-child {
    margin-right: 0;
    border-top-right-radius: 0.25rem;
    border-bottom-right-radius: 0.25rem;
    border-bottom-left-radius: 0;
  }
}
.list-group-flush .list-group-item {
  border-right: 0;
  border-left: 0;
  border-radius: 0;
}
.list-group-flush .list-group-item:last-child {
  margin-bottom: -1px;
}
.list-group-flush:first-child .list-group-item:first-child {
  border-top: 0;
}
.list-group-flush:last-child .list-group-item:last-child {
  margin-bottom: 0;
  border-bottom: 0;
}

.list-group-item-primary {
  color: rgb(0, 63.96, 132.6);
  background-color: rgb(183.6, 218.04, 255);
}
.list-group-item-primary.list-group-item-action:hover, .list-group-item-primary.list-group-item-action:focus {
  color: rgb(0, 63.96, 132.6);
  background-color: rgb(158.1, 204.84, 255);
}
.list-group-item-primary.list-group-item-action.active {
  color: #fff;
  background-color: rgb(0, 63.96, 132.6);
  border-color: rgb(0, 63.96, 132.6);
}

.list-group-item-secondary {
  color: rgb(56.16, 60.84, 65);
  background-color: rgb(213.84, 216.36, 218.6);
}
.list-group-item-secondary.list-group-item-action:hover, .list-group-item-secondary.list-group-item-action:focus {
  color: rgb(56.16, 60.84, 65);
  background-color: rgb(200.3075090253, 203.6560288809, 206.6324909747);
}
.list-group-item-secondary.list-group-item-action.active {
  color: #fff;
  background-color: rgb(56.16, 60.84, 65);
  border-color: rgb(56.16, 60.84, 65);
}

.list-group-item-success {
  color: rgb(20.8, 86.84, 35.88);
  background-color: rgb(194.8, 230.36, 202.92);
}
.list-group-item-success.list-group-item-action:hover, .list-group-item-success.list-group-item-action:focus {
  color: rgb(20.8, 86.84, 35.88);
  background-color: rgb(176.7059405941, 222.9540594059, 187.2665346535);
}
.list-group-item-success.list-group-item-action.active {
  color: #fff;
  background-color: rgb(20.8, 86.84, 35.88);
  border-color: rgb(20.8, 86.84, 35.88);
}

.list-group-item-info {
  color: rgb(11.96, 84.24, 95.68);
  background-color: rgb(190.04, 228.96, 235.12);
}
.list-group-item-info.list-group-item-action:hover, .list-group-item-info.list-group-item-action:focus {
  color: rgb(11.96, 84.24, 95.68);
  background-color: rgb(170.5152475248, 221.1332673267, 229.1447524752);
}
.list-group-item-info.list-group-item-action.active {
  color: #fff;
  background-color: rgb(11.96, 84.24, 95.68);
  border-color: rgb(11.96, 84.24, 95.68);
}

.list-group-item-warning {
  color: rgb(132.6, 100.36, 3.64);
  background-color: rgb(255, 237.64, 185.56);
}
.list-group-item-warning.list-group-item-action:hover, .list-group-item-warning.list-group-item-action:focus {
  color: rgb(132.6, 100.36, 3.64);
  background-color: rgb(255, 231.265, 160.06);
}
.list-group-item-warning.list-group-item-action.active {
  color: #fff;
  background-color: rgb(132.6, 100.36, 3.64);
  border-color: rgb(132.6, 100.36, 3.64);
}

.list-group-item-danger {
  color: rgb(114.4, 27.56, 35.88);
  background-color: rgb(245.2, 198.44, 202.92);
}
.list-group-item-danger.list-group-item-action:hover, .list-group-item-danger.list-group-item-action:focus {
  color: rgb(114.4, 27.56, 35.88);
  background-color: rgb(241.4341772152, 176.7058227848, 182.9073417722);
}
.list-group-item-danger.list-group-item-action.active {
  color: #fff;
  background-color: rgb(114.4, 27.56, 35.88);
  border-color: rgb(114.4, 27.56, 35.88);
}

.list-group-item-light {
  color: rgb(128.96, 129.48, 130);
  background-color: rgb(253.04, 253.32, 253.6);
}
.list-group-item-light.list-group-item-action:hover, .list-group-item-light.list-group-item-action:focus {
  color: rgb(128.96, 129.48, 130);
  background-color: rgb(238.165, 240.57, 242.975);
}
.list-group-item-light.list-group-item-action.active {
  color: #fff;
  background-color: rgb(128.96, 129.48, 130);
  border-color: rgb(128.96, 129.48, 130);
}

.list-group-item-dark {
  color: rgb(27.04, 30.16, 33.28);
  background-color: rgb(198.16, 199.84, 201.52);
}
.list-group-item-dark.list-group-item-action:hover, .list-group-item-dark.list-group-item-action:focus {
  color: rgb(27.04, 30.16, 33.28);
  background-color: rgb(185.0216751269, 187.09, 189.1583248731);
}
.list-group-item-dark.list-group-item-action.active {
  color: #fff;
  background-color: rgb(27.04, 30.16, 33.28);
  border-color: rgb(27.04, 30.16, 33.28);
}

.close {
  float: right;
  font-size: 1.5rem;
  font-weight: 700;
  line-height: 1;
  color: #000;
  text-shadow: 0 1px 0 #fff;
  opacity: 0.5;
}
.close:hover {
  color: #000;
  text-decoration: none;
}
.close:not(:disabled):not(.disabled):hover, .close:not(:disabled):not(.disabled):focus {
  opacity: 0.75;
}

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

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

.toast {
  max-width: 350px;
  overflow: hidden;
  font-size: 0.875rem;
  background-color: rgba(255, 255, 255, 0.85);
  background-clip: padding-box;
  border: 1px solid rgba(0, 0, 0, 0.1);
  box-shadow: 0 0.25rem 0.75rem rgba(0, 0, 0, 0.1);
  backdrop-filter: blur(10px);
  opacity: 0;
  border-radius: 0.25rem;
}
.toast:not(:last-child) {
  margin-bottom: 0.75rem;
}
.toast.showing {
  opacity: 1;
}
.toast.show {
  display: block;
  opacity: 1;
}
.toast.hide {
  display: none;
}

.toast-header {
  display: flex;
  align-items: center;
  padding: 0.25rem 0.75rem;
  color: #6c757d;
  background-color: rgba(255, 255, 255, 0.85);
  background-clip: padding-box;
  border-bottom: 1px solid rgba(0, 0, 0, 0.05);
}

.toast-body {
  padding: 0.75rem;
}

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

.modal {
  position: fixed;
  top: 0;
  left: 0;
  z-index: 1050;
  display: none;
  width: 100%;
  height: 100%;
  overflow: hidden;
  outline: 0;
}

.modal-dialog {
  position: relative;
  width: auto;
  margin: 0.5rem;
  pointer-events: none;
}
.modal.fade .modal-dialog {
  transition: transform 0.3s ease-out;
}
@media (prefers-reduced-motion: reduce) {
  .modal.fade .modal-dialog {
    transition: none;
  }
}
.modal.fade .modal-dialog {
  transform: translate(0, -50px);
}
.modal.show .modal-dialog {
  transform: none;
}

.modal-dialog-scrollable {
  display: flex;
  max-height: calc(100% - 1rem);
}
.modal-dialog-scrollable .modal-content {
  max-height: calc(100vh - 1rem);
  overflow: hidden;
}
.modal-dialog-scrollable .modal-header,
.modal-dialog-scrollable .modal-footer {
  flex-shrink: 0;
}
.modal-dialog-scrollable .modal-body {
  overflow-y: auto;
}

.modal-dialog-centered {
  display: flex;
  align-items: center;
  min-height: calc(100% - 1rem);
}
.modal-dialog-centered::before {
  display: block;
  height: calc(100vh - 1rem);
  content: "";
}
.modal-dialog-centered.modal-dialog-scrollable {
  flex-direction: column;
  justify-content: center;
  height: 100%;
}
.modal-dialog-centered.modal-dialog-scrollable .modal-content {
  max-height: none;
}
.modal-dialog-centered.modal-dialog-scrollable::before {
  content: none;
}

.modal-content {
  position: relative;
  display: flex;
  flex-direction: column;
  width: 100%;
  pointer-events: auto;
  background-color: #fff;
  background-clip: padding-box;
  border: 1px solid rgba(0, 0, 0, 0.2);
  border-radius: 0.3rem;
  outline: 0;
}

.modal-backdrop {
  position: fixed;
  top: 0;
  left: 0;
  z-index: 1040;
  width: 100vw;
  height: 100vh;
  background-color: #000;
}
.modal-backdrop.fade {
  opacity: 0;
}
.modal-backdrop.show {
  opacity: 0.5;
}

.modal-header {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  padding: 1rem 1rem;
  border-bottom: 1px solid #dee2e6;
  border-top-left-radius: 0.3rem;
  border-top-right-radius: 0.3rem;
}
.modal-header .close {
  padding: 1rem 1rem;
  margin: -1rem -1rem -1rem auto;
}

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

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

.modal-footer {
  display: flex;
  align-items: center;
  justify-content: flex-end;
  padding: 1rem;
  border-top: 1px solid #dee2e6;
  border-bottom-right-radius: 0.3rem;
  border-bottom-left-radius: 0.3rem;
}
.modal-footer > :not(:first-child) {
  margin-left: 0.25rem;
}
.modal-footer > :not(:last-child) {
  margin-right: 0.25rem;
}

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

@media (min-width: 576px) {
  .modal-dialog {
    max-width: 500px;
    margin: 1.75rem auto;
  }
  .modal-dialog-scrollable {
    max-height: calc(100% - 3.5rem);
  }
  .modal-dialog-scrollable .modal-content {
    max-height: calc(100vh - 3.5rem);
  }
  .modal-dialog-centered {
    min-height: calc(100% - 3.5rem);
  }
  .modal-dialog-centered::before {
    height: calc(100vh - 3.5rem);
  }
  .modal-sm {
    max-width: 300px;
  }
}
@media (min-width: 992px) {
  .modal-lg,
  .modal-xl {
    max-width: 800px;
  }
}
@media (min-width: 1200px) {
  .modal-xl {
    max-width: 1140px;
  }
}
.tooltip {
  position: absolute;
  z-index: 1070;
  display: block;
  margin: 0;
  font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "Helvetica Neue", Arial, "Noto Sans", sans-serif, "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol", "Noto Color Emoji";
  font-style: normal;
  font-weight: 400;
  line-height: 1.5;
  text-align: left;
  text-align: start;
  text-decoration: none;
  text-shadow: none;
  text-transform: none;
  letter-spacing: normal;
  word-break: normal;
  word-spacing: normal;
  white-space: normal;
  line-break: auto;
  font-size: 0.875rem;
  word-wrap: break-word;
  opacity: 0;
}
.tooltip.show {
  opacity: 0.9;
}
.tooltip .arrow {
  position: absolute;
  display: block;
  width: 0.8rem;
  height: 0.4rem;
}
.tooltip .arrow::before {
  position: absolute;
  content: "";
  border-color: transparent;
  border-style: solid;
}

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

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

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

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

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

.popover {
  position: absolute;
  top: 0;
  left: 0;
  z-index: 1060;
  display: block;
  max-width: 276px;
  font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "Helvetica Neue", Arial, "Noto Sans", sans-serif, "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol", "Noto Color Emoji";
  font-style: normal;
  font-weight: 400;
  line-height: 1.5;
  text-align: left;
  text-align: start;
  text-decoration: none;
  text-shadow: none;
  text-transform: none;
  letter-spacing: normal;
  word-break: normal;
  word-spacing: normal;
  white-space: normal;
  line-break: auto;
  font-size: 0.875rem;
  word-wrap: break-word;
  background-color: #fff;
  background-clip: padding-box;
  border: 1px solid rgba(0, 0, 0, 0.2);
  border-radius: 0.3rem;
}
.popover .arrow {
  position: absolute;
  display: block;
  width: 1rem;
  height: 0.5rem;
  margin: 0 0.3rem;
}
.popover .arrow::before, .popover .arrow::after {
  position: absolute;
  display: block;
  content: "";
  border-color: transparent;
  border-style: solid;
}

.bs-popover-top, .bs-popover-auto[x-placement^=top] {
  margin-bottom: 0.5rem;
}
.bs-popover-top > .arrow, .bs-popover-auto[x-placement^=top] > .arrow {
  bottom: calc((0.5rem + 1px) * -1);
}
.bs-popover-top > .arrow::before, .bs-popover-auto[x-placement^=top] > .arrow::before {
  bottom: 0;
  border-width: 0.5rem 0.5rem 0;
  border-top-color: rgba(0, 0, 0, 0.25);
}
.bs-popover-top > .arrow::after, .bs-popover-auto[x-placement^=top] > .arrow::after {
  bottom: 1px;
  border-width: 0.5rem 0.5rem 0;
  border-top-color: #fff;
}

.bs-popover-right, .bs-popover-auto[x-placement^=right] {
  margin-left: 0.5rem;
}
.bs-popover-right > .arrow, .bs-popover-auto[x-placement^=right] > .arrow {
  left: calc((0.5rem + 1px) * -1);
  width: 0.5rem;
  height: 1rem;
  margin: 0.3rem 0;
}
.bs-popover-right > .arrow::before, .bs-popover-auto[x-placement^=right] > .arrow::before {
  left: 0;
  border-width: 0.5rem 0.5rem 0.5rem 0;
  border-right-color: rgba(0, 0, 0, 0.25);
}
.bs-popover-right > .arrow::after, .bs-popover-auto[x-placement^=right] > .arrow::after {
  left: 1px;
  border-width: 0.5rem 0.5rem 0.5rem 0;
  border-right-color: #fff;
}

.bs-popover-bottom, .bs-popover-auto[x-placement^=bottom] {
  margin-top: 0.5rem;
}
.bs-popover-bottom > .arrow, .bs-popover-auto[x-placement^=bottom] > .arrow {
  top: calc((0.5rem + 1px) * -1);
}
.bs-popover-bottom > .arrow::before, .bs-popover-auto[x-placement^=bottom] > .arrow::before {
  top: 0;
  border-width: 0 0.5rem 0.5rem 0.5rem;
  border-bottom-color: rgba(0, 0, 0, 0.25);
}
.bs-popover-bottom > .arrow::after, .bs-popover-auto[x-placement^=bottom] > .arrow::after {
  top: 1px;
  border-width: 0 0.5rem 0.5rem 0.5rem;
  border-bottom-color: #fff;
}
.bs-popover-bottom .popover-header::before, .bs-popover-auto[x-placement^=bottom] .popover-header::before {
  position: absolute;
  top: 0;
  left: 50%;
  display: block;
  width: 1rem;
  margin-left: -0.5rem;
  content: "";
  border-bottom: 1px solid rgb(247.35, 247.35, 247.35);
}

.bs-popover-left, .bs-popover-auto[x-placement^=left] {
  margin-right: 0.5rem;
}
.bs-popover-left > .arrow, .bs-popover-auto[x-placement^=left] > .arrow {
  right: calc((0.5rem + 1px) * -1);
  width: 0.5rem;
  height: 1rem;
  margin: 0.3rem 0;
}
.bs-popover-left > .arrow::before, .bs-popover-auto[x-placement^=left] > .arrow::before {
  right: 0;
  border-width: 0.5rem 0 0.5rem 0.5rem;
  border-left-color: rgba(0, 0, 0, 0.25);
}
.bs-popover-left > .arrow::after, .bs-popover-auto[x-placement^=left] > .arrow::after {
  right: 1px;
  border-width: 0.5rem 0 0.5rem 0.5rem;
  border-left-color: #fff;
}

.popover-header {
  padding: 0.5rem 0.75rem;
  margin-bottom: 0;
  font-size: 1rem;
  background-color: rgb(247.35, 247.35, 247.35);
  border-bottom: 1px solid rgb(234.6, 234.6, 234.6);
  border-top-left-radius: calc(0.3rem - 1px);
  border-top-right-radius: calc(0.3rem - 1px);
}
.popover-header:empty {
  display: none;
}

.popover-body {
  padding: 0.5rem 0.75rem;
  color: #212529;
}

.carousel {
  position: relative;
}

.carousel.pointer-event {
  touch-action: pan-y;
}

.carousel-inner {
  position: relative;
  width: 100%;
  overflow: hidden;
}
.carousel-inner::after {
  display: block;
  clear: both;
  content: "";
}

.carousel-item {
  position: relative;
  display: none;
  float: left;
  width: 100%;
  margin-right: -100%;
  backface-visibility: hidden;
  transition: transform 0.6s ease-in-out;
}
@media (prefers-reduced-motion: reduce) {
  .carousel-item {
    transition: none;
  }
}

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

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

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

.carousel-fade .carousel-item {
  opacity: 0;
  transition-property: opacity;
  transform: none;
}
.carousel-fade .carousel-item.active,
.carousel-fade .carousel-item-next.carousel-item-left,
.carousel-fade .carousel-item-prev.carousel-item-right {
  z-index: 1;
  opacity: 1;
}
.carousel-fade .active.carousel-item-left,
.carousel-fade .active.carousel-item-right {
  z-index: 0;
  opacity: 0;
  transition: 0s 0.6s opacity;
}
@media (prefers-reduced-motion: reduce) {
  .carousel-fade .active.carousel-item-left,
  .carousel-fade .active.carousel-item-right {
    transition: none;
  }
}

.carousel-control-prev,
.carousel-control-next {
  position: absolute;
  top: 0;
  bottom: 0;
  z-index: 1;
  display: flex;
  align-items: center;
  justify-content: center;
  width: 15%;
  color: #fff;
  text-align: center;
  opacity: 0.5;
  transition: opacity 0.15s ease;
}
@media (prefers-reduced-motion: reduce) {
  .carousel-control-prev,
  .carousel-control-next {
    transition: none;
  }
}
.carousel-control-prev:hover, .carousel-control-prev:focus,
.carousel-control-next:hover,
.carousel-control-next:focus {
  color: #fff;
  text-decoration: none;
  outline: 0;
  opacity: 0.9;
}

.carousel-control-prev {
  left: 0;
}

.carousel-control-next {
  right: 0;
}

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

.carousel-control-prev-icon {
  background-image: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' fill='%23fff' viewBox='0 0 8 8'%3e%3cpath d='M5.25 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,%3csvg xmlns='http://www.w3.org/2000/svg' fill='%23fff' viewBox='0 0 8 8'%3e%3cpath d='M2.75 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 {
  position: absolute;
  right: 0;
  bottom: 0;
  left: 0;
  z-index: 15;
  display: flex;
  justify-content: center;
  padding-left: 0;
  margin-right: 15%;
  margin-left: 15%;
  list-style: none;
}
.carousel-indicators li {
  box-sizing: content-box;
  flex: 0 1 auto;
  width: 30px;
  height: 3px;
  margin-right: 3px;
  margin-left: 3px;
  text-indent: -999px;
  cursor: pointer;
  background-color: #fff;
  background-clip: padding-box;
  border-top: 10px solid transparent;
  border-bottom: 10px solid transparent;
  opacity: 0.5;
  transition: opacity 0.6s ease;
}
@media (prefers-reduced-motion: reduce) {
  .carousel-indicators li {
    transition: none;
  }
}
.carousel-indicators .active {
  opacity: 1;
}

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

@keyframes spinner-border {
  to {
    transform: rotate(360deg);
  }
}
.spinner-border {
  display: inline-block;
  width: 2rem;
  height: 2rem;
  vertical-align: text-bottom;
  border: 0.25em solid currentColor;
  border-right-color: transparent;
  border-radius: 50%;
  animation: spinner-border 0.75s linear infinite;
}

.spinner-border-sm {
  width: 1rem;
  height: 1rem;
  border-width: 0.2em;
}

@keyframes spinner-grow {
  0% {
    transform: scale(0);
  }
  50% {
    opacity: 1;
  }
}
.spinner-grow {
  display: inline-block;
  width: 2rem;
  height: 2rem;
  vertical-align: text-bottom;
  background-color: currentColor;
  border-radius: 50%;
  opacity: 0;
  animation: spinner-grow 0.75s linear infinite;
}

.spinner-grow-sm {
  width: 1rem;
  height: 1rem;
}

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

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

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

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

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

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

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

a.bg-primary:hover, a.bg-primary:focus,
button.bg-primary:hover,
button.bg-primary:focus {
  background-color: rgb(0, 98.4, 204) !important;
}

.bg-secondary {
  background-color: #6c757d !important;
}

a.bg-secondary:hover, a.bg-secondary:focus,
button.bg-secondary:hover,
button.bg-secondary:focus {
  background-color: rgb(84.3605150215, 91.3905579399, 97.6394849785) !important;
}

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

a.bg-success:hover, a.bg-success:focus,
button.bg-success:hover,
button.bg-success:focus {
  background-color: rgb(30.1449275362, 125.8550724638, 52) !important;
}

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

a.bg-info:hover, a.bg-info:focus,
button.bg-info:hover,
button.bg-info:focus {
  background-color: rgb(17.3333333333, 122.0869565217, 138.6666666667) !important;
}

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

a.bg-warning:hover, a.bg-warning:focus,
button.bg-warning:hover,
button.bg-warning:focus {
  background-color: rgb(211, 158.25, 0) !important;
}

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

a.bg-danger:hover, a.bg-danger:focus,
button.bg-danger:hover,
button.bg-danger:focus {
  background-color: rgb(189.2151898734, 32.7848101266, 47.7721518987) !important;
}

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

a.bg-light:hover, a.bg-light:focus,
button.bg-light:hover,
button.bg-light:focus {
  background-color: rgb(218.25, 223.5, 228.75) !important;
}

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

a.bg-dark:hover, a.bg-dark:focus,
button.bg-dark:hover,
button.bg-dark:focus {
  background-color: rgb(29.1379310345, 32.5, 35.8620689655) !important;
}

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

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

.border {
  border: 1px solid #dee2e6 !important;
}

.border-top {
  border-top: 1px solid #dee2e6 !important;
}

.border-right {
  border-right: 1px solid #dee2e6 !important;
}

.border-bottom {
  border-bottom: 1px solid #dee2e6 !important;
}

.border-left {
  border-left: 1px solid #dee2e6 !important;
}

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

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

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

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

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

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

.border-secondary {
  border-color: #6c757d !important;
}

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

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

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

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

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

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

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

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

.rounded {
  border-radius: 0.25rem !important;
}

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

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

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

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

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

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

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

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

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

.d-none {
  display: none !important;
}

.d-inline {
  display: inline !important;
}

.d-inline-block {
  display: inline-block !important;
}

.d-block {
  display: block !important;
}

.d-table {
  display: table !important;
}

.d-table-row {
  display: table-row !important;
}

.d-table-cell {
  display: table-cell !important;
}

.d-flex {
  display: flex !important;
}

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

@media (min-width: 576px) {
  .d-sm-none {
    display: none !important;
  }
  .d-sm-inline {
    display: inline !important;
  }
  .d-sm-inline-block {
    display: inline-block !important;
  }
  .d-sm-block {
    display: block !important;
  }
  .d-sm-table {
    display: table !important;
  }
  .d-sm-table-row {
    display: table-row !important;
  }
  .d-sm-table-cell {
    display: table-cell !important;
  }
  .d-sm-flex {
    display: flex !important;
  }
  .d-sm-inline-flex {
    display: inline-flex !important;
  }
}
@media (min-width: 768px) {
  .d-md-none {
    display: none !important;
  }
  .d-md-inline {
    display: inline !important;
  }
  .d-md-inline-block {
    display: inline-block !important;
  }
  .d-md-block {
    display: block !important;
  }
  .d-md-table {
    display: table !important;
  }
  .d-md-table-row {
    display: table-row !important;
  }
  .d-md-table-cell {
    display: table-cell !important;
  }
  .d-md-flex {
    display: flex !important;
  }
  .d-md-inline-flex {
    display: inline-flex !important;
  }
}
@media (min-width: 992px) {
  .d-lg-none {
    display: none !important;
  }
  .d-lg-inline {
    display: inline !important;
  }
  .d-lg-inline-block {
    display: inline-block !important;
  }
  .d-lg-block {
    display: block !important;
  }
  .d-lg-table {
    display: table !important;
  }
  .d-lg-table-row {
    display: table-row !important;
  }
  .d-lg-table-cell {
    display: table-cell !important;
  }
  .d-lg-flex {
    display: flex !important;
  }
  .d-lg-inline-flex {
    display: inline-flex !important;
  }
}
@media (min-width: 1200px) {
  .d-xl-none {
    display: none !important;
  }
  .d-xl-inline {
    display: inline !important;
  }
  .d-xl-inline-block {
    display: inline-block !important;
  }
  .d-xl-block {
    display: block !important;
  }
  .d-xl-table {
    display: table !important;
  }
  .d-xl-table-row {
    display: table-row !important;
  }
  .d-xl-table-cell {
    display: table-cell !important;
  }
  .d-xl-flex {
    display: flex !important;
  }
  .d-xl-inline-flex {
    display: inline-flex !important;
  }
}
@media print {
  .d-print-none {
    display: none !important;
  }
  .d-print-inline {
    display: inline !important;
  }
  .d-print-inline-block {
    display: inline-block !important;
  }
  .d-print-block {
    display: block !important;
  }
  .d-print-table {
    display: table !important;
  }
  .d-print-table-row {
    display: table-row !important;
  }
  .d-print-table-cell {
    display: table-cell !important;
  }
  .d-print-flex {
    display: flex !important;
  }
  .d-print-inline-flex {
    display: inline-flex !important;
  }
}
.embed-responsive {
  position: relative;
  display: block;
  width: 100%;
  padding: 0;
  overflow: hidden;
}
.embed-responsive::before {
  display: block;
  content: "";
}
.embed-responsive .embed-responsive-item,
.embed-responsive iframe,
.embed-responsive embed,
.embed-responsive object,
.embed-responsive video {
  position: absolute;
  top: 0;
  bottom: 0;
  left: 0;
  width: 100%;
  height: 100%;
  border: 0;
}

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

.align-items-baseline {
  align-items: baseline !important;
}

.align-items-stretch {
  align-items: stretch !important;
}

.align-content-start {
  align-content: flex-start !important;
}

.align-content-end {
  align-content: flex-end !important;
}

.align-content-center {
  align-content: center !important;
}

.align-content-between {
  align-content: space-between !important;
}

.align-content-around {
  align-content: space-around !important;
}

.align-content-stretch {
  align-content: stretch !important;
}

.align-self-auto {
  align-self: auto !important;
}

.align-self-start {
  align-self: flex-start !important;
}

.align-self-end {
  align-self: flex-end !important;
}

.align-self-center {
  align-self: center !important;
}

.align-self-baseline {
  align-self: baseline !important;
}

.align-self-stretch {
  align-self: stretch !important;
}

@media (min-width: 576px) {
  .flex-sm-row {
    flex-direction: row !important;
  }
  .flex-sm-column {
    flex-direction: column !important;
  }
  .flex-sm-row-reverse {
    flex-direction: row-reverse !important;
  }
  .flex-sm-column-reverse {
    flex-direction: column-reverse !important;
  }
  .flex-sm-wrap {
    flex-wrap: wrap !important;
  }
  .flex-sm-nowrap {
    flex-wrap: nowrap !important;
  }
  .flex-sm-wrap-reverse {
    flex-wrap: wrap-reverse !important;
  }
  .flex-sm-fill {
    flex: 1 1 auto !important;
  }
  .flex-sm-grow-0 {
    flex-grow: 0 !important;
  }
  .flex-sm-grow-1 {
    flex-grow: 1 !important;
  }
  .flex-sm-shrink-0 {
    flex-shrink: 0 !important;
  }
  .flex-sm-shrink-1 {
    flex-shrink: 1 !important;
  }
  .justify-content-sm-start {
    justify-content: flex-start !important;
  }
  .justify-content-sm-end {
    justify-content: flex-end !important;
  }
  .justify-content-sm-center {
    justify-content: center !important;
  }
  .justify-content-sm-between {
    justify-content: space-between !important;
  }
  .justify-content-sm-around {
    justify-content: space-around !important;
  }
  .align-items-sm-start {
    align-items: flex-start !important;
  }
  .align-items-sm-end {
    align-items: flex-end !important;
  }
  .align-items-sm-center {
    align-items: center !important;
  }
  .align-items-sm-baseline {
    align-items: baseline !important;
  }
  .align-items-sm-stretch {
    align-items: stretch !important;
  }
  .align-content-sm-start {
    align-content: flex-start !important;
  }
  .align-content-sm-end {
    align-content: flex-end !important;
  }
  .align-content-sm-center {
    align-content: center !important;
  }
  .align-content-sm-between {
    align-content: space-between !important;
  }
  .align-content-sm-around {
    align-content: space-around !important;
  }
  .align-content-sm-stretch {
    align-content: stretch !important;
  }
  .align-self-sm-auto {
    align-self: auto !important;
  }
  .align-self-sm-start {
    align-self: flex-start !important;
  }
  .align-self-sm-end {
    align-self: flex-end !important;
  }
  .align-self-sm-center {
    align-self: center !important;
  }
  .align-self-sm-baseline {
    align-self: baseline !important;
  }
  .align-self-sm-stretch {
    align-self: stretch !important;
  }
}
@media (min-width: 768px) {
  .flex-md-row {
    flex-direction: row !important;
  }
  .flex-md-column {
    flex-direction: column !important;
  }
  .flex-md-row-reverse {
    flex-direction: row-reverse !important;
  }
  .flex-md-column-reverse {
    flex-direction: column-reverse !important;
  }
  .flex-md-wrap {
    flex-wrap: wrap !important;
  }
  .flex-md-nowrap {
    flex-wrap: nowrap !important;
  }
  .flex-md-wrap-reverse {
    flex-wrap: wrap-reverse !important;
  }
  .flex-md-fill {
    flex: 1 1 auto !important;
  }
  .flex-md-grow-0 {
    flex-grow: 0 !important;
  }
  .flex-md-grow-1 {
    flex-grow: 1 !important;
  }
  .flex-md-shrink-0 {
    flex-shrink: 0 !important;
  }
  .flex-md-shrink-1 {
    flex-shrink: 1 !important;
  }
  .justify-content-md-start {
    justify-content: flex-start !important;
  }
  .justify-content-md-end {
    justify-content: flex-end !important;
  }
  .justify-content-md-center {
    justify-content: center !important;
  }
  .justify-content-md-between {
    justify-content: space-between !important;
  }
  .justify-content-md-around {
    justify-content: space-around !important;
  }
  .align-items-md-start {
    align-items: flex-start !important;
  }
  .align-items-md-end {
    align-items: flex-end !important;
  }
  .align-items-md-center {
    align-items: center !important;
  }
  .align-items-md-baseline {
    align-items: baseline !important;
  }
  .align-items-md-stretch {
    align-items: stretch !important;
  }
  .align-content-md-start {
    align-content: flex-start !important;
  }
  .align-content-md-end {
    align-content: flex-end !important;
  }
  .align-content-md-center {
    align-content: center !important;
  }
  .align-content-md-between {
    align-content: space-between !important;
  }
  .align-content-md-around {
    align-content: space-around !important;
  }
  .align-content-md-stretch {
    align-content: stretch !important;
  }
  .align-self-md-auto {
    align-self: auto !important;
  }
  .align-self-md-start {
    align-self: flex-start !important;
  }
  .align-self-md-end {
    align-self: flex-end !important;
  }
  .align-self-md-center {
    align-self: center !important;
  }
  .align-self-md-baseline {
    align-self: baseline !important;
  }
  .align-self-md-stretch {
    align-self: stretch !important;
  }
}
@media (min-width: 992px) {
  .flex-lg-row {
    flex-direction: row !important;
  }
  .flex-lg-column {
    flex-direction: column !important;
  }
  .flex-lg-row-reverse {
    flex-direction: row-reverse !important;
  }
  .flex-lg-column-reverse {
    flex-direction: column-reverse !important;
  }
  .flex-lg-wrap {
    flex-wrap: wrap !important;
  }
  .flex-lg-nowrap {
    flex-wrap: nowrap !important;
  }
  .flex-lg-wrap-reverse {
    flex-wrap: wrap-reverse !important;
  }
  .flex-lg-fill {
    flex: 1 1 auto !important;
  }
  .flex-lg-grow-0 {
    flex-grow: 0 !important;
  }
  .flex-lg-grow-1 {
    flex-grow: 1 !important;
  }
  .flex-lg-shrink-0 {
    flex-shrink: 0 !important;
  }
  .flex-lg-shrink-1 {
    flex-shrink: 1 !important;
  }
  .justify-content-lg-start {
    justify-content: flex-start !important;
  }
  .justify-content-lg-end {
    justify-content: flex-end !important;
  }
  .justify-content-lg-center {
    justify-content: center !important;
  }
  .justify-content-lg-between {
    justify-content: space-between !important;
  }
  .justify-content-lg-around {
    justify-content: space-around !important;
  }
  .align-items-lg-start {
    align-items: flex-start !important;
  }
  .align-items-lg-end {
    align-items: flex-end !important;
  }
  .align-items-lg-center {
    align-items: center !important;
  }
  .align-items-lg-baseline {
    align-items: baseline !important;
  }
  .align-items-lg-stretch {
    align-items: stretch !important;
  }
  .align-content-lg-start {
    align-content: flex-start !important;
  }
  .align-content-lg-end {
    align-content: flex-end !important;
  }
  .align-content-lg-center {
    align-content: center !important;
  }
  .align-content-lg-between {
    align-content: space-between !important;
  }
  .align-content-lg-around {
    align-content: space-around !important;
  }
  .align-content-lg-stretch {
    align-content: stretch !important;
  }
  .align-self-lg-auto {
    align-self: auto !important;
  }
  .align-self-lg-start {
    align-self: flex-start !important;
  }
  .align-self-lg-end {
    align-self: flex-end !important;
  }
  .align-self-lg-center {
    align-self: center !important;
  }
  .align-self-lg-baseline {
    align-self: baseline !important;
  }
  .align-self-lg-stretch {
    align-self: stretch !important;
  }
}
@media (min-width: 1200px) {
  .flex-xl-row {
    flex-direction: row !important;
  }
  .flex-xl-column {
    flex-direction: column !important;
  }
  .flex-xl-row-reverse {
    flex-direction: row-reverse !important;
  }
  .flex-xl-column-reverse {
    flex-direction: column-reverse !important;
  }
  .flex-xl-wrap {
    flex-wrap: wrap !important;
  }
  .flex-xl-nowrap {
    flex-wrap: nowrap !important;
  }
  .flex-xl-wrap-reverse {
    flex-wrap: wrap-reverse !important;
  }
  .flex-xl-fill {
    flex: 1 1 auto !important;
  }
  .flex-xl-grow-0 {
    flex-grow: 0 !important;
  }
  .flex-xl-grow-1 {
    flex-grow: 1 !important;
  }
  .flex-xl-shrink-0 {
    flex-shrink: 0 !important;
  }
  .flex-xl-shrink-1 {
    flex-shrink: 1 !important;
  }
  .justify-content-xl-start {
    justify-content: flex-start !important;
  }
  .justify-content-xl-end {
    justify-content: flex-end !important;
  }
  .justify-content-xl-center {
    justify-content: center !important;
  }
  .justify-content-xl-between {
    justify-content: space-between !important;
  }
  .justify-content-xl-around {
    justify-content: space-around !important;
  }
  .align-items-xl-start {
    align-items: flex-start !important;
  }
  .align-items-xl-end {
    align-items: flex-end !important;
  }
  .align-items-xl-center {
    align-items: center !important;
  }
  .align-items-xl-baseline {
    align-items: baseline !important;
  }
  .align-items-xl-stretch {
    align-items: stretch !important;
  }
  .align-content-xl-start {
    align-content: flex-start !important;
  }
  .align-content-xl-end {
    align-content: flex-end !important;
  }
  .align-content-xl-center {
    align-content: center !important;
  }
  .align-content-xl-between {
    align-content: space-between !important;
  }
  .align-content-xl-around {
    align-content: space-around !important;
  }
  .align-content-xl-stretch {
    align-content: stretch !important;
  }
  .align-self-xl-auto {
    align-self: auto !important;
  }
  .align-self-xl-start {
    align-self: flex-start !important;
  }
  .align-self-xl-end {
    align-self: flex-end !important;
  }
  .align-self-xl-center {
    align-self: center !important;
  }
  .align-self-xl-baseline {
    align-self: baseline !important;
  }
  .align-self-xl-stretch {
    align-self: stretch !important;
  }
}
.float-left {
  float: left !important;
}

.float-right {
  float: right !important;
}

.float-none {
  float: none !important;
}

@media (min-width: 576px) {
  .float-sm-left {
    float: left !important;
  }
  .float-sm-right {
    float: right !important;
  }
  .float-sm-none {
    float: none !important;
  }
}
@media (min-width: 768px) {
  .float-md-left {
    float: left !important;
  }
  .float-md-right {
    float: right !important;
  }
  .float-md-none {
    float: none !important;
  }
}
@media (min-width: 992px) {
  .float-lg-left {
    float: left !important;
  }
  .float-lg-right {
    float: right !important;
  }
  .float-lg-none {
    float: none !important;
  }
}
@media (min-width: 1200px) {
  .float-xl-left {
    float: left !important;
  }
  .float-xl-right {
    float: right !important;
  }
  .float-xl-none {
    float: none !important;
  }
}
.overflow-auto {
  overflow: auto !important;
}

.overflow-hidden {
  overflow: hidden !important;
}

.position-static {
  position: static !important;
}

.position-relative {
  position: relative !important;
}

.position-absolute {
  position: absolute !important;
}

.position-fixed {
  position: fixed !important;
}

.position-sticky {
  position: sticky !important;
}

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

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

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

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

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

.shadow-sm {
  box-shadow: 0 0.125rem 0.25rem rgba(0, 0, 0, 0.075) !important;
}

.shadow {
  box-shadow: 0 0.5rem 1rem rgba(0, 0, 0, 0.15) !important;
}

.shadow-lg {
  box-shadow: 0 1rem 3rem rgba(0, 0, 0, 0.175) !important;
}

.shadow-none {
  box-shadow: none !important;
}

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

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

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

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

.w-auto {
  width: auto !important;
}

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

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

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

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

.h-auto {
  height: auto !important;
}

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

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

.min-vw-100 {
  min-width: 100vw !important;
}

.min-vh-100 {
  min-height: 100vh !important;
}

.vw-100 {
  width: 100vw !important;
}

.vh-100 {
  height: 100vh !important;
}

.stretched-link::after {
  position: absolute;
  top: 0;
  right: 0;
  bottom: 0;
  left: 0;
  z-index: 1;
  pointer-events: auto;
  content: "";
  background-color: rgba(0, 0, 0, 0);
}

.m-0 {
  margin: 0 !important;
}

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

.mr-0,
.mx-0 {
  margin-right: 0 !important;
}

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

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

.m-1 {
  margin: 0.25rem !important;
}

.mt-1,
.my-1 {
  margin-top: 0.25rem !important;
}

.mr-1,
.mx-1 {
  margin-right: 0.25rem !important;
}

.mb-1,
.my-1 {
  margin-bottom: 0.25rem !important;
}

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

.m-2 {
  margin: 0.5rem !important;
}

.mt-2,
.my-2 {
  margin-top: 0.5rem !important;
}

.mr-2,
.mx-2 {
  margin-right: 0.5rem !important;
}

.mb-2,
.my-2 {
  margin-bottom: 0.5rem !important;
}

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

.p-0 {
  padding: 0 !important;
}

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

.pr-0,
.px-0 {
  padding-right: 0 !important;
}

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

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

.p-1 {
  padding: 0.25rem !important;
}

.pt-1,
.py-1 {
  padding-top: 0.25rem !important;
}

.pr-1,
.px-1 {
  padding-right: 0.25rem !important;
}

.pb-1,
.py-1 {
  padding-bottom: 0.25rem !important;
}

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

.p-2 {
  padding: 0.5rem !important;
}

.pt-2,
.py-2 {
  padding-top: 0.5rem !important;
}

.pr-2,
.px-2 {
  padding-right: 0.5rem !important;
}

.pb-2,
.py-2 {
  padding-bottom: 0.5rem !important;
}

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

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

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

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

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

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

.p-4 {
  padding: 1.5rem !important;
}

.pt-4,
.py-4 {
  padding-top: 1.5rem !important;
}

.pr-4,
.px-4 {
  padding-right: 1.5rem !important;
}

.pb-4,
.py-4 {
  padding-bottom: 1.5rem !important;
}

.pl-4,
.px-4 {
  padding-left: 1.5rem !important;
}

.p-5 {
  padding: 3rem !important;
}

.pt-5,
.py-5 {
  padding-top: 3rem !important;
}

.pr-5,
.px-5 {
  padding-right: 3rem !important;
}

.pb-5,
.py-5 {
  padding-bottom: 3rem !important;
}

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

.m-n1 {
  margin: -0.25rem !important;
}

.mt-n1,
.my-n1 {
  margin-top: -0.25rem !important;
}

.mr-n1,
.mx-n1 {
  margin-right: -0.25rem !important;
}

.mb-n1,
.my-n1 {
  margin-bottom: -0.25rem !important;
}

.ml-n1,
.mx-n1 {
  margin-left: -0.25rem !important;
}

.m-n2 {
  margin: -0.5rem !important;
}

.mt-n2,
.my-n2 {
  margin-top: -0.5rem !important;
}

.mr-n2,
.mx-n2 {
  margin-right: -0.5rem !important;
}

.mb-n2,
.my-n2 {
  margin-bottom: -0.5rem !important;
}

.ml-n2,
.mx-n2 {
  margin-left: -0.5rem !important;
}

.m-n3 {
  margin: -1rem !important;
}

.mt-n3,
.my-n3 {
  margin-top: -1rem !important;
}

.mr-n3,
.mx-n3 {
  margin-right: -1rem !important;
}

.mb-n3,
.my-n3 {
  margin-bottom: -1rem !important;
}

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

.m-n4 {
  margin: -1.5rem !important;
}

.mt-n4,
.my-n4 {
  margin-top: -1.5rem !important;
}

.mr-n4,
.mx-n4 {
  margin-right: -1.5rem !important;
}

.mb-n4,
.my-n4 {
  margin-bottom: -1.5rem !important;
}

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

.m-n5 {
  margin: -3rem !important;
}

.mt-n5,
.my-n5 {
  margin-top: -3rem !important;
}

.mr-n5,
.mx-n5 {
  margin-right: -3rem !important;
}

.mb-n5,
.my-n5 {
  margin-bottom: -3rem !important;
}

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

.m-auto {
  margin: auto !important;
}

.mt-auto,
.my-auto {
  margin-top: auto !important;
}

.mr-auto,
.mx-auto {
  margin-right: auto !important;
}

.mb-auto,
.my-auto {
  margin-bottom: auto !important;
}

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

@media (min-width: 576px) {
  .m-sm-0 {
    margin: 0 !important;
  }
  .mt-sm-0,
  .my-sm-0 {
    margin-top: 0 !important;
  }
  .mr-sm-0,
  .mx-sm-0 {
    margin-right: 0 !important;
  }
  .mb-sm-0,
  .my-sm-0 {
    margin-bottom: 0 !important;
  }
  .ml-sm-0,
  .mx-sm-0 {
    margin-left: 0 !important;
  }
  .m-sm-1 {
    margin: 0.25rem !important;
  }
  .mt-sm-1,
  .my-sm-1 {
    margin-top: 0.25rem !important;
  }
  .mr-sm-1,
  .mx-sm-1 {
    margin-right: 0.25rem !important;
  }
  .mb-sm-1,
  .my-sm-1 {
    margin-bottom: 0.25rem !important;
  }
  .ml-sm-1,
  .mx-sm-1 {
    margin-left: 0.25rem !important;
  }
  .m-sm-2 {
    margin: 0.5rem !important;
  }
  .mt-sm-2,
  .my-sm-2 {
    margin-top: 0.5rem !important;
  }
  .mr-sm-2,
  .mx-sm-2 {
    margin-right: 0.5rem !important;
  }
  .mb-sm-2,
  .my-sm-2 {
    margin-bottom: 0.5rem !important;
  }
  .ml-sm-2,
  .mx-sm-2 {
    margin-left: 0.5rem !important;
  }
  .m-sm-3 {
    margin: 1rem !important;
  }
  .mt-sm-3,
  .my-sm-3 {
    margin-top: 1rem !important;
  }
  .mr-sm-3,
  .mx-sm-3 {
    margin-right: 1rem !important;
  }
  .mb-sm-3,
  .my-sm-3 {
    margin-bottom: 1rem !important;
  }
  .ml-sm-3,
  .mx-sm-3 {
    margin-left: 1rem !important;
  }
  .m-sm-4 {
    margin: 1.5rem !important;
  }
  .mt-sm-4,
  .my-sm-4 {
    margin-top: 1.5rem !important;
  }
  .mr-sm-4,
  .mx-sm-4 {
    margin-right: 1.5rem !important;
  }
  .mb-sm-4,
  .my-sm-4 {
    margin-bottom: 1.5rem !important;
  }
  .ml-sm-4,
  .mx-sm-4 {
    margin-left: 1.5rem !important;
  }
  .m-sm-5 {
    margin: 3rem !important;
  }
  .mt-sm-5,
  .my-sm-5 {
    margin-top: 3rem !important;
  }
  .mr-sm-5,
  .mx-sm-5 {
    margin-right: 3rem !important;
  }
  .mb-sm-5,
  .my-sm-5 {
    margin-bottom: 3rem !important;
  }
  .ml-sm-5,
  .mx-sm-5 {
    margin-left: 3rem !important;
  }
  .p-sm-0 {
    padding: 0 !important;
  }
  .pt-sm-0,
  .py-sm-0 {
    padding-top: 0 !important;
  }
  .pr-sm-0,
  .px-sm-0 {
    padding-right: 0 !important;
  }
  .pb-sm-0,
  .py-sm-0 {
    padding-bottom: 0 !important;
  }
  .pl-sm-0,
  .px-sm-0 {
    padding-left: 0 !important;
  }
  .p-sm-1 {
    padding: 0.25rem !important;
  }
  .pt-sm-1,
  .py-sm-1 {
    padding-top: 0.25rem !important;
  }
  .pr-sm-1,
  .px-sm-1 {
    padding-right: 0.25rem !important;
  }
  .pb-sm-1,
  .py-sm-1 {
    padding-bottom: 0.25rem !important;
  }
  .pl-sm-1,
  .px-sm-1 {
    padding-left: 0.25rem !important;
  }
  .p-sm-2 {
    padding: 0.5rem !important;
  }
  .pt-sm-2,
  .py-sm-2 {
    padding-top: 0.5rem !important;
  }
  .pr-sm-2,
  .px-sm-2 {
    padding-right: 0.5rem !important;
  }
  .pb-sm-2,
  .py-sm-2 {
    padding-bottom: 0.5rem !important;
  }
  .pl-sm-2,
  .px-sm-2 {
    padding-left: 0.5rem !important;
  }
  .p-sm-3 {
    padding: 1rem !important;
  }
  .pt-sm-3,
  .py-sm-3 {
    padding-top: 1rem !important;
  }
  .pr-sm-3,
  .px-sm-3 {
    padding-right: 1rem !important;
  }
  .pb-sm-3,
  .py-sm-3 {
    padding-bottom: 1rem !important;
  }
  .pl-sm-3,
  .px-sm-3 {
    padding-left: 1rem !important;
  }
  .p-sm-4 {
    padding: 1.5rem !important;
  }
  .pt-sm-4,
  .py-sm-4 {
    padding-top: 1.5rem !important;
  }
  .pr-sm-4,
  .px-sm-4 {
    padding-right: 1.5rem !important;
  }
  .pb-sm-4,
  .py-sm-4 {
    padding-bottom: 1.5rem !important;
  }
  .pl-sm-4,
  .px-sm-4 {
    padding-left: 1.5rem !important;
  }
  .p-sm-5 {
    padding: 3rem !important;
  }
  .pt-sm-5,
  .py-sm-5 {
    padding-top: 3rem !important;
  }
  .pr-sm-5,
  .px-sm-5 {
    padding-right: 3rem !important;
  }
  .pb-sm-5,
  .py-sm-5 {
    padding-bottom: 3rem !important;
  }
  .pl-sm-5,
  .px-sm-5 {
    padding-left: 3rem !important;
  }
  .m-sm-n1 {
    margin: -0.25rem !important;
  }
  .mt-sm-n1,
  .my-sm-n1 {
    margin-top: -0.25rem !important;
  }
  .mr-sm-n1,
  .mx-sm-n1 {
    margin-right: -0.25rem !important;
  }
  .mb-sm-n1,
  .my-sm-n1 {
    margin-bottom: -0.25rem !important;
  }
  .ml-sm-n1,
  .mx-sm-n1 {
    margin-left: -0.25rem !important;
  }
  .m-sm-n2 {
    margin: -0.5rem !important;
  }
  .mt-sm-n2,
  .my-sm-n2 {
    margin-top: -0.5rem !important;
  }
  .mr-sm-n2,
  .mx-sm-n2 {
    margin-right: -0.5rem !important;
  }
  .mb-sm-n2,
  .my-sm-n2 {
    margin-bottom: -0.5rem !important;
  }
  .ml-sm-n2,
  .mx-sm-n2 {
    margin-left: -0.5rem !important;
  }
  .m-sm-n3 {
    margin: -1rem !important;
  }
  .mt-sm-n3,
  .my-sm-n3 {
    margin-top: -1rem !important;
  }
  .mr-sm-n3,
  .mx-sm-n3 {
    margin-right: -1rem !important;
  }
  .mb-sm-n3,
  .my-sm-n3 {
    margin-bottom: -1rem !important;
  }
  .ml-sm-n3,
  .mx-sm-n3 {
    margin-left: -1rem !important;
  }
  .m-sm-n4 {
    margin: -1.5rem !important;
  }
  .mt-sm-n4,
  .my-sm-n4 {
    margin-top: -1.5rem !important;
  }
  .mr-sm-n4,
  .mx-sm-n4 {
    margin-right: -1.5rem !important;
  }
  .mb-sm-n4,
  .my-sm-n4 {
    margin-bottom: -1.5rem !important;
  }
  .ml-sm-n4,
  .mx-sm-n4 {
    margin-left: -1.5rem !important;
  }
  .m-sm-n5 {
    margin: -3rem !important;
  }
  .mt-sm-n5,
  .my-sm-n5 {
    margin-top: -3rem !important;
  }
  .mr-sm-n5,
  .mx-sm-n5 {
    margin-right: -3rem !important;
  }
  .mb-sm-n5,
  .my-sm-n5 {
    margin-bottom: -3rem !important;
  }
  .ml-sm-n5,
  .mx-sm-n5 {
    margin-left: -3rem !important;
  }
  .m-sm-auto {
    margin: auto !important;
  }
  .mt-sm-auto,
  .my-sm-auto {
    margin-top: auto !important;
  }
  .mr-sm-auto,
  .mx-sm-auto {
    margin-right: auto !important;
  }
  .mb-sm-auto,
  .my-sm-auto {
    margin-bottom: auto !important;
  }
  .ml-sm-auto,
  .mx-sm-auto {
    margin-left: auto !important;
  }
}
@media (min-width: 768px) {
  .m-md-0 {
    margin: 0 !important;
  }
  .mt-md-0,
  .my-md-0 {
    margin-top: 0 !important;
  }
  .mr-md-0,
  .mx-md-0 {
    margin-right: 0 !important;
  }
  .mb-md-0,
  .my-md-0 {
    margin-bottom: 0 !important;
  }
  .ml-md-0,
  .mx-md-0 {
    margin-left: 0 !important;
  }
  .m-md-1 {
    margin: 0.25rem !important;
  }
  .mt-md-1,
  .my-md-1 {
    margin-top: 0.25rem !important;
  }
  .mr-md-1,
  .mx-md-1 {
    margin-right: 0.25rem !important;
  }
  .mb-md-1,
  .my-md-1 {
    margin-bottom: 0.25rem !important;
  }
  .ml-md-1,
  .mx-md-1 {
    margin-left: 0.25rem !important;
  }
  .m-md-2 {
    margin: 0.5rem !important;
  }
  .mt-md-2,
  .my-md-2 {
    margin-top: 0.5rem !important;
  }
  .mr-md-2,
  .mx-md-2 {
    margin-right: 0.5rem !important;
  }
  .mb-md-2,
  .my-md-2 {
    margin-bottom: 0.5rem !important;
  }
  .ml-md-2,
  .mx-md-2 {
    margin-left: 0.5rem !important;
  }
  .m-md-3 {
    margin: 1rem !important;
  }
  .mt-md-3,
  .my-md-3 {
    margin-top: 1rem !important;
  }
  .mr-md-3,
  .mx-md-3 {
    margin-right: 1rem !important;
  }
  .mb-md-3,
  .my-md-3 {
    margin-bottom: 1rem !important;
  }
  .ml-md-3,
  .mx-md-3 {
    margin-left: 1rem !important;
  }
  .m-md-4 {
    margin: 1.5rem !important;
  }
  .mt-md-4,
  .my-md-4 {
    margin-top: 1.5rem !important;
  }
  .mr-md-4,
  .mx-md-4 {
    margin-right: 1.5rem !important;
  }
  .mb-md-4,
  .my-md-4 {
    margin-bottom: 1.5rem !important;
  }
  .ml-md-4,
  .mx-md-4 {
    margin-left: 1.5rem !important;
  }
  .m-md-5 {
    margin: 3rem !important;
  }
  .mt-md-5,
  .my-md-5 {
    margin-top: 3rem !important;
  }
  .mr-md-5,
  .mx-md-5 {
    margin-right: 3rem !important;
  }
  .mb-md-5,
  .my-md-5 {
    margin-bottom: 3rem !important;
  }
  .ml-md-5,
  .mx-md-5 {
    margin-left: 3rem !important;
  }
  .p-md-0 {
    padding: 0 !important;
  }
  .pt-md-0,
  .py-md-0 {
    padding-top: 0 !important;
  }
  .pr-md-0,
  .px-md-0 {
    padding-right: 0 !important;
  }
  .pb-md-0,
  .py-md-0 {
    padding-bottom: 0 !important;
  }
  .pl-md-0,
  .px-md-0 {
    padding-left: 0 !important;
  }
  .p-md-1 {
    padding: 0.25rem !important;
  }
  .pt-md-1,
  .py-md-1 {
    padding-top: 0.25rem !important;
  }
  .pr-md-1,
  .px-md-1 {
    padding-right: 0.25rem !important;
  }
  .pb-md-1,
  .py-md-1 {
    padding-bottom: 0.25rem !important;
  }
  .pl-md-1,
  .px-md-1 {
    padding-left: 0.25rem !important;
  }
  .p-md-2 {
    padding: 0.5rem !important;
  }
  .pt-md-2,
  .py-md-2 {
    padding-top: 0.5rem !important;
  }
  .pr-md-2,
  .px-md-2 {
    padding-right: 0.5rem !important;
  }
  .pb-md-2,
  .py-md-2 {
    padding-bottom: 0.5rem !important;
  }
  .pl-md-2,
  .px-md-2 {
    padding-left: 0.5rem !important;
  }
  .p-md-3 {
    padding: 1rem !important;
  }
  .pt-md-3,
  .py-md-3 {
    padding-top: 1rem !important;
  }
  .pr-md-3,
  .px-md-3 {
    padding-right: 1rem !important;
  }
  .pb-md-3,
  .py-md-3 {
    padding-bottom: 1rem !important;
  }
  .pl-md-3,
  .px-md-3 {
    padding-left: 1rem !important;
  }
  .p-md-4 {
    padding: 1.5rem !important;
  }
  .pt-md-4,
  .py-md-4 {
    padding-top: 1.5rem !important;
  }
  .pr-md-4,
  .px-md-4 {
    padding-right: 1.5rem !important;
  }
  .pb-md-4,
  .py-md-4 {
    padding-bottom: 1.5rem !important;
  }
  .pl-md-4,
  .px-md-4 {
    padding-left: 1.5rem !important;
  }
  .p-md-5 {
    padding: 3rem !important;
  }
  .pt-md-5,
  .py-md-5 {
    padding-top: 3rem !important;
  }
  .pr-md-5,
  .px-md-5 {
    padding-right: 3rem !important;
  }
  .pb-md-5,
  .py-md-5 {
    padding-bottom: 3rem !important;
  }
  .pl-md-5,
  .px-md-5 {
    padding-left: 3rem !important;
  }
  .m-md-n1 {
    margin: -0.25rem !important;
  }
  .mt-md-n1,
  .my-md-n1 {
    margin-top: -0.25rem !important;
  }
  .mr-md-n1,
  .mx-md-n1 {
    margin-right: -0.25rem !important;
  }
  .mb-md-n1,
  .my-md-n1 {
    margin-bottom: -0.25rem !important;
  }
  .ml-md-n1,
  .mx-md-n1 {
    margin-left: -0.25rem !important;
  }
  .m-md-n2 {
    margin: -0.5rem !important;
  }
  .mt-md-n2,
  .my-md-n2 {
    margin-top: -0.5rem !important;
  }
  .mr-md-n2,
  .mx-md-n2 {
    margin-right: -0.5rem !important;
  }
  .mb-md-n2,
  .my-md-n2 {
    margin-bottom: -0.5rem !important;
  }
  .ml-md-n2,
  .mx-md-n2 {
    margin-left: -0.5rem !important;
  }
  .m-md-n3 {
    margin: -1rem !important;
  }
  .mt-md-n3,
  .my-md-n3 {
    margin-top: -1rem !important;
  }
  .mr-md-n3,
  .mx-md-n3 {
    margin-right: -1rem !important;
  }
  .mb-md-n3,
  .my-md-n3 {
    margin-bottom: -1rem !important;
  }
  .ml-md-n3,
  .mx-md-n3 {
    margin-left: -1rem !important;
  }
  .m-md-n4 {
    margin: -1.5rem !important;
  }
  .mt-md-n4,
  .my-md-n4 {
    margin-top: -1.5rem !important;
  }
  .mr-md-n4,
  .mx-md-n4 {
    margin-right: -1.5rem !important;
  }
  .mb-md-n4,
  .my-md-n4 {
    margin-bottom: -1.5rem !important;
  }
  .ml-md-n4,
  .mx-md-n4 {
    margin-left: -1.5rem !important;
  }
  .m-md-n5 {
    margin: -3rem !important;
  }
  .mt-md-n5,
  .my-md-n5 {
    margin-top: -3rem !important;
  }
  .mr-md-n5,
  .mx-md-n5 {
    margin-right: -3rem !important;
  }
  .mb-md-n5,
  .my-md-n5 {
    margin-bottom: -3rem !important;
  }
  .ml-md-n5,
  .mx-md-n5 {
    margin-left: -3rem !important;
  }
  .m-md-auto {
    margin: auto !important;
  }
  .mt-md-auto,
  .my-md-auto {
    margin-top: auto !important;
  }
  .mr-md-auto,
  .mx-md-auto {
    margin-right: auto !important;
  }
  .mb-md-auto,
  .my-md-auto {
    margin-bottom: auto !important;
  }
  .ml-md-auto,
  .mx-md-auto {
    margin-left: auto !important;
  }
}
@media (min-width: 992px) {
  .m-lg-0 {
    margin: 0 !important;
  }
  .mt-lg-0,
  .my-lg-0 {
    margin-top: 0 !important;
  }
  .mr-lg-0,
  .mx-lg-0 {
    margin-right: 0 !important;
  }
  .mb-lg-0,
  .my-lg-0 {
    margin-bottom: 0 !important;
  }
  .ml-lg-0,
  .mx-lg-0 {
    margin-left: 0 !important;
  }
  .m-lg-1 {
    margin: 0.25rem !important;
  }
  .mt-lg-1,
  .my-lg-1 {
    margin-top: 0.25rem !important;
  }
  .mr-lg-1,
  .mx-lg-1 {
    margin-right: 0.25rem !important;
  }
  .mb-lg-1,
  .my-lg-1 {
    margin-bottom: 0.25rem !important;
  }
  .ml-lg-1,
  .mx-lg-1 {
    margin-left: 0.25rem !important;
  }
  .m-lg-2 {
    margin: 0.5rem !important;
  }
  .mt-lg-2,
  .my-lg-2 {
    margin-top: 0.5rem !important;
  }
  .mr-lg-2,
  .mx-lg-2 {
    margin-right: 0.5rem !important;
  }
  .mb-lg-2,
  .my-lg-2 {
    margin-bottom: 0.5rem !important;
  }
  .ml-lg-2,
  .mx-lg-2 {
    margin-left: 0.5rem !important;
  }
  .m-lg-3 {
    margin: 1rem !important;
  }
  .mt-lg-3,
  .my-lg-3 {
    margin-top: 1rem !important;
  }
  .mr-lg-3,
  .mx-lg-3 {
    margin-right: 1rem !important;
  }
  .mb-lg-3,
  .my-lg-3 {
    margin-bottom: 1rem !important;
  }
  .ml-lg-3,
  .mx-lg-3 {
    margin-left: 1rem !important;
  }
  .m-lg-4 {
    margin: 1.5rem !important;
  }
  .mt-lg-4,
  .my-lg-4 {
    margin-top: 1.5rem !important;
  }
  .mr-lg-4,
  .mx-lg-4 {
    margin-right: 1.5rem !important;
  }
  .mb-lg-4,
  .my-lg-4 {
    margin-bottom: 1.5rem !important;
  }
  .ml-lg-4,
  .mx-lg-4 {
    margin-left: 1.5rem !important;
  }
  .m-lg-5 {
    margin: 3rem !important;
  }
  .mt-lg-5,
  .my-lg-5 {
    margin-top: 3rem !important;
  }
  .mr-lg-5,
  .mx-lg-5 {
    margin-right: 3rem !important;
  }
  .mb-lg-5,
  .my-lg-5 {
    margin-bottom: 3rem !important;
  }
  .ml-lg-5,
  .mx-lg-5 {
    margin-left: 3rem !important;
  }
  .p-lg-0 {
    padding: 0 !important;
  }
  .pt-lg-0,
  .py-lg-0 {
    padding-top: 0 !important;
  }
  .pr-lg-0,
  .px-lg-0 {
    padding-right: 0 !important;
  }
  .pb-lg-0,
  .py-lg-0 {
    padding-bottom: 0 !important;
  }
  .pl-lg-0,
  .px-lg-0 {
    padding-left: 0 !important;
  }
  .p-lg-1 {
    padding: 0.25rem !important;
  }
  .pt-lg-1,
  .py-lg-1 {
    padding-top: 0.25rem !important;
  }
  .pr-lg-1,
  .px-lg-1 {
    padding-right: 0.25rem !important;
  }
  .pb-lg-1,
  .py-lg-1 {
    padding-bottom: 0.25rem !important;
  }
  .pl-lg-1,
  .px-lg-1 {
    padding-left: 0.25rem !important;
  }
  .p-lg-2 {
    padding: 0.5rem !important;
  }
  .pt-lg-2,
  .py-lg-2 {
    padding-top: 0.5rem !important;
  }
  .pr-lg-2,
  .px-lg-2 {
    padding-right: 0.5rem !important;
  }
  .pb-lg-2,
  .py-lg-2 {
    padding-bottom: 0.5rem !important;
  }
  .pl-lg-2,
  .px-lg-2 {
    padding-left: 0.5rem !important;
  }
  .p-lg-3 {
    padding: 1rem !important;
  }
  .pt-lg-3,
  .py-lg-3 {
    padding-top: 1rem !important;
  }
  .pr-lg-3,
  .px-lg-3 {
    padding-right: 1rem !important;
  }
  .pb-lg-3,
  .py-lg-3 {
    padding-bottom: 1rem !important;
  }
  .pl-lg-3,
  .px-lg-3 {
    padding-left: 1rem !important;
  }
  .p-lg-4 {
    padding: 1.5rem !important;
  }
  .pt-lg-4,
  .py-lg-4 {
    padding-top: 1.5rem !important;
  }
  .pr-lg-4,
  .px-lg-4 {
    padding-right: 1.5rem !important;
  }
  .pb-lg-4,
  .py-lg-4 {
    padding-bottom: 1.5rem !important;
  }
  .pl-lg-4,
  .px-lg-4 {
    padding-left: 1.5rem !important;
  }
  .p-lg-5 {
    padding: 3rem !important;
  }
  .pt-lg-5,
  .py-lg-5 {
    padding-top: 3rem !important;
  }
  .pr-lg-5,
  .px-lg-5 {
    padding-right: 3rem !important;
  }
  .pb-lg-5,
  .py-lg-5 {
    padding-bottom: 3rem !important;
  }
  .pl-lg-5,
  .px-lg-5 {
    padding-left: 3rem !important;
  }
  .m-lg-n1 {
    margin: -0.25rem !important;
  }
  .mt-lg-n1,
  .my-lg-n1 {
    margin-top: -0.25rem !important;
  }
  .mr-lg-n1,
  .mx-lg-n1 {
    margin-right: -0.25rem !important;
  }
  .mb-lg-n1,
  .my-lg-n1 {
    margin-bottom: -0.25rem !important;
  }
  .ml-lg-n1,
  .mx-lg-n1 {
    margin-left: -0.25rem !important;
  }
  .m-lg-n2 {
    margin: -0.5rem !important;
  }
  .mt-lg-n2,
  .my-lg-n2 {
    margin-top: -0.5rem !important;
  }
  .mr-lg-n2,
  .mx-lg-n2 {
    margin-right: -0.5rem !important;
  }
  .mb-lg-n2,
  .my-lg-n2 {
    margin-bottom: -0.5rem !important;
  }
  .ml-lg-n2,
  .mx-lg-n2 {
    margin-left: -0.5rem !important;
  }
  .m-lg-n3 {
    margin: -1rem !important;
  }
  .mt-lg-n3,
  .my-lg-n3 {
    margin-top: -1rem !important;
  }
  .mr-lg-n3,
  .mx-lg-n3 {
    margin-right: -1rem !important;
  }
  .mb-lg-n3,
  .my-lg-n3 {
    margin-bottom: -1rem !important;
  }
  .ml-lg-n3,
  .mx-lg-n3 {
    margin-left: -1rem !important;
  }
  .m-lg-n4 {
    margin: -1.5rem !important;
  }
  .mt-lg-n4,
  .my-lg-n4 {
    margin-top: -1.5rem !important;
  }
  .mr-lg-n4,
  .mx-lg-n4 {
    margin-right: -1.5rem !important;
  }
  .mb-lg-n4,
  .my-lg-n4 {
    margin-bottom: -1.5rem !important;
  }
  .ml-lg-n4,
  .mx-lg-n4 {
    margin-left: -1.5rem !important;
  }
  .m-lg-n5 {
    margin: -3rem !important;
  }
  .mt-lg-n5,
  .my-lg-n5 {
    margin-top: -3rem !important;
  }
  .mr-lg-n5,
  .mx-lg-n5 {
    margin-right: -3rem !important;
  }
  .mb-lg-n5,
  .my-lg-n5 {
    margin-bottom: -3rem !important;
  }
  .ml-lg-n5,
  .mx-lg-n5 {
    margin-left: -3rem !important;
  }
  .m-lg-auto {
    margin: auto !important;
  }
  .mt-lg-auto,
  .my-lg-auto {
    margin-top: auto !important;
  }
  .mr-lg-auto,
  .mx-lg-auto {
    margin-right: auto !important;
  }
  .mb-lg-auto,
  .my-lg-auto {
    margin-bottom: auto !important;
  }
  .ml-lg-auto,
  .mx-lg-auto {
    margin-left: auto !important;
  }
}
@media (min-width: 1200px) {
  .m-xl-0 {
    margin: 0 !important;
  }
  .mt-xl-0,
  .my-xl-0 {
    margin-top: 0 !important;
  }
  .mr-xl-0,
  .mx-xl-0 {
    margin-right: 0 !important;
  }
  .mb-xl-0,
  .my-xl-0 {
    margin-bottom: 0 !important;
  }
  .ml-xl-0,
  .mx-xl-0 {
    margin-left: 0 !important;
  }
  .m-xl-1 {
    margin: 0.25rem !important;
  }
  .mt-xl-1,
  .my-xl-1 {
    margin-top: 0.25rem !important;
  }
  .mr-xl-1,
  .mx-xl-1 {
    margin-right: 0.25rem !important;
  }
  .mb-xl-1,
  .my-xl-1 {
    margin-bottom: 0.25rem !important;
  }
  .ml-xl-1,
  .mx-xl-1 {
    margin-left: 0.25rem !important;
  }
  .m-xl-2 {
    margin: 0.5rem !important;
  }
  .mt-xl-2,
  .my-xl-2 {
    margin-top: 0.5rem !important;
  }
  .mr-xl-2,
  .mx-xl-2 {
    margin-right: 0.5rem !important;
  }
  .mb-xl-2,
  .my-xl-2 {
    margin-bottom: 0.5rem !important;
  }
  .ml-xl-2,
  .mx-xl-2 {
    margin-left: 0.5rem !important;
  }
  .m-xl-3 {
    margin: 1rem !important;
  }
  .mt-xl-3,
  .my-xl-3 {
    margin-top: 1rem !important;
  }
  .mr-xl-3,
  .mx-xl-3 {
    margin-right: 1rem !important;
  }
  .mb-xl-3,
  .my-xl-3 {
    margin-bottom: 1rem !important;
  }
  .ml-xl-3,
  .mx-xl-3 {
    margin-left: 1rem !important;
  }
  .m-xl-4 {
    margin: 1.5rem !important;
  }
  .mt-xl-4,
  .my-xl-4 {
    margin-top: 1.5rem !important;
  }
  .mr-xl-4,
  .mx-xl-4 {
    margin-right: 1.5rem !important;
  }
  .mb-xl-4,
  .my-xl-4 {
    margin-bottom: 1.5rem !important;
  }
  .ml-xl-4,
  .mx-xl-4 {
    margin-left: 1.5rem !important;
  }
  .m-xl-5 {
    margin: 3rem !important;
  }
  .mt-xl-5,
  .my-xl-5 {
    margin-top: 3rem !important;
  }
  .mr-xl-5,
  .mx-xl-5 {
    margin-right: 3rem !important;
  }
  .mb-xl-5,
  .my-xl-5 {
    margin-bottom: 3rem !important;
  }
  .ml-xl-5,
  .mx-xl-5 {
    margin-left: 3rem !important;
  }
  .p-xl-0 {
    padding: 0 !important;
  }
  .pt-xl-0,
  .py-xl-0 {
    padding-top: 0 !important;
  }
  .pr-xl-0,
  .px-xl-0 {
    padding-right: 0 !important;
  }
  .pb-xl-0,
  .py-xl-0 {
    padding-bottom: 0 !important;
  }
  .pl-xl-0,
  .px-xl-0 {
    padding-left: 0 !important;
  }
  .p-xl-1 {
    padding: 0.25rem !important;
  }
  .pt-xl-1,
  .py-xl-1 {
    padding-top: 0.25rem !important;
  }
  .pr-xl-1,
  .px-xl-1 {
    padding-right: 0.25rem !important;
  }
  .pb-xl-1,
  .py-xl-1 {
    padding-bottom: 0.25rem !important;
  }
  .pl-xl-1,
  .px-xl-1 {
    padding-left: 0.25rem !important;
  }
  .p-xl-2 {
    padding: 0.5rem !important;
  }
  .pt-xl-2,
  .py-xl-2 {
    padding-top: 0.5rem !important;
  }
  .pr-xl-2,
  .px-xl-2 {
    padding-right: 0.5rem !important;
  }
  .pb-xl-2,
  .py-xl-2 {
    padding-bottom: 0.5rem !important;
  }
  .pl-xl-2,
  .px-xl-2 {
    padding-left: 0.5rem !important;
  }
  .p-xl-3 {
    padding: 1rem !important;
  }
  .pt-xl-3,
  .py-xl-3 {
    padding-top: 1rem !important;
  }
  .pr-xl-3,
  .px-xl-3 {
    padding-right: 1rem !important;
  }
  .pb-xl-3,
  .py-xl-3 {
    padding-bottom: 1rem !important;
  }
  .pl-xl-3,
  .px-xl-3 {
    padding-left: 1rem !important;
  }
  .p-xl-4 {
    padding: 1.5rem !important;
  }
  .pt-xl-4,
  .py-xl-4 {
    padding-top: 1.5rem !important;
  }
  .pr-xl-4,
  .px-xl-4 {
    padding-right: 1.5rem !important;
  }
  .pb-xl-4,
  .py-xl-4 {
    padding-bottom: 1.5rem !important;
  }
  .pl-xl-4,
  .px-xl-4 {
    padding-left: 1.5rem !important;
  }
  .p-xl-5 {
    padding: 3rem !important;
  }
  .pt-xl-5,
  .py-xl-5 {
    padding-top: 3rem !important;
  }
  .pr-xl-5,
  .px-xl-5 {
    padding-right: 3rem !important;
  }
  .pb-xl-5,
  .py-xl-5 {
    padding-bottom: 3rem !important;
  }
  .pl-xl-5,
  .px-xl-5 {
    padding-left: 3rem !important;
  }
  .m-xl-n1 {
    margin: -0.25rem !important;
  }
  .mt-xl-n1,
  .my-xl-n1 {
    margin-top: -0.25rem !important;
  }
  .mr-xl-n1,
  .mx-xl-n1 {
    margin-right: -0.25rem !important;
  }
  .mb-xl-n1,
  .my-xl-n1 {
    margin-bottom: -0.25rem !important;
  }
  .ml-xl-n1,
  .mx-xl-n1 {
    margin-left: -0.25rem !important;
  }
  .m-xl-n2 {
    margin: -0.5rem !important;
  }
  .mt-xl-n2,
  .my-xl-n2 {
    margin-top: -0.5rem !important;
  }
  .mr-xl-n2,
  .mx-xl-n2 {
    margin-right: -0.5rem !important;
  }
  .mb-xl-n2,
  .my-xl-n2 {
    margin-bottom: -0.5rem !important;
  }
  .ml-xl-n2,
  .mx-xl-n2 {
    margin-left: -0.5rem !important;
  }
  .m-xl-n3 {
    margin: -1rem !important;
  }
  .mt-xl-n3,
  .my-xl-n3 {
    margin-top: -1rem !important;
  }
  .mr-xl-n3,
  .mx-xl-n3 {
    margin-right: -1rem !important;
  }
  .mb-xl-n3,
  .my-xl-n3 {
    margin-bottom: -1rem !important;
  }
  .ml-xl-n3,
  .mx-xl-n3 {
    margin-left: -1rem !important;
  }
  .m-xl-n4 {
    margin: -1.5rem !important;
  }
  .mt-xl-n4,
  .my-xl-n4 {
    margin-top: -1.5rem !important;
  }
  .mr-xl-n4,
  .mx-xl-n4 {
    margin-right: -1.5rem !important;
  }
  .mb-xl-n4,
  .my-xl-n4 {
    margin-bottom: -1.5rem !important;
  }
  .ml-xl-n4,
  .mx-xl-n4 {
    margin-left: -1.5rem !important;
  }
  .m-xl-n5 {
    margin: -3rem !important;
  }
  .mt-xl-n5,
  .my-xl-n5 {
    margin-top: -3rem !important;
  }
  .mr-xl-n5,
  .mx-xl-n5 {
    margin-right: -3rem !important;
  }
  .mb-xl-n5,
  .my-xl-n5 {
    margin-bottom: -3rem !important;
  }
  .ml-xl-n5,
  .mx-xl-n5 {
    margin-left: -3rem !important;
  }
  .m-xl-auto {
    margin: auto !important;
  }
  .mt-xl-auto,
  .my-xl-auto {
    margin-top: auto !important;
  }
  .mr-xl-auto,
  .mx-xl-auto {
    margin-right: auto !important;
  }
  .mb-xl-auto,
  .my-xl-auto {
    margin-bottom: auto !important;
  }
  .ml-xl-auto,
  .mx-xl-auto {
    margin-left: auto !important;
  }
}
.text-monospace {
  font-family: SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace !important;
}

.text-justify {
  text-align: justify !important;
}

.text-wrap {
  white-space: normal !important;
}

.text-nowrap {
  white-space: nowrap !important;
}

.text-truncate {
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.text-left {
  text-align: left !important;
}

.text-right {
  text-align: right !important;
}

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

@media (min-width: 576px) {
  .text-sm-left {
    text-align: left !important;
  }
  .text-sm-right {
    text-align: right !important;
  }
  .text-sm-center {
    text-align: center !important;
  }
}
@media (min-width: 768px) {
  .text-md-left {
    text-align: left !important;
  }
  .text-md-right {
    text-align: right !important;
  }
  .text-md-center {
    text-align: center !important;
  }
}
@media (min-width: 992px) {
  .text-lg-left {
    text-align: left !important;
  }
  .text-lg-right {
    text-align: right !important;
  }
  .text-lg-center {
    text-align: center !important;
  }
}
@media (min-width: 1200px) {
  .text-xl-left {
    text-align: left !important;
  }
  .text-xl-right {
    text-align: right !important;
  }
  .text-xl-center {
    text-align: center !important;
  }
}
.text-lowercase {
  text-transform: lowercase !important;
}

.text-uppercase {
  text-transform: uppercase !important;
}

.text-capitalize {
  text-transform: capitalize !important;
}

.font-weight-light {
  font-weight: 300 !important;
}

.font-weight-lighter {
  font-weight: lighter !important;
}

.font-weight-normal {
  font-weight: 400 !important;
}

.font-weight-bold {
  font-weight: 700 !important;
}

.font-weight-bolder {
  font-weight: bolder !important;
}

.font-italic {
  font-style: italic !important;
}

.text-white {
  color: #fff !important;
}

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

a.text-primary:hover, a.text-primary:focus {
  color: rgb(0, 86.1, 178.5) !important;
}

.text-secondary {
  color: #6c757d !important;
}

a.text-secondary:hover, a.text-secondary:focus {
  color: rgb(72.5407725322, 78.5858369099, 83.9592274678) !important;
}

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

a.text-success:hover, a.text-success:focus {
  color: rgb(25.2173913043, 105.2826086957, 43.5) !important;
}

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

a.text-info:hover, a.text-info:focus {
  color: rgb(14.5, 102.1304347826, 116) !important;
}

.text-warning {
  color: #ffc107 !important;
}

a.text-warning:hover, a.text-warning:focus {
  color: rgb(185.5, 139.125, 0) !important;
}

.text-danger {
  color: #dc3545 !important;
}

a.text-danger:hover, a.text-danger:focus {
  color: rgb(167.4810126582, 29.0189873418, 42.2848101266) !important;
}

.text-light {
  color: #f8f9fa !important;
}

a.text-light:hover, a.text-light:focus {
  color: rgb(203.375, 210.75, 218.125) !important;
}

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

a.text-dark:hover, a.text-dark:focus {
  color: rgb(17.7068965517, 19.75, 21.7931034483) !important;
}

.text-body {
  color: #212529 !important;
}

.text-muted {
  color: #6c757d !important;
}

.text-black-50 {
  color: rgba(0, 0, 0, 0.5) !important;
}

.text-white-50 {
  color: rgba(255, 255, 255, 0.5) !important;
}

.text-hide {
  font: 0/0 a;
  color: transparent;
  text-shadow: none;
  background-color: transparent;
  border: 0;
}

.text-decoration-none {
  text-decoration: none !important;
}

.text-break {
  word-break: break-word !important;
  overflow-wrap: break-word !important;
}

.text-reset {
  color: inherit !important;
}

.visible {
  visibility: visible !important;
}

.invisible {
  visibility: hidden !important;
}

@media print {
  *,
  *::before,
  *::after {
    text-shadow: none !important;
    box-shadow: none !important;
  }
  a:not(.btn) {
    text-decoration: underline;
  }
  abbr[title]::after {
    content: " (" attr(title) ")";
  }
  pre {
    white-space: pre-wrap !important;
  }
  pre,
  blockquote {
    border: 1px solid #adb5bd;
    page-break-inside: avoid;
  }
  thead {
    display: table-header-group;
  }
  tr,
  img {
    page-break-inside: avoid;
  }
  p,
  h2,
  h3 {
    orphans: 3;
    widows: 3;
  }
  h2,
  h3 {
    page-break-after: avoid;
  }
  @page {
    size: a3;
  }
  body {
    min-width: 992px !important;
  }
  .container {
    min-width: 992px !important;
  }
  .navbar {
    display: none;
  }
  .badge {
    border: 1px solid #000;
  }
  .table {
    border-collapse: collapse !important;
  }
  .table td,
  .table th {
    background-color: #fff !important;
  }
  .table-bordered th,
  .table-bordered td {
    border: 1px solid #dee2e6 !important;
  }
  .table-dark {
    color: inherit;
  }
  .table-dark th,
  .table-dark td,
  .table-dark thead th,
  .table-dark tbody + tbody {
    border-color: #dee2e6;
  }
  .table .thead-dark th {
    color: inherit;
    border-color: #dee2e6;
  }
}
@font-face {
  font-family: "Raleway";
  src: url("/themes/praddy/assets/dist/fonts/Raleway/Raleway-Light.ttf");
}
@font-face {
  font-family: "Raleway-extra-light";
  src: url("/themes/praddy/assets/dist/fonts/Raleway/Raleway-ExtraLight.ttf");
}
@font-face {
  font-family: "Raleway-bold";
  src: url("/themes/praddy/assets/dist/fonts/Raleway/Raleway-SemiBold.ttf");
}
@font-face {
  font-family: "Audrey";
  src: url("/themes/praddy/assets/dist/fonts/Audrey/Audrey-Normal.otf");
}
@font-face {
  font-family: "Audrey-Oblique";
  src: url("/themes/praddy/assets/dist/fonts/Audrey/Audrey-NormalOblique.otf");
}
@font-face {
  font-family: "Audrey-Bold";
  src: url("/themes/praddy/assets/dist/fonts/Audrey/Audrey-Bold.otf");
}
@font-face {
  font-family: "Audrey-BoldOblique";
  src: url("/themes/praddy/assets/dist/fonts/Audrey/Audrey-BoldOblique.otf");
}
@font-face {
  font-family: "Audrey-Medium";
  src: url("/themes/praddy/assets/dist/fonts/Audrey/Audrey-Medium.otf");
}
@font-face {
  font-family: "Audrey-MediumOblique";
  src: url("/themes/praddy/assets/dist/fonts/Audrey/Audrey-MediumOblique.otf");
}
.bg-dark {
  background: #1e1e1e !important;
}

._nomargin {
  margin: 0 !important;
}

._nopadding {
  padding: 0 !important;
}

._noliststyle {
  list-style: none !important;
}

/*
 * Reset | Normalize
 */
body,
html {
  margin: 0;
  padding: 0;
  font-family: "Raleway", "Lato", sans-serif;
  background-color: #fff;
  text-rendering: optimizeLegibility;
}

/* Mobile: sem zoom por pinça e sem scroll horizontal na página */
@media (max-width: 991.98px) {
  html {
    overflow-x: hidden;
    -webkit-text-size-adjust: 100%;
  }
  body {
    overflow-x: hidden;
    width: 100%;
    max-width: 100vw;
    position: relative;
    overscroll-behavior-x: none;
  }
}
.-bg-dark {
  background-color: #1e1e1e;
}

.-bg-grey {
  background-color: #bebebc;
}

.-bg-grey-darker {
  background-color: #7d7d7d;
}

.-bg-light {
  background-color: #fff;
  color: #1e1e1e;
}

.page-section {
  padding: 25px 0;
}

.body-wrapper {
  width: 100%;
  padding: 58px 0;
}

@media (max-width: 991.98px) {
  .body-wrapper {
    padding-top: calc(5rem + env(safe-area-inset-top, 0px));
  }
}
/*
 -------------------------------------------------------------------
 Header
 -------------------------------------------------------------------
*/
#page-header {
  position: relative;
}

/*
 -------------------------------------------------------------------
 Pages
 -------------------------------------------------------------------
*/
.page-banner {
  margin-bottom: 35px;
  max-height: 500px;
  overflow: hidden;
}
.page-banner > .image {
  width: 100%;
  margin: 0 auto;
  max-width: 2100px;
}

/*
 -------------------------------------------------------------------
 Responsiveness
 -------------------------------------------------------------------
*/
@media (min-width: 992px) {
  .body-wrapper {
    padding-top: 80px;
  }
}
/* Evita faixa branca antes do footer (padding-bottom global do .body-wrapper). */
.body-wrapper.reserved-login-page {
  padding-bottom: 0;
}

/*
 -------------------------------------------------------------------
 Components
 -------------------------------------------------------------------
*/
/* Botão flutuante WhatsApp (substitui ícone Robbu grande) */
#robbu-whatsapp-button.wa-float {
  position: fixed;
  z-index: 10050;
  right: max(1rem, env(safe-area-inset-right, 0px));
  bottom: max(1rem, env(safe-area-inset-bottom, 0px));
  width: 2.75rem;
  height: 2.75rem;
  padding: 0;
  margin: 0;
  border: 0;
  border-radius: 50%;
  background: #25d366;
  color: #fff;
  box-shadow: 0 2px 10px rgba(0, 0, 0, 0.14), 0 1px 3px rgba(0, 0, 0, 0.08);
  display: flex;
  align-items: center;
  justify-content: center;
  text-decoration: none;
  transition: transform 0.2s ease, box-shadow 0.2s ease, background 0.2s ease;
}
#robbu-whatsapp-button.wa-float:hover, #robbu-whatsapp-button.wa-float:focus-visible {
  color: #fff;
  background: #20bd5a;
  text-decoration: none;
  transform: scale(1.05);
  box-shadow: 0 4px 16px rgba(37, 211, 102, 0.35);
}
#robbu-whatsapp-button.wa-float:focus-visible {
  outline: 2px solid rgba(37, 211, 102, 0.5);
  outline-offset: 3px;
}
#robbu-whatsapp-button.wa-float svg {
  display: block;
  width: 1.35rem;
  height: 1.35rem;
  flex-shrink: 0;
}

@media (min-width: 992px) {
  #robbu-whatsapp-button.wa-float {
    width: 3rem;
    height: 3rem;
    right: 1.35rem;
    bottom: 1.35rem;
  }
  #robbu-whatsapp-button.wa-float svg {
    width: 1.45rem;
    height: 1.45rem;
  }
}
.navbar-main {
  background-color: #1e1e1e;
  color: #fff;
  min-height: 80px;
  padding-top: 0;
  padding-bottom: 0;
  /* Respiro lateral + safe-area (evita logo/links colados à borda) */
  padding-left: max(clamp(1.25rem, 4vw, 3rem), env(safe-area-inset-left, 0px));
  padding-right: max(clamp(1.25rem, 4vw, 3rem), env(safe-area-inset-right, 0px));
}
.navbar-main .navbar-brand {
  position: relative;
  z-index: 1030;
}
.navbar-main .navbar-brand .image {
  height: 48px;
  width: auto;
}
.navbar-main .nav-link {
  color: #fff !important;
  font-size: 0.75rem;
  font-weight: 500;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  padding: 0.5rem 0.75rem !important;
  transition: color 0.2s ease;
}
.navbar-main .nav-link:hover, .navbar-main .nav-link:focus {
  color: #bebebc !important;
}
.navbar-main .nav-icon {
  height: 1.25rem;
  width: 1.25rem;
  display: block;
}
.navbar-main .dropdown-toggle::after {
  margin-left: 0.25rem;
  vertical-align: middle;
}
.navbar-main .navbar-nav-actions {
  flex-direction: row;
  align-items: center;
}
.navbar-main .nav-locale-picker a {
  color: rgba(255, 255, 255, 0.9) !important;
  text-decoration: none;
  font-size: 0.75rem;
  letter-spacing: 0.05em;
}
.navbar-main .nav-locale-picker a:hover {
  color: #fff !important;
}

.mega-menu {
  margin-top: 0 !important;
  padding: 0 !important;
  border: none !important;
  border-radius: 0 !important;
  background: rgba(13, 13, 13, 0.82) !important;
  backdrop-filter: saturate(140%) blur(14px);
  -webkit-backdrop-filter: saturate(140%) blur(14px);
  box-shadow: 0 16px 48px rgba(0, 0, 0, 0.35) !important;
  flex-direction: column;
  max-height: none !important;
  /* auto: evita cortar colunas quando há muitas tipologias (antes: hidden) */
  overflow-x: auto;
  overflow-y: auto;
}

/* Largura total do painel (o .mega-menu já é 100vw); interior preenche altura e faz scroll se necessário */
.mega-menu-inner {
  display: flex;
  flex-direction: row;
  flex-wrap: wrap;
  justify-content: space-between;
  align-items: flex-start;
  gap: clamp(1.25rem, 2.5vw, 2rem);
  width: 100%;
  max-width: min(100%, 90rem);
  margin: 0 auto;
  padding: 2rem max(clamp(1.25rem, 4vw, 3rem), env(safe-area-inset-left, 0px)) max(clamp(1.25rem, 4vw, 3rem), env(safe-area-inset-right, 0px));
  box-sizing: border-box;
  flex: 1 1 auto;
  min-height: 0;
  overflow-y: auto;
}

/*
 * Produtos: tipologias em 3 colunas × 2 linhas, bloco centrado (alinhado à nav central da navbar)
 */
.mega-menu--typologies .mega-menu-inner {
  justify-content: center;
  align-items: flex-start;
  gap: clamp(2rem, 4.5vw, 3.25rem);
  max-width: 100%;
}

/* Tipologias: colunas verticais (título + lista), uma linha de 6 em ecrã largo; 3×2 em viewports médios */
.mega-menu--typologies .mega-menu-columns {
  display: grid;
  grid-template-columns: repeat(6, minmax(0, 1fr));
  column-gap: clamp(1.1rem, 2.2vw, 2rem);
  row-gap: 1.65rem;
  align-items: start;
  justify-items: stretch;
  width: auto;
  max-width: min(100%, 56rem);
  flex: 1 1 auto;
  min-width: 0;
}

@media (min-width: 992px) and (max-width: 1299.98px) {
  .mega-menu--typologies .mega-menu-columns {
    grid-template-columns: repeat(3, minmax(0, 1fr));
    max-width: min(100%, 44rem);
  }
}
.mega-menu-inner--commerce-collections .mega-menu-columns {
  display: block;
}

.mega-menu-column {
  min-width: 0;
  max-width: none;
}

/* Uma linha por tipologia: evita «COMPLEMEN-/TOS»; coluna não encolhe abaixo do título */
.mega-menu--typologies .mega-menu-column {
  min-width: min-content;
}

.mega-menu-column .mega-menu-column__title {
  margin: 0 0 0.9rem;
  padding-bottom: 0.5rem;
  border-bottom: 1px solid rgba(255, 255, 255, 0.22);
  font-size: 0.72rem;
  font-weight: 700;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: #fff;
  line-height: 1.35;
  white-space: nowrap;
  overflow-wrap: normal;
  word-wrap: normal;
  hyphens: manual;
}
.mega-menu-column .mega-menu-links {
  list-style: none;
  padding: 0.15rem 0 0;
  margin: 0;
}
.mega-menu-column .mega-menu-links li {
  margin-bottom: 0.52rem;
}
.mega-menu-column .mega-menu-links li:last-child {
  margin-bottom: 0;
}
.mega-menu-column .mega-menu-links a {
  display: inline-block;
  color: rgba(255, 255, 255, 0.55);
  font-size: 0.78rem;
  font-weight: 400;
  letter-spacing: 0.03em;
  line-height: 1.5;
  text-transform: none;
  text-decoration: none;
  transition: color 0.2s ease;
}
.mega-menu-column .mega-menu-links a:hover {
  color: rgba(255, 255, 255, 0.92);
}

.mega-menu-featured {
  flex: 0 0 clamp(240px, 24vw, 340px);
  width: clamp(240px, 24vw, 340px);
  min-width: min(100%, 220px);
  max-width: min(100%, 340px);
}
.mega-menu-featured .mega-menu-featured-label {
  display: block;
  font-size: 0.65rem;
  font-weight: 600;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: rgba(255, 255, 255, 0.7);
  margin-bottom: 0.5rem;
}
.mega-menu-featured .mega-menu-featured-link {
  display: block;
  text-decoration: none;
  color: inherit;
  position: relative;
  border-radius: 4px;
  overflow: hidden;
}
.mega-menu-featured .mega-menu-featured-link::after {
  content: "";
  position: absolute;
  left: 0;
  right: 0;
  bottom: 0;
  height: 48%;
  background: linear-gradient(180deg, rgba(0, 0, 0, 0) 0%, rgba(0, 0, 0, 0.68) 100%);
  pointer-events: none;
}
.mega-menu-featured .mega-menu-featured-img {
  width: 100%;
  height: clamp(260px, 36vh, 480px);
  object-fit: cover;
  object-position: center center;
  display: block;
  background: rgba(255, 255, 255, 0.06);
}
.mega-menu-featured .mega-menu-featured-title {
  position: absolute;
  left: 1rem;
  right: 1rem;
  bottom: 0.9rem;
  z-index: 1;
  display: block;
  margin: 0;
  font-size: 0.95rem;
  color: #fff;
  line-height: 1.35;
  text-shadow: 0 2px 10px rgba(0, 0, 0, 0.65);
}
.mega-menu-featured .mega-menu-featured-placeholder {
  height: clamp(260px, 36vh, 480px);
  background: rgba(255, 255, 255, 0.06);
  display: flex;
  align-items: center;
  justify-content: center;
  color: rgba(255, 255, 255, 0.7);
  font-size: 0.85rem;
}

.mega-menu-featured-carousel {
  position: relative;
  width: 100%;
}

.mega-menu-featured-carousel__viewport {
  position: relative;
  width: 100%;
  border-radius: 4px;
  overflow: hidden;
  aspect-ratio: 3/4;
  max-height: clamp(260px, 36vh, 480px);
}

.mega-menu-featured-slide {
  position: absolute;
  inset: 0;
  opacity: 0;
  visibility: hidden;
  transition: opacity 0.45s ease;
  z-index: 0;
}
.mega-menu-featured-slide.is-active {
  opacity: 1;
  visibility: visible;
  z-index: 1;
}
.mega-menu-featured-slide .mega-menu-featured-link {
  height: 100%;
}
.mega-menu-featured-slide .mega-menu-featured-img {
  height: 100%;
  width: 100%;
  object-fit: cover;
}

.mega-menu--typologies .mega-menu-featured {
  flex: 0 0 clamp(230px, 23vw, 330px);
  width: clamp(230px, 23vw, 330px);
  max-width: min(100%, 330px);
}

/* Mega menu Coleções (Commerce): grelha de cartões — título em caps + retângulo 3:2 */
.mega-menu-inner--commerce-collections {
  flex-direction: column;
  align-items: stretch;
  /* Evita centrar no eixo vertical (herdado de .mega-menu-inner) e mantém grelha colada ao topo */
  justify-content: flex-start !important;
  width: 100%;
  max-width: none;
  padding-top: 1.75rem;
  padding-bottom: 1.75rem;
}

/* CSS Grid: trilhos de largura uniforme; justify-content centra o bloco (sem “linhas” desalinhadas) */
.mega-menu-collections-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(17.5rem, 22rem));
  justify-content: center;
  gap: clamp(1.75rem, 3vw, 3rem);
  justify-items: stretch;
  align-items: start;
  width: 100%;
  margin: 0 auto;
  padding: 0;
  list-style: none;
  box-sizing: border-box;
}

.mega-menu-collections-grid__cell {
  margin: 0;
  padding: 0;
  list-style: none;
  min-width: 0;
}

.mega-menu-collection-card {
  display: flex;
  flex-direction: row;
  flex-wrap: nowrap;
  align-items: stretch;
  gap: clamp(0.65rem, 1.5vw, 1rem);
  width: 100%;
  max-width: none;
  text-decoration: none !important;
  color: inherit;
  transition: opacity 0.2s ease;
}
.mega-menu-collection-card:hover {
  opacity: 0.92;
}
.mega-menu-collection-card:hover .mega-menu-collection-card__img {
  transform: scale(1.02);
}
.mega-menu-collection-card:focus-visible {
  outline: 2px solid rgba(255, 255, 255, 0.5);
  outline-offset: 4px;
}

.mega-menu-collection-card__body {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  justify-content: center;
  flex: 1 1 0;
  min-width: 0;
  gap: 0.35rem;
}

.mega-menu-collection-card__title {
  display: block;
  font-size: 0.68rem;
  font-weight: 700;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: rgba(255, 255, 255, 0.92);
  margin: 0;
  line-height: 1.3;
  white-space: normal;
}

.mega-menu-collection-card__desc {
  margin: 0;
  font-size: 0.7rem;
  font-weight: 400;
  line-height: 1.45;
  letter-spacing: 0.02em;
  text-transform: none;
  color: rgba(255, 255, 255, 0.68);
  display: -webkit-box;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 5;
  overflow: hidden;
}

.mega-menu-collection-card__media {
  display: block;
  flex: 0 0 54%;
  width: 54%;
  max-width: 54%;
  align-self: center;
  aspect-ratio: 1/1;
  border-radius: 2px;
  overflow: hidden;
  background: rgba(255, 255, 255, 0.06);
}

.mega-menu-collection-card__media--placeholder {
  min-height: 0;
}

.mega-menu-collection-card__img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center center;
  display: block;
  transition: transform 0.35s ease;
}

@media (min-width: 992px) {
  .navbar-main {
    height: 80px;
    transition: background-color 0.3s ease;
  }
  .navbar-main.-fixed {
    background-color: #1e1e1e !important;
    height: 80px;
    box-shadow: 0 2px 20px rgba(0, 0, 0, 0.15);
  }
  .navbar-main.-fixed .navbar-brand .image {
    height: 48px;
  }
  .navbar-main .navbar-collapse {
    flex-grow: 0;
  }
  .navbar-main .nav-link {
    font-size: 0.7rem;
  }
  .navbar-main {
    /*
     * Coleções: com align-items:center no .navbar-nav, o <li> encolhia à altura do link.
     * Entre o fim do link e o topo do mega menu (position:fixed) o rato não estava sobre
     * nenhum descendente → perdia-se o :hover e o menu fechava antes de chegar às categorias.
     */
  }
  .navbar-main .nav-item-collections,
  .navbar-main .nav-item-commerce-collections {
    position: relative;
    align-self: stretch;
    display: flex;
    align-items: center;
  }
  .navbar-main .nav-item-collections > .nav-link,
  .navbar-main .nav-item-commerce-collections > .nav-link {
    display: flex;
    align-items: center;
    height: 100%;
  }
  .navbar-main {
    overflow: visible;
  }
  .navbar-main .dropdown-menu.mega-menu {
    position: fixed !important;
    left: 50% !important;
    right: auto !important;
    margin-left: -50vw !important;
    margin-right: 0 !important;
    width: 100vw !important;
    min-width: 100vw !important;
    max-width: 100vw !important;
    top: 80px !important;
    /* Limita a altura do mega menu para não ocupar o ecrã inteiro */
    height: auto !important;
    min-height: 0 !important;
    max-height: min(32rem, 100vh - 80px) !important;
    max-height: min(32rem, 100dvh - 80px) !important;
    transform: none !important;
    box-sizing: border-box !important;
  }
  .navbar-main.-fixed .dropdown-menu.mega-menu {
    top: 80px !important;
    height: auto !important;
    min-height: 0 !important;
    max-height: min(32rem, 100vh - 80px) !important;
    max-height: min(32rem, 100dvh - 80px) !important;
  }
  .navbar-main {
    /* Coleções (commerce): precisa de mais área vertical para não cortar os cards */
  }
  .navbar-main .dropdown-menu.mega-menu.mega-menu--commerce-collections {
    max-height: min(44rem, 100vh - 80px) !important;
    max-height: min(44rem, 100dvh - 80px) !important;
  }
  .navbar-main.-fixed .dropdown-menu.mega-menu.mega-menu--commerce-collections {
    max-height: min(44rem, 100vh - 80px) !important;
    max-height: min(44rem, 100dvh - 80px) !important;
  }
  .navbar-main .nav-item-collections:hover .mega-menu,
  .navbar-main .nav-item-collections .mega-menu:hover,
  .navbar-main .nav-item-commerce-collections:hover .mega-menu,
  .navbar-main .nav-item-commerce-collections .mega-menu:hover,
  .navbar-main .mega-menu.show {
    display: flex !important;
  }
}
/* Desktop: tipologias em 3×2 + destaque; mega menu produtos um pouco mais alto (duas linhas) */
@media (min-width: 992px) {
  .mega-menu-inner {
    flex-wrap: nowrap;
    align-items: flex-start;
    justify-content: space-between;
    gap: clamp(1.25rem, 2.5vw, 2rem);
  }
  .mega-menu--typologies .mega-menu-inner {
    flex-wrap: nowrap;
    justify-content: center;
  }
  .mega-menu--typologies .mega-menu-columns {
    max-width: min(100%, 56rem);
    column-gap: clamp(1.1rem, 2.2vw, 2rem);
    row-gap: 1.5rem;
  }
  .nav-item-collections .dropdown-menu.mega-menu--typologies {
    max-height: min(38rem, 100vh - 80px) !important;
    max-height: min(38rem, 100dvh - 80px) !important;
  }
  .navbar-main.-fixed .nav-item-collections .dropdown-menu.mega-menu--typologies {
    max-height: min(38rem, 100vh - 80px) !important;
    max-height: min(38rem, 100dvh - 80px) !important;
  }
  .mega-menu-featured {
    display: flex;
    flex-direction: column;
    flex: 0 0 clamp(240px, 24vw, 340px);
    width: clamp(240px, 24vw, 340px);
    max-width: min(100%, 340px);
    min-width: 0;
  }
  .mega-menu--typologies .mega-menu-featured {
    flex: 0 0 clamp(230px, 23vw, 330px);
    width: clamp(230px, 23vw, 330px);
    max-width: min(100%, 330px);
  }
  .mega-menu-featured-link {
    display: block;
  }
  .mega-menu-featured-img {
    width: 100%;
    height: clamp(160px, 22vh, 300px);
    max-height: 32vh;
    flex: none;
  }
  .mega-menu--typologies .mega-menu-featured-img,
  .mega-menu--typologies .mega-menu-featured-placeholder {
    height: clamp(240px, 32vh, 400px);
    max-height: 40vh;
  }
  .mega-menu--typologies .mega-menu-featured-carousel__viewport {
    max-height: clamp(240px, 32vh, 400px);
    aspect-ratio: 3/4;
  }
  .mega-menu--typologies .mega-menu-featured-carousel .mega-menu-featured-slide .mega-menu-featured-img {
    height: 100%;
    max-height: none;
  }
  .mega-menu-featured-placeholder {
    height: clamp(160px, 22vh, 300px);
    max-height: 32vh;
  }
}
@media (max-width: 991.98px) {
  .navbar-main .navbar-collapse#navbarMain {
    display: none !important;
  }
  .navbar-main .navbar-nav-actions .d-none.d-lg-block {
    display: none !important;
  }
  .mega-menu-inner {
    flex-direction: column;
    align-items: stretch;
    max-width: 100%;
  }
  .mega-menu--typologies .mega-menu-columns {
    grid-template-columns: 1fr;
    width: 100%;
    max-width: 100%;
    flex: 1 1 auto;
  }
  .mega-menu-column {
    max-width: 100%;
  }
  .mega-menu-featured {
    width: 100%;
    max-width: 100%;
    min-width: 0;
  }
}
.fw-menu,
.fw-search {
  height: 0;
  visibility: hidden;
  transition: height 0.4s ease, visibility 0.4s ease;
  background-color: #fff;
  position: fixed;
  width: 100%;
  z-index: 10000;
  top: 100%;
  overflow-y: auto;
}
.fw-menu.active,
.fw-search.active {
  height: 100%;
  visibility: visible;
  top: 0;
}

.fw-menu {
  background-color: #1e1e1e;
}
.fw-menu .fw-menu__inner {
  padding: 1rem max(1.25rem, env(safe-area-inset-right, 0px)) 2rem max(1.25rem, env(safe-area-inset-left, 0px));
  max-width: 100%;
  min-height: 100%;
  box-sizing: border-box;
}
.fw-menu .fw-menu__top {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 1rem;
}
.fw-menu .fw-menu__brand {
  display: flex;
  align-items: center;
}
.fw-menu .fw-menu__logo-img {
  height: 36px;
  width: auto;
  max-width: 168px;
  object-fit: contain;
}
.fw-menu .fw-menu__top-right {
  display: flex;
  align-items: center;
  gap: 0.75rem;
}
.fw-menu .fw-menu__locale a {
  color: rgba(255, 255, 255, 0.9) !important;
  font-size: 0.8rem;
  text-decoration: none !important;
}
.fw-menu .fw-menu__close {
  background: none;
  border: none;
  padding: 0.25rem;
  margin: 0;
  cursor: pointer;
  color: #fff;
  line-height: 0;
}
.fw-menu .fw-menu__close-icon {
  width: 1.75rem;
  height: 1.75rem;
  display: block;
}
.fw-menu .fw-menu__search-bar {
  display: block;
  width: 100%;
  text-align: left;
  padding: 0.85rem 1rem;
  margin-bottom: 1.5rem;
  border: none;
  border-radius: 2px;
  background: rgba(255, 255, 255, 0.1);
  color: rgba(255, 255, 255, 0.9);
  font-size: 0.9rem;
  cursor: pointer;
  font-family: inherit;
}
.fw-menu .fw-menu__search-text {
  opacity: 0.88;
}
.fw-menu .fw-menu__panels {
  position: relative;
}
.fw-menu .fw-menu-panel {
  display: none;
}
.fw-menu .fw-menu-panel.is-active {
  display: block;
}
.fw-menu .fw-menu__nav {
  display: flex;
  flex-direction: column;
}
.fw-menu .fw-menu__link {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 0.7rem 0;
  border: none;
  background: transparent;
  font-size: 1rem;
  font-weight: 500;
  color: #fff !important;
  text-decoration: none !important;
  text-align: left;
  width: 100%;
  font-family: inherit;
  cursor: pointer;
  line-height: 1.3;
  touch-action: manipulation;
  -webkit-tap-highlight-color: transparent;
}
.fw-menu .fw-menu__chevron {
  width: 1.25rem;
  height: 1.25rem;
  flex-shrink: 0;
  opacity: 0.7;
}
.fw-menu .fw-menu__back {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  width: 100%;
  padding: 0.5rem 0 1rem;
  margin-bottom: 0.25rem;
  border: none;
  background: none;
  font-size: 0.72rem;
  font-weight: 600;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: #fff;
  cursor: pointer;
  font-family: inherit;
  text-align: left;
}
.fw-menu .fw-menu__chevron--back {
  width: 1.25rem;
  height: 1.25rem;
  flex-shrink: 0;
  opacity: 0.55;
}
.fw-menu .fw-menu__collections-scroll {
  max-height: calc(100vh - 200px);
  overflow-y: auto;
  -webkit-overflow-scrolling: touch;
  padding-bottom: 2rem;
  scrollbar-width: thin;
}
.fw-menu .fw-menu__group {
  margin-top: 1rem;
}
.fw-menu .fw-menu__group:first-child {
  margin-top: 0;
}
.fw-menu .fw-menu__group-title {
  margin: 0 0 0.45rem;
  font-size: 0.68rem;
  font-weight: 600;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: rgba(255, 255, 255, 0.92);
}
.fw-menu .fw-menu__group-list {
  list-style: none;
  margin: 0;
  padding: 0;
}
.fw-menu .fw-menu__sublink {
  display: block;
  padding: 0.42rem 0;
  font-size: 0.92rem;
  font-weight: 400;
  color: rgba(255, 255, 255, 0.78) !important;
  text-decoration: none !important;
}

.fw-menu .fw-menu__sublink--collection {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: 0.2rem;
}

.fw-menu .fw-menu__sublink--collection .fw-menu__sublink-title {
  font-size: 0.92rem;
  font-weight: 500;
  color: rgba(255, 255, 255, 0.88) !important;
}

.fw-menu .fw-menu__sublink--collection .fw-menu__sublink-desc {
  font-size: 0.72rem;
  line-height: 1.45;
  font-weight: 400;
  color: rgba(255, 255, 255, 0.52) !important;
}
.fw-menu .fw-menu__footer {
  margin-top: 2.25rem;
  padding-top: 1.35rem;
}
.fw-menu .fw-menu__footer-title {
  font-weight: 600;
  font-size: 0.85rem;
  margin: 0 0 0.45rem;
  color: rgba(255, 255, 255, 0.88);
}
.fw-menu .fw-menu__footer-text {
  font-size: 0.8rem;
  line-height: 1.55;
  color: rgba(255, 255, 255, 0.68);
  margin: 0 0 0.35rem;
}

body.menu-open,
body.search-open {
  overflow: hidden;
}

.company-info .title {
  font-size: 10pt;
}

.menu-link {
  font-family: "Raleway-bold";
  font-size: 26pt;
  color: #1e1e1e !important;
  text-decoration: none !important;
  padding-bottom: 2px;
  overflow: hidden;
  display: block;
  position: relative;
}
.menu-link > .link-border {
  display: block;
  width: 0;
  height: 2px;
  background-color: #1e1e1e !important;
  transition: width 0.35s ease;
}
.menu-link:hover > .link-border {
  width: 100%;
}
.menu-link > .mask {
  content: " ";
  display: block;
  width: 100%;
  height: 100%;
  background-color: #ECE9E3;
  position: absolute;
  top: 0;
  left: 0;
}

.product-search > .input {
  font-size: 34pt;
  border: none;
  border-bottom: 1px solid #000;
  border-radius: 0;
  outline: none;
  box-shadow: none;
}
.product-search > .input:focus {
  outline: none;
}
.product-search > .input-group-append > .btn {
  border: none;
  border-bottom: 1px solid #000;
  border-radius: 0;
  background: none;
  font-size: 34pt;
  color: #bebebc;
  box-shadow: none;
}
.product-search > .input-group-append > .btn:hover,
.product-search > .input-group-append > .btn:active,
.product-search > .input-group-append > .btn:focus {
  background: none;
  color: #1e1e1e;
  box-shadow: none;
}

#search-product-list {
  margin: 0;
  padding: 0;
  list-style: none;
}
#search-product-list > .productinfo {
  display: flex;
  align-items: center;
}
#search-product-list > .productinfo > .icon {
  text-align: right;
  flex-grow: 1;
  padding-top: 15px;
}
#search-product-list > .productinfo > .name {
  font-size: 32pt;
  flex-grow: 16;
  text-decoration: none !important;
  color: #1e1e1e;
  display: block;
  padding: 10px 10px 10px 0;
  font-weight: bold;
}
#search-product-list > .productinfo > .name > .category {
  font-size: 18pt;
  font-weight: 300;
}

.fw-search {
  background-color: #fff;
  -webkit-overflow-scrolling: touch;
}
.fw-search__inner {
  padding: 1rem 1.25rem 2rem;
  max-width: 720px;
  margin: 0 auto;
}
.fw-search__top {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 1.25rem;
}
.fw-search__title {
  font-size: 0.7rem;
  font-weight: 600;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: #1a1a1a;
}
.fw-search__close {
  background: none;
  border: none;
  padding: 0.25rem;
  margin: 0;
  cursor: pointer;
  color: #1a1a1a;
  line-height: 0;
}
.fw-search__close-icon {
  width: 1.75rem;
  height: 1.75rem;
  display: block;
}
.fw-search__field {
  display: flex;
  align-items: stretch;
  border-radius: 2px;
  overflow: hidden;
  background: #f0f0f0;
  border: 1px solid rgba(0, 0, 0, 0.06);
}
.fw-search__input {
  flex: 1;
  border: none !important;
  background: transparent !important;
  box-shadow: none !important;
  padding: 0.9rem 1rem;
  font-size: 1rem;
  color: #1a1a1a;
  min-width: 0;
  border-radius: 0 !important;
}
.fw-search__input:focus {
  outline: none;
}
.fw-search__input::placeholder {
  color: #888;
}
.fw-search__submit {
  border: none !important;
  background: transparent !important;
  box-shadow: none !important;
  padding: 0 1rem;
  color: #555;
  cursor: pointer;
  font-size: 1.1rem;
}
.fw-search__submit:hover, .fw-search__submit:focus {
  color: #111;
}
.fw-search__results {
  margin-top: 1rem;
}
.fw-search__list {
  margin: 0;
  padding: 0;
  list-style: none;
}
.fw-search #search-product-list > .productinfo {
  padding: 0.65rem 0;
}
.fw-search #search-product-list > .productinfo > .icon {
  padding-top: 0;
  flex-grow: 0;
  flex-shrink: 0;
  color: #999;
  font-size: 0.85rem;
}
.fw-search #search-product-list > .productinfo > .name {
  font-size: 1rem !important;
  font-weight: 600 !important;
  letter-spacing: 0.05em;
  text-transform: uppercase;
  padding: 0 !important;
  color: #1a1a1a !important;
  flex-grow: 1;
  line-height: 1.35;
}
.fw-search #search-product-list > .productinfo > .name > .category {
  font-size: 0.85rem !important;
  font-weight: 400 !important;
  text-transform: none;
  letter-spacing: 0;
  color: #666 !important;
  margin-left: 0.4rem;
}
.fw-search__load-more-wrap .btn {
  font-size: 0.85rem;
  padding: 0.5rem 1.25rem;
}

/* Paginação editorial — sem caixas Bootstrap; alinhada ao resto do site */
.praddy-pagination {
  display: flex;
  justify-content: center;
  width: 100%;
  margin-top: clamp(2.5rem, 5vw, 4rem) !important;
  padding: 0 1rem;
  box-sizing: border-box;
}
.praddy-pagination .pagination {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: center;
  gap: 0.15rem 0.35rem;
  margin: 0;
  padding: 0;
  list-style: none;
  border: none;
  border-radius: 0;
}
.praddy-pagination .page-item {
  margin: 0;
  border: none;
}
.praddy-pagination .page-item + .page-item {
  margin-left: 0;
}
.praddy-pagination .page-link,
.praddy-pagination span.page-link {
  position: relative;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 2.35rem;
  height: 2.35rem;
  padding: 0 0.5rem;
  margin: 0;
  font-size: 0.6875rem;
  font-weight: 500;
  letter-spacing: 0.1em;
  line-height: 1;
  color: rgba(17, 17, 17, 0.45);
  text-decoration: none !important;
  background: transparent !important;
  border: none !important;
  border-radius: 0 !important;
  box-shadow: none !important;
  transition: color 0.2s ease, opacity 0.2s ease;
}
.praddy-pagination .page-link:hover, .praddy-pagination .page-link:focus,
.praddy-pagination span.page-link:hover,
.praddy-pagination span.page-link:focus {
  color: #1e1e1e;
  background: transparent !important;
}
.praddy-pagination .page-link:focus-visible,
.praddy-pagination span.page-link:focus-visible {
  outline: 1px solid rgba(17, 17, 17, 0.35);
  outline-offset: 3px;
}
.praddy-pagination .page-link .fa,
.praddy-pagination span.page-link .fa {
  font-size: 0.85rem;
  opacity: 0.7;
}
.praddy-pagination .page-item.active .page-link {
  color: #1e1e1e !important;
  font-weight: 600;
  background: transparent !important;
  border: none !important;
}
.praddy-pagination .page-item.active .page-link::after {
  content: "";
  position: absolute;
  left: 50%;
  bottom: 0.2rem;
  transform: translateX(-50%);
  width: 1.15rem;
  height: 1px;
  background-color: currentColor;
  opacity: 0.85;
}
.praddy-pagination .page-item.disabled .page-link {
  color: rgba(17, 17, 17, 0.22) !important;
  pointer-events: none;
  cursor: default;
}
.praddy-pagination .page-item.disabled .page-link .fa {
  opacity: 0.4;
}
.praddy-pagination {
  /* Separador visual suave entre números e setas */
}
.praddy-pagination .page-item:first-child .page-link {
  margin-right: 0.35rem;
}
.praddy-pagination .page-item:last-child .page-link {
  margin-left: 0.35rem;
}

.newsletter-container {
  text-align: center;
  margin: 0 auto;
  padding: 40px 0 0;
}

.newsletter-form {
  position: relative;
}
.newsletter-form > .input-button {
  display: flex;
  border: 1px solid #7d7d7d;
}
.newsletter-form > .input-button > .input,
.newsletter-form > .input-button > .action {
  border: none;
}
.newsletter-form > .input-button > .action {
  cursor: pointer;
}

.newsletter-container > .title {
  margin-top: 0;
}
.newsletter-container.-pagesection {
  padding-top: 30px;
  max-width: 680px;
}
.newsletter-container.-pagesection > .newsletter-form {
  padding: 0 5px;
}
.newsletter-container.-pagesection > .newsletter-form > .input-button > .action {
  padding: 10px 15px;
}
.newsletter-container.-pagesection > .newsletter-form > .input-button > .input {
  border-right: 1px solid #7d7d7d;
  padding: 10px 15px;
  width: 100%;
}
.newsletter-container.-footer {
  padding-top: 40px;
}
.newsletter-container.-footer > .title {
  color: #fff;
}
.newsletter-container.-footer > .newsletter-form {
  width: 70%;
  margin: 0 auto;
}
.newsletter-container.-footer > .newsletter-form > .input {
  border: none;
  background-color: transparent;
  border-bottom: 1px solid #7d7d7d;
  padding: 10px 15px;
  width: 100%;
  color: #fff;
  font-family: "Raleway";
  font-size: 14pt;
}
.newsletter-container.-footer > .newsletter-form > .action {
  margin-top: 25px;
  border: none;
  padding: 3px 3px 7px;
  border-bottom: 1px solid #bebebc;
  background-color: transparent;
  text-transform: uppercase;
  color: #fff;
  font-size: 14pt;
  font-weight: 300;
  font-family: "Raleway";
}

@media (min-width: 480px) {
  .newsletter-container.-pagesection > .newsletter-form {
    padding: 0 15px;
  }
  .newsletter-container.-footer {
    padding: 35px 0 40px 15px;
    border-left: 2px solid #fff;
    flex-grow: 1;
    margin: 0;
    text-align: left;
  }
  .newsletter-container.-footer > .newsletter-form {
    width: 70%;
    margin: 0;
  }
  .newsletter-container.-footer > .newsletter-form > .action {
    position: absolute;
    right: 0;
    bottom: 0;
    cursor: pointer;
  }
}
@media (min-width: 768px) {
  .newsletter-container.-pagesection > .newsletter-form {
    padding: 0 40px;
  }
  .newsletter-container.-footer > .newsletter-form {
    width: 100%;
    max-width: 450px;
    position: relative;
  }
  .newsletter-container.-footer {
    flex-grow: 4;
  }
}
footer.-bg-dark {
  background-color: #1e1e1e !important;
}

.page-footer {
  padding: 2.75rem 0 1.25rem;
}
.page-footer > .container {
  display: flex;
  flex-direction: column;
  align-items: stretch;
  justify-content: space-between;
  gap: 1.75rem;
}
.page-footer .newsletter-container.-footer {
  padding: 0;
  margin: 0;
  border-left: none;
  text-align: left;
  max-width: 28rem;
}
.page-footer .newsletter-container.-footer > .title {
  color: #ebebeb;
  font-size: 1.125rem;
  font-weight: 300;
  margin-bottom: 0.75rem;
}
.page-footer .footer-brand-mark {
  width: 120px;
  height: 120px;
  object-fit: contain;
  margin-bottom: 0.75rem;
}
.page-footer .footer-newsletter-field {
  width: 100%;
  max-width: 24rem;
}
.page-footer .newsletter-container.-footer > .newsletter-form > .footer-newsletter-field > .input {
  border: none;
  background-color: transparent;
  border-bottom: 1px solid rgba(235, 235, 235, 0.7);
  width: 100%;
  color: #ebebeb;
  font-size: 0.95rem;
  padding: 0.45rem 0;
}

.socialmedia-sitemap {
  text-align: left;
  margin-top: 0;
  border-top: 1px solid rgba(255, 255, 255, 0.22);
  padding-top: 1rem;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
  flex-wrap: wrap;
}

.social-media-list {
  vertical-align: middle;
}
.social-media-list > .socialmedia {
  display: inline-block;
  padding: 15px;
}
.social-media-list > .socialmedia:last-child {
  padding-right: 0;
}
.social-media-list > .socialmedia > .link {
  color: #fff;
}
.social-media-list > .socialmedia > .link:hover {
  color: #bebebc;
}

.copyright {
  color: #fff;
  text-align: center;
  width: 100%;
  margin-top: 40px;
}

.cookies-legal {
  font-size: 0.56rem;
  letter-spacing: 0.05em;
  margin: 0;
  text-align: left;
  color: rgba(255, 255, 255, 0.66);
}
.cookies-legal .footer-copyright-text {
  color: #fff;
}
.cookies-legal .footer-credits-text {
  display: inline-block;
  margin-top: 0.35rem;
  color: rgba(255, 255, 255, 0.66);
}
.cookies-legal .footer-credits-text a:hover {
  color: #bebebc !important;
}
.cookies-legal > a:hover {
  color: #bebebc !important;
}

@media (min-width: 425px) and (max-width: 767px) {
  .page-footer > .container {
    gap: 1.5rem;
  }
  .page-footer > .container > .newsletter-container.-footer,
  .page-footer > .container > .socialmedia-sitemap {
    width: 100%;
  }
}
@media (min-width: 768px) {
  .page-footer > .container {
    flex-direction: row;
    flex-wrap: nowrap;
    align-items: flex-end;
  }
  .page-footer > .container > .socialmedia-sitemap {
    margin-top: 0;
    flex-grow: 1;
    text-align: right;
    justify-content: space-between;
  }
  .page-footer .social-media-list.-only {
    padding: 0;
    text-align: left !important;
  }
  .page-footer .cookies-legal.-only {
    text-align: right;
  }
}
/*
 -------------------------------------------------------------------
 Pages
 -------------------------------------------------------------------
*/
.bg-dark {
  background: #1e1e1e !important;
}

@font-face {
  font-family: "Raleway";
  src: url("/themes/praddy/assets/dist/fonts/Raleway/Raleway-Light.ttf");
}
@font-face {
  font-family: "Raleway-extra-light";
  src: url("/themes/praddy/assets/dist/fonts/Raleway/Raleway-ExtraLight.ttf");
}
@font-face {
  font-family: "Raleway-bold";
  src: url("/themes/praddy/assets/dist/fonts/Raleway/Raleway-SemiBold.ttf");
}
@font-face {
  font-family: "Audrey";
  src: url("/themes/praddy/assets/dist/fonts/Audrey/Audrey-Normal.otf");
}
@font-face {
  font-family: "Audrey-Oblique";
  src: url("/themes/praddy/assets/dist/fonts/Audrey/Audrey-NormalOblique.otf");
}
@font-face {
  font-family: "Audrey-Bold";
  src: url("/themes/praddy/assets/dist/fonts/Audrey/Audrey-Bold.otf");
}
@font-face {
  font-family: "Audrey-BoldOblique";
  src: url("/themes/praddy/assets/dist/fonts/Audrey/Audrey-BoldOblique.otf");
}
@font-face {
  font-family: "Audrey-Medium";
  src: url("/themes/praddy/assets/dist/fonts/Audrey/Audrey-Medium.otf");
}
@font-face {
  font-family: "Audrey-MediumOblique";
  src: url("/themes/praddy/assets/dist/fonts/Audrey/Audrey-MediumOblique.otf");
}
.page-section.-bg-dark {
  color: #fff;
}
.page-section.-info {
  text-align: center;
}
.page-section.-info > .container > .title {
  position: relative;
  padding-bottom: 25px;
  font-family: "Raleway-bold";
  font-size: 18pt;
}
.page-section.-info > .container > .title:after {
  content: "";
  width: 50px;
  height: 1px;
  background-color: #bebebc;
  position: absolute;
  bottom: 0;
  left: 50%;
  transform: translate(-50%, 0);
}
.page-section.-info > .container > .description {
  font-size: 14pt;
  line-height: 25px;
}

/*
 -------------------------------------------------------------------
 Header slide
 -------------------------------------------------------------------
*/
.slide-image {
  padding-bottom: 80%;
  background-size: cover;
  min-height: 100px !important;
}

.slick-next,
.slick-prev {
  top: 45% !important;
}
.slick-next::before,
.slick-prev::before {
  font-family: inherit !important;
}

.slick-next::before {
  content: "\f105" !important;
}

.slick-prev::before {
  content: "\f104" !important;
}

/* Só espaço vertical entre blocos; laterais em full bleed (sem padding horizontal) */
.home-page-inset {
  padding-top: clamp(0.625rem, 2.75vw, 2.875rem);
  padding-bottom: 0;
  padding-left: 0;
  padding-right: 0;
  box-sizing: border-box;
}

/* Respiro entre o slide superior e o hero / primeiro bloco (slick-theme também pode meter margin) */
.slide-header.slick-slider {
  margin-bottom: clamp(0.75rem, 2.5vw, 1.75rem) !important;
}

.slide-header .slick-list,
.slide-header .slick-track {
  margin-bottom: 0;
}

/* Destaques home — fundo branco contínuo com a área de imagem */
.featured-product-container.container-fluid {
  padding-left: 0;
  padding-right: 0;
}

.featured-product-container {
  max-width: min(1800px, 100%);
  margin-left: auto;
  margin-right: auto;
  overflow: hidden;
  padding: 0 0 clamp(2rem, 5vw, 3.5rem);
  box-sizing: border-box;
}

.featured-product__row {
  margin-top: 0;
}

/* Especificidade > .no-gutters > [class*=col-] do Bootstrap (senão padding horizontal fica sempre 0) */
.row.featured-product__row.no-gutters > .featured-product-details {
  background-color: #fff;
  padding-top: clamp(1.75rem, 4vw, 2.85rem);
  padding-bottom: clamp(1.75rem, 4vw, 2.85rem);
  padding-left: clamp(2.25rem, 7vw, 6rem);
  padding-right: clamp(2rem, 5.5vw, 4.5rem);
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  box-sizing: border-box;
  min-height: 0;
}
.row.featured-product__row.no-gutters > .featured-product-details .light-text {
  font-weight: 300;
}
.row.featured-product__row.no-gutters > .featured-product-details .extra-light-text {
  font-weight: 200;
}
.row.featured-product__row.no-gutters > .featured-product-details .btn {
  font-family: "Raleway-bold";
  border-radius: 0;
}

.featured-product__copy {
  flex: 1 1 auto;
  max-width: 38rem;
}

.featured-product__title {
  letter-spacing: 0.1em;
  text-transform: uppercase;
  font-size: clamp(1rem, 1.8vw, 1.2rem);
  margin-bottom: clamp(0.75rem, 2vw, 1.1rem);
  color: #1e1e1e;
  line-height: 1.35;
}

.featured-product__description {
  line-height: 1.65;
  color: #4a4a4a;
  margin-bottom: 0;
  font-size: clamp(0.9375rem, 1.35vw, 1rem);
}

.featured-product__cta {
  margin-top: clamp(1.25rem, 2.5vw, 1.75rem);
  align-self: flex-start;
  padding: 0.45rem 1.5rem !important;
  border-radius: 0;
  font-size: 0.75rem;
  letter-spacing: 0.12em;
}

.featured-product__thumbs {
  margin-top: clamp(1.5rem, 3.5vw, 2.25rem);
  padding-top: clamp(1.25rem, 2.5vw, 1.75rem);
}

.featured-thumb {
  padding: 0 0.35rem;
}
.featured-thumb:first-child {
  padding-left: 0;
}
.featured-thumb:last-child {
  padding-right: 0;
}
.featured-thumb {
  display: flex;
  align-items: stretch;
  justify-content: center;
}

.featured-product__thumb-img {
  display: block;
  width: 100%;
  height: auto;
  object-fit: contain;
  background-color: #fff;
  box-sizing: border-box;
}

/* Mesmo respiro superior que .featured-product-details — evita título “descolado” do topo da imagem */
.row.featured-product__row.no-gutters > .featured-image {
  padding-top: clamp(1.75rem, 4vw, 2.85rem);
  box-sizing: border-box;
}

.featured-image {
  max-height: 980px;
  overflow: hidden;
  background-color: #fff;
  display: flex;
  align-items: flex-start;
  justify-content: center;
  min-height: 0;
}

.featured-product__hero-img {
  width: 100%;
  height: auto;
  max-height: none;
  object-fit: contain;
  object-position: top center;
  display: block;
}

@media (min-width: 768px) {
  .row.featured-product__row.no-gutters > .featured-product-details {
    min-height: 100%;
  }
  .featured-thumb {
    margin-bottom: 0;
  }
}
/*
 -------------------------------------------------------------------
 Home — hero produto (logo após o slider; antes dos destaques / vídeo)
 -------------------------------------------------------------------
*/
.home-product-hero {
  position: relative;
  --home-hero-outer-gutter: clamp(1rem, 2.8vw, 2rem);
  width: 100%;
  margin-top: 0;
  margin-bottom: 0;
  padding-bottom: 0;
  background: #fff;
  color: #1a1a1a;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

.home-product-hero::before {
  content: "";
  display: block;
  width: 100%;
  height: clamp(1rem, 2.8vw, 2.25rem);
  background: #fff;
  flex-shrink: 0;
}

@media (min-width: 992px) {
  .home-product-hero {
    box-shadow: inset 0 1px 0 rgba(0, 0, 0, 0.06);
  }
}

.home-product-hero__split {
  display: flex;
  flex-direction: column;
  min-height: 0;
  padding-left: var(--home-hero-outer-gutter);
  padding-right: var(--home-hero-outer-gutter);
  box-sizing: border-box;
}

@media (min-width: 992px) {
  .home-product-hero__split {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    grid-template-rows: minmax(clamp(360px, 48vh, 720px), auto);
    align-items: stretch;
    justify-items: stretch;
    column-gap: clamp(0.65rem, 1.8vw, 1.15rem);
    background: #fff;
  }
}

.home-product-hero__col--media {
  position: relative;
  flex: 1 1 auto;
  min-height: 52vh;
  background: #fff;
  overflow: hidden;
  order: 1;
  padding-left: 0;
  padding-right: 0;
  box-sizing: border-box;
}

@media (min-width: 992px) {
  .home-product-hero__col--media {
    order: 0;
    width: auto;
    min-height: 0;
    height: 100%;
  }
}

.home-product-hero__col--copy {
  flex: 1 1 auto;
  display: flex;
  flex-direction: column;
  align-items: stretch;
  justify-content: flex-start;
  text-align: left;
  padding-top: clamp(3rem, 9vw, 4rem);
  padding-right: clamp(2rem, 6vw, 2.5rem);
  padding-bottom: clamp(3rem, 9vw, 4rem);
  padding-left: clamp(1.25rem, 5vw, 1.75rem);
  background: #fff;
  order: 0;
}

@media (max-width: 991.98px) {
  .home-product-hero__col--copy {
    padding-left: clamp(1.25rem, 5vw, 1.75rem);
    padding-right: clamp(1.4rem, 4.5vw, 1.9rem);
  }
}

@media (min-width: 992px) {
  .home-product-hero__col--copy {
    width: auto;
    min-height: 0;
    height: 100%;
    padding-top: clamp(2.75rem, 5.5vh, 4.5rem);
    padding-right: clamp(2.25rem, 4.5vw, 3.75rem);
    padding-bottom: clamp(2.75rem, 5.5vh, 4.5rem);
    padding-left: clamp(1.25rem, 5vw, 1.75rem);
    overflow: visible;
    box-shadow: 6px 0 32px rgba(0, 0, 0, 0.04);
    z-index: 1;
    justify-content: flex-start;
  }
}

.home-product-hero__copy-stack {
  width: 100%;
  max-width: 100%;
  margin-left: 0;
  margin-right: 0;
}

@media (min-width: 992px) {
  .home-product-hero__copy-stack {
    max-width: min(34rem, 94%);
    margin-top: 0;
    margin-bottom: 0;
    margin-left: 0;
    margin-right: auto;
  }
}

.home-product-hero__viewport {
  position: absolute;
  top: 0;
  bottom: 0;
  left: 0;
  right: 0;
  width: 100%;
  height: 100%;
}

.home-product-hero__slide {
  position: absolute;
  inset: 0;
  opacity: 0;
  visibility: hidden;
  transition: opacity 1s ease, visibility 1s ease;
  z-index: 0;
}

.home-product-hero__slide.is-active {
  opacity: 1;
  visibility: visible;
  z-index: 1;
}

.home-product-hero__media {
  position: absolute;
  inset: 0;
  overflow: hidden;
}

.home-product-hero__img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center center;
  display: block;
}

@media (max-width: 991.98px) {
  .home-product-hero__col--media {
    min-height: 48vh;
  }
}

.home-product-hero__kicker {
  margin: 0 0 0.85rem;
  font-family: "Raleway", "Lato", sans-serif;
  font-size: 0.6875rem;
  font-weight: 600;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  color: rgba(26, 26, 26, 0.38);
}

.home-product-hero__title {
  margin: 0;
  padding-bottom: 1.25rem;
  margin-bottom: 1.5rem;
  max-width: 100%;
  font-family: "Audrey", Georgia, "Times New Roman", serif;
  font-size: clamp(1.5rem, 2.85vw, 2.35rem);
  font-weight: 400;
  line-height: 1.12;
  letter-spacing: 0.02em;
  color: #0d0d0d;
  hyphens: none;
  overflow-wrap: normal;
  word-break: normal;
  border-bottom: 1px solid rgba(0, 0, 0, 0.08);
}

.home-product-hero__body {
  width: 100%;
  max-width: 34rem;
  margin: 0 0 2rem;
  font-family: "Raleway", "Lato", sans-serif;
  font-size: clamp(0.9375rem, 1.05vw, 1.03125rem);
  font-weight: 400;
  line-height: 1.95;
  color: #3a3a3a;
}

.home-product-hero__body h1,
.home-product-hero__body h2,
.home-product-hero__body h3,
.home-product-hero__body h4,
.home-product-hero__body h5,
.home-product-hero__body h6,
.home-product-hero__body p,
.home-product-hero__body span {
  font: inherit;
  color: inherit;
  letter-spacing: inherit;
}

.home-product-hero__body h1,
.home-product-hero__body h2,
.home-product-hero__body h3,
.home-product-hero__body h4,
.home-product-hero__body h5,
.home-product-hero__body h6,
.home-product-hero__body p {
  margin: 0 0 1.35em;
}

.home-product-hero__body h1:last-child,
.home-product-hero__body h2:last-child,
.home-product-hero__body h3:last-child,
.home-product-hero__body h4:last-child,
.home-product-hero__body h5:last-child,
.home-product-hero__body h6:last-child,
.home-product-hero__body p:last-child {
  margin-bottom: 0;
}

.home-product-hero__read-more {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  margin: 0 0 1.4rem;
  padding: 0.55rem 1rem;
  border: 1px solid rgba(20, 20, 20, 0.2);
  background: transparent;
  color: #1e1e1e;
  font-family: "Raleway", "Lato", sans-serif;
  font-size: 0.7rem;
  font-weight: 600;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  cursor: pointer;
}

@media (max-width: 991.98px) {
  .home-product-hero__copy-stack {
    display: flex;
    flex-direction: column;
    align-items: center;
  }
  .home-product-hero__read-more,
  .home-product-hero__cta {
    display: flex !important;
    align-items: center;
    justify-content: center;
    width: 100%;
    max-width: 20rem;
    margin-left: auto !important;
    margin-right: auto !important;
    box-sizing: border-box;
  }
  .home-product-hero__read-more {
    margin-bottom: 0.7rem !important;
  }
  .home-product-hero__cta {
    margin-top: 0 !important;
    margin-bottom: 0 !important;
  }
  .home-product-hero__body[data-read-more][data-expanded=false] {
    max-height: 13.2em;
    overflow: hidden;
    position: relative;
  }
  .home-product-hero__body[data-read-more][data-expanded=false]::after {
    content: "";
    position: absolute;
    left: 0;
    right: 0;
    bottom: 0;
    height: 2.8em;
    background: linear-gradient(180deg, rgba(255, 255, 255, 0) 0%, #fff 85%);
    pointer-events: none;
  }
}

@media (min-width: 992px) {
  .home-product-hero__read-more {
    display: none;
  }
}

.home-product-hero__body ul,
.home-product-hero__body ol {
  margin: 0 0 1.35em;
  padding-left: 1.25rem;
}

.home-product-hero__body li {
  margin-bottom: 0.5em;
}

.home-product-hero__body li:last-child {
  margin-bottom: 0;
}

.home-product-hero__body strong {
  font-weight: 600;
  color: #222;
}

.home-product-hero__body a {
  color: #2c2c2c;
  text-decoration: underline;
  text-decoration-color: rgba(44, 44, 44, 0.28);
  text-underline-offset: 0.22em;
  transition: color 0.2s ease, text-decoration-color 0.2s ease;
}

.home-product-hero__body a:hover {
  color: #0d0d0d;
  text-decoration-color: rgba(13, 13, 13, 0.5);
}

.home-product-hero__cta {
  display: inline-block;
  padding: 0.72rem 1.9rem;
  font-family: "Raleway", "Lato", sans-serif;
  font-size: 0.6875rem;
  font-weight: 600;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  text-decoration: none;
  color: #fff;
  border: 1px solid #1a1a1a;
  background: #1a1a1a;
  transition: background 0.22s ease, color 0.22s ease, border-color 0.22s ease, transform 0.2s ease;
}

.home-product-hero__cta:hover {
  color: #1a1a1a;
  background: #fff;
  border-color: #1a1a1a;
  text-decoration: none;
  transform: translateY(-1px);
}

/*
 -------------------------------------------------------------------
 Production slide
 -------------------------------------------------------------------
*/
#production-section {
  padding-top: 0 !important;
  padding-bottom: 0 !important;
}

#production-slide {
  margin-top: 0;
  margin-bottom: -10px;
  background: #1e1e1e;
}
#production-slide .slider-nav .slick-track {
  transform: none !important;
  display: flex;
  justify-content: center;
  width: 100% !important;
}
#production-slide .slider-nav .slick-track > .slick-slide {
  width: auto !important;
  max-width: 450px;
  overflow: hidden;
  cursor: pointer;
}

.home-video-hero {
  position: relative;
  margin-top: 0;
  margin-bottom: 0;
  background: #1e1e1e;
}
.home-video-hero__video {
  object-fit: cover;
}

/*
 -------------------------------------------------------------------
 Products (estilos da listagem: import global em style.scss)
 -------------------------------------------------------------------
*/
/*
 -------------------------------------------------------------------
 News (secção home)
 -------------------------------------------------------------------
*/
.home-news-section {
  background-color: #fff;
  padding-top: clamp(1.75rem, 4vw, 2.75rem);
  padding-bottom: clamp(1.75rem, 5vh, 3rem);
  padding-left: 0;
  padding-right: 0;
}

/* Largura contida para cartões mais pequenos; sem padding lateral na secção (só margens auto) */
.home-news-section__inner {
  max-width: min(56rem, 100%);
  margin-left: auto;
  margin-right: auto;
  padding-left: 0;
  padding-right: 0;
}

.home-news-section__inner .home-news__grid {
  margin-left: 0;
  margin-right: 0;
}

.home-news-section__inner .home-news__item {
  padding-left: 0.5rem;
  padding-right: 0.5rem;
}

.articles-list > .newsarticle {
  display: flex;
  flex-direction: column;
}
.articles-list > .newsarticle > .content,
.articles-list > .newsarticle > .image {
  display: block;
  color: #1e1e1e;
}
.articles-list > .newsarticle > .image > .img-fluid {
  width: 100%;
}
.articles-list > .newsarticle > .content {
  padding: 35px 0;
  text-align: justify;
  text-decoration: none;
}
.articles-list {
  /* /news: link envolve imagem + texto */
}
.articles-list > .newsarticle > .newsarticle__link--list {
  display: flex;
  flex-direction: column;
  width: 100%;
  color: #1e1e1e;
  text-decoration: none;
}
.articles-list > .newsarticle > .newsarticle__link--list:hover {
  color: #1e1e1e;
  text-decoration: none;
}
.articles-list > .newsarticle > .newsarticle__link--list > .content,
.articles-list > .newsarticle > .newsarticle__link--list > .image {
  display: block;
  color: #1e1e1e;
}
.articles-list > .newsarticle > .newsarticle__link--list > .image > .img-fluid {
  width: 100%;
}
.articles-list > .newsarticle > .newsarticle__link--list > .content {
  padding: 35px 0;
  text-align: justify;
}

.articles-list.-featured {
  padding: 35px 0;
}
.articles-list.-featured > .newsarticle {
  margin-bottom: 25px;
}
.articles-list.-featured > .newsarticle > .newsarticle__link {
  display: flex;
  flex-direction: column;
  height: 100%;
  color: #1e1e1e;
  text-decoration: none;
}
.articles-list.-featured > .newsarticle > .newsarticle__link:hover {
  color: #1e1e1e;
  text-decoration: none;
}
.articles-list.-featured > .newsarticle > .newsarticle__link > .image {
  max-width: 650px;
  max-height: 400px;
  overflow: hidden;
}
.articles-list.-featured > .newsarticle > .newsarticle__link > .image > .img-fluid {
  width: 100%;
}
.articles-list.-featured > .newsarticle > .newsarticle__link > .content {
  position: relative;
  margin-top: 15px;
  padding: 0;
}
.articles-list.-featured > .newsarticle > .newsarticle__link > .content > .date {
  margin: 15px 0;
  font-weight: bold;
}
.articles-list.-featured > .newsarticle > .newsarticle__link > .content > .title {
  font-family: "Raleway-bold";
  text-transform: uppercase;
  margin-top: 15px;
}
.articles-list.-featured > .newsarticle:last-child,
.articles-list.-featured > .newsarticle > .newsarticle__link > .content > .description {
  margin-bottom: 0;
}

/* Home — grelha 3 colunas: imagem, data, título caps, resumo */
.home-news__head {
  margin-bottom: 1rem;
}

.home-news__title {
  font-family: "Raleway-bold";
  text-transform: uppercase;
  font-size: clamp(0.8125rem, 1.35vw, 1rem);
  letter-spacing: 0.12em;
  margin: 0;
  color: #1e1e1e;
}

.home-news__all {
  display: inline-block;
  font-size: 0.6875rem;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: #1e1e1e;
  line-height: 1.2;
  text-decoration: none;
  transition: opacity 0.2s ease;
}
.home-news__all:hover {
  color: #1e1e1e;
  text-decoration: underline;
  text-underline-offset: 4px;
  opacity: 0.85;
}

.home-news__item {
  margin-bottom: 2rem;
}
@media (min-width: 768px) {
  .home-news__item {
    margin-bottom: 0;
  }
}

.home-news__link {
  display: flex;
  flex-direction: column;
  height: 100%;
  text-decoration: none;
  color: #1e1e1e;
}
.home-news__link:hover, .home-news__link:focus {
  color: #1e1e1e;
  text-decoration: none;
}
.home-news__link:hover .home-news__img, .home-news__link:focus .home-news__img {
  opacity: 0.92;
}

.home-news__media {
  overflow: hidden;
  background: #fff;
  margin-bottom: 0.55rem;
  border-radius: 1px;
}

.home-news__img {
  display: block;
  width: 100%;
  height: auto;
  max-height: 9.5rem;
  aspect-ratio: 4/3;
  object-fit: cover;
  object-position: center center;
  transition: opacity 0.3s ease;
  border: none;
  vertical-align: top;
}

.home-news__body {
  text-align: left;
  padding: 0;
  flex: 1 1 auto;
}

.home-news__date {
  display: block;
  margin: 0 0 0.35rem;
  font-size: 0.625rem;
  font-weight: 500;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: rgb(101.4, 101.4, 101.4);
}

.home-news__headline {
  margin: 0 0 0.4rem;
  font-family: "Raleway-bold";
  font-size: clamp(0.6875rem, 1.05vw, 0.8125rem);
  font-weight: 700;
  line-height: 1.3;
  letter-spacing: 0.09em;
  text-transform: uppercase;
  color: #1e1e1e;
}

.home-news__excerpt {
  margin: 0;
  font-family: "Raleway", "Lato", sans-serif;
  font-size: 0.6875rem;
  font-weight: 300;
  line-height: 1.5;
  color: rgb(75.9, 75.9, 75.9);
  display: -webkit-box;
  -webkit-line-clamp: 3;
  -webkit-box-orient: vertical;
  overflow: hidden;
}

@media (min-width: 768px) {
  .articles-list:not(.-featured) .newsarticle > .newsarticle__link--list {
    flex-direction: row;
    align-items: stretch;
  }
  .articles-list:not(.-featured) .newsarticle:nth-child(even) > .newsarticle__link--list {
    flex-direction: row-reverse;
  }
  .articles-list:not(.-featured) .newsarticle > .newsarticle__link--list > .image {
    width: 50%;
    overflow: hidden;
    max-height: 380px;
  }
  .articles-list:not(.-featured) .newsarticle > .newsarticle__link--list > .image > .img-fluid {
    max-width: none;
  }
  .articles-list:not(.-featured) .newsarticle > .newsarticle__link--list > .content {
    width: 50%;
    padding: 35px;
  }
  /*
  -------------------------------------------------------------------
  Featured
  -------------------------------------------------------------------
  */
  .articles-list.-featured {
    flex-direction: row;
  }
  .articles-list.-featured .newsarticle {
    display: block;
  }
  .articles-list.-featured .newsarticle > .newsarticle__link > .image {
    width: 100%;
  }
  .articles-list.-featured .newsarticle > .newsarticle__link > .content {
    padding: 15px 0 0 25px;
    margin-top: 0;
    width: 100%;
  }
  .articles-list.-featured > .newsarticle > .newsarticle__link > .content > .date {
    position: absolute;
    top: 45px;
    left: -30px;
    transform: rotateZ(-90deg);
  }
  .home-news__head {
    margin-bottom: 1rem;
  }
}
/*
 -------------------------------------------------------------------
 Europe Union
 -------------------------------------------------------------------
*/
#eu-section {
  padding: 35px 25px;
}
#eu-section > .image {
  filter: grayscale(100%);
}

/*
 -------------------------------------------------------------------
 Newsletter
 -------------------------------------------------------------------
*/
#newsletter-consent {
  display: flex;
  padding-left: 10%;
  margin-top: 20px;
  align-items: flex-start;
  text-align: left;
  cursor: pointer;
}
#newsletter-consent > .text {
  margin-left: 15px;
}

@media (min-width: 768px) {
  .slide-image {
    padding-bottom: 50%;
  }
}
/*
 -------------------------------------------------------------------
 Home — carrossel de produtos (AJAX)
 -------------------------------------------------------------------
*/
.home-products-carousel {
  background-color: #fff;
  padding-top: 2rem;
  padding-bottom: 3rem;
}
.home-products-carousel__inner {
  max-width: 1800px;
  margin: 0 auto;
  padding: 0 16px;
}
.home-products-carousel__headline {
  display: flex;
  align-items: center;
  gap: 14px;
  margin: 0 0 1rem;
}
.home-products-carousel__headline-line {
  flex: 1 1 auto;
  height: 1px;
  background: rgba(0, 0, 0, 0.14);
}
.home-products-carousel__headline-title {
  flex: 0 0 auto;
  font-size: 0.7rem;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: #515151;
  font-weight: 400;
  white-space: nowrap;
}
.home-products-carousel__filter {
  text-align: center;
  margin-bottom: 1.75rem;
  position: relative;
  z-index: 5;
}
.home-products-carousel__filter-toggle {
  background: transparent;
  border: none;
  cursor: pointer;
  font-family: inherit;
  font-size: 0.7rem;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: #1e1e1e;
  display: inline-flex;
  align-items: center;
  gap: 0.4rem;
  padding: 0.4rem 0;
}
.home-products-carousel__filter-chevron {
  display: block;
  width: 0;
  height: 0;
  border-left: 4px solid transparent;
  border-right: 4px solid transparent;
  border-bottom: 5px solid #1e1e1e;
  transition: transform 0.2s ease;
}
.home-products-carousel__filter.is-open .home-products-carousel__filter-chevron {
  transform: rotate(180deg);
}
.home-products-carousel__filter-list {
  list-style: none;
  margin: 0;
  padding: 0.35rem 0;
  max-width: 320px;
  position: absolute;
  top: calc(100% + 0.35rem);
  left: 50%;
  transform: translateX(-50%);
  width: min(90vw, 320px);
  background: rgba(255, 255, 255, 0.98);
  border: 1px solid rgba(0, 0, 0, 0.08);
  box-shadow: 0 10px 24px rgba(0, 0, 0, 0.08);
  max-height: 280px;
  overflow-y: auto;
}
.home-products-carousel__filter-list[hidden] {
  display: none !important;
}
.home-products-carousel__filter-item {
  display: block;
  width: 100%;
  background: none;
  border: none;
  text-align: center;
  font-family: inherit;
  font-size: 0.7rem;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: rgb(119.25, 119.25, 119.25);
  padding: 0.45rem 0.5rem;
  cursor: pointer;
  transition: color 0.15s;
}
.home-products-carousel__filter-item:hover, .home-products-carousel__filter-item:focus {
  color: #1e1e1e;
  outline: none;
}
.home-products-carousel__filter-item.is-active {
  color: #1e1e1e;
  font-weight: 600;
}
.home-products-carousel__viewport {
  display: flex;
  align-items: stretch;
  gap: 8px;
}
.home-products-carousel__scroll {
  flex: 1;
  min-width: 0;
  overflow-x: auto;
  overflow-y: hidden;
  scroll-behavior: smooth;
  -webkit-overflow-scrolling: touch;
  scroll-snap-type: x mandatory;
  scrollbar-width: thin;
}
.home-products-carousel__scroll::-webkit-scrollbar {
  height: 5px;
}
.home-products-carousel__scroll::-webkit-scrollbar-thumb {
  background: rgba(0, 0, 0, 0.15);
  border-radius: 3px;
}
.home-products-carousel__track {
  display: flex;
  gap: 1.25rem;
  padding: 4px 4px 12px;
}
.home-products-carousel__slide {
  flex: 0 0 auto;
  width: min(70vw, 300px);
  scroll-snap-align: start;
}
.home-products-carousel__card {
  display: block;
  text-decoration: none;
  color: inherit;
}
.home-products-carousel__card:hover, .home-products-carousel__card:focus {
  text-decoration: none;
  color: inherit;
}
.home-products-carousel__card:hover .home-products-carousel__name, .home-products-carousel__card:focus .home-products-carousel__name {
  opacity: 0.75;
}
.home-products-carousel__media {
  background-color: #fff;
  aspect-ratio: 6/7;
  overflow: hidden;
  display: flex;
  align-items: center;
  justify-content: center;
  border: 1px solid rgba(0, 0, 0, 0.06);
}
.home-products-carousel__media img {
  width: auto !important;
  height: auto !important;
  max-width: 100%;
  max-height: 100%;
  object-fit: contain !important;
  object-position: center center;
  padding: 10px;
}
.home-products-carousel__cat {
  margin: 0.85rem 0 0.25rem;
  font-size: 0.72rem;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: rgb(111.6, 111.6, 111.6);
  font-weight: 300;
}
.home-products-carousel__name {
  margin: 0;
  font-size: 1.05rem;
  font-family: "Raleway-bold", "Raleway", "Lato", sans-serif;
  font-weight: 600;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  line-height: 1.25;
  transition: opacity 0.2s;
}
.home-products-carousel__nav {
  flex: 0 0 42px;
  width: 42px;
  height: 42px;
  align-self: center;
  border-radius: 50%;
  border: 1px solid rgba(0, 0, 0, 0.12);
  background: #fff;
  color: #1e1e1e;
  font-size: 1.35rem;
  line-height: 1;
  padding: 0;
  cursor: pointer;
  transition: background 0.15s, border-color 0.15s;
}
.home-products-carousel__nav:hover, .home-products-carousel__nav:focus {
  background: #fff;
  border-color: rgba(0, 0, 0, 0.2);
  outline: none;
}
.home-products-carousel__nav span {
  display: block;
  margin-top: -2px;
}
.home-products-carousel__empty, .home-products-carousel__loading {
  text-align: center;
  font-size: 0.9rem;
  color: rgb(93.75, 93.75, 93.75);
  margin: 1rem 0 0;
}
.home-products-carousel__loading {
  font-weight: 300;
}

.home-section-separator {
  background: #fff;
  padding: 0.75rem 0 1rem;
}
.home-section-separator__inner {
  max-width: 1800px;
  margin: 0 auto;
  padding: 0 16px;
  display: flex;
  align-items: center;
  gap: 14px;
}
.home-section-separator__line {
  flex: 1 1 auto;
  height: 1px;
  background: rgba(0, 0, 0, 0.14);
}
.home-section-separator__title {
  flex: 0 0 auto;
  font-size: 0.7rem;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: #515151;
  font-weight: 400;
  white-space: nowrap;
}

@media (min-width: 768px) {
  .home-products-carousel__slide {
    width: min(32vw, 340px);
  }
  .home-products-carousel__nav {
    flex: 0 0 48px;
    width: 48px;
    height: 48px;
  }
}
.filter-list {
  list-style: none;
  text-align: left;
  margin: 16px 0;
  padding: 0;
}
.filter-list > .filter {
  display: inline-block;
  margin: 6px 6px 6px 0;
}
.filter-list > .filter > .item {
  display: inline-block;
  padding: 0.5rem 0.85rem;
  border: 1px solid rgba(0, 0, 0, 0.12);
  border-radius: 999px;
  color: #595959;
  text-decoration: none;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  font-size: 0.78rem;
  font-family: "Raleway-bold", "Raleway", sans-serif;
  transition: all 0.2s ease;
}
.filter-list > .filter > .item:hover,
.filter-list > .filter > .item.is-active {
  color: #000;
  border-color: rgba(0, 0, 0, 0.55);
  background: #fff;
  transform: translateY(-1px);
}

.material-title {
  font-weight: bold;
  text-align: center;
}

.materials-nav {
  border-top: 1px solid #efefef;
  border-bottom: 1px solid #efefef;
  background: #fff !important;
}

.materials-nav__title {
  font-size: 0.9rem;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: #4f4f4f !important;
  font-family: "Raleway-bold", "Raleway", sans-serif;
}

.materials-page {
  padding-bottom: 2.5rem;
}

.material {
  transform: scale(1);
  opacity: 1;
  transition: all 0.5s ease;
  margin: 0 -15px 1.5rem;
}
.material.-hidden {
  transform: scale(0);
  opacity: 0;
  height: 0;
  transition: all 0.5s ease;
  margin: 0;
}

.material-item {
  text-align: center;
  text-transform: uppercase;
  margin-bottom: 22px;
  transition: transform 0.3s;
  padding: 0.45rem;
  cursor: pointer;
}
.material-item .material-card {
  min-height: 260px;
  border: 1px solid #efefef;
  border-radius: 14px;
  padding: 1.15rem 0.85rem 1rem;
  background: #fff;
  transition: all 0.25s ease;
}
.material-item .image {
  width: 140px;
  height: 140px;
  object-fit: cover;
  margin: 0 auto;
  border: 3px solid #f7f7f7;
}
.material-item > .title {
  font-size: 0.78rem;
  font-family: "Raleway-bold", "Raleway", sans-serif;
  letter-spacing: 0.08em;
  color: #1f1f1f;
}
.material-item > .reference {
  font-size: 0.7rem;
  letter-spacing: 0.13em;
  color: #7a7a7a;
}
.material-item:hover .material-card {
  transform: translateY(-4px);
  border-color: #d8d8d8;
  box-shadow: 0 12px 26px rgba(0, 0, 0, 0.08);
}

.category-text {
  margin-bottom: 2rem !important;
  font-size: 1.02rem;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: #2a2a2a;
  font-family: "Audrey-Bold", "Raleway-bold", sans-serif;
  text-align: center;
}

@media (max-width: 991.98px) {
  .materials-nav__title {
    margin-left: 0 !important;
  }
}
@media (max-width: 575.98px) {
  .category-text {
    font-size: 0.86rem;
    margin-top: 2.2rem !important;
  }
  .material-item .material-card {
    min-height: 238px;
  }
  .material-item .image {
    width: 120px;
    height: 120px;
  }
}
.page-maps {
  padding-bottom: 70%;
}

.page-adresses {
  min-height: 320px;
  height: 100%;
}
.page-adresses > .title {
  font-weight: bold;
}
.page-adresses > .data {
  font-weight: 600;
}

.contact-form > .form-group {
  border-bottom: 1px solid #7d7d7d;
}
.contact-form > .form-group:last-child {
  border-bottom: none;
}
.contact-form > .form-group > .field > .form-control {
  border: none;
  background: none;
}
.contact-form > .form-group > .col-form-label {
  word-wrap: break-word;
}

/* -------------------------------------------------------------------------
   Página de produto — estilo editorial (referência: Poliform / Flexform)
   ------------------------------------------------------------------------- */
/* Cinza só na faixa galeria + ficha; resto da página (breadcrumb, hero, blocos abaixo) em branco */
.product-page {
  background-color: #fff;
  color: #1e1e1e;
}

/* A regra global .body-wrapper aplica 58px em baixo e cria “faixa branca” antes do footer no produto */
.body-wrapper.product-page {
  padding-bottom: 0;
}

.product-page__breadcrumb-wrap {
  padding-top: 1.25rem;
  padding-bottom: clamp(1rem, 2.5vw, 1.75rem);
  background-color: #fff;
}

.product-page__breadcrumb {
  font-size: 0.6875rem;
  font-weight: 400;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: #9a9a9a;
  margin: 0;
  line-height: 1.6;
}

.product-page__breadcrumb-sep {
  display: inline-block;
  margin: 0 0.5rem;
  color: #d0d0d0;
  font-weight: 300;
  letter-spacing: 0;
  text-transform: none;
}

.product-page__breadcrumb-link {
  color: #8a8a8a;
  text-decoration: none;
  transition: color 0.2s ease;
}
.product-page__breadcrumb-link:hover, .product-page__breadcrumb-link:focus {
  color: #1e1e1e;
}

.product-page__breadcrumb-current {
  color: #111;
  font-weight: 500;
  letter-spacing: 0.1em;
}

.product-page__main {
  padding-top: clamp(0.5rem, 1.5vw, 1.25rem);
  padding-bottom: clamp(3rem, 8vw, 6rem);
  background-color: #fff;
}

/* Largura editorial alinhada entre hero e bloco inferior (site antigo) */
.product-page__content-width {
  width: 100%;
  max-width: min(1320px, 100%);
  margin-left: auto;
  margin-right: auto;
  box-sizing: border-box;
}

.product-page__hero-band {
  background-color: #fff;
  padding-bottom: clamp(0.5rem, 2vw, 1.25rem);
}

.product-page__figure--hero {
  margin: 0 auto;
  max-width: 100%;
  padding-left: clamp(0.75rem, 2.2vw, 2rem);
  padding-right: clamp(0.75rem, 2.2vw, 2rem);
  box-sizing: border-box;
}

.product-page__lower-band {
  background-color: #f2f2f2;
  padding-top: clamp(1.75rem, 4.5vw, 3rem);
  padding-bottom: clamp(2.5rem, 6vw, 4.5rem);
  margin-top: 0;
}

/* Cinza até à borda: o .products-page__shell na main aplica padding lateral branco — estende-se a faixa com margens negativas e repõe-se o respiro só no conteúdo */
.product-page__main.products-page__shell .product-page__lower-band {
  margin-left: calc(-1 * var(--products-shell-pl));
  margin-right: calc(-1 * var(--products-shell-pr));
  padding-left: var(--products-shell-pl);
  padding-right: var(--products-shell-pr);
  box-sizing: border-box;
}

/* Grelha galeria + ficha em largura útil total (sem faixas cinzentas extra por causa do max-width editorial) */
.product-page__lower-band .product-page__content-width {
  max-width: none;
  width: 100%;
}

.product-page__split-lower {
  align-items: stretch;
  /* Evita ver o cinzento da .lower-band no canal entre colunas (arredondamentos / flex) */
  background-color: #fff;
}

.product-page__lower-band .product-page__col-gallery,
.product-page__lower-band .product-page__col-detail {
  background-color: #fff;
}

.product-page__gallery-panel {
  background-color: #fff;
  padding: clamp(1.1rem, 2.8vw, 2rem);
  height: 100%;
  box-sizing: border-box;
}

.product-page__detail-inner.product-page__detail-panel {
  background-color: #fff;
  padding: clamp(1.35rem, 3.5vw, 2.75rem) clamp(1.25rem, 3.5vw, 2.5rem);
  height: 100%;
  box-sizing: border-box;
  max-width: 100%;
}

.product-page__preview-box {
  display: flex;
  flex-direction: row;
  align-items: center;
  gap: clamp(0.35rem, 1.5vw, 0.65rem);
  margin-bottom: clamp(0.65rem, 2vw, 1.1rem);
}

/* Altura fixa: as setas mantêm-se ao centro vertical mesmo quando a foto muda de proporção */
.product-page__preview-stage {
  flex: 1 1 auto;
  min-width: 0;
  height: min(48vh, 520px);
  max-height: min(48vh, 520px);
  display: flex;
  align-items: center;
  justify-content: center;
  background-color: #fff;
}

.product-page__gallery-arrow {
  flex-shrink: 0;
  width: 2.5rem;
  height: 2.5rem;
  padding: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  border: 1px solid rgba(30, 30, 30, 0.12);
  border-radius: 50%;
  background: rgba(255, 255, 255, 0.96);
  color: #2a2a2a;
  box-shadow: 0 4px 14px rgba(0, 0, 0, 0.06);
  cursor: pointer;
  transition: background 0.2s ease, border-color 0.2s ease, color 0.2s ease;
}
.product-page__gallery-arrow:hover, .product-page__gallery-arrow:focus {
  background: #fff;
  border-color: rgba(30, 30, 30, 0.22);
  color: #000;
  outline: none;
}
.product-page__gallery-arrow svg {
  display: block;
}

.product-page__figure--inline {
  flex: 1 1 auto;
  margin: 0;
  min-width: 0;
  width: 100%;
  height: 100%;
  min-height: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  background-color: #fff;
}

.product-page__inline-preview {
  display: block;
  width: auto;
  height: auto;
  max-width: 100%;
  max-height: 100%;
  margin: 0 auto;
  object-fit: contain;
  object-position: center center;
  background-color: #fff;
}

.product-page__figure {
  margin: 0;
  width: 100%;
  overflow: hidden;
  position: relative;
  background-color: #fff;
}

.product-page__hero-img {
  display: block;
  width: 100%;
  max-width: 100%;
  height: auto;
  max-height: min(74vh, 900px);
  object-fit: contain;
  object-position: center center;
  background-color: #fff;
  margin-left: auto;
  margin-right: auto;
  cursor: default;
  pointer-events: none;
}

.js-product-lightbox-trigger {
  cursor: pointer;
}

#product-slide {
  margin: 0;
  padding: clamp(0.5rem, 1.5vw, 0.85rem) 0;
  background-color: #fff;
  position: relative;
}
#product-slide .slick-slide {
  text-align: center;
}
#product-slide .slick-list,
#product-slide .slick-track {
  background-color: #fff;
}
#product-slide .product-page__thumb-slide {
  padding: 0 0.15rem;
  box-sizing: border-box;
}
#product-slide .product-page__thumb-btn {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  margin: 0;
  padding: 0.2rem;
  border: 1px solid rgba(30, 30, 30, 0.1);
  border-radius: 3px;
  background: #fff;
  cursor: pointer;
  transition: border-color 0.2s ease, box-shadow 0.2s ease;
  min-height: 4.5rem;
}
#product-slide .product-page__thumb-btn:hover, #product-slide .product-page__thumb-btn:focus {
  border-color: rgba(30, 30, 30, 0.28);
  outline: none;
}
#product-slide .product-page__thumb-btn.is-active {
  border-color: rgba(30, 30, 30, 0.45);
  box-shadow: 0 0 0 1px rgba(30, 30, 30, 0.12);
}
#product-slide .product-page__thumb-img {
  max-width: 100%;
  max-height: 4rem;
  width: auto;
  height: auto;
  margin: 0 auto;
  object-fit: contain;
  vertical-align: middle;
  background-color: #fff;
  pointer-events: none;
}
#product-slide {
  /* Setas do slider: botões discretos (evita ::before FontAwesome global do tema) */
}
#product-slide .product-page__slick-arrow {
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  z-index: 3;
  width: 2.5rem;
  height: 2.5rem;
  padding: 0;
  margin: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  border: 1px solid rgba(30, 30, 30, 0.12);
  border-radius: 50%;
  background: rgba(255, 255, 255, 0.92);
  color: #2a2a2a;
  box-shadow: 0 4px 18px rgba(0, 0, 0, 0.06);
  cursor: pointer;
  transition: background 0.2s ease, border-color 0.2s ease, color 0.2s ease, box-shadow 0.2s ease;
}
#product-slide .product-page__slick-arrow:hover, #product-slide .product-page__slick-arrow:focus {
  background: #fff;
  border-color: rgba(30, 30, 30, 0.28);
  color: #000;
  box-shadow: 0 6px 22px rgba(0, 0, 0, 0.1);
  outline: none;
}
#product-slide .product-page__slick-arrow::before {
  display: none !important;
  content: none !important;
}
#product-slide .product-page__slick-arrow svg {
  display: block;
}
#product-slide .slick-prev.product-page__slick-arrow {
  left: -0.85rem !important;
}
#product-slide .slick-next.product-page__slick-arrow {
  right: -0.85rem !important;
}

@media (max-width: 767.98px) {
  #product-slide .slick-slide > div {
    display: flex !important;
    justify-content: center;
    width: 100%;
  }
  #product-slide .slick-list {
    margin-left: auto;
    margin-right: auto;
  }
}
.product-page__detail {
  display: flex;
  flex-direction: column;
  justify-content: flex-start;
  background-color: #fff;
}

.product-page__detail-inner {
  width: 100%;
}

.product-page__eyebrow {
  font-size: 0.6875rem;
  font-weight: 500;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  color: #8a8a8a;
  margin: 0 0 1rem;
}

.product-page__product-title {
  font-family: "Audrey", Georgia, "Times New Roman", serif;
  font-size: clamp(1.75rem, 3.2vw, 2.5rem);
  font-weight: 400;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  line-height: 1.15;
  color: #1e1e1e;
  margin: 0 0 0.75rem;
}

.product-page__reference {
  font-family: "Raleway", "Lato", sans-serif;
  font-size: 0.8125rem;
  font-weight: 400;
  letter-spacing: 0.08em;
  color: #7d7d7d;
  margin: 0 0 1.75rem;
}

.product-page__description {
  font-family: "Raleway", "Lato", sans-serif;
  font-size: 0.9375rem;
  font-weight: 300;
  line-height: 1.75;
  color: #4a4a4a;
  margin-bottom: 2rem;
}
.product-page__description p {
  margin-bottom: 0.75rem;
}
.product-page__description p:last-child {
  margin-bottom: 0;
}

.product-page__specs {
  list-style: none;
  margin: 0 0 1.35rem;
  padding: 0;
  display: flex;
  flex-wrap: wrap;
  gap: 0.65rem 1.35rem;
  font-size: 0.8125rem;
  font-weight: 300;
  letter-spacing: 0.06em;
  color: #5a5a5a;
}

.product-page__spec {
  margin: 0;
}

.product-page__spec-key {
  font-weight: 500;
  color: #1e1e1e;
  margin-right: 0.25rem;
}

.product-page__materials-block {
  margin-bottom: 2rem;
}

.product-page__materials-heading {
  font-family: "Raleway", "Lato", sans-serif;
  font-size: 0.6875rem;
  font-weight: 600;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: #6a6a6a;
  margin: 0 0 0.85rem;
}

.product-page__material-thumb {
  border-radius: 50%;
  box-shadow: 0 1px 4px rgba(0, 0, 0, 0.1);
  display: block;
}

/* Especificidade acima de `.product-materials` global (evita space-between + max-width 450px) */
.product-materials.product-page__materials {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 0.75rem 1rem;
  align-items: start;
  justify-content: stretch;
  max-width: 100%;
  width: 100%;
  padding-top: 0;
  margin-bottom: 0;
}

.product-page__materials .product-material {
  display: flex;
  align-items: flex-start;
  gap: 0.65rem;
  margin-bottom: 0;
  min-width: 0;
}

.product-page__materials .product-material .image,
.product-page__materials .product-material .details {
  display: block;
  vertical-align: unset;
}

.product-page__materials .product-material .image {
  flex-shrink: 0;
  margin-right: 0;
  line-height: 0;
}

.product-page__materials .product-material .details {
  display: flex;
  flex-direction: column;
  gap: 0.2rem;
  min-width: 0;
  text-transform: none;
}

.product-page__materials .product-material .details .name {
  font-family: "Raleway", "Lato", sans-serif;
  font-size: 0.6875rem;
  font-weight: 600;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: #2e2e2e;
  line-height: 1.35;
}

.product-page__materials .product-material .details .category {
  font-family: "Raleway", "Lato", sans-serif;
  font-size: 0.625rem;
  font-weight: 400;
  letter-spacing: 0.05em;
  text-transform: none;
  color: #7a7a7a;
  line-height: 1.4;
}

.product-page__cta {
  display: inline-block;
  font-family: "Raleway", "Lato", sans-serif;
  font-size: 0.6875rem;
  font-weight: 600;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: #fff;
  background: #1e1e1e;
  border: none;
  padding: 1rem 2.25rem;
  cursor: pointer;
  transition: background 0.2s ease, transform 0.2s ease;
}
.product-page__cta:hover, .product-page__cta:focus {
  background: #000;
  color: #fff;
}

/* Bloco “Detalhes” — grelha com gap real (não usar Bootstrap row com .cell { padding: 0 }) */
.product-page__details-block {
  margin-top: clamp(2rem, 5vw, 3.5rem);
  padding-top: clamp(1.5rem, 4vw, 2.5rem);
  border-top: 1px solid rgba(30, 30, 30, 0.06);
}

.product-page__details-title {
  font-family: "Raleway", "Lato", sans-serif;
  font-size: 0.75rem;
  font-weight: 500;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  text-align: left;
  color: #6a6a6a;
  max-width: min(1196px, 92vw);
  margin: 0 auto clamp(1.25rem, 3vw, 2rem);
}

.product-page__details-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: clamp(1.5rem, 4.5vw, 3rem);
  align-items: start;
  /* ~+30% face à grelha anterior (920px) — detalhes mais legíveis */
  max-width: min(1196px, 92vw);
  margin-left: auto;
  margin-right: auto;
}
@media (min-width: 768px) {
  .product-page__details-grid {
    grid-template-columns: 1fr 1fr;
    gap: clamp(1.25rem, 3vw, 2rem);
  }
}

.product-page__details-figure {
  margin: 0;
  background-color: #fff;
  display: flex;
  justify-content: center;
  align-items: center;
}

.product-page__extra-img {
  display: block;
  width: 100%;
  max-width: 100%;
  height: auto;
  max-height: min(55vh, 546px);
  vertical-align: top;
  object-fit: contain;
  object-position: center center;
  background-color: #fff;
  margin-left: auto;
  margin-right: auto;
}

/* Lightbox galeria (imagem principal + slider + bloco detalhes) */
/* z-index abaixo da navbar; top deslocado para o conteúdo não ficar por baixo do menu */
.product-page__lightbox {
  position: fixed;
  top: 80px;
  right: 0;
  bottom: 0;
  left: 0;
  z-index: 1020;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: clamp(0.75rem, 3vw, 1.5rem);
  opacity: 0;
  visibility: hidden;
  pointer-events: none;
  transition: opacity 0.28s ease, visibility 0.28s ease;
}
.product-page__lightbox.is-open {
  opacity: 1;
  visibility: visible;
  pointer-events: auto;
}

@media (max-width: 991.98px) {
  .product-page__lightbox {
    top: calc(5rem + env(safe-area-inset-top, 0px));
  }
  .product-page__lightbox-panel {
    max-height: calc(100dvh - 5rem - env(safe-area-inset-top, 0px) - 2rem);
  }
  .product-page__lightbox-stage {
    height: min(100dvh - 5rem - env(safe-area-inset-top, 0px) - 2rem, 900px);
    max-height: min(100dvh - 5rem - env(safe-area-inset-top, 0px) - 2rem, 900px);
    min-height: min(100dvh - 5rem - env(safe-area-inset-top, 0px) - 2rem, 900px);
  }
}
.product-page__lightbox-backdrop {
  position: absolute;
  inset: 0;
  margin: 0;
  padding: 0;
  border: 0;
  background: #fff;
  cursor: pointer;
}

.product-page__lightbox-panel {
  position: relative;
  z-index: 1;
  width: min(96vw, 1600px);
  max-width: min(96vw, 1600px);
  max-height: calc(100dvh - 80px - 2rem);
  pointer-events: none;
}
.product-page__lightbox-panel .product-page__lightbox-img,
.product-page__lightbox-panel .product-page__lightbox-close,
.product-page__lightbox-panel .product-page__lightbox-nav {
  pointer-events: auto;
}

/* Área de altura estável: altura em função do espaço abaixo da navbar (não sobrepõe o menu) */
.product-page__lightbox-stage {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  height: min(100dvh - 80px - 2rem, 900px);
  max-height: min(100dvh - 80px - 2rem, 900px);
  min-height: min(100dvh - 80px - 2rem, 900px);
  margin: 0 auto;
  box-sizing: border-box;
}

.product-page__lightbox-img {
  display: block;
  max-width: min(88vw, 1400px);
  max-height: 100%;
  width: auto;
  height: auto;
  object-fit: contain;
  background: #fff;
  margin: 0 auto;
}

/* Canto superior direito do ecrã; abaixo da navbar fixa (≈80px, alinhado ao tema) */
.product-page__lightbox-close {
  position: fixed;
  top: calc(80px + 0.65rem);
  right: max(0.75rem, env(safe-area-inset-right, 0px));
  z-index: 3;
  width: 2.5rem;
  height: 2.5rem;
  padding: 0;
  border: 1px solid rgba(30, 30, 30, 0.18);
  border-radius: 50%;
  background: rgba(255, 255, 255, 0.98);
  color: #2a2a2a;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  box-shadow: 0 4px 18px rgba(0, 0, 0, 0.08);
  transition: background 0.2s ease, border-color 0.2s ease, color 0.2s ease;
}
.product-page__lightbox-close:hover, .product-page__lightbox-close:focus {
  background: #fff;
  border-color: rgba(30, 30, 30, 0.28);
  color: #000;
  outline: none;
}

@media (max-width: 991.98px) {
  .product-page__lightbox-close {
    /* .body-wrapper usa ~5rem de padding-top no mobile; manter X abaixo da barra */
    top: calc(5rem + env(safe-area-inset-top, 0px) + 0.5rem);
  }
}
.product-page__lightbox-nav {
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  flex-shrink: 0;
  width: 2.75rem;
  height: 2.75rem;
  padding: 0;
  border: 1px solid rgba(30, 30, 30, 0.15);
  border-radius: 50%;
  background: rgba(255, 255, 255, 0.96);
  color: #2a2a2a;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  box-shadow: 0 4px 18px rgba(0, 0, 0, 0.06);
  transition: background 0.2s ease, border-color 0.2s ease, color 0.2s ease;
}
.product-page__lightbox-nav:hover, .product-page__lightbox-nav:focus {
  background: #fff;
  border-color: rgba(30, 30, 30, 0.28);
  color: #000;
  outline: none;
}
.product-page__lightbox-nav.is-hidden {
  display: none !important;
}

.product-page__lightbox-nav--prev {
  left: clamp(0.4rem, 1.2vw, 1rem);
}

.product-page__lightbox-nav--next {
  right: clamp(0.4rem, 1.2vw, 1rem);
}

@media (max-width: 575.98px) {
  .product-page__lightbox-panel {
    width: 100%;
    max-width: 100%;
  }
}
.product-page__downloads {
  padding: clamp(1.75rem, 4vw, 2.75rem) 0;
  background-color: #fff;
  border-top: 1px solid rgba(30, 30, 30, 0.06);
}

.product-page__section-title {
  font-family: "Raleway", "Lato", sans-serif;
  font-size: clamp(0.8125rem, 1.05vw, 0.9375rem);
  font-weight: 600;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  text-align: center;
  color: #4a4a4a;
  margin: 0 0 clamp(1rem, 2.2vw, 1.5rem);
}

.product-page__section-title--related {
  margin-bottom: clamp(1.25rem, 3vw, 2rem);
}

.product-page__download-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
  gap: 1rem;
  max-width: 960px;
  margin: 0 auto;
}

.product-page__download-card {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 0.5rem;
  min-height: 88px;
  padding: 1.1rem 1.25rem;
  background: #ebeae8;
  text-decoration: none !important;
  color: #1e1e1e !important;
  font-size: 0.8125rem;
  font-weight: 600;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  text-align: center;
  transition: background 0.2s ease, color 0.2s ease;
}
.product-page__download-card:hover, .product-page__download-card:focus {
  background: #e2e1de;
  color: #1e1e1e !important;
}

.product-page__download-label {
  line-height: 1.4;
}

.product-page__download-icon {
  font-size: 0.85rem;
  opacity: 0.65;
}

/* Sobrescreve estilos globais .product-download / .a0 … (grelha editorial) */
.product-page__download-card.product-download {
  padding: 1.1rem 1.25rem;
}

.product-page__download-card.a0,
.product-page__download-card.a1,
.product-page__download-card.a2 {
  border: none !important;
}

.product-page__related {
  padding: clamp(2rem, 5vw, 3.25rem) 0 clamp(2.5rem, 6vw, 4rem);
  background-color: #fff;
}

.product-page__related-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 340px));
  justify-content: center;
  justify-items: center;
  width: fit-content;
  max-width: 100%;
  gap: 2rem 2.25rem;
  margin: 0 auto;
}

/* Garantir centragem horizontal no shell (evita conflito se .row voltar a ser usado aqui) */
.products-page__shell > .product-page__related-grid {
  margin-left: auto !important;
  margin-right: auto !important;
}

.product-page__related-item {
  margin-bottom: 0;
  display: flex;
  justify-content: center;
  width: 100%;
  max-width: none;
  flex: none;
  padding-left: 0;
  padding-right: 0;
}

.product-page__related-link {
  display: flex;
  flex-direction: column;
  align-items: center;
  text-decoration: none;
  color: inherit;
  text-align: center;
  transition: opacity 0.2s ease;
}
.product-page__related-link:hover, .product-page__related-link:focus {
  opacity: 0.85;
  text-decoration: none;
}

.product-page__related-media {
  width: min(100%, 380px);
  height: clamp(250px, 28vw, 340px);
  margin-left: auto;
  margin-right: auto;
  overflow: hidden;
  margin-bottom: 1rem;
  background: #fff;
  display: flex;
  align-items: center;
  justify-content: center;
}
.product-page__related-media img {
  width: 100%;
  height: 100%;
  object-fit: contain;
  object-position: center center;
  background-color: #fff;
  display: block;
}

@media (max-width: 991.98px) {
  .product-page__related-grid {
    grid-template-columns: repeat(2, minmax(0, 340px));
    width: fit-content;
    gap: 2rem 2rem;
  }
}
@media (max-width: 575.98px) {
  .product-page__related-grid {
    grid-template-columns: 1fr;
    gap: 2rem;
    max-width: 380px;
    width: 100%;
  }
}
.product-page__related-name {
  display: block;
  font-family: "Raleway", "Lato", sans-serif;
  font-size: 0.8125rem;
  font-weight: 500;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: #1e1e1e;
  margin-bottom: 0.35rem;
}

.product-page__related-cat {
  display: block;
  font-size: 0.75rem;
  font-weight: 300;
  letter-spacing: 0.04em;
  color: #8a8a8a;
}

@media (min-width: 992px) {
  .product-page__detail-inner.product-page__detail-panel {
    padding-top: clamp(1.25rem, 3.5vw, 2.25rem);
    padding-bottom: clamp(2rem, 5vw, 3.25rem);
    padding-left: clamp(1.75rem, 4vw, 3rem);
    padding-right: clamp(1.5rem, 3.5vw, 2.75rem);
  }
}
@media (max-width: 767.98px) {
  .product-page__breadcrumb {
    text-align: center;
  }
  .product-page__col-gallery {
    margin-bottom: 1.5rem;
  }
  .product-page__detail-inner.product-page__detail-panel {
    max-width: none;
    text-align: center;
  }
  .product-page__specs {
    justify-content: center;
  }
  .product-page__materials-block {
    display: flex;
    flex-direction: column;
    align-items: center;
  }
  .product-materials.product-page__materials {
    grid-template-columns: 1fr;
    gap: 0.9rem;
    max-width: 22rem;
    margin-left: auto;
    margin-right: auto;
  }
  .product-page__materials .product-material {
    max-width: 100%;
    justify-content: flex-start;
    text-align: left;
  }
  .product-page__cta {
    width: 100%;
    max-width: 20rem;
  }
}
@media (min-width: 768px) {
  .product-page__detail-inner.product-page__detail-panel {
    text-align: left;
  }
  .product-page__cta {
    width: auto;
  }
}
/* Largura total do ecrã com respiro lateral (substitui o .container estreito) */
/* Sem utilitário .px-0 no mesmo elemento: o Bootstrap zera padding com !important e anula isto. */
.products-page__shell {
  --products-shell-pl: max(clamp(1.5rem, 5vw, 4rem), env(safe-area-inset-left, 0px));
  --products-shell-pr: max(clamp(1.5rem, 5vw, 4rem), env(safe-area-inset-right, 0px));
  width: 100%;
  max-width: 100%;
  padding-left: var(--products-shell-pl) !important;
  padding-right: var(--products-shell-pr) !important;
  box-sizing: border-box;
}

/*
 * Grelha dentro do shell: margem -15px da .row + padding grande do shell desalinha.
 * Zerar margens da row — o conteúdo fica dentro da área já com padding; centrado com flex na listagem lux.
 */
.products-page__grid {
  width: 100%;
  max-width: min(1280px, 96vw);
  margin-left: auto;
  margin-right: auto;
  padding-left: max(15px, env(safe-area-inset-left, 0px));
  padding-right: max(15px, env(safe-area-inset-right, 0px));
  box-sizing: border-box;
}

/* Faixa de coleções (substitui navbar genérica) */
.products-page__collections {
  background-color: #f2f2f2;
  border-bottom: 1px solid rgba(30, 30, 30, 0.06);
}

.products-page__collections-inner {
  display: flex;
  flex-wrap: wrap;
  align-items: baseline;
  gap: 0.35rem 1.25rem;
  padding-top: 1.1rem;
  padding-bottom: 1.1rem;
}

@media (max-width: 991.98px) {
  .products-page__collections-inner {
    padding-top: 1.5rem;
    padding-bottom: 1.2rem;
  }
}
@media (max-width: 575.98px) {
  .products-page__collections-inner {
    flex-direction: column;
    align-items: flex-start;
    gap: 0.75rem;
    padding-top: 1.65rem;
  }
}
.products-page__collections-label {
  flex-shrink: 0;
  font-size: 0.75rem;
  font-weight: 500;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: #7d7d7d;
}

.products-page__collections-nav {
  flex: 1;
  min-width: 0;
}

.products-page__collections-list {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 0.35rem 1.25rem;
}

@media (max-width: 575.98px) {
  .products-page__collections-list {
    flex-wrap: nowrap;
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
    padding-bottom: 0.35rem;
    margin-bottom: -0.25rem;
    width: 100%;
    gap: 0.75rem;
  }
}
.products-page__collections-item {
  flex-shrink: 0;
}

.products-page__col-link {
  display: inline-block;
  padding: 0.35rem 0;
  font-size: 0.9375rem;
  font-weight: 400;
  letter-spacing: 0.02em;
  color: #6a6a6a;
  text-decoration: none;
  border-bottom: 2px solid transparent;
  transition: color 0.2s ease, border-color 0.2s ease;
}
.products-page__col-link:hover, .products-page__col-link:focus {
  color: #1e1e1e;
  text-decoration: none;
}
.products-page__col-link.is-active {
  color: #1e1e1e;
  font-weight: 500;
  border-bottom-color: rgba(30, 30, 30, 0.35);
}

/* Página de listagem — breadcrumb + título */
.products-page__intro {
  padding-top: 1.25rem;
  padding-bottom: 1.75rem;
  text-align: center;
}

.products-page__intro--after-collections {
  background-color: #fff;
  text-align: left;
}

.products-page__intro--after-collections .products-page__title {
  text-align: center;
  margin-top: 0.5rem;
}

/* Breadcrumb da listagem: mesmas classes que .product-page__breadcrumb (produto) */
/* Mesma família e ritmo que .product-page__product-title (página de produto) */
.products-page__title {
  font-family: "Audrey", Georgia, "Times New Roman", serif;
  font-size: 1.25rem;
  font-weight: 400;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  margin: 0 auto;
  max-width: min(42rem, 100%);
  padding-left: 0.5rem;
  padding-right: 0.5rem;
  line-height: 1.15;
  color: #1e1e1e;
  box-sizing: border-box;
  overflow-wrap: anywhere;
  word-break: break-word;
}

.product-materials {
  padding-top: 1em;
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: space-between;
  max-width: 450px;
}

.product-material {
  margin-bottom: 1em;
}
.product-material .image,
.product-material .details {
  display: inline-block;
  vertical-align: top;
  text-transform: uppercase;
}
.product-material .image {
  margin-right: 0.2em;
}
.product-material .details .name {
  font-size: 0.65rem;
  font-weight: bolder;
}
.product-material .details .category {
  font-size: 0.5rem;
  letter-spacing: 1px;
}

/* Botão WhatsApp: estilos em _whatsapp-float.scss */
/*
 * Página de notícia (Indikator News — componente newsPost).
 */
.article-page-body {
  background: #fff;
  padding-bottom: clamp(2.5rem, 6vh, 4rem);
}
.article-page__shell {
  max-width: 52rem;
  margin-left: auto;
  margin-right: auto;
  padding-left: clamp(1rem, 4vw, 2.5rem);
  padding-right: clamp(1rem, 4vw, 2.5rem);
}
.article-page__breadcrumb-wrap {
  padding-top: 1.25rem;
  padding-bottom: 0.75rem;
}
.article-page__back {
  display: inline-block;
  margin-bottom: clamp(1.25rem, 3vw, 2rem);
  font-size: 0.6875rem;
  font-weight: 500;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: #6e6e6e;
  text-decoration: none;
  transition: color 0.2s ease, opacity 0.2s ease;
}
.article-page__back:hover,
.article-page__back:focus {
  color: #1e1e1e;
  text-decoration: underline;
  text-underline-offset: 4px;
  opacity: 0.9;
}
.article-page__header {
  margin-bottom: clamp(1.5rem, 4vw, 2.5rem);
  text-align: left;
}
.article-page__date {
  display: block;
  margin: 0 0 0.65rem;
  font-family: "Raleway", "Lato", sans-serif;
  font-size: 0.625rem;
  font-weight: 500;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: #6e6e6e;
}
.article-page__title {
  margin: 0;
  font-family: "Raleway-bold", "Raleway", "Lato", sans-serif;
  font-size: clamp(1.375rem, 3.2vw, 2rem);
  font-weight: 700;
  line-height: 1.25;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: #1e1e1e;
}
.article-page__tags {
  display: flex;
  flex-wrap: wrap;
  gap: 0.4rem;
  margin: 1rem 0 0;
  padding: 0;
  list-style: none;
}
.article-page__tag span {
  display: inline-block;
  padding: 0.2rem 0.55rem;
  font-size: 0.5625rem;
  font-weight: 500;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: #5a5a5a;
  background: #f4f4f4;
  border-radius: 1px;
}
.article-page__hero {
  margin: 0 0 clamp(1.75rem, 4vw, 2.75rem);
  overflow: hidden;
  background: #f6f6f6;
  border-radius: 1px;
}
.article-page__hero-img {
  display: block;
  width: 100%;
  max-width: 100%;
  height: auto;
  vertical-align: top;
}
.article-page__body {
  max-width: 100%;
  overflow-x: hidden;
}
.article-page__richtext {
  font-family: "Raleway", "Lato", sans-serif;
  font-size: clamp(0.9375rem, 1.05vw, 1rem);
  font-weight: 300;
  line-height: 1.8;
  color: #3a3a3a;
  word-wrap: break-word;
  overflow-wrap: anywhere;
}
.article-page__richtext p,
.article-page__richtext li,
.article-page__richtext span,
.article-page__richtext div {
  font-family: inherit;
  font-size: inherit;
  font-weight: inherit;
  line-height: inherit;
  color: inherit;
}
.article-page__richtext strong,
.article-page__richtext b {
  font-weight: 500;
}
.article-page__richtext p {
  margin: 0 0 1.1rem;
}
.article-page__richtext p:last-child {
  margin-bottom: 0;
}
.article-page__richtext h2,
.article-page__richtext h3,
.article-page__richtext h4 {
  margin: 1.75rem 0 0.75rem;
  font-family: "Raleway-bold", "Raleway", "Lato", sans-serif;
  font-weight: 700;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: #1e1e1e;
  line-height: 1.3;
}
.article-page__richtext h2 {
  font-size: clamp(1rem, 1.8vw, 1.125rem);
}
.article-page__richtext h3 {
  font-size: clamp(0.9375rem, 1.5vw, 1.0625rem);
}
.article-page__richtext a {
  color: #1e1e1e;
  text-decoration: underline;
  text-underline-offset: 3px;
  transition: opacity 0.2s ease;
}
.article-page__richtext a:hover,
.article-page__richtext a:focus {
  opacity: 0.75;
}
.article-page__richtext ul,
.article-page__richtext ol {
  margin: 0 0 1.1rem;
  padding-left: 1.25rem;
}
.article-page__richtext blockquote {
  margin: 1.5rem 0;
  padding-left: 1rem;
  border-left: 2px solid #ddd;
  color: #505050;
  font-style: italic;
}
.article-page__richtext img {
  display: block;
  max-width: 100%;
  height: auto;
  margin: 1.5rem 0;
}
.article-page__richtext video {
  max-width: 100%;
  height: auto;
}
.article-page__richtext iframe {
  max-width: 100%;
}
.article-page__richtext figure {
  max-width: 100%;
  margin: 1.5rem 0;
}
.article-page__pager {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: clamp(0.75rem, 2vw, 1.25rem);
  margin-top: clamp(2.5rem, 6vw, 4rem);
  padding-top: clamp(1.75rem, 4vw, 2.5rem);
  border-top: 1px solid #e8e8e8;
}
.article-page__pager-spacer {
  display: block;
}
.article-page__pager-link {
  display: flex;
  flex-direction: column;
  gap: 0.35rem;
  padding: clamp(0.85rem, 2vw, 1.15rem) clamp(1rem, 2.5vw, 1.25rem);
  text-decoration: none;
  color: #1e1e1e;
  background: #fafafa;
  border: 1px solid #ececec;
  border-radius: 1px;
  transition: background 0.2s ease, border-color 0.2s ease;
}
.article-page__pager-link:hover,
.article-page__pager-link:focus {
  color: #1e1e1e;
  text-decoration: none;
  background: #f2f2f2;
  border-color: #ddd;
}
.article-page__pager-link--next {
  text-align: right;
  align-items: flex-end;
}
.article-page__pager-label {
  font-size: 0.5625rem;
  font-weight: 600;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: #7a7a7a;
}
.article-page__pager-title {
  font-family: "Raleway-bold", "Raleway", "Lato", sans-serif;
  font-size: clamp(0.6875rem, 1.2vw, 0.8125rem);
  font-weight: 700;
  line-height: 1.35;
  letter-spacing: 0.05em;
  text-transform: uppercase;
}
@media (max-width: 575.98px) {
  .article-page__pager {
    grid-template-columns: 1fr;
  }
  .article-page__pager-link--next {
    text-align: left;
    align-items: flex-start;
  }
  .article-page__pager-spacer {
    display: none;
  }
}
.post {
  max-width: 100%;
  overflow-x: hidden;
}
.post img,
.post video,
.post iframe,
.post figure {
  max-width: 100%;
}

.decor-project-page {
  padding-bottom: clamp(3rem, 8vw, 5rem);
  max-width: min(1600px, 96vw);
  margin-left: auto;
  margin-right: auto;
}
.decor-project-page__intro {
  margin: 0 0 1rem;
  text-align: center;
}
.decor-project-page__intro-title {
  margin: 0;
  font-family: "Raleway", "Lato", "Helvetica Neue", Helvetica, Arial, sans-serif;
  font-size: clamp(1.35rem, 2.8vw, 2rem);
  font-weight: 600;
  line-height: 1.2;
  color: #1e1e1e;
}

/* Full-bleed: sai do contentor estreito e usa toda a largura do viewport */
.decor-project-page__instr-banner {
  width: 100vw;
  max-width: 100vw;
  margin-left: calc(50% - 50vw);
  margin-right: calc(50% - 50vw);
  margin-bottom: clamp(0.75rem, 2vw, 1.25rem);
  padding: 0;
  text-align: center;
}

.decor-project-page__instr-banner img,
.decor-project-page__instr-img {
  display: block;
  width: 100%;
  max-width: 100%;
  height: auto;
  margin: 0;
}

.decor-project-page__topbar {
  padding-bottom: 1.1rem;
  margin-bottom: 0.25rem;
}

.decor-project-page__breadcrumb {
  margin-top: 0;
  margin-bottom: 0;
}

.decor-project-page__rule {
  display: block;
  width: 100%;
  max-width: 100%;
  height: 0;
  margin: 0 0 clamp(1.75rem, 4vw, 2.5rem);
  padding: 0;
  border: 0;
  border-top: 1px solid rgba(30, 30, 30, 0.1);
}

.decor-project-page__layout {
  display: flex;
  flex-direction: column;
  gap: clamp(1.75rem, 4vw, 2.5rem);
}

.decor-project-page__guest-notice {
  margin: 0 0 1.35rem;
  padding: 0 0 1.1rem;
  max-width: 40rem;
  border-bottom: 1px solid rgba(30, 30, 30, 0.08);
}

.decor-project-page__guest-notice-copy {
  margin: 0 0 0.65rem;
  font-size: 0.8125rem;
  font-weight: 300;
  line-height: 1.55;
  color: rgba(30, 30, 30, 0.58);
}
.decor-project-page__guest-notice-copy strong {
  display: block;
  margin-bottom: 0.4rem;
  font-family: "Raleway", "Lato", sans-serif;
  font-size: 0.875rem;
  font-weight: 600;
  letter-spacing: 0.02em;
  color: rgba(30, 30, 30, 0.78);
}

.decor-project-page__guest-login.decor-project-page__link-products {
  margin-top: 0;
}

.decor-project-page__header {
  margin-bottom: 0;
}

.decor-project-page__title {
  font-family: "Raleway", "Lato", sans-serif;
  font-size: clamp(1.35rem, 2.5vw, 1.75rem);
  font-weight: 300;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: #1e1e1e;
  margin-bottom: 1.25rem;
}

.decor-project-page__how {
  padding: 1rem 1.15rem 1.1rem;
  background: rgba(255, 255, 255, 0.65);
  border: 1px solid rgba(30, 30, 30, 0.08);
  border-radius: 10px;
  max-width: 42rem;
}

.decor-project-page__how-title {
  margin: 0 0 0.65rem;
  font-family: "Raleway", "Lato", sans-serif;
  font-size: 0.8125rem;
  font-weight: 600;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  color: rgba(30, 30, 30, 0.55);
}

.decor-project-page__steps {
  margin: 0;
  padding-left: 1.2rem;
  font-size: 0.875rem;
  font-weight: 300;
  line-height: 1.55;
  color: rgba(30, 30, 30, 0.78);
}
.decor-project-page__steps li {
  margin-bottom: 0.45rem;
  padding-left: 0.25rem;
}
.decor-project-page__steps li:last-child {
  margin-bottom: 0;
}

.decor-project-page__ac-wrap {
  display: flex;
  flex-direction: column;
  gap: 0.35rem;
  width: 100%;
  max-width: 100%;
}

.decor-project-page__ac-field {
  position: relative;
  width: 100%;
  max-width: min(28rem, 100%);
}

.decor-project-page__ac-input {
  width: 100%;
  max-width: 100%;
}

.decor-project-page__ac-list {
  list-style: none;
  margin: 0.2rem 0 0;
  padding: 0.25rem 0;
  position: absolute;
  top: 100%;
  left: 0;
  right: 0;
  width: 100%;
  z-index: 40;
  max-height: 240px;
  overflow-y: auto;
  background: #fff;
  border: 1px solid rgba(30, 30, 30, 0.14);
  border-radius: 6px;
  box-shadow: 0 10px 28px rgba(0, 0, 0, 0.08);
}

.decor-project-page__ac-item {
  padding: 0.5rem 0.75rem;
  font-size: 0.875rem;
  font-weight: 300;
  line-height: 1.4;
  color: #1e1e1e;
  cursor: pointer;
}
.decor-project-page__ac-item:hover, .decor-project-page__ac-item:focus {
  background: rgba(30, 30, 30, 0.06);
}
.decor-project-page__ac-item--muted {
  cursor: default;
  font-size: 0.8125rem;
  color: rgba(30, 30, 30, 0.45);
}
.decor-project-page__ac-item--muted:hover {
  background: transparent;
}

.decor-project-page__search-hint {
  margin: 0;
  min-height: 1.15em;
  font-size: 0.75rem;
  font-weight: 300;
  line-height: 1.4;
  color: rgba(30, 30, 30, 0.48);
}

.decor-project-page__panel {
  margin-bottom: 0;
  display: flex;
  flex-direction: column;
  gap: clamp(1.35rem, 3vw, 1.85rem);
}

/* Cartões de secção — hierarquia mais clara */
.decor-project-page__card,
.decor-project-page__editor-card {
  padding: 1.35rem 1.5rem 1.5rem;
  background: #fafaf9;
  border: 1px solid rgba(30, 30, 30, 0.09);
  border-radius: 10px;
  box-shadow: 0 1px 0 rgba(255, 255, 255, 0.8) inset;
}

.decor-project-page__card-head {
  padding-bottom: 1.1rem;
  margin-bottom: 1.25rem;
  border-bottom: 1px solid rgba(30, 30, 30, 0.08);
}
.decor-project-page__card-head .decor-project-page__section-title {
  margin-bottom: 0.5rem;
}
.decor-project-page__card-head .decor-project-page__section-kicker {
  margin-bottom: 0;
  max-width: 44rem;
}

.decor-project-page__card-block {
  margin-bottom: 0;
}
.decor-project-page__card-block--actions {
  margin-bottom: 0;
}

.decor-project-page__card-rule {
  display: block;
  width: 100%;
  height: 0;
  margin: 0.35rem 0 1.15rem;
  padding: 0;
  border: 0;
  border-top: 1px solid rgba(30, 30, 30, 0.09);
}

.decor-project-page__card--inline-new {
  padding: 1.25rem 1.5rem 1.35rem;
  background: #f7f6f4;
  border-style: solid;
  border-color: rgba(30, 30, 30, 0.1);
}

.decor-project-page__card--empty {
  margin-bottom: 0;
}

.decor-project-page__card--quote {
  padding: 1.5rem 1.5rem 1.75rem;
}

.decor-project-page__section-title {
  font-family: "Raleway", "Lato", sans-serif;
  font-size: 1.0625rem;
  font-weight: 600;
  letter-spacing: 0.02em;
  text-transform: none;
  color: #1e1e1e;
  margin: 0 0 0.35rem;
  line-height: 1.3;
}

.decor-project-page__section-kicker {
  margin: 0 0 1.15rem;
  font-size: 0.8125rem;
  font-weight: 300;
  line-height: 1.5;
  color: rgba(30, 30, 30, 0.58);
  max-width: 40rem;
}

.decor-project-page__toolbar .decor-project-page__card-head .decor-project-page__section-kicker {
  margin-bottom: 0;
}

.decor-project-page__subsection-title {
  font-family: "Raleway", "Lato", sans-serif;
  font-size: 0.8125rem;
  font-weight: 600;
  letter-spacing: 0.04em;
  text-transform: none;
  color: rgba(30, 30, 30, 0.75);
  margin: 0 0 0.35rem;
}

.decor-project-page__subsection-hint {
  margin: 0 0 0.85rem;
  font-size: 0.75rem;
  font-weight: 300;
  line-height: 1.45;
  color: rgba(30, 30, 30, 0.5);
  max-width: 36rem;
}

.decor-project-page__label--soft {
  font-size: 0.8125rem;
  font-weight: 500;
  letter-spacing: 0.03em;
  text-transform: none;
  color: rgba(30, 30, 30, 0.72);
  margin-bottom: 0.4rem;
}

.decor-project-page__control {
  font-family: "Raleway", "Lato", sans-serif;
  font-size: 0.9375rem;
  font-weight: 300;
  padding: 0.55rem 0.75rem;
  border: 1px solid rgba(30, 30, 30, 0.18);
  border-radius: 6px;
  background: #fff;
  color: #1e1e1e;
}
.decor-project-page__control:focus {
  outline: none;
  border-color: rgba(30, 30, 30, 0.45);
  box-shadow: 0 0 0 3px rgba(30, 30, 30, 0.06);
}

.decor-project-page__control--block {
  display: block;
  width: 100%;
  max-width: 100%;
}

.decor-project-page__share-block {
  margin-top: 0;
  padding-top: 0;
}
.decor-project-page__share-block .decor-project-page__card-rule {
  margin-top: 0;
  margin-bottom: 1.1rem;
}
.decor-project-page__share-block .decor-project-page__subsection-title {
  margin-top: 0;
}

.decor-project-page__share-buttons {
  display: flex;
  flex-wrap: wrap;
  gap: 0.5rem 0.75rem;
}

.decor-project-page__editor-card #decor-project-name-panel {
  margin-bottom: 0.35rem;
}

.decor-project-page__meta {
  display: flex;
  flex-direction: column;
  gap: 1.1rem;
}

.decor-project-page__meta-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: 1rem;
  width: 100%;
}

.decor-project-page__meta-field {
  min-width: 0;
}
.decor-project-page__meta-field--full {
  grid-column: 1/-1;
}

textarea.decor-project-page__textarea--project-notes {
  min-height: 3.75rem;
  max-width: 100%;
  resize: vertical;
}

.decor-project-page__archive-box {
  margin-top: 0.25rem;
  padding: 0.85rem 1rem;
  background: rgba(255, 255, 255, 0.7);
  border: 1px solid rgba(30, 30, 30, 0.08);
  border-radius: 8px;
}

.decor-project-page__archive-label {
  display: flex;
  align-items: flex-start;
  gap: 0.65rem;
  margin: 0;
  cursor: pointer;
  font-size: 0.8125rem;
  font-weight: 400;
  line-height: 1.45;
  color: rgba(30, 30, 30, 0.78);
}

.decor-project-page__archive-text {
  flex: 1;
  min-width: 0;
}

.decor-project-page__checkbox {
  margin: 0.2rem 0 0;
  flex-shrink: 0;
  width: 1rem;
  height: 1rem;
  accent-color: #1e1e1e;
}

.decor-project-page__zero-msg {
  margin-bottom: 1.25rem;
}

.decor-project-page__zero-text {
  margin: 0;
  font-weight: 300;
  font-size: 0.9375rem;
  color: rgba(30, 30, 30, 0.72);
  line-height: 1.5;
}

.decor-project-page__toolbar {
  display: flex;
  flex-direction: column;
  gap: 0;
  margin-bottom: 0;
}

.decor-project-page__toolbar.decor-project-page__card {
  gap: 0;
}

.decor-project-page__card-rule--meta {
  margin-top: 0.15rem;
  margin-bottom: 1.2rem;
}

.decor-project-page__toolbar-row {
  display: flex;
  flex-direction: column;
  gap: 0.35rem;
  width: 100%;
  max-width: 100%;
}

.decor-project-page__toolbar-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 0.5rem 0.75rem;
}

.decor-project-page__btn-delete {
  border-color: rgba(138, 43, 43, 0.45);
  color: #6b2222;
}
.decor-project-page__btn-delete:hover {
  border-color: rgba(138, 43, 43, 0.75);
  color: #4a1515;
}

.decor-project-page__new-inline.decor-project-page__card--inline-new {
  margin-bottom: 0;
  border-top: none;
}

.decor-project-page__new-inline:not(.decor-project-page__card--inline-new) {
  margin-bottom: 1.25rem;
  padding: 1rem 0 0;
  border-top: 1px solid rgba(30, 30, 30, 0.08);
}

.decor-project-page__new-inline-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 0.5rem 0.75rem;
  margin-top: 0.75rem;
}

.decor-project-page__label {
  display: block;
  font-size: 0.6875rem;
  font-weight: 600;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: rgba(30, 30, 30, 0.55);
  margin-bottom: 0.5rem;
}

.decor-project-page__input {
  display: block;
  width: 100%;
  max-width: 28rem;
  font-family: "Raleway", "Lato", sans-serif;
  font-size: 0.9375rem;
  font-weight: 300;
  padding: 0.65rem 0.85rem;
  border: 1px solid rgba(30, 30, 30, 0.15);
  border-radius: 2px;
  background: #fff;
  color: #1e1e1e;
}
.decor-project-page__input:focus {
  outline: none;
  border-color: rgba(30, 30, 30, 0.45);
}

.decor-project-page__input--wide {
  max-width: 100%;
}

textarea.decor-project-page__input {
  min-height: 6.5rem;
  resize: vertical;
  max-width: 100%;
}

.decor-project-page__input--qty {
  max-width: 5.5rem;
}

.decor-project-page__empty {
  padding: 2.5rem 1.5rem;
  text-align: center;
  border: 1px dashed rgba(30, 30, 30, 0.12);
  background: rgba(255, 255, 255, 0.6);
  margin-bottom: 0;
}
.decor-project-page__empty p {
  margin: 0 0 1rem;
  font-weight: 300;
  color: rgba(30, 30, 30, 0.65);
}

.decor-project-page__empty.decor-project-page__card--empty {
  border-style: dashed;
  background: rgba(255, 255, 255, 0.75);
}

.decor-project-page__link-products {
  font-size: 0.6875rem;
  font-weight: 600;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: #1e1e1e;
  border-bottom: 1px solid currentColor;
  text-decoration: none;
}
.decor-project-page__link-products:hover {
  color: #000;
}

.decor-project-page__zones {
  display: flex;
  flex-direction: column;
  gap: 2.5rem;
  margin-top: 0;
  margin-bottom: 0;
  padding-top: 0.25rem;
}

.decor-project-page__zone,
#decor-project-quote {
  scroll-margin-top: 72px;
}

@media (max-width: 991.98px) {
  .decor-project-page__zone,
  #decor-project-quote {
    scroll-margin-top: calc(5rem + env(safe-area-inset-top, 0px) + 10px);
  }
}
@media (min-width: 992px) {
  .decor-project-page__zone,
  #decor-project-quote {
    scroll-margin-top: calc(80px + 14px);
  }
}
.decor-project-page__zone-title {
  font-family: "Raleway", "Lato", sans-serif;
  font-size: 0.75rem;
  font-weight: 600;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: #1e1e1e;
  margin: 0 0 1rem;
  padding-bottom: 0.5rem;
  border-bottom: 1px solid rgba(30, 30, 30, 0.08);
}

.decor-project-page__items {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: 1.25rem;
}

.decor-project-page__item {
  display: grid;
  grid-template-columns: 88px 1fr;
  gap: 1rem 1.25rem;
  padding: 1.25rem;
  background: #fff;
  border: 1px solid rgba(30, 30, 30, 0.08);
  align-items: start;
}
@media (max-width: 575px) {
  .decor-project-page__item {
    grid-template-columns: 72px 1fr;
  }
}

.decor-project-page__item-media-link {
  display: block;
  line-height: 0;
  color: inherit;
  text-decoration: none;
}
.decor-project-page__item-media-link:hover .decor-project-page__item-img, .decor-project-page__item-media-link:focus .decor-project-page__item-img {
  opacity: 0.92;
}
.decor-project-page__item-media-link:focus {
  outline: 2px solid rgba(30, 30, 30, 0.35);
  outline-offset: 2px;
}

.decor-project-page__item-img {
  width: 100%;
  aspect-ratio: 1;
  object-fit: cover;
  background: #fff;
  transition: opacity 0.15s ease;
}

.decor-project-page__item-img--placeholder {
  background: #ece9e3;
}

.decor-project-page__item-product-link {
  color: inherit;
  text-decoration: none;
}
.decor-project-page__item-product-link:hover, .decor-project-page__item-product-link:focus {
  text-decoration: underline;
  color: #000;
}

.decor-project-page__item-body {
  min-width: 0;
}

.decor-project-page__item-title {
  font-size: 1rem;
  font-weight: 500;
  margin: 0 0 0.2rem;
  color: #1e1e1e;
}

.decor-project-page__item-ref {
  font-size: 0.8125rem;
  font-weight: 300;
  color: rgba(30, 30, 30, 0.5);
  margin: 0 0 0.75rem;
}

.decor-project-page__item-row {
  margin-bottom: 0.65rem;
}
.decor-project-page__item-row--actions {
  display: flex;
  flex-wrap: wrap;
  gap: 0.5rem 1rem;
  align-items: center;
  margin-top: 0.75rem;
}

.decor-project-page__item-select {
  font-size: 0.8125rem;
  font-weight: 300;
  padding: 0.35rem 0.5rem;
  border: 1px solid rgba(30, 30, 30, 0.15);
  max-width: 100%;
  background: #fff;
}

.decor-project-page__item-remove {
  font-size: 0.625rem;
  font-weight: 600;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  background: none;
  border: none;
  padding: 0;
  cursor: pointer;
  color: rgba(30, 30, 30, 0.45);
}
.decor-project-page__item-remove:hover {
  color: #000;
}

.decor-project-page__mat-list {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: 0.4rem;
}

.decor-project-page__mat-row {
  display: flex;
  flex-direction: column;
  gap: 0.35rem;
  padding-bottom: 0.35rem;
  margin-bottom: 0.35rem;
  border-bottom: 1px solid rgba(30, 30, 30, 0.06);
}
.decor-project-page__mat-row:last-child {
  padding-bottom: 0;
  margin-bottom: 0;
  border-bottom: 0;
}

.decor-project-page__mat-row-tools {
  display: flex;
  gap: 0.5rem;
  align-items: stretch;
  flex-wrap: nowrap;
}

.decor-project-page__mat-trigger {
  flex: 1;
  min-width: 0;
  display: flex;
  align-items: center;
  gap: 0.65rem;
  padding: 0.4rem 0.5rem;
  border: 1px solid rgba(30, 30, 30, 0.12);
  background: #fff;
  cursor: pointer;
  text-align: left;
  font-family: "Raleway", "Lato", sans-serif;
  transition: border-color 0.15s ease, background 0.15s ease;
}
.decor-project-page__mat-trigger:hover, .decor-project-page__mat-trigger:focus {
  border-color: rgba(30, 30, 30, 0.28);
  background: rgba(30, 30, 30, 0.02);
  outline: none;
}

.decor-project-page__mat-thumb {
  width: 48px;
  height: 48px;
  object-fit: cover;
  flex-shrink: 0;
  background: #fff;
}

.decor-project-page__mat-thumb--empty {
  display: block;
  width: 48px;
  height: 48px;
  flex-shrink: 0;
  background: #ece9e3;
}

.decor-project-page__mat-meta {
  flex: 1;
  min-width: 0;
  font-size: 0.8125rem;
  font-weight: 300;
  line-height: 1.35;
  color: #1e1e1e;
}

.decor-project-page__mat-trigger-hint {
  flex-shrink: 0;
  font-size: 0.65rem;
  color: rgba(30, 30, 30, 0.35);
  margin-left: 0.15rem;
}

.decor-project-page__mat-apply {
  display: flex;
  flex-direction: column;
  gap: 0.2rem;
  padding-left: 0.15rem;
}

.decor-project-page__mat-apply-label {
  margin: 0;
  font-size: 0.6875rem;
  letter-spacing: 0.05em;
  text-transform: uppercase;
  color: rgba(30, 30, 30, 0.48);
}

.decor-project-page__mat-remove {
  flex-shrink: 0;
  width: 1.75rem;
  height: 1.75rem;
  border: none;
  background: rgba(30, 30, 30, 0.06);
  cursor: pointer;
  line-height: 1;
  font-size: 1rem;
  color: rgba(30, 30, 30, 0.5);
}
.decor-project-page__mat-remove:hover {
  background: rgba(30, 30, 30, 0.1);
  color: #000;
}

.decor-project-page__mat-add {
  margin-top: 0.35rem;
  font-size: 0.625rem;
  font-weight: 600;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  background: none;
  border: none;
  padding: 0;
  cursor: pointer;
  color: #1e1e1e;
  text-decoration: underline;
  text-underline-offset: 2px;
}
.decor-project-page__mat-add:hover {
  color: #000;
}

.decor-project-page__quote {
  margin-top: 0;
  padding-top: 0;
  border-top: none;
}

.decor-project-page__quote.decor-project-page__card--quote {
  margin-top: 0;
}
.decor-project-page__quote.decor-project-page__card--quote .decor-project-page__quote-title {
  padding-bottom: 0.85rem;
  margin-bottom: 1.35rem;
  border-bottom: 1px solid rgba(30, 30, 30, 0.08);
}

.decor-project-page__quote-title {
  font-family: "Raleway", "Lato", sans-serif;
  font-size: 0.75rem;
  font-weight: 600;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  margin: 0 0 1.25rem;
  color: #1e1e1e;
}

.decor-project-page__form-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 1rem 1.25rem;
  margin-bottom: 1rem;
}
@media (max-width: 767px) {
  .decor-project-page__form-grid {
    grid-template-columns: 1fr;
  }
}

.decor-project-page__field--full {
  grid-column: 1/-1;
}

.decor-project-page__required-hint {
  font-size: 0.75rem;
  font-weight: 300;
  color: rgba(30, 30, 30, 0.5);
  margin: 0 0 1rem;
}

.decor-project-page__submit {
  margin-top: 0.25rem;
}

.decor-project-page__form-msg {
  margin: 1rem 0 0;
  font-size: 0.875rem;
  font-weight: 300;
}
.decor-project-page__form-msg.is-error {
  color: #8a2b2b;
}
.decor-project-page__form-msg.is-success {
  color: #1e5a1e;
}

/* Atalhos: um botão + painel — canto inferior esquerdo (evita colisão com WhatsApp / Robbu à direita) */
.decor-project-page__jump {
  position: fixed;
  z-index: 10080;
  left: max(0.75rem, env(safe-area-inset-left, 0px) + 0.35rem);
  right: auto;
  bottom: max(0.85rem, env(safe-area-inset-bottom, 0px) + 0.5rem);
  pointer-events: none;
}
.decor-project-page__jump[hidden] {
  display: none !important;
}

.decor-project-page__jump-stack {
  display: flex;
  flex-direction: column-reverse;
  align-items: flex-start;
  gap: 0.5rem;
  pointer-events: auto;
}

.decor-project-page__jump-panel {
  min-width: 11rem;
  max-width: min(18rem, 100vw - 2rem);
  padding: 0.65rem 0.75rem 0.75rem;
  background: #fff;
  border: 1px solid rgba(30, 30, 30, 0.14);
  border-radius: 10px;
  box-shadow: 0 8px 28px rgba(0, 0, 0, 0.12);
}
.decor-project-page__jump-panel[hidden] {
  display: none !important;
}

.decor-project-page__jump-panel-title {
  margin: 0 0 0.5rem;
  font-family: "Raleway", "Lato", sans-serif;
  font-size: 0.6875rem;
  font-weight: 600;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: rgba(30, 30, 30, 0.5);
}

.decor-project-page__jump-menu {
  list-style: none;
  margin: 0;
  padding: 0;
}

.decor-project-page__jump-menu-item {
  margin: 0;
  padding: 0;
}
.decor-project-page__jump-menu-item[hidden] {
  display: none !important;
}

.decor-project-page__jump-menu-label {
  display: block;
  margin: 0.35rem 0 0.25rem;
  font-family: "Raleway", "Lato", sans-serif;
  font-size: 0.625rem;
  font-weight: 600;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: rgba(30, 30, 30, 0.45);
}

.decor-project-page__jump-menu-action {
  display: block;
  width: 100%;
  box-sizing: border-box;
  margin: 0;
  padding: 0.5rem 0.4rem;
  border: 0;
  border-radius: 6px;
  background: transparent;
  font-family: "Raleway", "Lato", sans-serif;
  font-size: 0.8125rem;
  font-weight: 400;
  letter-spacing: 0.02em;
  text-align: left;
  text-transform: none;
  text-decoration: none;
  color: #1e1e1e;
  cursor: pointer;
  transition: background 0.12s ease;
}
.decor-project-page__jump-menu-action:hover, .decor-project-page__jump-menu-action:focus {
  background: rgba(30, 30, 30, 0.06);
  outline: none;
}
.decor-project-page__jump-menu-action--accent {
  margin-top: 0.15rem;
  font-weight: 600;
  color: #fff;
  background: #1e1e1e;
  text-align: center;
}
.decor-project-page__jump-menu-action--accent:hover, .decor-project-page__jump-menu-action--accent:focus {
  background: #111;
  color: #fff;
}

.decor-project-page__jump-roomslist {
  list-style: none;
  margin: 0;
  padding: 0;
  max-height: min(40vh, 220px);
  overflow-y: auto;
  border-radius: 6px;
  border: 1px solid rgba(30, 30, 30, 0.08);
}

.decor-project-page__jump-room-link {
  display: block;
  padding: 0.45rem 0.65rem;
  font-size: 0.8125rem;
  font-weight: 400;
  letter-spacing: 0.02em;
  text-transform: none;
  color: #1e1e1e;
  text-decoration: none;
  border-bottom: 1px solid rgba(30, 30, 30, 0.06);
}
.decor-project-page__jump-room-link:last-child {
  border-bottom: 0;
}
.decor-project-page__jump-room-link:hover, .decor-project-page__jump-room-link:focus {
  background: rgba(30, 30, 30, 0.06);
  outline: none;
}

.decor-project-page__jump-toggle {
  width: 2.75rem;
  height: 2.75rem;
  padding: 0;
  border-radius: 50%;
  border: 1px solid rgba(30, 30, 30, 0.2);
  background: #1e1e1e;
  color: #fff;
  cursor: pointer;
  box-shadow: 0 4px 18px rgba(0, 0, 0, 0.18);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  transition: background 0.15s ease, box-shadow 0.15s ease, transform 0.12s ease;
}
.decor-project-page__jump-toggle:hover {
  background: #111;
  box-shadow: 0 6px 22px rgba(0, 0, 0, 0.22);
}
.decor-project-page__jump-toggle:focus {
  outline: none;
  box-shadow: 0 0 0 3px rgba(30, 30, 30, 0.15), 0 4px 18px rgba(0, 0, 0, 0.18);
}
.decor-project-page__jump-toggle[aria-expanded=true] {
  transform: scale(0.96);
}

.decor-project-page__jump-toggle-bars {
  display: flex;
  flex-direction: column;
  justify-content: center;
  gap: 0.22rem;
  width: 1rem;
  height: 1rem;
}
.decor-project-page__jump-toggle-bars::before, .decor-project-page__jump-toggle-bars::after {
  content: "";
  display: block;
  height: 2px;
  background: currentColor;
  border-radius: 1px;
}
.decor-project-page__jump-toggle-bars::before {
  box-shadow: 0 0.37rem 0 currentColor;
}

/* Modal escolha de material (projeto decoração) */
.decor-mat-modal {
  display: none;
  position: fixed;
  z-index: 1000003;
  inset: 0;
  align-items: center;
  justify-content: center;
  padding: 1rem;
  box-sizing: border-box;
}
.decor-mat-modal.is-open {
  display: flex;
}

.decor-mat-modal__backdrop {
  position: absolute;
  inset: 0;
  border: 0;
  padding: 0;
  margin: 0;
  background: rgba(0, 0, 0, 0.45);
  cursor: pointer;
}

.decor-mat-modal__panel {
  position: relative;
  z-index: 1;
  background: #fff;
  width: 100%;
  max-width: 720px;
  max-height: min(88vh, 640px);
  display: flex;
  flex-direction: column;
  box-shadow: 0 20px 60px rgba(0, 0, 0, 0.22);
  padding: 1.25rem 1.25rem 1rem;
}

.decor-mat-modal__close {
  position: absolute;
  top: 0.5rem;
  right: 0.5rem;
  width: 2.25rem;
  height: 2.25rem;
  border: none;
  background: none;
  cursor: pointer;
  font-size: 1.5rem;
  line-height: 1;
  color: rgba(30, 30, 30, 0.4);
}
.decor-mat-modal__close:hover {
  color: #000;
}

.decor-mat-modal__title {
  font-family: "Raleway", "Lato", sans-serif;
  font-size: 0.8125rem;
  font-weight: 600;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  margin: 0 2rem 0.75rem 0;
  color: #1e1e1e;
}

.decor-mat-modal__scroll {
  overflow: auto;
  flex: 1;
  min-height: 0;
  -webkit-overflow-scrolling: touch;
}

.decor-mat-modal__groups {
  display: flex;
  flex-direction: column;
  gap: 1.35rem;
  padding-bottom: 0.5rem;
}

.decor-mat-modal__group-title {
  font-family: "Raleway", "Lato", sans-serif;
  font-size: 0.6875rem;
  font-weight: 600;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  margin: 0 0 0.65rem;
  padding-bottom: 0.35rem;
  border-bottom: 1px solid rgba(30, 30, 30, 0.08);
  color: rgba(30, 30, 30, 0.55);
}

.decor-mat-modal__group-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(104px, 1fr));
  gap: 0.65rem;
}

.decor-mat-modal__tile {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 0.35rem;
  padding: 0.5rem 0.35rem;
  border: 1px solid rgba(30, 30, 30, 0.1);
  background: #fff;
  cursor: pointer;
  text-align: center;
  transition: border-color 0.15s ease, box-shadow 0.15s ease;
}
.decor-mat-modal__tile:hover, .decor-mat-modal__tile:focus {
  border-color: rgba(30, 30, 30, 0.35);
  box-shadow: 0 4px 14px rgba(0, 0, 0, 0.06);
  outline: none;
}

.decor-mat-modal__tile-img {
  width: 80px;
  height: 80px;
  object-fit: cover;
  background: #fff;
}

.decor-mat-modal__tile-ph {
  display: block;
  width: 80px;
  height: 80px;
  background: #ece9e3;
}

.decor-mat-modal__tile-ref {
  font-size: 0.625rem;
  font-weight: 600;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: #1e1e1e;
  max-width: 100%;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.decor-mat-modal__tile-name {
  font-size: 0.6875rem;
  font-weight: 300;
  line-height: 1.25;
  color: rgba(30, 30, 30, 0.65);
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
  max-width: 100%;
}

/* Modal detalhes do item (projeto decoração) */
.decor-item-modal {
  display: none;
  position: fixed;
  inset: 0;
  z-index: 1000002;
  padding: 1.25rem;
  align-items: center;
  justify-content: center;
}
.decor-item-modal.is-open {
  display: flex;
}

.decor-item-modal__backdrop {
  position: absolute;
  inset: 0;
  border: 0;
  background: rgba(12, 12, 12, 0.5);
  cursor: pointer;
}

.decor-item-modal__panel {
  position: relative;
  z-index: 1;
  width: min(920px, calc(100vw - 2rem));
  max-height: calc(100vh - 2rem);
  overflow: auto;
  background: #fff;
  border: 1px solid rgba(30, 30, 30, 0.12);
  box-shadow: 0 18px 44px rgba(0, 0, 0, 0.16);
  padding: 1rem 1rem 1.1rem;
}

.decor-item-modal__close {
  position: absolute;
  top: 0.25rem;
  right: 0.25rem;
  width: 2.5rem;
  height: 2.5rem;
  display: flex;
  align-items: center;
  justify-content: center;
  border: 0;
  background: transparent;
  color: rgba(30, 30, 30, 0.6);
  font-size: 1.75rem;
  line-height: 1;
  cursor: pointer;
}

.decor-item-modal__title {
  margin: 0 2.85rem 1rem 0;
  font-family: "Raleway", "Lato", sans-serif;
  font-size: 0.8125rem;
  font-weight: 600;
  letter-spacing: 0.11em;
  text-transform: uppercase;
  color: #1e1e1e;
}

.decor-item-modal__body {
  padding-top: 0.35rem;
}

.decor-item-modal__body .decor-project-page__item-details {
  border-top: 0;
  padding: 0;
}

.decor-item-modal__body .decor-project-page__item-head {
  padding-right: 2.75rem;
}

/* Modal produto — adicionar ao projeto */
.decor-add-modal {
  display: none;
  position: fixed;
  z-index: 1000000;
  left: 0;
  top: 0;
  width: 100%;
  height: 100%;
  align-items: flex-start;
  justify-content: center;
  padding: 1rem;
  box-sizing: border-box;
  background: rgba(0, 0, 0, 0.45);
  overflow-y: auto;
}
.decor-add-modal.is-open {
  display: flex;
}

.decor-add-modal__panel {
  background: #fff;
  max-width: 420px;
  width: 100%;
  max-height: calc(100dvh - 2rem);
  margin: auto 0;
  padding: 1.75rem 1.5rem;
  position: relative;
  overflow-y: auto;
  -webkit-overflow-scrolling: touch;
  box-shadow: 0 20px 60px rgba(0, 0, 0, 0.2);
}

.decor-add-modal__title {
  font-family: "Raleway", "Lato", sans-serif;
  font-size: 1rem;
  font-weight: 500;
  margin: 0 0 1rem;
  color: #1e1e1e;
}

.decor-add-modal__close {
  position: absolute;
  top: 0.75rem;
  right: 0.75rem;
  width: 2rem;
  height: 2rem;
  border: none;
  background: none;
  cursor: pointer;
  font-size: 1.5rem;
  line-height: 1;
  color: rgba(30, 30, 30, 0.4);
}
.decor-add-modal__close:hover {
  color: #000;
}

.decor-add-modal__no-projects {
  margin: 0 0 1rem;
  font-size: 0.875rem;
  font-weight: 300;
  line-height: 1.45;
  color: rgba(30, 30, 30, 0.72);
}
.decor-add-modal__no-projects a {
  color: #1e1e1e;
  font-weight: 500;
  text-decoration: underline;
  text-underline-offset: 2px;
}
.decor-add-modal__no-projects a:hover {
  color: #000;
}

.decor-add-modal__project-label {
  margin-top: 0.25rem;
}

.js-decor-add-project-field {
  margin-bottom: 0.75rem;
}

.decor-add-modal__project-select {
  width: 100%;
  max-width: 100%;
  margin-top: 0.35rem;
}

.decor-add-modal__qty-label {
  display: block;
  margin-top: 0.75rem;
}

.decor-add-modal__actions {
  display: flex;
  gap: 0.75rem;
  margin-top: 1.25rem;
  flex-wrap: wrap;
}

.decor-add-modal__actions--split {
  width: 100%;
  justify-content: space-between;
  align-items: center;
}

.product-page__lead-form {
  display: grid;
  gap: 0.5rem;
}
.product-page__lead-form label {
  display: block;
  margin: 0.1rem 0 0.15rem;
  font-size: 0.8125rem;
  font-weight: 500;
  line-height: 1.3;
}
.product-page__lead-form input,
.product-page__lead-form select,
.product-page__lead-form textarea {
  width: 100%;
  padding: 0.65rem 0.75rem;
  border: 1px solid #d8d8d8;
  border-radius: 8px;
  font: inherit;
  box-sizing: border-box;
}
.product-page__lead-form textarea {
  min-height: 4.5rem;
  resize: vertical;
}
.product-page__lead-form .product-page__cta {
  margin-top: 0.35rem;
}

.product-page__cta-row {
  display: flex;
  flex-wrap: wrap;
  gap: 0.75rem 1rem;
  align-items: center;
  margin-top: 0.25rem;
}

.product-page__cta--secondary {
  background: transparent;
  color: #1e1e1e;
  border: 1px solid rgba(30, 30, 30, 0.35);
}
.product-page__cta--secondary:hover, .product-page__cta--secondary:focus {
  background: rgba(30, 30, 30, 0.06);
  color: #000;
}

.decor-project-page__quote-actions .product-page__cta--secondary,
#decor-project-order-trigger {
  background: #e4e4e4;
  color: #1a1a1a;
  border: 1px solid rgba(0, 0, 0, 0.14);
}
.decor-project-page__quote-actions .product-page__cta--secondary:hover,
.decor-project-page__quote-actions .product-page__cta--secondary:focus,
#decor-project-order-trigger:hover,
#decor-project-order-trigger:focus {
  background: #d6d6d6;
  color: #111;
  border-color: rgba(0, 0, 0, 0.2);
}

.nav-decor-project {
  position: relative;
}
.nav-decor-project .decor-project-nav-badge {
  position: absolute;
  top: -2px;
  right: -6px;
}

.fw-menu__link .decor-project-nav-badge {
  position: static;
  margin-left: 0.35rem;
  vertical-align: middle;
}

.decor-project-nav-badge {
  display: none;
  min-width: 16px;
  height: 16px;
  padding: 0 4px;
  font-size: 10px;
  font-weight: 700;
  line-height: 16px;
  text-align: center;
  color: #fff;
  background: #1e1e1e;
  border-radius: 999px;
}
.decor-project-nav-badge.is-visible {
  display: inline-block;
}

.nav-decor-project .decor-project-nav-badge.is-visible {
  display: block;
}

/* —— Página pública: projeto partilhado (cliente) —— */
.decor-share-page {
  max-width: 1180px;
  margin: 0 auto;
  padding-left: clamp(1rem, 3vw, 1.5rem);
  padding-right: clamp(1rem, 3vw, 1.5rem);
  padding-bottom: clamp(3rem, 7vw, 4.5rem);
  padding-top: calc(58px + clamp(1.25rem, 3vw, 1.75rem));
}
@media (max-width: 991.98px) {
  .decor-share-page {
    padding-top: calc(5rem + env(safe-area-inset-top, 0px) + clamp(1.25rem, 3vw, 1.75rem));
  }
}
@media (min-width: 992px) {
  .decor-share-page {
    padding-top: calc(80px + clamp(1.5rem, 4vw, 2.75rem));
  }
}

.decor-share-page__layout {
  display: grid;
  grid-template-columns: 1fr;
  gap: 2rem;
}
@media (min-width: 992px) {
  .decor-share-page__layout {
    grid-template-columns: minmax(0, 1fr) minmax(280px, 360px);
    gap: 2.5rem;
    align-items: start;
  }
}

.decor-share-page__main {
  min-width: 0;
}

@media (min-width: 992px) {
  .decor-share-page__aside {
    position: sticky;
    top: calc(80px + 1.25rem);
  }
}

.decor-share-page__hero {
  border-radius: 14px;
  padding: 1.5rem 1.6rem 1.6rem;
  background: linear-gradient(160deg, #fafaf8 0%, #f2f0ec 55%, #ebe8e2 100%);
  border: 1px solid rgba(30, 30, 30, 0.08);
  box-shadow: 0 12px 40px rgba(0, 0, 0, 0.04);
  margin-bottom: 2rem;
}

.decor-share-page__badge {
  display: inline-block;
  font-size: 0.6875rem;
  font-weight: 600;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: rgba(30, 30, 30, 0.45);
  margin: 0 0 0.75rem;
}

.decor-share-page__title {
  font-family: "Raleway", "Lato", sans-serif;
  font-size: clamp(1.5rem, 3.5vw, 2rem);
  font-weight: 600;
  letter-spacing: 0.02em;
  text-transform: none;
  color: #1e1e1e;
  margin: 0 0 0.35rem;
  line-height: 1.2;
}

.decor-share-page__status {
  margin: 0 0 0.85rem;
  font-size: 0.9375rem;
  font-weight: 400;
  color: rgba(30, 30, 30, 0.55);
}

.decor-share-page__byline {
  margin: 0 0 1rem;
  font-size: 0.8125rem;
  font-weight: 300;
  color: rgba(30, 30, 30, 0.6);
  line-height: 1.45;
}

.decor-share-page__byline-name {
  font-weight: 600;
  color: rgba(30, 30, 30, 0.85);
}

.decor-share-page__notes {
  margin: 0 0 1.25rem;
  padding: 1rem 1.15rem;
  background: rgba(255, 255, 255, 0.75);
  border: 1px solid rgba(30, 30, 30, 0.07);
  border-radius: 10px;
  font-size: 0.875rem;
  line-height: 1.55;
  color: rgba(30, 30, 30, 0.78);
  white-space: pre-wrap;
}

.decor-share-page__toolbar {
  margin: 0;
}

.decor-share-page__btn-print {
  font-family: "Raleway", "Lato", sans-serif;
  font-size: 0.8125rem;
  font-weight: 600;
  letter-spacing: 0.06em;
  padding: 0.65rem 1.35rem;
  border-radius: 8px;
  border: 1px solid #1e1e1e;
  background: #1e1e1e;
  color: #fff;
  cursor: pointer;
  transition: background 0.15s ease, color 0.15s ease;
}
.decor-share-page__btn-print:hover {
  background: #333;
  border-color: #333;
}

.decor-share-page__products-title {
  font-family: "Raleway", "Lato", sans-serif;
  font-size: 0.75rem;
  font-weight: 600;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: rgba(30, 30, 30, 0.5);
  margin: 0 0 1.1rem;
  padding-bottom: 0.5rem;
  border-bottom: 1px solid rgba(30, 30, 30, 0.1);
}

.decor-share-page__item {
  display: grid;
  grid-template-columns: 108px 1fr;
  gap: 1.15rem 1.35rem;
  padding: 1.35rem 1.4rem;
  margin-bottom: 1rem;
  background: #fff;
  border: 1px solid rgba(30, 30, 30, 0.09);
  border-radius: 12px;
  box-shadow: 0 2px 12px rgba(0, 0, 0, 0.03);
}
@media (max-width: 575px) {
  .decor-share-page__item {
    grid-template-columns: 80px 1fr;
    padding: 1.1rem 1rem;
  }
}

.decor-share-page__item-img {
  width: 100%;
  aspect-ratio: 1;
  object-fit: cover;
  border-radius: 8px;
  background: #eee;
}

.decor-share-page__item-ph {
  width: 100%;
  aspect-ratio: 1;
  border-radius: 8px;
  background: #ece9e3;
}

.decor-share-page__item-name {
  font-family: "Raleway", "Lato", sans-serif;
  font-size: 1.0625rem;
  font-weight: 600;
  margin: 0 0 0.5rem;
  color: #1e1e1e;
}

.decor-share-page__item-meta {
  font-size: 0.875rem;
  line-height: 1.45;
  color: rgba(30, 30, 30, 0.72);
  margin: 0.2rem 0;
}
.decor-share-page__item-meta--strong {
  font-weight: 600;
  margin-top: 0.65rem;
  color: rgba(30, 30, 30, 0.55);
  font-size: 0.6875rem;
  letter-spacing: 0.1em;
  text-transform: uppercase;
}

.decor-share-page__item-k {
  font-weight: 600;
  color: rgba(30, 30, 30, 0.45);
  margin-right: 0.25rem;
}

.decor-share-page__mat-apply {
  display: inline;
  font-weight: 400;
  color: rgba(30, 30, 30, 0.55);
}

.decor-share-page__mat-list {
  margin: 0.35rem 0 0;
  padding-left: 1.2rem;
  font-size: 0.875rem;
  color: rgba(30, 30, 30, 0.75);
}

.decor-share-page__empty {
  font-size: 0.9375rem;
  color: rgba(30, 30, 30, 0.5);
  margin: 0;
}

.decor-share-page__card {
  padding: 1.35rem 1.4rem 1.5rem;
  background: #fff;
  border: 1px solid rgba(30, 30, 30, 0.1);
  border-radius: 14px;
  box-shadow: 0 8px 32px rgba(0, 0, 0, 0.06);
}
.decor-share-page__card--muted {
  background: #fafafa;
  box-shadow: none;
}

.decor-share-page__card-title {
  font-family: "Raleway", "Lato", sans-serif;
  font-size: 1.0625rem;
  font-weight: 600;
  margin: 0 0 0.5rem;
  color: #1e1e1e;
  letter-spacing: 0.02em;
}

.decor-share-page__card-intro {
  margin: 0 0 1.15rem;
  font-size: 0.8125rem;
  font-weight: 300;
  line-height: 1.55;
  color: rgba(30, 30, 30, 0.62);
}

.decor-share-page__field {
  margin-bottom: 1rem;
}

.decor-share-page__label {
  display: block;
  font-size: 0.75rem;
  font-weight: 600;
  letter-spacing: 0.04em;
  color: rgba(30, 30, 30, 0.55);
  margin-bottom: 0.35rem;
}

.decor-share-page__req {
  color: #8a2b2b;
}

.decor-share-page__input {
  display: block;
  width: 100%;
  box-sizing: border-box;
  font-family: "Raleway", "Lato", sans-serif;
  font-size: 0.9375rem;
  font-weight: 300;
  padding: 0.6rem 0.75rem;
  border: 1px solid rgba(30, 30, 30, 0.18);
  border-radius: 8px;
  background: #fafafa;
}
.decor-share-page__input:focus {
  outline: none;
  border-color: rgba(30, 30, 30, 0.45);
  background: #fff;
}

.decor-share-page__textarea {
  min-height: 7rem;
  resize: vertical;
}

.decor-share-page__submit {
  width: 100%;
  margin-top: 0.25rem;
  padding: 0.75rem 1rem;
  font-family: "Raleway", "Lato", sans-serif;
  font-size: 0.8125rem;
  font-weight: 600;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  border: none;
  border-radius: 8px;
  background: #1e1e1e;
  color: #fff;
  cursor: pointer;
}
.decor-share-page__submit:hover {
  background: #333;
}

.decor-share-page__form-feedback {
  margin: 0.85rem 0 0;
  font-size: 0.8125rem;
  line-height: 1.45;
  min-height: 1.2em;
}
.decor-share-page__form-feedback--ok {
  color: #1e5a1e;
}
.decor-share-page__form-feedback--err {
  color: #8a2b2b;
}

@media print {
  .decor-share-page__layout {
    display: block;
  }
  .decor-share-page__aside {
    display: none !important;
  }
  .decor-share-page__hero {
    box-shadow: none;
    border: 1px solid #ddd;
  }
  .decor-share-page {
    padding-top: 0;
    max-width: 100%;
  }
}
.product-list .item:hover .image,
.category-list .item:hover .image,
.product-related .item:hover .image {
  opacity: 0.55;
  transition: 0.3s ease;
}
.product-list .link,
.category-list .link,
.product-related .link {
  text-decoration: none;
  display: block;
  color: #1e1e1e;
}
.product-list .title,
.product-list .subtitle,
.category-list .title,
.category-list .subtitle,
.product-related .title,
.product-related .subtitle {
  text-align: center;
  text-transform: uppercase;
  margin-bottom: 1em;
}
.product-list .image,
.category-list .image,
.product-related .image {
  opacity: 1;
  transition: 0.3s ease;
}

.product-related .title {
  margin-bottom: 0.2em;
}

/* Listagem: grelha Bootstrap como no tema antigo */
.product-list--lux .product-list--lux__cell[data-aos] {
  opacity: 1 !important;
  transform: none !important;
}
.product-list--lux .product-list--lux__cell {
  display: flex;
  flex-direction: column;
  align-items: center;
  padding-left: clamp(6px, 0.8vw, 12px);
  padding-right: clamp(6px, 0.8vw, 12px);
}
.product-list--lux .product-list--lux__card {
  display: block;
  width: 100%;
  text-decoration: none;
  color: #1e1e1e;
  text-align: center;
}
.product-list--lux .product-list--lux__card:hover, .product-list--lux .product-list--lux__card:focus {
  text-decoration: none;
  color: #1e1e1e;
}
.product-list--lux .product-list--lux__card:hover .product-list--lux__img, .product-list--lux .product-list--lux__card:focus .product-list--lux__img {
  opacity: 0.92;
}
.product-list--lux .product-list--lux__media {
  margin-bottom: 1rem;
  width: 100%;
  max-width: 100%;
}
.product-list--lux .product-list--lux__img {
  display: block;
  width: 100%;
  max-width: min(100%, 400px);
  height: auto;
  margin-left: auto;
  margin-right: auto;
  opacity: 1;
  transition: opacity 0.35s ease;
}
.product-list--lux .product-list--lux__meta {
  width: 100%;
  text-align: center;
  padding: 0 0.25rem 0.5rem;
}
.product-list--lux .product-list--lux__name {
  display: block;
  font-size: 0.8125rem;
  font-weight: 500;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  line-height: 1.35;
  margin-bottom: 0.35rem;
}
.product-list--lux .product-list--lux__category {
  display: block;
  font-size: 0.75rem;
  font-weight: 300;
  letter-spacing: 0.06em;
  text-transform: capitalize;
  color: #7d7d7d;
}

/*
 -------------------------------------------------------------------
 Product - Downloads
 -------------------------------------------------------------------
*/
.product-download {
  padding: 35px;
  display: block;
  text-decoration: none !important;
  text-transform: uppercase;
  color: #1e1e1e;
}
.product-download:hover {
  color: #1e1e1e;
}

.a0 {
  border-right: 0.5px solid #1e1e1e;
}

.a1 {
  border-right: 0.5px solid #1e1e1e;
}

/*
 -------------------------------------------------------------------
 Override Bootstrap
 -------------------------------------------------------------------
*/
.page-item.active > .page-link {
  background-color: #1e1e1e;
  border-color: #1e1e1e;
}

.page-link {
  line-height: 1.35;
  color: #1e1e1e;
}
.page-link:hover {
  color: #1e1e1e;
}

.-with-slider {
  padding-top: 75px;
}

@media (min-width: 768px) {
  .-with-slider {
    padding-top: 0;
  }
}

/* Decor project visual refresh (header + cards) */
.decor-project-page__how {
  padding: 1rem;
  background: #f7f7f6;
  border: 1px solid rgba(30, 30, 30, 0.08);
  border-radius: 12px;
  max-width: 56rem;
}
.decor-project-page__steps {
  list-style: none;
  margin: 0;
  padding: 0;
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
  gap: 0.65rem;
}
.decor-project-page__step-item {
  display: flex;
  align-items: flex-start;
  gap: 0.65rem;
  padding: 0.75rem 0.8rem;
  background: #fff;
  border: 1px solid rgba(30, 30, 30, 0.08);
  border-radius: 10px;
}
.decor-project-page__step-index {
  display: inline-flex;
  flex-shrink: 0;
  align-items: center;
  justify-content: center;
  width: 1.75rem;
  height: 1.75rem;
  border-radius: 999px;
  background: rgba(30, 30, 30, 0.92);
  color: #fff;
  font-size: 0.625rem;
  font-weight: 600;
  letter-spacing: 0.08em;
}
.decor-project-page__step-copy {
  font-size: 0.8125rem;
  font-weight: 400;
  line-height: 1.45;
  color: rgba(30, 30, 30, 0.78);
}
.decor-project-page__item {
  grid-template-columns: 96px 1fr;
  gap: 1rem 1.1rem;
  padding: 1rem;
  border-radius: 12px;
  box-shadow: 0 4px 16px rgba(0, 0, 0, 0.03);
}
@media (max-width: 575px) {
  .decor-project-page__item {
    grid-template-columns: 82px 1fr;
  }
}
.decor-project-page__item-head {
  display: flex;
  gap: 0.85rem;
  align-items: flex-start;
  justify-content: space-between;
}
.decor-project-page__item-head-copy {
  min-width: 0;
}
.decor-project-page__item-kicker {
  margin: 0 0 0.25rem;
  font-size: 0.625rem;
  font-weight: 600;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: rgba(30, 30, 30, 0.5);
}
.decor-project-page__item-thumbs {
  display: flex;
  gap: 0.25rem;
  flex-wrap: wrap;
  max-width: 84px;
}
.decor-project-page__thumb-mini {
  width: 36px;
  height: 36px;
  border-radius: 6px;
  object-fit: cover;
  background: #ece9e3;
  border: 1px solid rgba(30, 30, 30, 0.08);
}
.decor-project-page__thumb-mini--empty {
  display: block;
}
.decor-project-page__item-sep {
  display: block;
  height: 0;
  margin: 0.7rem 0 0.8rem;
  border: 0;
  border-top: 1px solid rgba(30, 30, 30, 0.08);
}
.decor-project-page__item-title {
  font-weight: 600;
}
.decor-project-page__item-ref {
  font-size: 0.75rem;
  font-weight: 500;
  letter-spacing: 0.05em;
  text-transform: uppercase;
  margin: 0;
}
.decor-project-page__item-row {
  margin-bottom: 0.75rem;
}
.decor-project-page__item-select {
  font-weight: 400;
  padding: 0.45rem 0.55rem;
  border-radius: 6px;
}

/* Decor project top design refinement */
.decor-project-page__header {
  display: grid;
  gap: 1rem;
  align-items: start;
}
@media (min-width: 992px) {
  .decor-project-page__header {
    grid-template-columns: minmax(280px, 0.8fr) minmax(0, 1.2fr);
    gap: 1.25rem;
  }
}
.decor-project-page__guest-notice {
  margin: 0;
  padding: 1rem 1.1rem;
  max-width: 100%;
  border: 1px solid rgba(30, 30, 30, 0.09);
  border-radius: 12px;
  background: linear-gradient(155deg, #fcfcfb 0%, #f5f4f2 100%);
  box-shadow: 0 8px 24px rgba(0, 0, 0, 0.04);
}
.decor-project-page__how {
  background: linear-gradient(155deg, #f9f9f8 0%, #f1f0ee 100%);
  border: 1px solid rgba(30, 30, 30, 0.09);
  border-radius: 14px;
  max-width: 100%;
  box-shadow: 0 10px 30px rgba(0, 0, 0, 0.05);
}
.decor-project-page__step-item {
  box-shadow: 0 3px 10px rgba(0, 0, 0, 0.04);
  transition: transform 0.18s ease, box-shadow 0.18s ease;
}
.decor-project-page__step-item:hover {
  transform: translateY(-2px);
  box-shadow: 0 8px 18px rgba(0, 0, 0, 0.07);
}
.decor-project-page__toolbar.decor-project-page__card {
  border-radius: 14px;
  box-shadow: 0 10px 26px rgba(0, 0, 0, 0.04);
}

/* Decor project item cards closer to design reference */
.decor-project-page__item {
  background: #ffffff;
  border: 1px solid rgba(30, 30, 30, 0.1);
  border-radius: 14px;
  box-shadow: 0 12px 28px rgba(0, 0, 0, 0.06);
}
.decor-project-page__item-img {
  border-radius: 10px;
  box-shadow: 0 5px 14px rgba(0, 0, 0, 0.08);
}
.decor-project-page__item-thumbs {
  position: relative;
  display: grid;
  grid-template-columns: repeat(2, 36px);
  grid-auto-rows: 36px;
  gap: 0.25rem;
  padding: 0.35rem;
  border-radius: 10px;
  background: rgba(30, 30, 30, 0.03);
  border: 1px solid rgba(30, 30, 30, 0.08);
}
.decor-project-page__item-thumbs::after {
  content: "";
  position: absolute;
  left: 10px;
  right: 10px;
  bottom: -8px;
  height: 8px;
  border-radius: 0 0 10px 10px;
  background: rgba(0, 0, 0, 0.12);
  filter: blur(2px);
  z-index: -1;
}
.decor-project-page__thumb-mini {
  border-radius: 5px;
  background: #f2f0ec;
}
.decor-project-page__item-title {
  font-size: 1.03rem;
}
.decor-project-page__item-badges {
  display: flex;
  gap: 0.35rem;
  flex-wrap: wrap;
  margin-top: 0.45rem;
}
.decor-project-page__item-badge {
  display: inline-flex;
  align-items: center;
  gap: 0.25rem;
  font-size: 0.625rem;
  font-weight: 600;
  letter-spacing: 0.03em;
  color: rgba(30, 30, 30, 0.7);
  background: #f3f3f2;
  border: 1px solid rgba(30, 30, 30, 0.1);
  border-radius: 999px;
  padding: 0.18rem 0.45rem;
}
.decor-project-page__item-badge::before {
  content: "";
  width: 0.34rem;
  height: 0.34rem;
  border-radius: 999px;
  background: currentColor;
  opacity: 0.45;
}
.decor-project-page__item-badge--neutral::before {
  background: #7f7f7f;
  opacity: 0.8;
}
.decor-project-page__item-badge--warn {
  color: #7a5a00;
  background: #fff9e9;
  border-color: rgba(122, 90, 0, 0.2);
}
.decor-project-page__item-badge--warn::before {
  background: #d6a100;
  opacity: 0.9;
}

/* Collapsible product rows (decor project) */
.decor-project-page__item {
  display: block;
  padding: 0;
  overflow: hidden;
}
.decor-project-page__item-summary {
  width: 100%;
  border: 0;
  background: transparent;
  padding: 0.9rem 1rem;
  display: grid;
  grid-template-columns: 58px minmax(140px, 1.15fr) minmax(5.25rem, 0.48fr) minmax(4.5rem, 0.38fr) minmax(11.25rem, 1fr) 22px;
  gap: 0.65rem;
  align-items: center;
  text-align: left;
  cursor: pointer;
}
.decor-project-page__item-summary-media {
  display: block;
  line-height: 0;
}
.decor-project-page__item-summary-img {
  width: 58px;
  height: 58px;
  object-fit: cover;
  border-radius: 8px;
  border: 1px solid rgba(30, 30, 30, 0.08);
  background: #f1efeb;
}
.decor-project-page__item-summary-main {
  min-width: 0;
  display: block;
}
.decor-project-page__item-summary-name {
  display: block;
  font-size: 0.92rem;
  font-weight: 600;
  color: #1e1e1e;
  line-height: 1.25;
  margin-bottom: 0.2rem;
}
.decor-project-page__item-summary-code {
  display: block;
  font-size: 0.75rem;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: rgba(30, 30, 30, 0.46);
}
.decor-project-page__item-summary-col {
  display: block;
  font-size: 0.65rem;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: rgba(30, 30, 30, 0.4);
}
.decor-project-page__item-summary-col strong {
  display: block;
  margin-top: 0.2rem;
  font-size: 0.78rem;
  letter-spacing: normal;
  text-transform: none;
  color: rgba(30, 30, 30, 0.82);
  font-weight: 600;
}
.decor-project-page__item-summary-toggle {
  display: inline-flex;
  width: 22px;
  height: 22px;
  align-items: center;
  justify-content: center;
  border-radius: 999px;
  background: rgba(30, 30, 30, 0.08);
  color: rgba(30, 30, 30, 0.7);
  font-size: 1rem;
  line-height: 1;
}
.decor-project-page__item-details {
  display: grid;
  grid-template-columns: 96px 1fr;
  gap: 1rem 1.1rem;
  padding: 0 1rem 1rem;
  border-top: 1px solid rgba(30, 30, 30, 0.09);
  align-items: start;
}
.decor-project-page__item.is-open .decor-project-page__item-summary-toggle {
  transform: rotate(45deg);
}
@media (max-width: 991.98px) {
  .decor-project-page__item-summary {
    grid-template-columns: 58px minmax(120px, 1fr) repeat(2, minmax(70px, 0.55fr)) 22px;
  }
  .decor-project-page__item-summary-col:nth-child(5) {
    display: none;
  }
}
@media (max-width: 575px) {
  .decor-project-page__item-summary {
    grid-template-columns: 52px minmax(0, 1fr) 22px;
    gap: 0.55rem;
    padding: 0.75rem 0.8rem;
  }
  .decor-project-page__item-summary-img {
    width: 52px;
    height: 52px;
  }
  .decor-project-page__item-summary-col {
    display: none;
  }
  .decor-project-page__item-details {
    grid-template-columns: 82px 1fr;
    padding: 0 0.8rem 0.8rem;
  }
}

/* Decor project premium hero carousel */
.decor-project-page__hero-carousel {
  position: relative;
  margin-bottom: clamp(1rem, 2.6vw, 1.6rem);
  padding: clamp(1rem, 2.6vw, 1.35rem);
  border-radius: 16px;
  border: 1px solid rgba(30, 30, 30, 0.1);
  background: linear-gradient(145deg, #f8f8f6 0%, #efeeeb 100%);
  box-shadow: 0 16px 34px rgba(0, 0, 0, 0.08);
}
.decor-project-page__hero-track {
  position: relative;
  min-height: 160px;
}
.decor-project-page__hero-slide {
  display: grid;
  grid-template-columns: 1.1fr 0.9fr;
  gap: 1rem;
  align-items: center;
  opacity: 0;
  transform: translateY(6px);
  transition: opacity 0.28s ease, transform 0.28s ease;
}
@media (max-width: 767px) {
  .decor-project-page__hero-slide {
    grid-template-columns: 1fr;
  }
}
.decor-project-page__hero-slide[hidden] {
  display: block !important;
  visibility: hidden;
  pointer-events: none;
  position: absolute;
  inset: 0;
}
.decor-project-page__hero-slide.is-active {
  opacity: 1;
  transform: translateY(0);
  visibility: visible;
  position: relative;
  inset: auto;
}
.decor-project-page__hero-content {
  min-width: 0;
}
.decor-project-page__hero-media {
  margin: 0;
  border-radius: 12px;
  overflow: hidden;
  border: 1px solid rgba(30, 30, 30, 0.12);
  box-shadow: 0 10px 22px rgba(0, 0, 0, 0.11);
  background: #f2f1ee;
}
.decor-project-page__hero-media img {
  width: 100%;
  height: 100%;
  min-height: 156px;
  max-height: 220px;
  object-fit: cover;
  display: block;
}
.decor-project-page__hero-kicker {
  margin: 0 0 0.45rem;
  font-size: 0.6875rem;
  font-weight: 600;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: rgba(30, 30, 30, 0.5);
}
.decor-project-page__hero-title {
  margin: 0 0 0.45rem;
  font-family: "Raleway", "Lato", "Helvetica Neue", Helvetica, Arial, sans-serif;
  font-size: clamp(1.15rem, 2.3vw, 1.45rem);
  font-weight: 600;
  line-height: 1.25;
  color: #1e1e1e;
}
.decor-project-page__hero-copy {
  margin: 0;
  max-width: 58ch;
  font-size: 0.9rem;
  line-height: 1.52;
  color: rgba(30, 30, 30, 0.7);
}
.decor-project-page__hero-dots {
  margin-top: 0.9rem;
  display: flex;
  align-items: center;
  gap: 0.4rem;
}
.decor-project-page__hero-dot {
  width: 9px;
  height: 9px;
  border-radius: 999px;
  padding: 0;
  border: 0;
  background: rgba(30, 30, 30, 0.24);
  cursor: pointer;
  transition: width 0.2s ease, background-color 0.2s ease;
}
.decor-project-page__hero-dot.is-active {
  width: 24px;
  background: rgba(30, 30, 30, 0.86);
}

/* Hero showcase matching provided visual direction */
.decor-project-page__hero-showcase {
  margin-top: 0.65rem;
  margin-bottom: clamp(1.1rem, 2.6vw, 1.8rem);
}
.decor-project-page__hero-pages {
  position: relative;
}
.decor-project-page__hero-page {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 1.35rem;
}
@media (max-width: 991.98px) {
  .decor-project-page__hero-page {
    grid-template-columns: 1fr;
  }
}
.decor-project-page__hero-nav {
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 0.35rem;
  margin-top: 0.85rem;
}
.decor-project-page__hero-nav-dot {
  width: 9px;
  height: 9px;
  border-radius: 999px;
  border: 0;
  padding: 0;
  background: rgba(30, 30, 30, 0.2);
  cursor: pointer;
}
.decor-project-page__hero-nav-dot.is-active {
  width: 24px;
  background: rgba(30, 30, 30, 0.9);
}
.decor-project-page__hero-col {
  text-align: center;
  display: flex;
  flex-direction: column;
  align-items: center;
}
.decor-project-page__hero-visual {
  height: 260px;
  border-radius: 0;
  background: #fff;
  border: 1px solid rgba(30, 30, 30, 0.1);
  box-shadow: 0 14px 30px rgba(0, 0, 0, 0.08);
  padding: 0.95rem;
  margin-bottom: 0.9rem;
  position: relative;
  overflow: hidden;
}
.decor-project-page__hero-col-title {
  margin: 0 0 0.3rem;
  font-family: "Raleway", "Lato", "Helvetica Neue", Helvetica, Arial, sans-serif;
  font-size: clamp(1.25rem, 2.2vw, 1.9rem);
  font-weight: 600;
  line-height: 1.2;
  color: #1e1e1e;
  min-height: 2.4em;
  width: 100%;
  max-width: 16ch;
  display: flex;
  align-items: flex-end;
  justify-content: center;
}
.decor-project-page__hero-col-copy {
  margin: 0 auto;
  font-family: "Raleway", "Lato", "Helvetica Neue", Helvetica, Arial, sans-serif;
  font-size: 1.02rem;
  line-height: 1.55;
  color: rgba(30, 30, 30, 0.72);
  max-width: 30ch;
  min-height: 4.7em;
}
@media (max-width: 991.98px) {
  .decor-project-page__hero-col-title,
  .decor-project-page__hero-col-copy {
    min-height: 0;
  }
}
.decor-project-page__hero-slot {
  width: 100%;
  height: 100%;
  object-fit: cover;
  border-radius: 10px;
  border: 1px solid rgba(30, 30, 30, 0.09);
  background: #fff;
}
.decor-project-page__hero-slot.is-empty {
  background: linear-gradient(135deg, #f6f5f3 0%, #ece9e3 100%);
}
.decor-project-page__hero-feedback-row {
  display: grid;
  grid-template-columns: 50px 1fr;
  gap: 0.7rem;
  align-items: start;
  margin-bottom: 0.75rem;
}
.decor-project-page__hero-slot--avatar {
  width: 50px;
  height: 50px;
  object-fit: contain;
  padding: 4px;
  background: #fff;
}
.decor-project-page__hero-feedback-copy {
  min-width: 0;
  text-align: left;
}
.decor-project-page__hero-feedback-title {
  margin: 0 0 0.25rem;
  font-family: "Raleway", "Lato", "Helvetica Neue", Helvetica, Arial, sans-serif;
  font-size: 0.95rem;
  font-weight: 600;
  color: rgba(30, 30, 30, 0.83);
}
.decor-project-page__hero-feedback-bubble {
  padding: 0.6rem 0.7rem;
  border-radius: 8px;
  border: 1px solid rgba(30, 30, 30, 0.12);
  background: #fff;
  font-family: "Raleway", "Lato", "Helvetica Neue", Helvetica, Arial, sans-serif;
  font-size: 0.92rem;
  line-height: 1.4;
  color: rgba(30, 30, 30, 0.72);
}
.decor-project-page__hero-live-stack {
  position: absolute;
  inset: 0.7rem;
}
.decor-project-page__hero-live-stack .decor-project-page__hero-slot {
  position: absolute;
  width: 58%;
  height: 58%;
  background: #fff;
  box-shadow: 0 8px 16px rgba(0, 0, 0, 0.12);
}
.decor-project-page__hero-live-stack .decor-project-page__hero-slot:nth-child(1) {
  left: 12%;
  top: 8%;
  transform: rotate(-8deg);
}
.decor-project-page__hero-live-stack .decor-project-page__hero-slot:nth-child(2) {
  left: 30%;
  top: 10%;
  transform: rotate(8deg);
}
.decor-project-page__hero-live-stack .decor-project-page__hero-slot:nth-child(3) {
  left: 20%;
  top: 22%;
  transform: rotate(-2deg);
}
.decor-project-page__hero-approval-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  grid-auto-rows: 66px;
  gap: 0.4rem;
}
.decor-project-page__hero-slot--big {
  grid-column: 1/3;
  grid-row: 1/3;
}
.decor-project-page__hero-approval-name {
  margin: 0.5rem 0 0;
  text-align: left;
  font-family: "Raleway", "Lato", "Helvetica Neue", Helvetica, Arial, sans-serif;
  font-size: 0.95rem;
  font-weight: 600;
  color: rgba(30, 30, 30, 0.86);
}

/* Final consistency overrides for top cards */
.decor-project-page__guest-notice {
  border: 1px solid rgba(30, 30, 30, 0.1);
  border-radius: 14px;
  background: #fff;
  box-shadow: none;
}
.decor-project-page__how {
  background: #fff;
  border: 1px solid rgba(30, 30, 30, 0.1);
  border-radius: 14px;
  box-shadow: none;
}
.decor-project-page__step-item {
  border: 1px solid rgba(30, 30, 30, 0.1);
  box-shadow: none;
}
.decor-project-page__step-item:hover {
  transform: none;
  box-shadow: none;
}

/* Consistência visual de todos os cards da página */
.decor-project-page__card,
.decor-project-page__editor-card,
.decor-project-page__item,
.decor-project-page__item-summary,
.decor-project-page__item-details,
.decor-project-page__empty,
.decor-project-page__quote,
.decor-project-page__how,
.decor-project-page__guest-notice {
  background: #fff;
  border-color: rgba(30, 30, 30, 0.1);
  box-shadow: none;
  border-radius: 0;
}

/* Modern workspace UX */
.decor-project-page__mode-tabs {
  display: flex;
  gap: 0.5rem;
  justify-content: center;
  margin: 0 0 1rem;
}
.decor-project-page__mode-tab {
  display: inline-flex;
  align-items: center;
  gap: 0.4rem;
  border: 1px solid rgba(30, 30, 30, 0.16);
  background: #fff;
  color: rgba(30, 30, 30, 0.75);
  padding: 0.45rem 0.75rem;
  font-family: "Raleway", "Lato", "Helvetica Neue", Helvetica, Arial, sans-serif;
  font-size: 0.8rem;
}
.decor-project-page__mode-tab.is-active {
  background: #1e1e1e;
  color: #fff;
  border-color: #1e1e1e;
}
.decor-project-page__mode-tab-icon {
  font-size: 0.82rem;
  line-height: 1;
}
.decor-project-page__layout {
  display: grid;
  grid-template-columns: minmax(260px, 320px) minmax(0, 1fr);
  gap: clamp(1rem, 2.4vw, 1.5rem);
}
@media (max-width: 991.98px) {
  .decor-project-page__layout {
    grid-template-columns: 1fr;
  }
}
@media (min-width: 992px) {
  .decor-project-page__panel {
    position: sticky;
    top: calc(80px + 0.75rem);
    align-self: start;
    max-height: calc(100vh - 80px - 1rem);
    overflow: auto;
    padding-right: 0.15rem;
  }
}
#decor-project-new-btn::before {
  content: "+ ";
}
#decor-project-delete-btn::before {
  content: "× ";
}
#decor-project-share-btn::before {
  content: "↗ ";
}
.decor-project-page__empty,
.decor-project-page__zones,
.decor-project-page__quote {
  grid-column: 2;
}
#decor-project-page[data-workspace-tab=manage] #decor-project-editor-block,
#decor-project-page[data-workspace-tab=manage] #decor-project-empty,
#decor-project-page[data-workspace-tab=manage] #decor-project-zones,
#decor-project-page[data-workspace-tab=manage] #decor-project-quote {
  display: none !important;
}
#decor-project-page[data-workspace-tab=edit] #decor-project-toolbar,
#decor-project-page[data-workspace-tab=edit] #decor-new-project-inline,
#decor-project-page[data-workspace-tab=edit] #decor-project-zero-msg {
  display: none !important;
}

.decor-project-page__item-summary {
  grid-template-columns: 58px minmax(160px, 1.2fr) repeat(3, minmax(82px, 0.6fr)) 22px;
}
@media (max-width: 991.98px) {
  .decor-project-page__item-summary {
    grid-template-columns: 58px minmax(120px, 1fr) repeat(2, minmax(70px, 0.55fr)) 22px;
  }
  .decor-project-page__item-summary-col:nth-child(5) {
    display: none;
  }
}.news-page-body {
  background: #fff;
  padding-bottom: clamp(2.5rem, 6vh, 4rem);
}

.news-page__shell {
  max-width: min(72rem, 100%);
  margin-left: auto;
  margin-right: auto;
  padding-left: clamp(1rem, 4vw, 2.5rem);
  padding-right: clamp(1rem, 4vw, 2.5rem);
}

.news-page__intro {
  padding-left: 0;
  padding-right: 0;
}

.news-page__intro .product-page__breadcrumb-wrap.products-page__shell {
  padding-left: 0 !important;
  padding-right: 0 !important;
  max-width: 100%;
}

.news-page__intro .product-page__breadcrumb-wrap {
  padding-top: 1.25rem;
  padding-bottom: 0.75rem;
}

.news-page__intro .product-page__breadcrumb {
  padding-left: 0.5rem;
}

.news-page__header {
  margin-bottom: clamp(1.75rem, 4vw, 2.75rem);
  padding-left: 0.5rem;
  text-align: left;
}

.news-page__title {
  font-family: Georgia, "Times New Roman", "Audrey", serif;
  font-size: clamp(1.125rem, 2.5vw, 1.5rem);
  font-weight: 400;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  margin: 0;
  line-height: 1.2;
  color: #1e1e1e;
}

.news-page__list.home-news .home-news-section__inner {
  padding-left: 0;
  padding-right: 0;
}

.news-page__item {
  margin-bottom: clamp(1.75rem, 4vw, 2.5rem);
}
@media (min-width: 992px) {
  .news-page__item {
    margin-bottom: 2.5rem;
  }
}

.news-page__item .home-news__headline {
  font-size: clamp(0.75rem, 1.2vw, 0.875rem);
}

.news-page__item .home-news__excerpt {
  font-size: clamp(0.6875rem, 1vw, 0.75rem);
  -webkit-line-clamp: 4;
}

.news-page__empty {
  margin: 0;
  padding: 2rem 0 3rem;
  font-size: 0.875rem;
  color: rgb(101.4, 101.4, 101.4);
  text-align: center;
}

/* Modal — pedido / encomenda enviado com sucesso */
.praddy-request-success-modal {
  display: none;
  position: fixed;
  inset: 0;
  z-index: 1000001;
  align-items: center;
  justify-content: center;
  padding: 1.25rem;
  box-sizing: border-box;
}

.praddy-request-success-modal.is-open {
  display: flex;
}

body.praddy-success-modal-open {
  overflow: hidden;
}

.praddy-request-success-modal__backdrop {
  position: absolute;
  inset: 0;
  background: rgba(18, 18, 18, 0.52);
  backdrop-filter: blur(2px);
}

.praddy-request-success-modal__panel {
  position: relative;
  z-index: 1;
  width: min(100%, 26rem);
  margin: auto;
  padding: 2rem 1.75rem 1.5rem;
  text-align: center;
  background: #fff;
  box-shadow: 0 24px 64px rgba(0, 0, 0, 0.18);
  animation: praddySuccessModalIn 0.35s ease-out;
}

@keyframes praddySuccessModalIn {
  from {
    opacity: 0;
    transform: translateY(12px) scale(0.98);
  }
  to {
    opacity: 1;
    transform: translateY(0) scale(1);
  }
}

.praddy-request-success-modal__icon {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 4rem;
  height: 4rem;
  margin: 0 auto 1.25rem;
  border-radius: 50%;
  background: #e8f5ec;
  color: #1f7a3f;
}

.praddy-request-success-modal__title {
  margin: 0 0 0.65rem;
  font-family: Raleway, Lato, sans-serif;
  font-size: clamp(1.2rem, 2.5vw, 1.45rem);
  font-weight: 600;
  line-height: 1.25;
  color: #1e1e1e;
}

.praddy-request-success-modal__text {
  margin: 0 0 1.5rem;
  font-size: 0.9375rem;
  font-weight: 300;
  line-height: 1.5;
  color: rgba(30, 30, 30, 0.72);
}

.praddy-request-success-modal__btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 8.5rem;
  padding: 0.7rem 1.75rem;
  border: none;
  background: #1e1e1e;
  color: #fff;
  font-family: Raleway, Lato, sans-serif;
  font-size: 0.8125rem;
  font-weight: 500;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  cursor: pointer;
  transition: background 0.2s ease, transform 0.15s ease;
}

.praddy-request-success-modal__btn:hover,
.praddy-request-success-modal__btn:focus-visible {
  background: #000;
  outline: none;
}

.praddy-request-success-modal__btn:active {
  transform: scale(0.98);
}

/* Modal — pedido / encomenda enviado com sucesso */
.praddy-request-success-modal {
  display: none;
  position: fixed;
  inset: 0;
  z-index: 1000001;
  align-items: center;
  justify-content: center;
  padding: 1.25rem;
  box-sizing: border-box;
}

.praddy-request-success-modal.is-open {
  display: flex;
}

body.praddy-success-modal-open {
  overflow: hidden;
}

.praddy-request-success-modal__backdrop {
  position: absolute;
  inset: 0;
  background: rgba(18, 18, 18, 0.52);
  backdrop-filter: blur(2px);
}

.praddy-request-success-modal__panel {
  position: relative;
  z-index: 1;
  width: min(100%, 26rem);
  margin: auto;
  padding: 2rem 1.75rem 1.5rem;
  text-align: center;
  background: #fff;
  box-shadow: 0 24px 64px rgba(0, 0, 0, 0.18);
  animation: praddySuccessModalIn 0.35s ease-out;
}

@keyframes praddySuccessModalIn {
  from {
    opacity: 0;
    transform: translateY(12px) scale(0.98);
  }
  to {
    opacity: 1;
    transform: translateY(0) scale(1);
  }
}

.praddy-request-success-modal__icon {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 4rem;
  height: 4rem;
  margin: 0 auto 1.25rem;
  border-radius: 50%;
  background: #e8f5ec;
  color: #1f7a3f;
}

.praddy-request-success-modal__title {
  margin: 0 0 0.65rem;
  font-family: Raleway, Lato, sans-serif;
  font-size: clamp(1.2rem, 2.5vw, 1.45rem);
  font-weight: 600;
  line-height: 1.25;
  color: #1e1e1e;
}

.praddy-request-success-modal__text {
  margin: 0 0 1.5rem;
  font-size: 0.9375rem;
  font-weight: 300;
  line-height: 1.5;
  color: rgba(30, 30, 30, 0.72);
}

.praddy-request-success-modal__btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 8.5rem;
  padding: 0.7rem 1.75rem;
  border: none;
  background: #1e1e1e;
  color: #fff;
  font-family: Raleway, Lato, sans-serif;
  font-size: 0.8125rem;
  font-weight: 500;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  cursor: pointer;
  transition: background 0.2s ease, transform 0.15s ease;
}

.praddy-request-success-modal__btn:hover,
.praddy-request-success-modal__btn:focus-visible {
  background: #000;
  outline: none;
}

.praddy-request-success-modal__btn:active {
  transform: scale(0.98);
}
