/*!
* Bootstrap v4.1.0 (https://getbootstrap.com/)
* Copyright 2011-2018 The Bootstrap Authors
* Copyright 2011-2018 Twitter, Inc.
* Licensed under MIT (https://github.com/twbs/bootstrap/blob/master/LICENSE)
*/
:root {
  --banner-blue-strong: #0089c7; /* azul mais intenso */
  --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: #78d5ef;
  --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: "Work Sans", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "Helvetica Neue", Arial, sans-serif, "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol";
  --font-family-monospace: SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace;
}

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

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

@-ms-viewport {
  width: device-width;
}

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

body {
  margin: 0;
  font-family: "Work Sans", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "Helvetica Neue", Arial, sans-serif, "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol";
  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 {
  -webkit-box-sizing: content-box;
  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;
  -webkit-text-decoration: underline dotted;
  text-decoration: underline dotted;
  cursor: help;
  border-bottom: 0;
}

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

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

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

dt {
  font-weight: 700;
}

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

blockquote {
  margin: 0 0 1rem;
}

dfn {
  font-style: italic;
}

b,
strong {
  font-weight: bolder;
}

small {
  font-size: 80%;
}

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

sub {
  bottom: -.25em;
}

sup {
  top: -.5em;
}

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

a:hover {
  color: #34c0e7;
  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: monospace, monospace;
  font-size: 1em;
}

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

figure {
  margin: 0 0 1rem;
}

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

svg:not(:root) {
  overflow: hidden;
}

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

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

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"] {
  -webkit-box-sizing: border-box;
  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: .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-cancel-button,
[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-family: inherit;
  font-weight: 500;
  line-height: 1.2;
  color: inherit;
}

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: 14px;
  font-weight: 400;
}

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

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

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

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

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

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

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

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

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

.img-fluid {
  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,
kbd,
pre,
samp {
  font-family: SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace;
}

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

.order-first {
  -webkit-box-ordinal-group: 0;
  -ms-flex-order: -1;
  order: -1;
}

.order-last {
  -webkit-box-ordinal-group: 14;
  -ms-flex-order: 13;
  order: 13;
}

.order-0 {
  -webkit-box-ordinal-group: 1;
  -ms-flex-order: 0;
  order: 0;
}

.order-1 {
  -webkit-box-ordinal-group: 2;
  -ms-flex-order: 1;
  order: 1;
}

.order-2 {
  -webkit-box-ordinal-group: 3;
  -ms-flex-order: 2;
  order: 2;
}

.order-3 {
  -webkit-box-ordinal-group: 4;
  -ms-flex-order: 3;
  order: 3;
}

.order-4 {
  -webkit-box-ordinal-group: 5;
  -ms-flex-order: 4;
  order: 4;
}

.order-5 {
  -webkit-box-ordinal-group: 6;
  -ms-flex-order: 5;
  order: 5;
}

.order-6 {
  -webkit-box-ordinal-group: 7;
  -ms-flex-order: 6;
  order: 6;
}

.order-7 {
  -webkit-box-ordinal-group: 8;
  -ms-flex-order: 7;
  order: 7;
}

.order-8 {
  -webkit-box-ordinal-group: 9;
  -ms-flex-order: 8;
  order: 8;
}

.order-9 {
  -webkit-box-ordinal-group: 10;
  -ms-flex-order: 9;
  order: 9;
}

.order-10 {
  -webkit-box-ordinal-group: 11;
  -ms-flex-order: 10;
  order: 10;
}

.order-11 {
  -webkit-box-ordinal-group: 12;
  -ms-flex-order: 11;
  order: 11;
}

.order-12 {
  -webkit-box-ordinal-group: 13;
  -ms-flex-order: 12;
  order: 12;
}

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

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

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

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

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

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

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

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

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

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

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

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

  .col-sm-auto {
    -webkit-box-flex: 0;
    -ms-flex: 0 0 auto;
    flex: 0 0 auto;
    width: auto;
    max-width: none;
  }

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

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

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

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

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

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

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

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

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

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

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

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

  .order-sm-first {
    -webkit-box-ordinal-group: 0;
    -ms-flex-order: -1;
    order: -1;
  }

  .order-sm-last {
    -webkit-box-ordinal-group: 14;
    -ms-flex-order: 13;
    order: 13;
  }

  .order-sm-0 {
    -webkit-box-ordinal-group: 1;
    -ms-flex-order: 0;
    order: 0;
  }

  .order-sm-1 {
    -webkit-box-ordinal-group: 2;
    -ms-flex-order: 1;
    order: 1;
  }

  .order-sm-2 {
    -webkit-box-ordinal-group: 3;
    -ms-flex-order: 2;
    order: 2;
  }

  .order-sm-3 {
    -webkit-box-ordinal-group: 4;
    -ms-flex-order: 3;
    order: 3;
  }

  .order-sm-4 {
    -webkit-box-ordinal-group: 5;
    -ms-flex-order: 4;
    order: 4;
  }

  .order-sm-5 {
    -webkit-box-ordinal-group: 6;
    -ms-flex-order: 5;
    order: 5;
  }

  .order-sm-6 {
    -webkit-box-ordinal-group: 7;
    -ms-flex-order: 6;
    order: 6;
  }

  .order-sm-7 {
    -webkit-box-ordinal-group: 8;
    -ms-flex-order: 7;
    order: 7;
  }

  .order-sm-8 {
    -webkit-box-ordinal-group: 9;
    -ms-flex-order: 8;
    order: 8;
  }

  .order-sm-9 {
    -webkit-box-ordinal-group: 10;
    -ms-flex-order: 9;
    order: 9;
  }

  .order-sm-10 {
    -webkit-box-ordinal-group: 11;
    -ms-flex-order: 10;
    order: 10;
  }

  .order-sm-11 {
    -webkit-box-ordinal-group: 12;
    -ms-flex-order: 11;
    order: 11;
  }

  .order-sm-12 {
    -webkit-box-ordinal-group: 13;
    -ms-flex-order: 12;
    order: 12;
  }

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

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

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

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

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

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

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

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

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

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

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

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

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

  .col-md-auto {
    -webkit-box-flex: 0;
    -ms-flex: 0 0 auto;
    flex: 0 0 auto;
    width: auto;
    max-width: none;
  }

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

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

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

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

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

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

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

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

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

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

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

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

  .order-md-first {
    -webkit-box-ordinal-group: 0;
    -ms-flex-order: -1;
    order: -1;
  }

  .order-md-last {
    -webkit-box-ordinal-group: 14;
    -ms-flex-order: 13;
    order: 13;
  }

  .order-md-0 {
    -webkit-box-ordinal-group: 1;
    -ms-flex-order: 0;
    order: 0;
  }

  .order-md-1 {
    -webkit-box-ordinal-group: 2;
    -ms-flex-order: 1;
    order: 1;
  }

  .order-md-2 {
    -webkit-box-ordinal-group: 3;
    -ms-flex-order: 2;
    order: 2;
  }

  .order-md-3 {
    -webkit-box-ordinal-group: 4;
    -ms-flex-order: 3;
    order: 3;
  }

  .order-md-4 {
    -webkit-box-ordinal-group: 5;
    -ms-flex-order: 4;
    order: 4;
  }

  .order-md-5 {
    -webkit-box-ordinal-group: 6;
    -ms-flex-order: 5;
    order: 5;
  }

  .order-md-6 {
    -webkit-box-ordinal-group: 7;
    -ms-flex-order: 6;
    order: 6;
  }

  .order-md-7 {
    -webkit-box-ordinal-group: 8;
    -ms-flex-order: 7;
    order: 7;
  }

  .order-md-8 {
    -webkit-box-ordinal-group: 9;
    -ms-flex-order: 8;
    order: 8;
  }

  .order-md-9 {
    -webkit-box-ordinal-group: 10;
    -ms-flex-order: 9;
    order: 9;
  }

  .order-md-10 {
    -webkit-box-ordinal-group: 11;
    -ms-flex-order: 10;
    order: 10;
  }

  .order-md-11 {
    -webkit-box-ordinal-group: 12;
    -ms-flex-order: 11;
    order: 11;
  }

  .order-md-12 {
    -webkit-box-ordinal-group: 13;
    -ms-flex-order: 12;
    order: 12;
  }

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

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

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

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

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

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

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

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

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

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

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

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

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

  .col-lg-auto {
    -webkit-box-flex: 0;
    -ms-flex: 0 0 auto;
    flex: 0 0 auto;
    width: auto;
    max-width: none;
  }

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

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

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

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

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

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

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

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

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

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

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

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

  .order-lg-first {
    -webkit-box-ordinal-group: 0;
    -ms-flex-order: -1;
    order: -1;
  }

  .order-lg-last {
    -webkit-box-ordinal-group: 14;
    -ms-flex-order: 13;
    order: 13;
  }

  .order-lg-0 {
    -webkit-box-ordinal-group: 1;
    -ms-flex-order: 0;
    order: 0;
  }

  .order-lg-1 {
    -webkit-box-ordinal-group: 2;
    -ms-flex-order: 1;
    order: 1;
  }

  .order-lg-2 {
    -webkit-box-ordinal-group: 3;
    -ms-flex-order: 2;
    order: 2;
  }

  .order-lg-3 {
    -webkit-box-ordinal-group: 4;
    -ms-flex-order: 3;
    order: 3;
  }

  .order-lg-4 {
    -webkit-box-ordinal-group: 5;
    -ms-flex-order: 4;
    order: 4;
  }

  .order-lg-5 {
    -webkit-box-ordinal-group: 6;
    -ms-flex-order: 5;
    order: 5;
  }

  .order-lg-6 {
    -webkit-box-ordinal-group: 7;
    -ms-flex-order: 6;
    order: 6;
  }

  .order-lg-7 {
    -webkit-box-ordinal-group: 8;
    -ms-flex-order: 7;
    order: 7;
  }

  .order-lg-8 {
    -webkit-box-ordinal-group: 9;
    -ms-flex-order: 8;
    order: 8;
  }

  .order-lg-9 {
    -webkit-box-ordinal-group: 10;
    -ms-flex-order: 9;
    order: 9;
  }

  .order-lg-10 {
    -webkit-box-ordinal-group: 11;
    -ms-flex-order: 10;
    order: 10;
  }

  .order-lg-11 {
    -webkit-box-ordinal-group: 12;
    -ms-flex-order: 11;
    order: 11;
  }

  .order-lg-12 {
    -webkit-box-ordinal-group: 13;
    -ms-flex-order: 12;
    order: 12;
  }

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

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

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

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

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

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

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

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

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

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

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

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

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

  .col-xl-auto {
    -webkit-box-flex: 0;
    -ms-flex: 0 0 auto;
    flex: 0 0 auto;
    width: auto;
    max-width: none;
  }

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

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

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

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

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

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

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

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

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

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

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

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

  .order-xl-first {
    -webkit-box-ordinal-group: 0;
    -ms-flex-order: -1;
    order: -1;
  }

  .order-xl-last {
    -webkit-box-ordinal-group: 14;
    -ms-flex-order: 13;
    order: 13;
  }

  .order-xl-0 {
    -webkit-box-ordinal-group: 1;
    -ms-flex-order: 0;
    order: 0;
  }

  .order-xl-1 {
    -webkit-box-ordinal-group: 2;
    -ms-flex-order: 1;
    order: 1;
  }

  .order-xl-2 {
    -webkit-box-ordinal-group: 3;
    -ms-flex-order: 2;
    order: 2;
  }

  .order-xl-3 {
    -webkit-box-ordinal-group: 4;
    -ms-flex-order: 3;
    order: 3;
  }

  .order-xl-4 {
    -webkit-box-ordinal-group: 5;
    -ms-flex-order: 4;
    order: 4;
  }

  .order-xl-5 {
    -webkit-box-ordinal-group: 6;
    -ms-flex-order: 5;
    order: 5;
  }

  .order-xl-6 {
    -webkit-box-ordinal-group: 7;
    -ms-flex-order: 6;
    order: 6;
  }

  .order-xl-7 {
    -webkit-box-ordinal-group: 8;
    -ms-flex-order: 7;
    order: 7;
  }

  .order-xl-8 {
    -webkit-box-ordinal-group: 9;
    -ms-flex-order: 8;
    order: 8;
  }

  .order-xl-9 {
    -webkit-box-ordinal-group: 10;
    -ms-flex-order: 9;
    order: 9;
  }

  .order-xl-10 {
    -webkit-box-ordinal-group: 11;
    -ms-flex-order: 10;
    order: 10;
  }

  .order-xl-11 {
    -webkit-box-ordinal-group: 12;
    -ms-flex-order: 11;
    order: 11;
  }

  .order-xl-12 {
    -webkit-box-ordinal-group: 13;
    -ms-flex-order: 12;
    order: 12;
  }

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

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

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

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

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

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

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

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

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

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

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

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

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

.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 .table {
  background-color: #fff;
}

.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 {
  background-color: rgba(0, 0, 0, 0.075);
}

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

.table .thead-dark th {
  color: #fff;
  background-color: #212529;
  border-color: #32383e;
}

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

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

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

.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 {
  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;
    -ms-overflow-style: -ms-autohiding-scrollbar;
  }

  .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;
    -ms-overflow-style: -ms-autohiding-scrollbar;
  }

  .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;
    -ms-overflow-style: -ms-autohiding-scrollbar;
  }

  .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;
    -ms-overflow-style: -ms-autohiding-scrollbar;
  }

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

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

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

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

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

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

.form-control:focus {
  color: #495057;
  background-color: #fff;
  border-color: #eaf8fd;
  outline: 0;
  -webkit-box-shadow: 0 0 0 0.2rem rgba(120, 213, 239, 0.25);
  box-shadow: 0 0 0 0.2rem rgba(120, 213, 239, 0.25);
}

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

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

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

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

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

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

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,
.input-group-sm>.form-control-plaintext.form-control,
.input-group-sm>.input-group-prepend>.form-control-plaintext.input-group-text,
.input-group-sm>.input-group-append>.form-control-plaintext.input-group-text,
.input-group-sm>.input-group-prepend>.form-control-plaintext.btn,
.input-group-sm>.input-group-append>.form-control-plaintext.btn,
.form-control-plaintext.form-control-lg,
.input-group-lg>.form-control-plaintext.form-control,
.input-group-lg>.input-group-prepend>.form-control-plaintext.input-group-text,
.input-group-lg>.input-group-append>.form-control-plaintext.input-group-text,
.input-group-lg>.input-group-prepend>.form-control-plaintext.btn,
.input-group-lg>.input-group-append>.form-control-plaintext.btn {
  padding-right: 0;
  padding-left: 0;
}

.form-control-sm,
.input-group-sm>.form-control,
.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;
}

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

.form-control-lg,
.input-group-lg>.form-control,
.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;
}

select.form-control-lg:not([size]):not([multiple]),
.input-group-lg>select.form-control:not([size]):not([multiple]),
.input-group-lg>.input-group-prepend>select.input-group-text:not([size]):not([multiple]),
.input-group-lg>.input-group-append>select.input-group-text:not([size]):not([multiple]),
.input-group-lg>.input-group-prepend>select.btn:not([size]):not([multiple]),
.input-group-lg>.input-group-append>select.btn:not([size]):not([multiple]) {
  height: calc(2.875rem + 2px);
}

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

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

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

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

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

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

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

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

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

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

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

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

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

.was-validated .form-control:valid:focus,
.form-control.is-valid:focus,
.was-validated .custom-select:valid:focus,
.custom-select.is-valid:focus {
  border-color: #28a745;
  -webkit-box-shadow: 0 0 0 0.2rem rgba(40, 167, 69, 0.25);
  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,
.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-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 {
  background-color: #71dd8a;
}

.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 {
  background-color: #34ce57;
}

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

.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~.custom-file-label::before,
.custom-file-input.is-valid~.custom-file-label::before {
  border-color: inherit;
}

.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 {
  -webkit-box-shadow: 0 0 0 0.2rem rgba(40, 167, 69, 0.25);
  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: .5rem;
  margin-top: .1rem;
  font-size: .875rem;
  line-height: 1;
  color: #fff;
  background-color: rgba(220, 53, 69, 0.8);
  border-radius: .2rem;
}

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

.was-validated .form-control:invalid:focus,
.form-control.is-invalid:focus,
.was-validated .custom-select:invalid:focus,
.custom-select.is-invalid:focus {
  border-color: #dc3545;
  -webkit-box-shadow: 0 0 0 0.2rem rgba(220, 53, 69, 0.25);
  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,
.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-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 {
  background-color: #efa2a9;
}

.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 {
  background-color: #e4606d;
}

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

.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~.custom-file-label::before,
.custom-file-input.is-invalid~.custom-file-label::before {
  border-color: inherit;
}

.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 {
  -webkit-box-shadow: 0 0 0 0.2rem rgba(220, 53, 69, 0.25);
  box-shadow: 0 0 0 0.2rem rgba(220, 53, 69, 0.25);
}

.form-inline {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: horizontal;
  -webkit-box-direction: normal;
  -ms-flex-flow: row wrap;
  flex-flow: row wrap;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
}

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

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

  .form-inline .form-group {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-flex: 0;
    -ms-flex: 0 0 auto;
    flex: 0 0 auto;
    -webkit-box-orient: horizontal;
    -webkit-box-direction: normal;
    -ms-flex-flow: row wrap;
    flex-flow: row wrap;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    margin-bottom: 0;
  }

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

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

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

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

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

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

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

.btn {
  display: inline-block;
  font-weight: 400;
  text-align: center;
  white-space: nowrap;
  vertical-align: middle;
  -webkit-user-select: none;
  -moz-user-select: none;
  -ms-user-select: none;
  user-select: none;
  border: 1px solid transparent;
  padding: 0.375rem 0.75rem;
  font-size: 1rem;
  line-height: 1.5;
  border-radius: 0.25rem;
  -webkit-transition: color 0.15s ease-in-out, background-color 0.15s ease-in-out, border-color 0.15s ease-in-out, -webkit-box-shadow 0.15s ease-in-out;
  transition: color 0.15s ease-in-out, background-color 0.15s ease-in-out, border-color 0.15s ease-in-out, -webkit-box-shadow 0.15s ease-in-out;
  -o-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;
  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;
  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, -webkit-box-shadow 0.15s ease-in-out;
}

@media screen and (prefers-reduced-motion: reduce) {
  .btn {
    -webkit-transition: none;
    -o-transition: none;
    transition: none;
  }
}

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

.btn:focus,
.btn.focus {
  outline: 0;
  -webkit-box-shadow: 0 0 0 0.2rem rgba(120, 213, 239, 0.25);
  box-shadow: 0 0 0 0.2rem rgba(120, 213, 239, 0.25);
}

.btn.disabled,
.btn:disabled {
  opacity: 0.65;
}

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

.btn:not(:disabled):not(.disabled):active,
.btn:not(:disabled):not(.disabled).active {
  background-image: none;
}

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

.btn-primary {
  color: #212529;
  background-color: #78d5ef;
  border-color: #78d5ef;
}

.btn-primary:hover {
  color: #212529;
  background-color: #56caeb;
  border-color: #4ac7ea;
}

.btn-primary:focus,
.btn-primary.focus {
  -webkit-box-shadow: 0 0 0 0.2rem rgba(120, 213, 239, 0.5);
  box-shadow: 0 0 0 0.2rem rgba(120, 213, 239, 0.5);
}

.btn-primary.disabled,
.btn-primary:disabled {
  color: #212529;
  background-color: #78d5ef;
  border-color: #78d5ef;
}

.btn-primary:not(:disabled):not(.disabled):active,
.btn-primary:not(:disabled):not(.disabled).active,
.show>.btn-primary.dropdown-toggle {
  color: #212529;
  background-color: #4ac7ea;
  border-color: #3fc3e8;
}

.btn-primary:not(:disabled):not(.disabled):active:focus,
.btn-primary:not(:disabled):not(.disabled).active:focus,
.show>.btn-primary.dropdown-toggle:focus {
  -webkit-box-shadow: 0 0 0 0.2rem rgba(120, 213, 239, 0.5);
  box-shadow: 0 0 0 0.2rem rgba(120, 213, 239, 0.5);
}

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

.btn-outline-primary:hover {
  color: #212529;
  background-color: #78d5ef;
  border-color: #78d5ef;
}

.btn-outline-primary:focus,
.btn-outline-primary.focus {
  -webkit-box-shadow: 0 0 0 0.2rem rgba(120, 213, 239, 0.5);
  box-shadow: 0 0 0 0.2rem rgba(120, 213, 239, 0.5);
}

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

.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 {
  -webkit-box-shadow: 0 0 0 0.2rem rgba(120, 213, 239, 0.5);
  box-shadow: 0 0 0 0.2rem rgba(120, 213, 239, 0.5);
}

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

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

.btn-outline-secondary:focus,
.btn-outline-secondary.focus {
  -webkit-box-shadow: 0 0 0 0.2rem rgba(108, 117, 125, 0.5);
  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 {
  -webkit-box-shadow: 0 0 0 0.2rem rgba(108, 117, 125, 0.5);
  box-shadow: 0 0 0 0.2rem rgba(108, 117, 125, 0.5);
}

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

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

.btn-outline-success:focus,
.btn-outline-success.focus {
  -webkit-box-shadow: 0 0 0 0.2rem rgba(40, 167, 69, 0.5);
  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 {
  -webkit-box-shadow: 0 0 0 0.2rem rgba(40, 167, 69, 0.5);
  box-shadow: 0 0 0 0.2rem rgba(40, 167, 69, 0.5);
}

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

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

.btn-outline-info:focus,
.btn-outline-info.focus {
  -webkit-box-shadow: 0 0 0 0.2rem rgba(23, 162, 184, 0.5);
  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 {
  -webkit-box-shadow: 0 0 0 0.2rem rgba(23, 162, 184, 0.5);
  box-shadow: 0 0 0 0.2rem rgba(23, 162, 184, 0.5);
}

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

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

.btn-outline-warning:focus,
.btn-outline-warning.focus {
  -webkit-box-shadow: 0 0 0 0.2rem rgba(255, 193, 7, 0.5);
  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 {
  -webkit-box-shadow: 0 0 0 0.2rem rgba(255, 193, 7, 0.5);
  box-shadow: 0 0 0 0.2rem rgba(255, 193, 7, 0.5);
}

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

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

.btn-outline-danger:focus,
.btn-outline-danger.focus {
  -webkit-box-shadow: 0 0 0 0.2rem rgba(220, 53, 69, 0.5);
  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 {
  -webkit-box-shadow: 0 0 0 0.2rem rgba(220, 53, 69, 0.5);
  box-shadow: 0 0 0 0.2rem rgba(220, 53, 69, 0.5);
}

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

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

.btn-outline-light:focus,
.btn-outline-light.focus {
  -webkit-box-shadow: 0 0 0 0.2rem rgba(248, 249, 250, 0.5);
  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 {
  -webkit-box-shadow: 0 0 0 0.2rem rgba(248, 249, 250, 0.5);
  box-shadow: 0 0 0 0.2rem rgba(248, 249, 250, 0.5);
}

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

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

.btn-outline-dark:focus,
.btn-outline-dark.focus {
  -webkit-box-shadow: 0 0 0 0.2rem rgba(52, 58, 64, 0.5);
  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 {
  -webkit-box-shadow: 0 0 0 0.2rem rgba(52, 58, 64, 0.5);
  box-shadow: 0 0 0 0.2rem rgba(52, 58, 64, 0.5);
}

.btn-link {
  font-weight: 400;
  color: #78d5ef;
  background-color: transparent;
}

.btn-link:hover {
  color: #34c0e7;
  text-decoration: underline;
  background-color: transparent;
  border-color: transparent;
}

.btn-link:focus,
.btn-link.focus {
  text-decoration: underline;
  border-color: transparent;
  -webkit-box-shadow: none;
  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 {
  -webkit-transition: opacity 0.15s linear;
  -o-transition: opacity 0.15s linear;
  transition: opacity 0.15s linear;
}

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

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

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

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

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

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

/* 
.dropdown-toggle::after {
  display: inline-block;
  width: 0;
  height: 0;
  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: #fff !important;
  text-align: left;
  list-style: none;
  background-color: #fff;
  background-clip: padding-box;
  border: 1px solid #fff;
  border-radius: 0.25rem;
}

.dropdown-menu-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;
  width: 0;
  height: 0;
  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;
  width: 0;
  height: 0;
  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;
  width: 0;
  height: 0;
  margin-left: 0.255em;
  vertical-align: 0.255em;
  content: "";
}

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

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

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

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

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

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

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

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

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

.dropdown-item.disabled,
.dropdown-item:disabled {
  color: #6c757d;
  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: -webkit-inline-box;
  display: -ms-inline-flexbox;
  display: inline-flex;
  vertical-align: middle;
}

.btn-group>.btn,
.btn-group-vertical>.btn {
  position: relative;
  -webkit-box-flex: 0;
  -ms-flex: 0 1 auto;
  flex: 0 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-group .btn+.btn,
.btn-group .btn+.btn-group,
.btn-group .btn-group+.btn,
.btn-group .btn-group+.btn-group,
.btn-group-vertical .btn+.btn,
.btn-group-vertical .btn+.btn-group,
.btn-group-vertical .btn-group+.btn,
.btn-group-vertical .btn-group+.btn-group {
  margin-left: -1px;
}

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

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

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

.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 {
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -ms-flex-direction: column;
  flex-direction: column;
  -webkit-box-align: start;
  -ms-flex-align: start;
  align-items: flex-start;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
}

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

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

.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: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
  -webkit-box-align: stretch;
  -ms-flex-align: stretch;
  align-items: stretch;
  width: 100%;
}

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

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

.input-group>.form-control+.form-control,
.input-group>.form-control+.custom-select,
.input-group>.form-control+.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: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: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  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,
.input-group>.custom-file:not(:first-child) .custom-file-label::after {
  border-top-left-radius: 0;
  border-bottom-left-radius: 0;
}

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

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

.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: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  padding: 0.375rem 0.75rem;
  margin-bottom: 0;
  font-size: 1rem;
  font-weight: 400;
  line-height: 1.5;
  color: #495057;
  text-align: center;
  white-space: nowrap;
  background-color: #e9ecef;
  border: 1px solid #ced4da;
  border-radius: 0.25rem;
}

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

.input-group>.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: -webkit-inline-box;
  display: -ms-inline-flexbox;
  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;
  background-color: #78d5ef;
}

.custom-control-input:focus~.custom-control-label::before {
  -webkit-box-shadow: 0 0 0 1px #fff, 0 0 0 0.2rem rgba(120, 213, 239, 0.25);
  box-shadow: 0 0 0 1px #fff, 0 0 0 0.2rem rgba(120, 213, 239, 0.25);
}

.custom-control-input:active~.custom-control-label::before {
  color: #fff;
  background-color: white;
}

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

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

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

.custom-control-label::before {
  position: absolute;
  top: 0.25rem;
  left: 0;
  display: block;
  width: 1rem;
  height: 1rem;
  pointer-events: none;
  content: "";
  -webkit-user-select: none;
  -moz-user-select: none;
  -ms-user-select: none;
  user-select: none;
  background-color: #dee2e6;
}

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

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

.custom-checkbox .custom-control-input:checked~.custom-control-label::before {
  background-color: #78d5ef;
}

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

.custom-checkbox .custom-control-input:indeterminate~.custom-control-label::before {
  background-color: #78d5ef;
}

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

.custom-checkbox .custom-control-input:disabled:checked~.custom-control-label::before {
  background-color: rgba(120, 213, 239, 0.5);
}

.custom-checkbox .custom-control-input:disabled:indeterminate~.custom-control-label::before {
  background-color: rgba(120, 213, 239, 0.5);
}

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

.custom-radio .custom-control-input:checked~.custom-control-label::before {
  background-color: #78d5ef;
}

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

.custom-radio .custom-control-input:disabled:checked~.custom-control-label::before {
  background-color: rgba(120, 213, 239, 0.5);
}

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

.custom-select:focus {
  border-color: #eaf8fd;
  outline: 0;
  -webkit-box-shadow: inset 0 1px 2px rgba(0, 0, 0, 0.075), 0 0 5px rgba(234, 248, 253, 0.5);
  box-shadow: inset 0 1px 2px rgba(0, 0, 0, 0.075), 0 0 5px rgba(234, 248, 253, 0.5);
}

.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 {
  opacity: 0;
}

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

.custom-select-lg {
  height: calc(2.875rem + 2px);
  padding-top: 0.375rem;
  padding-bottom: 0.375rem;
  font-size: 125%;
}

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

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

.custom-file-input:focus~.custom-file-label {
  border-color: #eaf8fd;
  -webkit-box-shadow: 0 0 0 0.2rem rgba(120, 213, 239, 0.25);
  box-shadow: 0 0 0 0.2rem rgba(120, 213, 239, 0.25);
}

.custom-file-input:focus~.custom-file-label::after {
  border-color: #eaf8fd;
}

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

.custom-file-label {
  position: absolute;
  top: 0;
  right: 0;
  left: 0;
  z-index: 1;
  height: calc(2.25rem + 2px);
  padding: 0.375rem 0.75rem;
  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(calc(2.25rem + 2px) - 1px * 2);
  padding: 0.375rem 0.75rem;
  line-height: 1.5;
  color: #495057;
  content: "Browse";
  background-color: #e9ecef;
  border-left: 1px solid #ced4da;
  border-radius: 0 0.25rem 0.25rem 0;
}

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

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

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

.custom-range::-webkit-slider-thumb {
  width: 1rem;
  height: 1rem;
  margin-top: -0.25rem;
  background-color: #78d5ef;
  border: 0;
  border-radius: 1rem;
  -webkit-appearance: none;
  appearance: none;
}

.custom-range::-webkit-slider-thumb:focus {
  outline: none;
  -webkit-box-shadow: 0 0 0 1px #fff, 0 0 0 0.2rem rgba(120, 213, 239, 0.25);
  box-shadow: 0 0 0 1px #fff, 0 0 0 0.2rem rgba(120, 213, 239, 0.25);
}

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

.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: #78d5ef;
  border: 0;
  border-radius: 1rem;
  -moz-appearance: none;
  appearance: none;
}

.custom-range::-moz-range-thumb:focus {
  outline: none;
  box-shadow: 0 0 0 1px #fff, 0 0 0 0.2rem rgba(120, 213, 239, 0.25);
}

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

.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;
  background-color: #78d5ef;
  border: 0;
  border-radius: 1rem;
  appearance: none;
}

.custom-range::-ms-thumb:focus {
  outline: none;
  box-shadow: 0 0 0 1px #fff, 0 0 0 0.2rem rgba(120, 213, 239, 0.25);
}

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

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

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

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

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

.nav-link.disabled {
  color: #6c757d;
}

.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: #78d5ef;
}

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

.navbar-toggler:not(:disabled):not(.disabled) {
  cursor: pointer;
}

.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 {
    -webkit-box-orient: horizontal;
    -webkit-box-direction: normal;
    -ms-flex-flow: row nowrap;
    flex-flow: row nowrap;
    -webkit-box-pack: start;
    -ms-flex-pack: start;
    justify-content: flex-start;
  }

  .navbar-expand-sm .navbar-nav {
    -webkit-box-orient: horizontal;
    -webkit-box-direction: normal;
    -ms-flex-direction: row;
    flex-direction: row;
  }

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

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

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

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

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

@media (max-width: 767.98px) {

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

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

  .navbar-expand-md .navbar-nav {
    -webkit-box-orient: horizontal;
    -webkit-box-direction: normal;
    -ms-flex-direction: row;
    flex-direction: row;
  }

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

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

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

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

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

@media (max-width: 991.98px) {

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

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

  .navbar-expand-lg .navbar-nav {
    -webkit-box-orient: horizontal;
    -webkit-box-direction: normal;
    -ms-flex-direction: row;
    flex-direction: row;
  }

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

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

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

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

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

@media (max-width: 1199.98px) {

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

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

  .navbar-expand-xl .navbar-nav {
    -webkit-box-orient: horizontal;
    -webkit-box-direction: normal;
    -ms-flex-direction: row;
    flex-direction: row;
  }

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

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

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

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

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

.navbar-expand {
  -webkit-box-orient: horizontal;
  -webkit-box-direction: normal;
  -ms-flex-flow: row nowrap;
  flex-flow: row nowrap;
  -webkit-box-pack: start;
  -ms-flex-pack: start;
  justify-content: flex-start;
}

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

.navbar-expand .navbar-nav {
  -webkit-box-orient: horizontal;
  -webkit-box-direction: normal;
  -ms-flex-direction: row;
  flex-direction: row;
}

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

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

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

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

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

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

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

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

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

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

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

.navbar-light .navbar-toggler {
  color: rgba(0, 0, 0, 0.5);
  border-color: rgba(0, 0, 0, 0.1);
}

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

.navbar-light .navbar-text {
  color: rgba(0, 0, 0, 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-toggler {
  border: none !important;
  box-shadow: none !important;
  outline: none !important;
}


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

.navbar-dark .navbar-text {
  color: 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: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -ms-flex-direction: column;
  flex-direction: column;
  min-width: 0;
  word-wrap: break-word;
  background-color: #fff;
  background-clip: border-box;
  border: 1px solid rgba(0, 0, 0, 0.125);
  border-radius: 0.25rem;
}

.card>hr {
  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 {
  -webkit-box-flex: 1;
  -ms-flex: 1 1 auto;
  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: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -ms-flex-direction: column;
  flex-direction: column;
}

.card-deck .card {
  margin-bottom: 15px;
}

@media (min-width: 576px) {
  .card-deck {
    -webkit-box-orient: horizontal;
    -webkit-box-direction: normal;
    -ms-flex-flow: row wrap;
    flex-flow: row wrap;
    margin-right: -15px;
    margin-left: -15px;
  }

  .card-deck .card {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-flex: 1;
    -ms-flex: 1 0 0%;
    flex: 1 0 0%;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -ms-flex-direction: column;
    flex-direction: column;
    margin-right: 15px;
    margin-bottom: 0;
    margin-left: 15px;
  }
}

.card-group {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -ms-flex-direction: column;
  flex-direction: column;
}

.card-group>.card {
  margin-bottom: 15px;
}

@media (min-width: 576px) {
  .card-group {
    -webkit-box-orient: horizontal;
    -webkit-box-direction: normal;
    -ms-flex-flow: row wrap;
    flex-flow: row wrap;
  }

  .card-group>.card {
    -webkit-box-flex: 1;
    -ms-flex: 1 0 0%;
    flex: 1 0 0%;
    margin-bottom: 0;
  }

  .card-group>.card+.card {
    margin-left: 0;
    border-left: 0;
  }

  .card-group>.card:first-child {
    border-top-right-radius: 0;
    border-bottom-right-radius: 0;
  }

  .card-group>.card:first-child .card-img-top,
  .card-group>.card:first-child .card-header {
    border-top-right-radius: 0;
  }

  .card-group>.card:first-child .card-img-bottom,
  .card-group>.card:first-child .card-footer {
    border-bottom-right-radius: 0;
  }

  .card-group>.card:last-child {
    border-top-left-radius: 0;
    border-bottom-left-radius: 0;
  }

  .card-group>.card:last-child .card-img-top,
  .card-group>.card:last-child .card-header {
    border-top-left-radius: 0;
  }

  .card-group>.card:last-child .card-img-bottom,
  .card-group>.card:last-child .card-footer {
    border-bottom-left-radius: 0;
  }

  .card-group>.card:only-child {
    border-radius: 0.25rem;
  }

  .card-group>.card:only-child .card-img-top,
  .card-group>.card:only-child .card-header {
    border-top-left-radius: 0.25rem;
    border-top-right-radius: 0.25rem;
  }

  .card-group>.card:only-child .card-img-bottom,
  .card-group>.card:only-child .card-footer {
    border-bottom-right-radius: 0.25rem;
    border-bottom-left-radius: 0.25rem;
  }

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

  .card-group>.card:not(:first-child):not(:last-child):not(:only-child) .card-img-top,
  .card-group>.card:not(:first-child):not(:last-child):not(:only-child) .card-img-bottom,
  .card-group>.card:not(:first-child):not(:last-child):not(:only-child) .card-header,
  .card-group>.card:not(:first-child):not(:last-child):not(:only-child) .card-footer {
    border-radius: 0;
  }
}

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

@media (min-width: 576px) {
  .card-columns {
    -webkit-column-count: 3;
    column-count: 3;
    -webkit-column-gap: 1.25rem;
    column-gap: 1.25rem;
    orphans: 1;
    widows: 1;
  }

  .card-columns .card {
    display: inline-block;
    width: 100%;
  }
}

.accordion .card:not(:first-of-type):not(:last-of-type) {
  border-bottom: 0;
  border-radius: 0;
}

.accordion .card:not(:first-of-type) .card-header:first-child {
  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;
}

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

.breadcrumb-item+.breadcrumb-item {
  padding-left: 0.5rem;
}

.breadcrumb-item+.breadcrumb-item::before {
  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: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  padding-left: 0;
  list-style: none;
  border-radius: 0.25rem;
}

.page-link {
  position: relative;
  display: block;
  padding: 0.5rem 0.75rem;
  margin-left: -1px;
  line-height: 1.25;
  color: #78d5ef;
  background-color: #fff;
  border: 1px solid #dee2e6;
}

.page-link:hover {
  z-index: 2;
  color: #34c0e7;
  text-decoration: none;
  background-color: #e9ecef;
  border-color: #dee2e6;
}

.page-link:focus {
  z-index: 2;
  outline: 0;
  -webkit-box-shadow: 0 0 0 0.2rem rgba(120, 213, 239, 0.25);
  box-shadow: 0 0 0 0.2rem rgba(120, 213, 239, 0.25);
}

.page-link:not(:disabled):not(.disabled) {
  cursor: pointer;
}

.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: #78d5ef;
  border-color: #78d5ef;
}

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

.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: #212529;
  background-color: #78d5ef;
}

.badge-primary[href]:hover,
.badge-primary[href]:focus {
  color: #212529;
  text-decoration: none;
  background-color: #4ac7ea;
}

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

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

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

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

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

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

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

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

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

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

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

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

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

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

.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: #3e6f7c;
  background-color: #e4f7fc;
  border-color: #d9f3fb;
}

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

.alert-primary .alert-link {
  color: #2d515a;
}

.alert-secondary {
  color: #383d41;
  background-color: #e2e3e5;
  border-color: #d6d8db;
}

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

.alert-secondary .alert-link {
  color: #202326;
}

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

@-webkit-keyframes progress-bar-stripes {
  from {
    background-position: 1rem 0;
  }

  to {
    background-position: 0 0;
  }
}

@keyframes progress-bar-stripes {
  from {
    background-position: 1rem 0;
  }

  to {
    background-position: 0 0;
  }
}

.progress {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  height: 1rem;
  overflow: hidden;
  font-size: 0.75rem;
  background-color: #e9ecef;
  border-radius: 0.25rem;
}

.progress-bar {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -ms-flex-direction: column;
  flex-direction: column;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  color: #fff;
  text-align: center;
  white-space: nowrap;
  background-color: #78d5ef;
  -webkit-transition: width 0.6s ease;
  -o-transition: width 0.6s ease;
  transition: width 0.6s ease;
}

@media screen and (prefers-reduced-motion: reduce) {
  .progress-bar {
    -webkit-transition: none;
    -o-transition: none;
    transition: none;
  }
}

.progress-bar-striped {
  background-image: -webkit-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-image: -o-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-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 {
  -webkit-animation: progress-bar-stripes 1s linear infinite;
  animation: progress-bar-stripes 1s linear infinite;
}

.media {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: start;
  -ms-flex-align: start;
  align-items: flex-start;
}

.media-body {
  -webkit-box-flex: 1;
  -ms-flex: 1;
  flex: 1;
}

.list-group {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -ms-flex-direction: column;
  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 {
  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:hover,
.list-group-item:focus {
  z-index: 1;
  text-decoration: none;
}

.list-group-item.disabled,
.list-group-item:disabled {
  color: #6c757d;
  background-color: #fff;
}

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

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

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

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

.list-group-item-primary {
  color: #3e6f7c;
  background-color: #d9f3fb;
}

.list-group-item-primary.list-group-item-action:hover,
.list-group-item-primary.list-group-item-action:focus {
  color: #3e6f7c;
  background-color: #c2ecf9;
}

.list-group-item-primary.list-group-item-action.active {
  color: #fff;
  background-color: #3e6f7c;
  border-color: #3e6f7c;
}

.list-group-item-secondary {
  color: #383d41;
  background-color: #d6d8db;
}

.list-group-item-secondary.list-group-item-action:hover,
.list-group-item-secondary.list-group-item-action:focus {
  color: #383d41;
  background-color: #c8cbcf;
}

.list-group-item-secondary.list-group-item-action.active {
  color: #fff;
  background-color: #383d41;
  border-color: #383d41;
}

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

.close:not(:disabled):not(.disabled) {
  cursor: pointer;
}

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

.modal-open {
  overflow: hidden;
}

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

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

.modal-dialog {
  position: relative;
  width: auto;
  margin: 0.5rem;
  pointer-events: none;
}

.modal.fade .modal-dialog {
  -webkit-transition: -webkit-transform 0.3s ease-out;
  transition: -webkit-transform 0.3s ease-out;
  -o-transition: transform 0.3s ease-out;
  transition: transform 0.3s ease-out;
  transition: transform 0.3s ease-out, -webkit-transform 0.3s ease-out;
  -webkit-transform: translate(0, -25%);
  -ms-transform: translate(0, -25%);
  transform: translate(0, -25%);
}

@media screen and (prefers-reduced-motion: reduce) {
  .modal.fade .modal-dialog {
    -webkit-transition: none;
    -o-transition: none;
    transition: none;
  }
}

.modal.show .modal-dialog {
  -webkit-transform: translate(0, 0);
  -ms-transform: translate(0, 0);
  transform: translate(0, 0);
}

.modal-dialog-centered {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  min-height: calc(100% - (0.5rem * 2));
}

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

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

.modal-backdrop.fade {
  opacity: 0;
}

.modal-backdrop.show {
  opacity: 0.5;
}

.modal-header {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: start;
  -ms-flex-align: start;
  align-items: flex-start;
  -webkit-box-pack: justify;
  -ms-flex-pack: justify;
  justify-content: space-between;
  padding: 1rem;
  border-bottom: 1px solid #e9ecef;
  border-top-left-radius: 0.3rem;
  border-top-right-radius: 0.3rem;
}

.modal-header .close {
  padding: 1rem;
  margin: -1rem -1rem -1rem auto;
}

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

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

.modal-footer {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  -webkit-box-pack: end;
  -ms-flex-pack: end;
  justify-content: flex-end;
  padding: 1rem;
  border-top: 1px solid #e9ecef;
}

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

.modal-footer> :not(:last-child) {
  margin-right: .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-centered {
    min-height: calc(100% - (1.75rem * 2));
  }

  .modal-sm {
    max-width: 300px;
  }
}

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

.tooltip {
  position: absolute;
  z-index: 1070;
  display: block;
  margin: 0;
  font-family: "Work Sans", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "Helvetica Neue", Arial, sans-serif, "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol";
  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: "Work Sans", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "Helvetica Neue", Arial, sans-serif, "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol";
  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,
.bs-popover-top .arrow::after,
.bs-popover-auto[x-placement^="top"] .arrow::after {
  border-width: 0.5rem 0.5rem 0;
}

.bs-popover-top .arrow::before,
.bs-popover-auto[x-placement^="top"] .arrow::before {
  bottom: 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-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,
.bs-popover-right .arrow::after,
.bs-popover-auto[x-placement^="right"] .arrow::after {
  border-width: 0.5rem 0.5rem 0.5rem 0;
}

.bs-popover-right .arrow::before,
.bs-popover-auto[x-placement^="right"] .arrow::before {
  left: 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-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,
.bs-popover-bottom .arrow::after,
.bs-popover-auto[x-placement^="bottom"] .arrow::after {
  border-width: 0 0.5rem 0.5rem 0.5rem;
}

.bs-popover-bottom .arrow::before,
.bs-popover-auto[x-placement^="bottom"] .arrow::before {
  top: 0;
  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-bottom-color: #fff;
}

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

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

.bs-popover-left .arrow,
.bs-popover-auto[x-placement^="left"] .arrow {
  right: calc((0.5rem + 1px) * -1);
  width: 0.5rem;
  height: 1rem;
  margin: 0.3rem 0;
}

.bs-popover-left .arrow::before,
.bs-popover-auto[x-placement^="left"] .arrow::before,
.bs-popover-left .arrow::after,
.bs-popover-auto[x-placement^="left"] .arrow::after {
  border-width: 0.5rem 0 0.5rem 0.5rem;
}

.bs-popover-left .arrow::before,
.bs-popover-auto[x-placement^="left"] .arrow::before {
  right: 0;
  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-left-color: #fff;
}

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

.popover-header:empty {
  display: none;
}

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

.carousel {
  position: relative;
}

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

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

@media screen and (prefers-reduced-motion: reduce) {
  .carousel-item {
    -webkit-transition: none;
    -o-transition: none;
    transition: none;
  }
}

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

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

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

@supports ((-webkit-transform-style: preserve-3d) or (transform-style: preserve-3d)) {

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

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

@supports ((-webkit-transform-style: preserve-3d) or (transform-style: preserve-3d)) {

  .carousel-item-next,
  .active.carousel-item-right {
    -webkit-transform: translate3d(100%, 0, 0);
    transform: translate3d(100%, 0, 0);
  }
}

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

@supports ((-webkit-transform-style: preserve-3d) or (transform-style: preserve-3d)) {

  .carousel-item-prev,
  .active.carousel-item-left {
    -webkit-transform: translate3d(-100%, 0, 0);
    transform: translate3d(-100%, 0, 0);
  }
}

.carousel-fade .carousel-item {
  opacity: 0;
  -webkit-transition-duration: .6s;
  -o-transition-duration: .6s;
  transition-duration: .6s;
  -webkit-transition-property: opacity;
  -o-transition-property: opacity;
  transition-property: opacity;
}

.carousel-fade .carousel-item.active,
.carousel-fade .carousel-item-next.carousel-item-left,
.carousel-fade .carousel-item-prev.carousel-item-right {
  opacity: 1;
}

.carousel-fade .active.carousel-item-left,
.carousel-fade .active.carousel-item-right {
  opacity: 0;
}

.carousel-fade .carousel-item-next,
.carousel-fade .carousel-item-prev,
.carousel-fade .carousel-item.active,
.carousel-fade .active.carousel-item-left,
.carousel-fade .active.carousel-item-prev {
  -webkit-transform: translateX(0);
  -ms-transform: translateX(0);
  transform: translateX(0);
}

@supports ((-webkit-transform-style: preserve-3d) or (transform-style: preserve-3d)) {

  .carousel-fade .carousel-item-next,
  .carousel-fade .carousel-item-prev,
  .carousel-fade .carousel-item.active,
  .carousel-fade .active.carousel-item-left,
  .carousel-fade .active.carousel-item-prev {
    -webkit-transform: translate3d(0, 0, 0);
    transform: translate3d(0, 0, 0);
  }
}

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

.carousel-control-prev:hover,
.carousel-control-prev:focus,
.carousel-control-next:hover,
.carousel-control-next:focus {
  color: #fff;
  text-decoration: none;
  outline: 0;
  opacity: .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: transparent no-repeat center center;
  background-size: 100% 100%;
}

.carousel-control-prev-icon {
  background-image: url("data:image/svg+xml;charset=utf8,%3Csvg xmlns='http://www.w3.org/2000/svg' fill='%23fff' viewBox='0 0 8 8'%3E%3Cpath d='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;charset=utf8,%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: 10px;
  left: 0;
  z-index: 15;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  padding-left: 0;
  margin-right: 15%;
  margin-left: 15%;
  list-style: none;
}

.carousel-indicators li {
  position: relative;
  -webkit-box-flex: 0;
  -ms-flex: 0 1 auto;
  flex: 0 1 auto;
  width: 30px;
  height: 3px;
  margin-right: 3px;
  margin-left: 3px;
  text-indent: -999px;
  background-color: rgba(255, 255, 255, 0.5);
}

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

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

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

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

.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: #78d5ef !important;
}

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

.border-primary {
  border-color: #78d5ef !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 {
  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-circle {
  border-radius: 50% !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: -webkit-box !important;
  display: -ms-flexbox !important;
  display: flex !important;
}

.d-inline-flex {
  display: -webkit-inline-box !important;
  display: -ms-inline-flexbox !important;
  display: inline-flex !important;
}

@media (min-width: 576px) {
  .d-sm-none {
    display: none !important;
  }

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

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

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

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

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

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

  .d-sm-flex {
    display: -webkit-box !important;
    display: -ms-flexbox !important;
    display: flex !important;
  }

  .d-sm-inline-flex {
    display: -webkit-inline-box !important;
    display: -ms-inline-flexbox !important;
    display: inline-flex !important;
  }
}

@media (min-width: 768px) {
  .d-md-none {
    display: none !important;
  }

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

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

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

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

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

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

  .d-md-flex {
    display: -webkit-box !important;
    display: -ms-flexbox !important;
    display: flex !important;
  }

  .d-md-inline-flex {
    display: -webkit-inline-box !important;
    display: -ms-inline-flexbox !important;
    display: inline-flex !important;
  }
}

@media (min-width: 992px) {
  .d-lg-none {
    display: none !important;
  }

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

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

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

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

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

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

  .d-lg-flex {
    display: -webkit-box !important;
    display: -ms-flexbox !important;
    display: flex !important;
  }

  .d-lg-inline-flex {
    display: -webkit-inline-box !important;
    display: -ms-inline-flexbox !important;
    display: inline-flex !important;
  }
}

@media (min-width: 1200px) {
  .d-xl-none {
    display: none !important;
  }

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

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

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

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

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

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

  .d-xl-flex {
    display: -webkit-box !important;
    display: -ms-flexbox !important;
    display: flex !important;
  }

  .d-xl-inline-flex {
    display: -webkit-inline-box !important;
    display: -ms-inline-flexbox !important;
    display: inline-flex !important;
  }
}

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

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

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

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

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

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

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

  .d-print-flex {
    display: -webkit-box !important;
    display: -ms-flexbox !important;
    display: flex !important;
  }

  .d-print-inline-flex {
    display: -webkit-inline-box !important;
    display: -ms-inline-flexbox !important;
    display: inline-flex !important;
  }
}

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

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

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

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

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

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

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

.flex-row {
  -webkit-box-orient: horizontal !important;
  -webkit-box-direction: normal !important;
  -ms-flex-direction: row !important;
  flex-direction: row !important;
}

.flex-column {
  -webkit-box-orient: vertical !important;
  -webkit-box-direction: normal !important;
  -ms-flex-direction: column !important;
  flex-direction: column !important;
}

.flex-row-reverse {
  -webkit-box-orient: horizontal !important;
  -webkit-box-direction: reverse !important;
  -ms-flex-direction: row-reverse !important;
  flex-direction: row-reverse !important;
}

.flex-column-reverse {
  -webkit-box-orient: vertical !important;
  -webkit-box-direction: reverse !important;
  -ms-flex-direction: column-reverse !important;
  flex-direction: column-reverse !important;
}

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

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

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

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

.flex-grow-0 {
  -webkit-box-flex: 0 !important;
  -ms-flex-positive: 0 !important;
  flex-grow: 0 !important;
}

.flex-grow-1 {
  -webkit-box-flex: 1 !important;
  -ms-flex-positive: 1 !important;
  flex-grow: 1 !important;
}

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

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

.justify-content-start {
  -webkit-box-pack: start !important;
  -ms-flex-pack: start !important;
  justify-content: flex-start !important;
}

.justify-content-end {
  -webkit-box-pack: end !important;
  -ms-flex-pack: end !important;
  justify-content: flex-end !important;
}

.justify-content-center {
  -webkit-box-pack: center !important;
  -ms-flex-pack: center !important;
  justify-content: center !important;
}

.justify-content-between {
  -webkit-box-pack: justify !important;
  -ms-flex-pack: justify !important;
  justify-content: space-between !important;
}

.justify-content-around {
  -ms-flex-pack: distribute !important;
  justify-content: space-around !important;
}

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

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

.align-items-center {
  -webkit-box-align: center !important;
  -ms-flex-align: center !important;
  align-items: center !important;
}

.align-items-baseline {
  -webkit-box-align: baseline !important;
  -ms-flex-align: baseline !important;
  align-items: baseline !important;
}

.align-items-stretch {
  -webkit-box-align: stretch !important;
  -ms-flex-align: stretch !important;
  align-items: stretch !important;
}

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

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

.align-content-center {
  -ms-flex-line-pack: center !important;
  align-content: center !important;
}

.align-content-between {
  -ms-flex-line-pack: justify !important;
  align-content: space-between !important;
}

.align-content-around {
  -ms-flex-line-pack: distribute !important;
  align-content: space-around !important;
}

.align-content-stretch {
  -ms-flex-line-pack: stretch !important;
  align-content: stretch !important;
}

.align-self-auto {
  -ms-flex-item-align: auto !important;
  align-self: auto !important;
}

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

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

.align-self-center {
  -ms-flex-item-align: center !important;
  align-self: center !important;
}

.align-self-baseline {
  -ms-flex-item-align: baseline !important;
  align-self: baseline !important;
}

.align-self-stretch {
  -ms-flex-item-align: stretch !important;
  align-self: stretch !important;
}

@media (min-width: 576px) {
  .flex-sm-row {
    -webkit-box-orient: horizontal !important;
    -webkit-box-direction: normal !important;
    -ms-flex-direction: row !important;
    flex-direction: row !important;
  }

  .flex-sm-column {
    -webkit-box-orient: vertical !important;
    -webkit-box-direction: normal !important;
    -ms-flex-direction: column !important;
    flex-direction: column !important;
  }

  .flex-sm-row-reverse {
    -webkit-box-orient: horizontal !important;
    -webkit-box-direction: reverse !important;
    -ms-flex-direction: row-reverse !important;
    flex-direction: row-reverse !important;
  }

  .flex-sm-column-reverse {
    -webkit-box-orient: vertical !important;
    -webkit-box-direction: reverse !important;
    -ms-flex-direction: column-reverse !important;
    flex-direction: column-reverse !important;
  }

  .flex-sm-wrap {
    -ms-flex-wrap: wrap !important;
    flex-wrap: wrap !important;
  }

  .flex-sm-nowrap {
    -ms-flex-wrap: nowrap !important;
    flex-wrap: nowrap !important;
  }

  .flex-sm-wrap-reverse {
    -ms-flex-wrap: wrap-reverse !important;
    flex-wrap: wrap-reverse !important;
  }

  .flex-sm-fill {
    -webkit-box-flex: 1 !important;
    -ms-flex: 1 1 auto !important;
    flex: 1 1 auto !important;
  }

  .flex-sm-grow-0 {
    -webkit-box-flex: 0 !important;
    -ms-flex-positive: 0 !important;
    flex-grow: 0 !important;
  }

  .flex-sm-grow-1 {
    -webkit-box-flex: 1 !important;
    -ms-flex-positive: 1 !important;
    flex-grow: 1 !important;
  }

  .flex-sm-shrink-0 {
    -ms-flex-negative: 0 !important;
    flex-shrink: 0 !important;
  }

  .flex-sm-shrink-1 {
    -ms-flex-negative: 1 !important;
    flex-shrink: 1 !important;
  }

  .justify-content-sm-start {
    -webkit-box-pack: start !important;
    -ms-flex-pack: start !important;
    justify-content: flex-start !important;
  }

  .justify-content-sm-end {
    -webkit-box-pack: end !important;
    -ms-flex-pack: end !important;
    justify-content: flex-end !important;
  }

  .justify-content-sm-center {
    -webkit-box-pack: center !important;
    -ms-flex-pack: center !important;
    justify-content: center !important;
  }

  .justify-content-sm-between {
    -webkit-box-pack: justify !important;
    -ms-flex-pack: justify !important;
    justify-content: space-between !important;
  }

  .justify-content-sm-around {
    -ms-flex-pack: distribute !important;
    justify-content: space-around !important;
  }

  .align-items-sm-start {
    -webkit-box-align: start !important;
    -ms-flex-align: start !important;
    align-items: flex-start !important;
  }

  .align-items-sm-end {
    -webkit-box-align: end !important;
    -ms-flex-align: end !important;
    align-items: flex-end !important;
  }

  .align-items-sm-center {
    -webkit-box-align: center !important;
    -ms-flex-align: center !important;
    align-items: center !important;
  }

  .align-items-sm-baseline {
    -webkit-box-align: baseline !important;
    -ms-flex-align: baseline !important;
    align-items: baseline !important;
  }

  .align-items-sm-stretch {
    -webkit-box-align: stretch !important;
    -ms-flex-align: stretch !important;
    align-items: stretch !important;
  }

  .align-content-sm-start {
    -ms-flex-line-pack: start !important;
    align-content: flex-start !important;
  }

  .align-content-sm-end {
    -ms-flex-line-pack: end !important;
    align-content: flex-end !important;
  }

  .align-content-sm-center {
    -ms-flex-line-pack: center !important;
    align-content: center !important;
  }

  .align-content-sm-between {
    -ms-flex-line-pack: justify !important;
    align-content: space-between !important;
  }

  .align-content-sm-around {
    -ms-flex-line-pack: distribute !important;
    align-content: space-around !important;
  }

  .align-content-sm-stretch {
    -ms-flex-line-pack: stretch !important;
    align-content: stretch !important;
  }

  .align-self-sm-auto {
    -ms-flex-item-align: auto !important;
    align-self: auto !important;
  }

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

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

  .align-self-sm-center {
    -ms-flex-item-align: center !important;
    align-self: center !important;
  }

  .align-self-sm-baseline {
    -ms-flex-item-align: baseline !important;
    align-self: baseline !important;
  }

  .align-self-sm-stretch {
    -ms-flex-item-align: stretch !important;
    align-self: stretch !important;
  }
}

@media (min-width: 768px) {
  .flex-md-row {
    -webkit-box-orient: horizontal !important;
    -webkit-box-direction: normal !important;
    -ms-flex-direction: row !important;
    flex-direction: row !important;
  }

  .flex-md-column {
    -webkit-box-orient: vertical !important;
    -webkit-box-direction: normal !important;
    -ms-flex-direction: column !important;
    flex-direction: column !important;
  }

  .flex-md-row-reverse {
    -webkit-box-orient: horizontal !important;
    -webkit-box-direction: reverse !important;
    -ms-flex-direction: row-reverse !important;
    flex-direction: row-reverse !important;
  }

  .flex-md-column-reverse {
    -webkit-box-orient: vertical !important;
    -webkit-box-direction: reverse !important;
    -ms-flex-direction: column-reverse !important;
    flex-direction: column-reverse !important;
  }

  .flex-md-wrap {
    -ms-flex-wrap: wrap !important;
    flex-wrap: wrap !important;
  }

  .flex-md-nowrap {
    -ms-flex-wrap: nowrap !important;
    flex-wrap: nowrap !important;
  }

  .flex-md-wrap-reverse {
    -ms-flex-wrap: wrap-reverse !important;
    flex-wrap: wrap-reverse !important;
  }

  .flex-md-fill {
    -webkit-box-flex: 1 !important;
    -ms-flex: 1 1 auto !important;
    flex: 1 1 auto !important;
  }

  .flex-md-grow-0 {
    -webkit-box-flex: 0 !important;
    -ms-flex-positive: 0 !important;
    flex-grow: 0 !important;
  }

  .flex-md-grow-1 {
    -webkit-box-flex: 1 !important;
    -ms-flex-positive: 1 !important;
    flex-grow: 1 !important;
  }

  .flex-md-shrink-0 {
    -ms-flex-negative: 0 !important;
    flex-shrink: 0 !important;
  }

  .flex-md-shrink-1 {
    -ms-flex-negative: 1 !important;
    flex-shrink: 1 !important;
  }

  .justify-content-md-start {
    -webkit-box-pack: start !important;
    -ms-flex-pack: start !important;
    justify-content: flex-start !important;
  }

  .justify-content-md-end {
    -webkit-box-pack: end !important;
    -ms-flex-pack: end !important;
    justify-content: flex-end !important;
  }

  .justify-content-md-center {
    -webkit-box-pack: center !important;
    -ms-flex-pack: center !important;
    justify-content: center !important;
  }

  .justify-content-md-between {
    -webkit-box-pack: justify !important;
    -ms-flex-pack: justify !important;
    justify-content: space-between !important;
  }

  .justify-content-md-around {
    -ms-flex-pack: distribute !important;
    justify-content: space-around !important;
  }

  .align-items-md-start {
    -webkit-box-align: start !important;
    -ms-flex-align: start !important;
    align-items: flex-start !important;
  }

  .align-items-md-end {
    -webkit-box-align: end !important;
    -ms-flex-align: end !important;
    align-items: flex-end !important;
  }

  .align-items-md-center {
    -webkit-box-align: center !important;
    -ms-flex-align: center !important;
    align-items: center !important;
  }

  .align-items-md-baseline {
    -webkit-box-align: baseline !important;
    -ms-flex-align: baseline !important;
    align-items: baseline !important;
  }

  .align-items-md-stretch {
    -webkit-box-align: stretch !important;
    -ms-flex-align: stretch !important;
    align-items: stretch !important;
  }

  .align-content-md-start {
    -ms-flex-line-pack: start !important;
    align-content: flex-start !important;
  }

  .align-content-md-end {
    -ms-flex-line-pack: end !important;
    align-content: flex-end !important;
  }

  .align-content-md-center {
    -ms-flex-line-pack: center !important;
    align-content: center !important;
  }

  .align-content-md-between {
    -ms-flex-line-pack: justify !important;
    align-content: space-between !important;
  }

  .align-content-md-around {
    -ms-flex-line-pack: distribute !important;
    align-content: space-around !important;
  }

  .align-content-md-stretch {
    -ms-flex-line-pack: stretch !important;
    align-content: stretch !important;
  }

  .align-self-md-auto {
    -ms-flex-item-align: auto !important;
    align-self: auto !important;
  }

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

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

  .align-self-md-center {
    -ms-flex-item-align: center !important;
    align-self: center !important;
  }

  .align-self-md-baseline {
    -ms-flex-item-align: baseline !important;
    align-self: baseline !important;
  }

  .align-self-md-stretch {
    -ms-flex-item-align: stretch !important;
    align-self: stretch !important;
  }
}

@media (min-width: 992px) {
  .flex-lg-row {
    -webkit-box-orient: horizontal !important;
    -webkit-box-direction: normal !important;
    -ms-flex-direction: row !important;
    flex-direction: row !important;
  }

  .flex-lg-column {
    -webkit-box-orient: vertical !important;
    -webkit-box-direction: normal !important;
    -ms-flex-direction: column !important;
    flex-direction: column !important;
  }

  .flex-lg-row-reverse {
    -webkit-box-orient: horizontal !important;
    -webkit-box-direction: reverse !important;
    -ms-flex-direction: row-reverse !important;
    flex-direction: row-reverse !important;
  }

  .flex-lg-column-reverse {
    -webkit-box-orient: vertical !important;
    -webkit-box-direction: reverse !important;
    -ms-flex-direction: column-reverse !important;
    flex-direction: column-reverse !important;
  }

  .flex-lg-wrap {
    -ms-flex-wrap: wrap !important;
    flex-wrap: wrap !important;
  }

  .flex-lg-nowrap {
    -ms-flex-wrap: nowrap !important;
    flex-wrap: nowrap !important;
  }

  .flex-lg-wrap-reverse {
    -ms-flex-wrap: wrap-reverse !important;
    flex-wrap: wrap-reverse !important;
  }

  .flex-lg-fill {
    -webkit-box-flex: 1 !important;
    -ms-flex: 1 1 auto !important;
    flex: 1 1 auto !important;
  }

  .flex-lg-grow-0 {
    -webkit-box-flex: 0 !important;
    -ms-flex-positive: 0 !important;
    flex-grow: 0 !important;
  }

  .flex-lg-grow-1 {
    -webkit-box-flex: 1 !important;
    -ms-flex-positive: 1 !important;
    flex-grow: 1 !important;
  }

  .flex-lg-shrink-0 {
    -ms-flex-negative: 0 !important;
    flex-shrink: 0 !important;
  }

  .flex-lg-shrink-1 {
    -ms-flex-negative: 1 !important;
    flex-shrink: 1 !important;
  }

  .justify-content-lg-start {
    -webkit-box-pack: start !important;
    -ms-flex-pack: start !important;
    justify-content: flex-start !important;
  }

  .justify-content-lg-end {
    -webkit-box-pack: end !important;
    -ms-flex-pack: end !important;
    justify-content: flex-end !important;
  }

  .justify-content-lg-center {
    -webkit-box-pack: center !important;
    -ms-flex-pack: center !important;
    justify-content: center !important;
  }

  .justify-content-lg-between {
    -webkit-box-pack: justify !important;
    -ms-flex-pack: justify !important;
    justify-content: space-between !important;
  }

  .justify-content-lg-around {
    -ms-flex-pack: distribute !important;
    justify-content: space-around !important;
  }

  .align-items-lg-start {
    -webkit-box-align: start !important;
    -ms-flex-align: start !important;
    align-items: flex-start !important;
  }

  .align-items-lg-end {
    -webkit-box-align: end !important;
    -ms-flex-align: end !important;
    align-items: flex-end !important;
  }

  .align-items-lg-center {
    -webkit-box-align: center !important;
    -ms-flex-align: center !important;
    align-items: center !important;
  }

  .align-items-lg-baseline {
    -webkit-box-align: baseline !important;
    -ms-flex-align: baseline !important;
    align-items: baseline !important;
  }

  .align-items-lg-stretch {
    -webkit-box-align: stretch !important;
    -ms-flex-align: stretch !important;
    align-items: stretch !important;
  }

  .align-content-lg-start {
    -ms-flex-line-pack: start !important;
    align-content: flex-start !important;
  }

  .align-content-lg-end {
    -ms-flex-line-pack: end !important;
    align-content: flex-end !important;
  }

  .align-content-lg-center {
    -ms-flex-line-pack: center !important;
    align-content: center !important;
  }

  .align-content-lg-between {
    -ms-flex-line-pack: justify !important;
    align-content: space-between !important;
  }

  .align-content-lg-around {
    -ms-flex-line-pack: distribute !important;
    align-content: space-around !important;
  }

  .align-content-lg-stretch {
    -ms-flex-line-pack: stretch !important;
    align-content: stretch !important;
  }

  .align-self-lg-auto {
    -ms-flex-item-align: auto !important;
    align-self: auto !important;
  }

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

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

  .align-self-lg-center {
    -ms-flex-item-align: center !important;
    align-self: center !important;
  }

  .align-self-lg-baseline {
    -ms-flex-item-align: baseline !important;
    align-self: baseline !important;
  }

  .align-self-lg-stretch {
    -ms-flex-item-align: stretch !important;
    align-self: stretch !important;
  }
}

@media (min-width: 1200px) {
  .flex-xl-row {
    -webkit-box-orient: horizontal !important;
    -webkit-box-direction: normal !important;
    -ms-flex-direction: row !important;
    flex-direction: row !important;
  }

  .flex-xl-column {
    -webkit-box-orient: vertical !important;
    -webkit-box-direction: normal !important;
    -ms-flex-direction: column !important;
    flex-direction: column !important;
  }

  .flex-xl-row-reverse {
    -webkit-box-orient: horizontal !important;
    -webkit-box-direction: reverse !important;
    -ms-flex-direction: row-reverse !important;
    flex-direction: row-reverse !important;
  }

  .flex-xl-column-reverse {
    -webkit-box-orient: vertical !important;
    -webkit-box-direction: reverse !important;
    -ms-flex-direction: column-reverse !important;
    flex-direction: column-reverse !important;
  }

  .flex-xl-wrap {
    -ms-flex-wrap: wrap !important;
    flex-wrap: wrap !important;
  }

  .flex-xl-nowrap {
    -ms-flex-wrap: nowrap !important;
    flex-wrap: nowrap !important;
  }

  .flex-xl-wrap-reverse {
    -ms-flex-wrap: wrap-reverse !important;
    flex-wrap: wrap-reverse !important;
  }

  .flex-xl-fill {
    -webkit-box-flex: 1 !important;
    -ms-flex: 1 1 auto !important;
    flex: 1 1 auto !important;
  }

  .flex-xl-grow-0 {
    -webkit-box-flex: 0 !important;
    -ms-flex-positive: 0 !important;
    flex-grow: 0 !important;
  }

  .flex-xl-grow-1 {
    -webkit-box-flex: 1 !important;
    -ms-flex-positive: 1 !important;
    flex-grow: 1 !important;
  }

  .flex-xl-shrink-0 {
    -ms-flex-negative: 0 !important;
    flex-shrink: 0 !important;
  }

  .flex-xl-shrink-1 {
    -ms-flex-negative: 1 !important;
    flex-shrink: 1 !important;
  }

  .justify-content-xl-start {
    -webkit-box-pack: start !important;
    -ms-flex-pack: start !important;
    justify-content: flex-start !important;
  }

  .justify-content-xl-end {
    -webkit-box-pack: end !important;
    -ms-flex-pack: end !important;
    justify-content: flex-end !important;
  }

  .justify-content-xl-center {
    -webkit-box-pack: center !important;
    -ms-flex-pack: center !important;
    justify-content: center !important;
  }

  .justify-content-xl-between {
    -webkit-box-pack: justify !important;
    -ms-flex-pack: justify !important;
    justify-content: space-between !important;
  }

  .justify-content-xl-around {
    -ms-flex-pack: distribute !important;
    justify-content: space-around !important;
  }

  .align-items-xl-start {
    -webkit-box-align: start !important;
    -ms-flex-align: start !important;
    align-items: flex-start !important;
  }

  .align-items-xl-end {
    -webkit-box-align: end !important;
    -ms-flex-align: end !important;
    align-items: flex-end !important;
  }

  .align-items-xl-center {
    -webkit-box-align: center !important;
    -ms-flex-align: center !important;
    align-items: center !important;
  }

  .align-items-xl-baseline {
    -webkit-box-align: baseline !important;
    -ms-flex-align: baseline !important;
    align-items: baseline !important;
  }

  .align-items-xl-stretch {
    -webkit-box-align: stretch !important;
    -ms-flex-align: stretch !important;
    align-items: stretch !important;
  }

  .align-content-xl-start {
    -ms-flex-line-pack: start !important;
    align-content: flex-start !important;
  }

  .align-content-xl-end {
    -ms-flex-line-pack: end !important;
    align-content: flex-end !important;
  }

  .align-content-xl-center {
    -ms-flex-line-pack: center !important;
    align-content: center !important;
  }

  .align-content-xl-between {
    -ms-flex-line-pack: justify !important;
    align-content: space-between !important;
  }

  .align-content-xl-around {
    -ms-flex-line-pack: distribute !important;
    align-content: space-around !important;
  }

  .align-content-xl-stretch {
    -ms-flex-line-pack: stretch !important;
    align-content: stretch !important;
  }

  .align-self-xl-auto {
    -ms-flex-item-align: auto !important;
    align-self: auto !important;
  }

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

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

  .align-self-xl-center {
    -ms-flex-item-align: center !important;
    align-self: center !important;
  }

  .align-self-xl-baseline {
    -ms-flex-item-align: baseline !important;
    align-self: baseline !important;
  }

  .align-self-xl-stretch {
    -ms-flex-item-align: stretch !important;
    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;
  }
}

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

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

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

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

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

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

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

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

.sr-only {
  position: absolute;
  width: 1px;
  height: 1px;
  padding: 0;
  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 {
  -webkit-box-shadow: 0 0.125rem 0.25rem rgba(0, 0, 0, 0.075) !important;
  box-shadow: 0 0.125rem 0.25rem rgba(0, 0, 0, 0.075) !important;
}

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

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

.shadow-none {
  -webkit-box-shadow: none !important;
  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;
}

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

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

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

.text-truncate {
  overflow: hidden;
  -o-text-overflow: ellipsis;
  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-normal {
  font-weight: 400 !important;
}

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

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

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

.text-primary {
  color: #78d5ef !important;
}

a.text-primary:hover,
a.text-primary:focus {
  color: #4ac7ea !important;
}

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

a.text-secondary:hover,
a.text-secondary:focus {
  color: #545b62 !important;
}

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

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

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

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

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

a.text-warning:hover,
a.text-warning:focus {
  color: #d39e00 !important;
}

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

a.text-danger:hover,
a.text-danger:focus {
  color: #bd2130 !important;
}

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

a.text-light:hover,
a.text-light:focus {
  color: #dae0e5 !important;
}

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

a.text-dark:hover,
a.text-dark:focus {
  color: #1d2124 !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: #fff !important;
}

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

.visible {
  visibility: visible !important;
}

.invisible {
  visibility: hidden !important;
}

@media print {

  *,
  *::before,
  *::after {
    text-shadow: none !important;
    -webkit-box-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;
  }
}

body {
  font-family: "Poppins", Arial, sans-serif;
  background: #fff;
  font-size: 14px;
  line-height: 1.8;
  font-weight: 400;
  color: #000;
}


a {
  -webkit-transition: .3s all ease;
  -o-transition: .3s all ease;
  transition: .3s all ease;
  color: #f85959;
}

a:hover {
  text-decoration: none;
  color: #f85959;
}

h1,
h2,
h3,
h4,
h5,
.h1,
.h2,
.h3,
.h4,
.h5 {
  line-height: 1.5;
  color: #000000;
  font-weight: 400;
}

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



/* Controle da cor da navbar no mobile */
@media (max-width: 991.98px) {
  .ftco-navbar-light {
    background: red !important; /* escolha a cor que quiser */
  }
}


.ftco-navbar-light .navbar-brand {
  color: #000;
}

/* NAV LINKS – ALTURA FIXA + CORES POR ESTADO */
.ftco-navbar-light .navbar-nav > .nav-item > .nav-link {
  font-size: 14px;
  padding: .9rem 20px;
  font-weight: 400;
  opacity: 1 !important;
}

/* Estado normal (sobre o banner) */
.ftco-navbar-light:not(.scrolled) .nav-link {
  color: #ffffff !important;
}

/* Estado com scroll */
.ftco-navbar-light.scrolled .nav-link {
  color: #000000 !important;
}


.ftco-navbar-light .navbar-nav>.nav-item>.nav-link:hover {
  color: #000;
}

.ftco-navbar-light .navbar-nav>.nav-item .dropdown-menu {
  border: none;
  background: #000;
  -webkit-box-shadow: 0px 10px 34px -20px rgba(0, 0, 0, 0.41);
  -moz-box-shadow: 0px 10px 34px -20px rgba(0, 0, 0, 0.41);
  box-shadow: 0px 10px 34px -20px rgba(0, 0, 0, 0.41);
}

.ftco-navbar-light .navbar-nav>.nav-item.ftco-seperator {
  position: relative;
  margin-left: 20px;
  padding-left: 20px;
}

@media (max-width: 991.98px) {
  .ftco-navbar-light .navbar-nav>.nav-item.ftco-seperator {
    padding-left: 0;
    margin-left: 0;
  }
}

.ftco-navbar-light .navbar-nav>.nav-item.ftco-seperator:before {
  position: absolute;
  content: "";
  top: 10px;
  bottom: 10px;
  left: 0;
  width: 2px;
  background: rgba(255, 255, 255, 0.05);
}

@media (max-width: 991.98px) {
  .ftco-navbar-light .navbar-nav>.nav-item.ftco-seperator:before {
    display: none;
  }
}

.ftco-navbar-light .navbar-nav>.nav-item.cta>a {
  color: #fff;
  border: 1px solid rgba(255, 255, 255, 0.4);
  padding-top: .5rem;
  padding-bottom: .5rem;
  padding-left: 20px;
  padding-right: 20px;
  margin-top: 4px;
  -webkit-border-radius: 30px;
  -moz-border-radius: 30px;
  -ms-border-radius: 30px;
  border-radius: 30px;
}

.ftco-navbar-light .navbar-nav>.nav-item.cta>a span {
  display: inline-block;
  color: #fff;
}

.ftco-navbar-light .navbar-nav>.nav-item.cta>a:hover {
  background: #f85959;
  border: 1px solid #f85959;
}

.ftco-navbar-light .navbar-nav>.nav-item.cta.cta-colored span {
  border-color: #f85959;
}

.ftco-navbar-light .navbar-nav>.nav-item.active>a {
  color: rgba(255, 255, 255, 0.5);
}

.ftco-navbar-light .navbar-toggler {
  border: none;
  color: rgba(255, 255, 255, 0.5) !important;
  cursor: pointer;
  padding-right: 0;
  text-transform: uppercase;
  font-size: 16px;
  letter-spacing: .1em;
}

.ftco-navbar-light.scrolled {
  position: fixed;
  right: 0;
  left: 0;
  top: 0;
  margin-top: -130px;
  background: #fff !important;
  -webkit-box-shadow: 0 0 10px 0 rgba(0, 0, 0, 0.1);
  box-shadow: 0 0 10px 0 rgba(0, 0, 0, 0.1);
}

.ftco-navbar-light.scrolled .nav-item.active>a {
  color: #f85959 !important;
}

/* CTA do menu – SEM alterar altura da navbar */
.ftco-navbar-light .nav-item.cta>a,
.ftco-navbar-light.scrolled .nav-item.cta>a {
  color: #fff !important;
  background: #f85959;
  border: none !important;

  padding: 0.6rem 20px !important;
  margin-top: 0 !important;     /* ← ESSENCIAL */

  border-radius: 30px;
}


.ftco-navbar-light.scrolled .nav-item.cta>a span {
  display: inline-block;
  color: #fff !important;
}

.ftco-navbar-light.scrolled .nav-item.cta.cta-colored span {
  border-color: #f85959;
}

@media (max-width: 991.98px) {
  .ftco-navbar-light.scrolled .navbar-nav {
    background: none;
    border-radius: 0px;
    padding-left: 0rem !important;
    padding-right: 0rem !important;
  }
}

@media (max-width: 767.98px) {
  .ftco-navbar-light.scrolled .navbar-nav {
    background: none;
    padding-left: 0 !important;
    padding-right: 0 !important;
  }
}

.ftco-navbar-light.scrolled .navbar-toggler {
  border: none;
  color: rgba(0, 0, 0, 0.5) !important;
  border-color: rgba(0, 0, 0, 0.5) !important;
  cursor: pointer;
  padding-right: 0;
  text-transform: uppercase;
  font-size: 16px;
  letter-spacing: .1em;
}

.ftco-navbar-light.scrolled .nav-link {
  padding-top: 0.6rem !important;
  padding-bottom: 0.6rem !important;
  color: #000000 !important;
}

.ftco-navbar-light.scrolled .nav-link.active {
  color: #f85959 !important;
}

.ftco-navbar-light.scrolled.awake {
  margin-top: 0px;
  -webkit-transition: .3s all ease-out;
  -o-transition: .3s all ease-out;
  transition: .3s all ease-out;
}

.ftco-navbar-light.scrolled.sleep {
  -webkit-transition: .3s all ease-out;
  -o-transition: .3s all ease-out;
  transition: .3s all ease-out;
}

.ftco-navbar-light.scrolled .navbar-brand {
  color: #000000;
}

.navbar-brand {
  font-weight: 700;
  font-size: 20px;
}


.slider-text {
  color: #000;
}

.slider-text h1 {
  font-size: 60px;
  color: #000;
  line-height: 1.2;
  font-weight: 200;
}

@media (max-width: 991.98px) {
  .slider-text h1 {
    font-size: 40px;
  }
}

.slider-text h1 strong {
  font-weight: 800;
}

.slider-text p {
  font-size: 20px;
  line-height: 1.5;
  font-weight: 300;
  color: rgba(255, 255, 255, 0.8);
}

.slider-text p strong {
  font-weight: 700;
}

.slider-text p strong a {
  color: #000000;
}

.slider-text .browse span {
  margin-right: 10px;
  font-size: 16px;
  color: #000000;
}

.slider-text .browse span a {
  color: #000000;
  padding: 10px 15px;
  background: #fff;
  -webkit-border-radius: 2px;
  -moz-border-radius: 2px;
  -ms-border-radius: 2px;
  border-radius: 2px;
}

@media (max-width: 767.98px) {
  .slider-text .browse span a {
    margin-bottom: 1px;
  }
}

.slider-text .browse span a i {
  color: #000000;
  font-size: 20px;
  margin-right: 7px;
}

.slider-text .browse span a:hover {
  color: white;
  background: #f85959;
}

.slider-text .browse span a:hover i {
  color: #fff;
}

.slider-text .breadcrumbs {
  text-transform: uppercase;
  font-size: 13px;
  letter-spacing: 1px;
  margin-bottom: 20px;
  z-index: 99;
}

.slider-text .breadcrumbs span {
  border-bottom: 2px solid rgba(255, 255, 255, 0.1);
  color: rgba(255, 255, 255, 0.7);
}

.slider-text .breadcrumbs span a {
  color: #fff;
}

.slider-text .bread {
  font-weight: 700 !important;
}

.slider-text .btn-primary {
  border: 1px solid rgba(255, 255, 255, 0.4);
  -webkit-border-radius: 30px;
  -moz-border-radius: 30px;
  -ms-border-radius: 30px;
  border-radius: 30px;
}

.slider-text .btn-primary:hover,
.slider-text .btn-primary:focus {
  background: #fff !important;
  color: #000000;
}

.owl-carousel {
  position: relative;
}

.owl-carousel .owl-item {
  opacity: .4;
}

.owl-carousel .owl-item.active {
  opacity: 1;
}

.owl-carousel .owl-nav {
  position: absolute;
  top: 50%;
  width: 100%;
}

.owl-carousel .owl-nav .owl-prev,
.owl-carousel .owl-nav .owl-next {
  position: absolute;
  -webkit-transform: translateY(-50%);
  -ms-transform: translateY(-50%);
  transform: translateY(-50%);
  margin-top: -10px;
  color: #1a8af9 !important;
  -moz-transition: all 0.7s ease;
  -o-transition: all 0.7s ease;
  -webkit-transition: all 0.7s ease;
  -ms-transition: all 0.7s ease;
  transition: all 0.7s ease;
  opacity: 0;
}

.owl-carousel .owl-nav .owl-prev span:before,
.owl-carousel .owl-nav .owl-next span:before {
  font-size: 30px;
}

.owl-carousel .owl-nav .owl-prev {
  left: 0;
}

.owl-carousel .owl-nav .owl-next {
  right: 0;
}

.owl-carousel .owl-dots {
  text-align: center;
}

.owl-carousel .owl-dots .owl-dot {
  width: 10px;
  height: 10px;
  margin: 5px;
  border-radius: 50%;
  background: #e6e6e6;
  position: relative;
}

.owl-carousel .owl-dots .owl-dot:after {
  position: absolute;
  top: -2px;
  left: -2px;
  right: 0;
  bottom: 0;
  width: 14px;
  height: 14px;
  content: '';
  border: 1px solid #e6e6e6;
  -webkit-border-radius: 50%;
  -moz-border-radius: 50%;
  -ms-border-radius: 50%;
  border-radius: 50%;
}

.owl-carousel .owl-dots .owl-dot.active {
  background: #b3b3b3;
}

.owl-carousel:hover .owl-nav .owl-prev,
.owl-carousel:hover .owl-nav .owl-next {
  opacity: 1;
}

.owl-carousel:hover .owl-nav .owl-prev {
  left: -25px;
}

.owl-carousel:hover .owl-nav .owl-next {
  right: -25px;
}

.owl-custom-nav {
  float: right;
  position: relative;
  z-index: 10;
  border: 1px solid red;
}

.owl-custom-nav .owl-custom-prev,
.owl-custom-nav .owl-custom-next {
  padding: 10px;
  font-size: 30px;
  background: #ccc;
  line-height: 0;
  width: 60px;
  text-align: center;
  display: inline-block;
}

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

.bg-primary {
  background: #f85959;
}


#accordion .card {
  margin-bottom: 5px;
  border: 1px solid #e6e6e6;
  -webkit-border-radius: 0;
  -moz-border-radius: 0;
  -ms-border-radius: 0;
  border-radius: 0;
}

#accordion .card .card-header {
  padding: 0;
  background: transparent;
  border-bottom: 1px solid #e6e6e6;
  -webkit-border-radius: 0;
  -moz-border-radius: 0;
  -ms-border-radius: 0;
  border-radius: 0;
}

#accordion .card .card-header a {
  padding: 12px 20px;
  display: block;
  font-size: 20px;
  font-weight: 400;
  color: #000000;
}

#accordion .card .card-header a span {
  float: right;
}

#accordion .card .card-header a span i {
  color: #8bc34a;
}

#accordion .card-body {
  border: 1px solid transparent;
}

#accordion [aria-expanded="false"]>.expanded,
#accordion [aria-expanded="true"]>.collapsed {
  display: none;
}

.services-section .container {
  margin-top: -120px;
  z-index: 2;
  position: relative;
}

.services {
  background: #fff;
  -webkit-box-shadow: 0px 2px 5px 0px rgba(0, 0, 0, 0.03);
  -moz-box-shadow: 0px 2px 5px 0px rgba(0, 0, 0, 0.03);
  box-shadow: 0px 2px 5px 0px rgba(0, 0, 0, 0.03);
  padding: 25px;
  -moz-transition: all 0.3s ease;
  -o-transition: all 0.3s ease;
  -webkit-transition: all 0.3s ease;
  -ms-transition: all 0.3s ease;
  transition: all 0.3s ease;
  -webkit-border-radius: 2px;
  -moz-border-radius: 2px;
  -ms-border-radius: 2px;
  border-radius: 2px;
}

.services .icon {
  line-height: 1.3;
  position: relative;
}

.services .icon span {
  font-size: 60px;
  color: #f85959;
}

.services .media-body h3 {
  font-size: 20px;
}

.services:hover {
  background: #f85959;
  color: #fff;
}

.services:hover .icon span {
  color: #fff;
}

.services:hover h3 {
  color: #fff;
}

.list-services {
  margin-top: 40px;
  padding: 0;
}

.list-services li {
  font-size: 18px;
  list-style: none;
}

.list-services li a {
  color: #000000;
}

.ftco-destination .owl-carousel .owl-stage-outer {
  padding-bottom: 2em;
  position: relative;
}

.destination {
  display: block;
  width: 100%;
  margin-bottom: 30px;
}

@media (max-width: 991.98px) {
  .destination {
    margin-bottom: 30px;
  }
}

.destination .img {
  display: block;
  height: 300px;
}

.destination .img-2 {
  height: 200px;
}

.destination .icon {
  width: 60px;
  height: 60px;
  background: #fff;
  opacity: 0;
  -webkit-border-radius: 50%;
  -moz-border-radius: 50%;
  -ms-border-radius: 50%;
  border-radius: 50%;
  -moz-transition: all 0.3s ease;
  -o-transition: all 0.3s ease;
  -webkit-transition: all 0.3s ease;
  -ms-transition: all 0.3s ease;
  transition: all 0.3s ease;
}

.destination .icon span {
  color: #000000;
}

.destination:hover .icon {
  opacity: 1;
}

.destination .text {
  border: 1px solid #e6e6e6;
  border-top: 1px solid transparent;
  background: #fff;
}

.destination .text h3 {
  font-size: 20px !important;
  font-weight: 300 !important;
}

.destination .text h3 a {
  color: #000000;
}

.destination .text span.listing {
  font-size: 15px;
}

.destination .text .rate i {
  font-size: 10px;
  color: #0066FF;
}

.destination .text .rate span {
  padding-left: 5px;
  font-size: 10px;
}

.destination .text .one {
  width: calc(100% - 70px);
}

.destination .text .two {
  width: 70px;
  text-align: right;
}

.destination .text .two .price {
  font-weight: 400;
  font-size: 12px;
  color: #2f89fc;
}

.destination .text .two .per-price {
  font-size: 20px;
  line-height: 1.4;
}

.destination .text .two .per-price small {
  font-size: 12px;
}

.destination .text .days span {
  font-size: 13px;
  color: black;
}

.destination .text .bottom-area {
  margin-bottom: 0;
}

.destination .text .bottom-area span {
  font-size: 12px;
}

@media (min-width: 768px) {
  .destination .text .bottom-area span:last-child {
    margin-left: 5px;
  }
}

.destination .text .bottom-area span:last-child a {
  background: #8bc34a;
  color: #fff;
  -webkit-border-radius: 4px;
  -moz-border-radius: 4px;
  -ms-border-radius: 4px;
  border-radius: 4px;
  padding: 3px 5px;
}

.destination .text .bottom-area span:last-child a:hover {
  background: #8bc34a;
  color: #fff;
}

.hotel-img {
  height: 600px;
  margin-bottom: 2em;
}

.hotel-single h2 {
  font-size: 22px;
}

.hotel-single .loc {
  margin-right: 10px;
}

.hotel-single .loc a {
  color: #999999;
}

.hotel-single .star i {
  color: #f85959;
}

.hotel-single ul {
  margin: 0;
  padding: 0;
}

.hotel-single ul li {
  list-style: none;
  margin-bottom: 10px;
}

.hotel-single .fields {
  width: 100%;
  position: relative;
}

.hotel-single .fields .form-control {
  -webkit-box-shadow: none !important;
  box-shadow: none !important;
  border: transparent;
  background: #fff !important;
  color: #4d4d4d !important;
  border: 1px solid #e6e6e6;
  font-size: 14px;
  width: 100%;
  height: 52px !important;
  padding: 10px 20px;
  -webkit-border-radius: 0;
  -moz-border-radius: 0;
  -ms-border-radius: 0;
  border-radius: 0;
}

.hotel-single .fields .form-control::-webkit-input-placeholder {
  /* Chrome/Opera/Safari */
  color: #4d4d4d;
}

.hotel-single .fields .form-control::-moz-placeholder {
  /* Firefox 19+ */
  color: #4d4d4d;
}

.hotel-single .fields .form-control:-ms-input-placeholder {
  /* IE 10+ */
  color: #4d4d4d;
}

.hotel-single .fields .form-control:-moz-placeholder {
  /* Firefox 18- */
  color: #4d4d4d;
}

.hotel-single .fields .icon {
  position: absolute;
  top: 50%;
  right: 30px;
  font-size: 14px;
  -webkit-transform: translateY(-50%);
  -ms-transform: translateY(-50%);
  transform: translateY(-50%);
  color: rgba(0, 0, 0, 0.7);
}

@media (max-width: 767.98px) {
  .hotel-single .fields .icon {
    right: 10px;
  }
}

.hotel-single .fields .select-wrap {
  position: relative;
}

.hotel-single .fields .select-wrap select {
  -webkit-appearance: none;
  -moz-appearance: none;
  appearance: none;
}

.hotel-single .form-group .btn {
  width: 100%;
  display: block !important;
  -webkit-border-radius: 2px;
  -moz-border-radius: 2px;
  -ms-border-radius: 2px;
  border-radius: 2px;
}

.ftco-section-parallax {
  position: relative;
}

.ftco-section-parallax .parallax-img {
  background-size: cover;
  background-repeat: no-repeat;
  background-position: center center;
  position: relative;
  padding: 10em 0;
  background: #2ebdc4;
  background: -moz-linear-gradient(-45deg, #2ebdc4 0%, #68e5b2 100%);
  background: -webkit-gradient(left top, right bottom, color-stop(0%, #2ebdc4), color-stop(100%, #68e5b2));
  background: -webkit-linear-gradient(-45deg, #2ebdc4 0%, #68e5b2 100%);
  background: -o-linear-gradient(-45deg, #2ebdc4 0%, #68e5b2 100%);
  background: -ms-linear-gradient(-45deg, #2ebdc4 0%, #68e5b2 100%);
  background: -webkit-linear-gradient(315deg, #2ebdc4 0%, #68e5b2 100%);
  background: -o-linear-gradient(315deg, #2ebdc4 0%, #68e5b2 100%);
  background: linear-gradient(135deg, #2ebdc4 0%, #68e5b2 100%);
  filter: progid:DXImageTransform.Microsoft.gradient(startColorstr='#2ebdc4', endColorstr='#68e5b2', GradientType=1);
}

.ftco-section-parallax .heading-section-white h2 {
  font-weight: 400 !important;
}

@media (min-width: 768px) {
  .block-3 {
    margin-bottom: 7em;
  }
}

.block-3 .text,
.block-3 .image {
  width: 100%;
  padding: 10% 7%;
  display: block;
}

@media (min-width: 768px) {

  .block-3 .text,
  .block-3 .image {
    width: 50%;
    padding: 10% 7%;
  }
}

.block-3 .text .subheading {
  font-size: 13px;
  text-transform: uppercase;
  letter-spacing: .1em;
}

.block-3 .text .heading {
  font-size: 30px;
  margin-bottom: 30px;
}

.block-3 .text .heading a {
  color: #000000;
}

.block-3 .text p:last-child {
  margin-bottom: 0;
}

.block-3 .image {
  background-size: cover;
  background-position: center center;
  background-repeat: no-repeat;
  position: relative;
}

.block-3 .image:after {
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  content: '';
  -webkit-box-shadow: 20px 20px 0 0 #fdd3d3;
  box-shadow: 20px 20px 0 0 #fdd3d3;
}

.block-3 .image.image-2:after {
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  content: '';
  -webkit-box-shadow: -20px 20px 0 0 #fdd3d3;
  box-shadow: -20px 20px 0 0 #fdd3d3;
}

@media (max-width: 767.98px) {
  .block-3 .image {
    height: 300px;
  }
}

.block-5 {
  overflow: hidden;
  background-size: cover;
  background-repeat: no-repeat;
  background-position: center center;
  height: 400px;
  position: relative;
  display: block;
}

.block-5:before {
  content: '';
  position: absolute;
  top: 0;
  right: 0;
  bottom: 0;
  left: 0;
  background: -moz-linear-gradient(top, transparent 0%, transparent 18%, rgba(0, 0, 0, 0.8) 99%, rgba(0, 0, 0, 0.8) 100%);
  background: -webkit-linear-gradient(top, transparent 0%, transparent 18%, rgba(0, 0, 0, 0.8) 99%, rgba(0, 0, 0, 0.8) 100%);
  background: -webkit-gradient(linear, left top, left bottom, from(transparent), color-stop(18%, transparent), color-stop(99%, rgba(0, 0, 0, 0.8)), to(rgba(0, 0, 0, 0.8)));
  background: -o-linear-gradient(top, transparent 0%, transparent 18%, rgba(0, 0, 0, 0.8) 99%, rgba(0, 0, 0, 0.8) 100%);
  background: linear-gradient(to bottom, transparent 0%, transparent 18%, rgba(0, 0, 0, 0.8) 99%, rgba(0, 0, 0, 0.8) 100%);
  filter: progid:DXImageTransform.Microsoft.gradient(startColorstr='#00000000', endColorstr='#cc000000', GradientType=0);
  opacity: .8;
}

.block-5 .text {
  position: absolute;
  bottom: 0;
  right: 0;
  left: 0;
  padding: 20px 20px 10px 20px;
  -webkit-transition: .8s all ease;
  -o-transition: .8s all ease;
  transition: .8s all ease;
}

.block-5 .text:before {
  bottom: 0;
  left: 0;
  right: 0;
  z-index: 1;
  background: #fff;
  visibility: hidden;
  opacity: 0;
  height: 0;
  position: absolute;
  content: "";
  -moz-transition: all 0.3s ease;
  -o-transition: all 0.3s ease;
  -webkit-transition: all 0.3s ease;
  -ms-transition: all 0.3s ease;
  transition: all 0.3s ease;
}

.block-5 .text .heading,
.block-5 .text .subheading,
.block-5 .text .post-meta,
.block-5 .text .excerpt,
.block-5 .text .price {
  z-index: 2;
  position: relative;
}

.block-5 .text .subheading {
  color: #fff;
  text-transform: uppercase;
  letter-spacing: .1em;
  font-size: 12px;
  margin-bottom: 5px;
  opacity: .6;
}

.block-5 .text .heading {
  color: #fff;
  margin: 0 0 10px 0;
  padding: 0;
  font-weight: bold;
  font-size: 24px;
  line-height: 1.2;
  font-weight: 400;
}

.block-5 .text .post-meta {
  line-height: 1.4;
  color: #fff;
  font-size: 14px;
}

.block-5 .text .post-meta span {
  display: inline-block;
  margin-right: 10px;
  margin-bottom: 10px;
  opacity: .6;
}

.block-5 .text .price {
  color: #fff;
}

.block-5 .text .excerpt {
  line-height: 1.4;
  color: #fff;
}

.block-5:hover .text:before,
.block-5:focus .text:before {
  visibility: visible;
  opacity: 1;
  height: 100%;
  background: #fff;
}

.block-5:hover .text .heading,
.block-5:hover .text .subheading,
.block-5:hover .text .post-meta,
.block-5:hover .text .price,
.block-5:hover .text .star-rate,
.block-5:focus .text .heading,
.block-5:focus .text .subheading,
.block-5:focus .text .post-meta,
.block-5:focus .text .price,
.block-5:focus .text .star-rate {
  color: #000000;
}

.aside-stretch {
  background: #fa8a8a;
}

.aside-stretch:after {
  position: absolute;
  top: 0;
  right: 100%;
  bottom: 0;
  content: '';
  width: 360%;
  background: #fa8a8a;
}

@media (max-width: 767.98px) {
  .aside-stretch {
    background: transparent;
  }

  .aside-stretch:after {
    background: transparent;
    display: none;
  }
}

.form-control {
  height: 52px !important;
  background: #fff !important;
  color: #000000 !important;
  font-size: 18px;
  border-radius: 0px;
  -webkit-box-shadow: none !important;
  box-shadow: none !important;
}

.form-control:focus,
.form-control:active {
  border-color: #000000;
}

textarea.form-control {
  height: inherit !important;
}

.ftco-vh-100 {
  min-height: 100vh;
  height: auto;
}

.ftco-vh-95 {
  min-height: 75vh;
  height: auto;
}

@media (max-width: 1199.98px) {
  .ftco-vh-100,
  .ftco-vh-75 {
    min-height: 85vh;
    padding-top: 0 !important;
    padding-bottom: 0 !important;
  }
}


.ftco-tab-nav {
  padding: 0;
  margin: 0;
  display: inline-block !important;
}

@media (max-width: 767.98px) {
  .ftco-tab-nav {
    display: block !important;
    margin-bottom: 10px;
    width: 100% !important;
  }
}

.ftco-tab-nav li {
  padding: 0;
  margin: 0 5px;
  display: inline-block !important;
}

@media (max-width: 767.98px) {
  .ftco-tab-nav li {
    display: block !important;
    margin-bottom: 10px;
    width: 100% !important;
  }
}

.ftco-tab-nav li a {
  text-transform: uppercase;
  font-size: 14px;
  letter-spacing: .2em;
  color: #ccc;
  border: 2px solid #ccc;
  border-radius: 0 !important;
}

.ftco-tab-nav li a.active {
  background: none !important;
  color: black !important;
  border: 2px solid #000000;
}

.ftco-animate {
  opacity: 0;
  visibility: hidden;
}

.bg-primary {
  background: #2bb0a6 !important;
}

.ftco-section .ftco-sub-title {
  font-size: 16px;
  text-transform: uppercase;
  letter-spacing: .5em;
  color: #d4d4d4;
  font-family: "Work Sans", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "Helvetica Neue", Arial, sans-serif, "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol";
  font-weight: 300;
}

.ftco-section .ftco-primary-title {
  margin-top: 0;
  margin-bottom: 30px;
}

.media-custom {
  background: #fff;
}

.media-custom .media-body .name {
  font-weight: 500;
  font-size: 16px;
  margin-bottom: 0;
  color: #f85959;
}

.media-custom .media-body .position {
  font-size: 13px;
  color: #d9d9d9;
}

.about-author .desc h3 {
  font-size: 24px;
}

.ftco-section {
  padding: 6em 0;
  position: relative;
}

@media (max-width: 767.98px) {
  .ftco-section {
    padding: 6em 0;
  }
}

@media (min-width: 768px) {
  .ftco-section .container-fluid {
    padding: 0 4em;
  }
}

.ftco-bg-dark {
  background: #3c312e;
}

.ftco-footer {
  font-size: 14px;
  background: #222831;
  padding: 8em 0 8em 0;
}

.ftco-footer .ftco-footer-logo {
  text-transform: uppercase;
  letter-spacing: .1em;
}

.ftco-footer .ftco-footer-widget h2 {
  font-weight: normal;
  color: #fff;
  margin-bottom: 40px;
  font-size: 18px;
  font-weight: 400;
}

.ftco-footer .ftco-footer-widget ul li a span {
  color: #fff;
}

.ftco-footer .ftco-footer-widget .btn-primary {
  background: #fff !important;
  border: 2px solid #fff !important;
}

.ftco-footer .ftco-footer-widget .btn-primary:hover {
  background: #fff;
  border: 2px solid #fff !important;
}

.ftco-footer p {
  color: rgba(255, 255, 255, 0.7);
}

.ftco-footer a {
  color: rgba(255, 255, 255, 0.7);
}

.ftco-footer a:hover {
  color: #fff;
}

.ftco-footer .ftco-heading-2 {
  font-size: 17px;
  font-weight: 400;
  color: #000000;
}

.ftco-footer-social li {
  list-style: none;
  margin: 0 10px 0 0;
  display: inline-block;
}

.ftco-footer-social li a {
  height: 50px;
  width: 50px;
  display: block;
  float: left;
  background: rgba(255, 255, 255, 0.05);
  border-radius: 50%;
  position: relative;
}

.ftco-footer-social li a span {
  position: absolute;
  font-size: 30px;
  top: 50%;
  left: 50%;
  -webkit-transform: translate(-50%, -50%);
  -ms-transform: translate(-50%, -50%);
  transform: translate(-50%, -50%);
}

.ftco-footer-social li a:hover {
  color: #fff;
}

.footer-small-nav>li {
  display: inline-block;
}

.footer-small-nav>li a {
  margin: 0 10px 10px 0;
}

.footer-small-nav>li a:hover,
.footer-small-nav>li a:focus {
  color: #f85959;
}

.media .ftco-icon {
  width: 100px;
}

.media .ftco-icon span {
  color: #f85959;
}

.ftco-media {
  background: #fff;
  border-radius: 0px;
}

.ftco-media .heading {
  font-weight: normal;
}

.ftco-media.ftco-media-shadow {
  padding: 40px;
  background: #fff;
  -webkit-box-shadow: 0 10px 50px -15px rgba(0, 0, 0, 0.3);
  box-shadow: 0 10px 50px -15px rgba(0, 0, 0, 0.3);
  -webkit-transition: .2s all ease;
  -o-transition: .2s all ease;
  transition: .2s all ease;
  position: relative;
  top: 0;
}

.ftco-media.ftco-media-shadow:hover,
.ftco-media.ftco-media-shadow:focus {
  top: -3px;
  -webkit-box-shadow: 0 10px 70px -15px rgba(0, 0, 0, 0.3);
  box-shadow: 0 10px 70px -15px rgba(0, 0, 0, 0.3);
}

.ftco-media .icon {
  font-size: 50px;
  display: block;
  color: #f85959;
}

.ftco-media.text-center .ftco-icon {
  margin: 0 auto;
}

.ftco-overflow-hidden {
  overflow: hidden;
}

.padding-top-bottom {
  padding-top: 120px;
  padding-bottom: 120px;
}

#map {
  height: 400px;
  width: 100%;
}

@media (max-width: 991.98px) {
  #map {
    height: 300px;
  }
}

@-webkit-keyframes pulse {
  0% {
    -webkit-box-shadow: 0 0 0 0 rgba(248, 89, 89, 0.4);
  }

  70% {
    -webkit-box-shadow: 0 0 0 30px rgba(248, 89, 89, 0);
  }

  100% {
    -webkit-box-shadow: 0 0 0 0 rgba(248, 89, 89, 0);
  }
}

@keyframes pulse {
  0% {
    -moz-box-shadow: 0 0 0 0 rgba(248, 89, 89, 0.4);
    -webkit-box-shadow: 0 0 0 0 rgba(248, 89, 89, 0.4);
    box-shadow: 0 0 0 0 rgba(248, 89, 89, 0.4);
  }

  70% {
    -moz-box-shadow: 0 0 0 30px rgba(248, 89, 89, 0);
    -webkit-box-shadow: 0 0 0 30px rgba(248, 89, 89, 0);
    box-shadow: 0 0 0 30px rgba(248, 89, 89, 0);
  }

  100% {
    -moz-box-shadow: 0 0 0 0 rgba(248, 89, 89, 0);
    -webkit-box-shadow: 0 0 0 0 rgba(248, 89, 89, 0);
    box-shadow: 0 0 0 0 rgba(248, 89, 89, 0);
  }
}

.heading-section .subheading {
  font-size: 14px;
  display: block;
  margin-bottom: 10px;
}


.heading-section h2 {
  font-size: 28px;
  font-weight: 300;
  color: #000;
}

.heading-section h2 strong {
  font-weight: 700;
}

@media (max-width: 767.98px) {
  .heading-section h2 {
    font-size: 26px !important;
  }
}

.heading-section.heading-section-white .subheading {
  color: rgba(255, 255, 255, 0.9);
}

.heading-section.heading-section-white h2 {
  font-size: 40px;
  color: #fff;
}

.heading-section.heading-section-white p {
  color: rgba(255, 255, 255, 0.9);
}

.hotel-img,
.hero-wrap,
.img,
.blog-img,
.user-img {
  background-size: cover;
  background-repeat: no-repeat;
  background-position: center center;
}

.testimony-section {
  position: relative;
}

.testimony-section .owl-carousel {
  margin: 0;
}

.testimony-section .owl-carousel .owl-stage-outer {
  padding-bottom: 2em;
  position: relative;
}

.testimony-wrap {
  -webkit-box-shadow: 0px 2px 5px 0px rgba(0, 0, 0, 0.03);
  -moz-box-shadow: 0px 2px 5px 0px rgba(0, 0, 0, 0.03);
  box-shadow: 0px 2px 5px 0px rgba(0, 0, 0, 0.03);
  background: #fff;
  display: block;
  position: relative;
  padding: 30px;
}

.testimony-wrap .text {
  width: calc(100% - 100px);
}

.testimony-wrap .user-img {
  width: 100px;
  height: 100px;
  border-radius: 50%;
  position: relative;
}

.testimony-wrap .user-img .quote {
  position: absolute;
  bottom: -10px;
  right: 0;
  width: 40px;
  height: 40px;
  background: #f85959;
  -webkit-border-radius: 50%;
  -moz-border-radius: 50%;
  -ms-border-radius: 50%;
  border-radius: 50%;
}

.testimony-wrap .user-img .quote i {
  color: #fff;
}

.testimony-wrap .name {
  font-weight: 500;
  font-size: 16px;
  margin-bottom: 0;
  color: #000000;
}

.testimony-wrap .position {
  font-size: 13px;
}

@media (max-width: 767.98px) {
  .about-image {
    height: 400px;
    margin-bottom: 30px;
  }
}

.ftco-section {
  position: relative;
  width: 100%;
  display: block;
}

.ftco-section .nav-pills p {
  margin-bottom: 0;
}

.ftco-section .nav-pills .nav-link {
  border-radius: 0;
  margin-bottom: 0;
  font-size: 18px;
  font-weight: 400;
  position: relative;
  display: inline-block;
  margin-left: 5px;
  margin-right: 5px;
  color: #b3b3b3;
  -webkit-border-radius: 30px;
  -moz-border-radius: 30px;
  -ms-border-radius: 30px;
  border-radius: 30px;
}

.ftco-section .nav-pills .nav-link:hover {
  color: #000000;
}

.ftco-section .nav-pills .nav-link.active {
  color: #fff;
  -moz-transition: all 0.3s ease;
  -o-transition: all 0.3s ease;
  -webkit-transition: all 0.3s ease;
  -ms-transition: all 0.3s ease;
  transition: all 0.3s ease;
}

.ftco-section .nav-pills .nav-link.active:after {
  opacity: 1;
}

@media (max-width: 767.98px) {
  .ftco-section .nav-pills .nav-link.active:after {
    opacity: 0;
  }
}

@media (max-width: 767.98px) {
  .ftco-section .nav-pills .nav-link {
    display: block;
    width: 100%;
    margin-bottom: 5px;
  }
}

.ftco-section .tab-content .tab-pane h2 {
  font-size: 24px;
}

.ftco-section .tab-content .tab-pane .one-forth {
  width: 50%;
}

.ftco-section .tab-content .tab-pane .one-forth img {
  -webkit-box-shadow: 0px 2px 5px 0px rgba(0, 0, 0, 0.03);
  -moz-box-shadow: 0px 2px 5px 0px rgba(0, 0, 0, 0.03);
  box-shadow: 0px 2px 5px 0px rgba(0, 0, 0, 0.03);
}

@media (max-width: 767.98px) {
  .ftco-section .tab-content .tab-pane .one-forth img {
    margin-bottom: 20px;
  }
}

@media (max-width: 767.98px) {
  .ftco-section .tab-content .tab-pane .one-forth {
    width: 100%;
  }
}

.ftco-section .tab-content .tab-pane .one-half {
  width: 50%;
}

@media (max-width: 767.98px) {
  .ftco-section .tab-content .tab-pane .one-half {
    width: 100%;
  }
}

.image-popup {
  cursor: -webkit-zoom-in;
  cursor: -moz-zoom-in;
  cursor: zoom-in;
}

.mfp-with-zoom .mfp-container,
.mfp-with-zoom.mfp-bg {
  opacity: 0;
  -webkit-backface-visibility: hidden;
  -webkit-transition: all 0.3s ease-out;
  -moz-transition: all 0.3s ease-out;
  -o-transition: all 0.3s ease-out;
  transition: all 0.3s ease-out;
}

.mfp-with-zoom.mfp-ready .mfp-container {
  opacity: 1;
}

.mfp-with-zoom.mfp-ready.mfp-bg {
  opacity: 0.8;
}

.mfp-with-zoom.mfp-removing .mfp-container,
.mfp-with-zoom.mfp-removing.mfp-bg {
  opacity: 0;
}

#section-counter {
  position: relative;
  z-index: 0;
}

#section-counter:after {
  position: absolute;
  top: 0;
  left: 0;
  bottom: 0;
  right: 0;
  content: '';
  z-index: -1;
  opacity: .9;
  background: #2ebdc4;
  background: -moz-linear-gradient(-45deg, #2ebdc4 0%, #68e5b2 100%);
  background: -webkit-gradient(left top, right bottom, color-stop(0%, #2ebdc4), color-stop(100%, #68e5b2));
  background: -webkit-linear-gradient(-45deg, #2ebdc4 0%, #68e5b2 100%);
  background: -o-linear-gradient(-45deg, #2ebdc4 0%, #68e5b2 100%);
  background: -ms-linear-gradient(-45deg, #2ebdc4 0%, #68e5b2 100%);
  background: -webkit-linear-gradient(315deg, #2ebdc4 0%, #68e5b2 100%);
  background: -o-linear-gradient(315deg, #2ebdc4 0%, #68e5b2 100%);
  background: linear-gradient(135deg, #2ebdc4 0%, #68e5b2 100%);
  filter: progid:DXImageTransform.Microsoft.gradient(startColorstr='#2ebdc4', endColorstr='#68e5b2', GradientType=1);
}

.ftco-counter {
  padding: 10em 0;
}

.ftco-counter .text strong.number {
  font-weight: 400;
  font-size: 30px;
  color: #fff;
}

.ftco-counter .text span {
  font-size: 16px;
  color: rgba(255, 255, 255, 0.7);
}

@media (max-width: 767.98px) {
  .ftco-counter .counter-wrap {
    margin-bottom: 20px;
  }
}

.ftco-counter .ftco-number {
  display: block;
  font-size: 72px;
  font-weight: bold;
  color: #f85959;
}

.ftco-counter .ftco-label {
  font-size: 12px;
  text-transform: uppercase;
  letter-spacing: .1em;
}

.block-20 {
  overflow: hidden;
  background-size: cover;
  background-repeat: no-repeat;
  background-position: center center;
  height: 250px;
  position: relative;
  display: block;
}

.blog-entry {
  background: #FAF9F6;
  border: 1px solid #e6e6e6;
}

@media (min-width: 768px) {
  .blog-entry {
    margin-bottom: 30px;
  }
}

@media (max-width: 767.98px) {
  .blog-entry {
    margin-bottom: 30px;
  }
}

.blog-entry .text {
  position: relative;
  border-top: 0;
  border-radius: 2px;
}

.blog-entry .text .tag {
  color: #000;
}

.blog-entry .text .heading {
  font-size: 16px;
  margin-bottom: 16px;
}

.blog-entry .text .heading a {
  color: #000000;
}

.blog-entry .text .heading a:hover,
.blog-entry .text .heading a:focus,
.blog-entry .text .heading a:active {
  color: #1a8af9;
}

.blog-entry .text .meta-chat {
  color: #b3b3b3;
}

.blog-entry .text .read {
  color: #000000;
  font-size: 12px;
}

.blog-entry .meta>div {
  display: inline-block;
  margin-right: 5px;
  margin-bottom: 5px;
  font-size: 15px;
}

.blog-entry .meta>div a {
  color: #b3b3b3;
  font-size: 15px;
}

.blog-entry .meta>div a:hover {
  color: #cccccc;
}

.block-23 ul {
  padding: 0;
}

.block-23 ul li,
.block-23 ul li>a {
  display: table;
  line-height: 1.5;
  margin-bottom: 15px;
}

.block-23 ul li span {
  color: rgba(255, 255, 255, 0.7);
}

.block-23 ul li .icon,
.block-23 ul li .text {
  display: table-cell;
  vertical-align: top;
}

.block-23 ul li .icon {
  width: 40px;
  font-size: 18px;
  padding-top: 2px;
  color: white;
}

.block-6 {
  margin-bottom: 40px;
}

.block-6 .media-body p {
  font-size: 16px;
}

.block-10 .chef-img {
  height: 400px;
}

.block-10 .person-info {
  height: 75px;
}

.block-10 .person-info span {
  display: block;
}

.block-10 .person-info .name {
  font-size: 20px;
  color: #000000;
  font-weight: 400;
}

.block-10 .person-info .position {
  font-size: 14px;
}

.block-16 figure {
  position: relative;
}

.block-16 figure .play-button {
  position: absolute;
  top: 50%;
  left: 50%;
  -webkit-transform: translate(-50%, -50%);
  -ms-transform: translate(-50%, -50%);
  transform: translate(-50%, -50%);
  font-size: 40px;
  width: 90px;
  height: 90px;
  background: #fff;
  display: block;
  border-radius: 50%;
  opacity: .7;
}

.block-16 figure .play-button:hover {
  opacity: 1;
}

.block-16 figure .play-button>span {
  position: absolute;
  left: 55%;
  top: 50%;
  -webkit-transform: translate(-50%, -50%);
  -ms-transform: translate(-50%, -50%);
  transform: translate(-50%, -50%);
}

.block-17 {
  background: #fff;
  overflow: hidden;
  -webkit-border-radius: 2px;
  -moz-border-radius: 2px;
  -ms-border-radius: 2px;
  border-radius: 2px;
}

.block-17 form .fields {
  width: calc(100% - 80px);
  position: relative;
}

.block-17 form .fields .one-third {
  width: 50%;
  background: #fff;
}

.block-17 form .fields .one-third:last-child {
  border-right: none;
  border-left: 1px solid rgba(0, 0, 0, 0.1);
}

.block-17 form .fields .one-third label {
  font-weight: 700;
  color: #000000;
}

.block-17 form .fields .form-control {
  -webkit-box-shadow: none !important;
  box-shadow: none !important;
  border: transparent;
  background: #fff !important;
  color: #4d4d4d !important;
  border: 2px solid rgba(0, 0, 0, 0.1);
  font-size: 14px;
  width: 100%;
  height: 70px !important;
  bordeR: 1px solid transparent;
  padding: 10px 30px;
  -webkit-border-radius: 0;
  -moz-border-radius: 0;
  -ms-border-radius: 0;
  border-radius: 0;
}

.block-17 form .fields .form-control::-webkit-input-placeholder {
  /* Chrome/Opera/Safari */
  color: #4d4d4d;
}

.block-17 form .fields .form-control::-moz-placeholder {
  /* Firefox 19+ */
  color: #4d4d4d;
}

.block-17 form .fields .form-control:-ms-input-placeholder {
  /* IE 10+ */
  color: #4d4d4d;
}

.block-17 form .fields .form-control:-moz-placeholder {
  /* Firefox 18- */
  color: #4d4d4d;
}

.block-17 form .fields .icon {
  position: absolute;
  top: 50%;
  right: 30px;
  font-size: 14px;
  -webkit-transform: translateY(-50%);
  -ms-transform: translateY(-50%);
  transform: translateY(-50%);
  color: rgba(0, 0, 0, 0.7);
}

@media (max-width: 767.98px) {
  .block-17 form .fields .icon {
    right: 10px;
  }
}

.block-17 form .fields .select-wrap {
  position: relative;
}

.block-17 form .fields .select-wrap select {
  -webkit-appearance: none;
  -moz-appearance: none;
  appearance: none;
}

.block-17 form .search-submit {
  width: 160px;
  background: #f85959;
  border: 1px solid #f85959;
  color: #fff;
  padding: 12px 10px;
  -webkit-border-radius: 0;
  -moz-border-radius: 0;
  -ms-border-radius: 0;
  border-radius: 0;
}

@media (max-width: 767.98px) {
  .block-17 form .search-submit {
    width: 80px;
  }
}

.block-17 form .search-submit:hover {
  background: #f85959 !important;
  color: #fff !important;
  border: 1px solid #f85959 !important;
}

.block-18 .icon>span {
  font-size: 40px;
}

.block-18 .text strong {
  font-size: 30px;
}

.block-18 .text span {
  display: block;
}

.block-27 ul {
  padding: 0;
  margin: 0;
}

.block-27 ul li {
  display: inline-block;
  margin-bottom: 4px;
  font-weight: 400;
}

.block-27 ul li a,
.block-27 ul li span {
  color: #f85959;
  text-align: center;
  display: inline-block;
  width: 40px;
  height: 40px;
  line-height: 40px;
  border-radius: 50%;
  border: 1px solid #fdd3d3;
}

.block-27 ul li.active a,
.block-27 ul li.active span {
  background: #fdd3d3;
  color: #f85959;
  border: 1px solid transparent;
}

.block-8 .accordion-item .heading {
  font-size: 16px;
  font-weight: 400;
  padding: 10px 0;
}

.block-8 .accordion-item .heading>a {
  padding-left: 35px;
  position: relative;
  color: #000000;
}

.block-8 .accordion-item .heading>a:before {
  width: 20px;
  height: 20px;
  line-height: 18px;
  border: 1px solid #ccc;
  text-align: center;
  font-size: 18px;
  top: .1em;
  left: 0;
}

.block-8 .accordion-item .heading>a[aria-expanded="true"]:before {
  font-family: 'icomoon';
  position: absolute;
  content: "\e316";
  -webkit-transition: .3s all ease;
  -o-transition: .3s all ease;
  transition: .3s all ease;
  background: #f85959;
  color: #fff;
  border: 1px solid #f85959;
}

.block-8 .accordion-item .heading>a[aria-expanded="false"]:before {
  content: "\e313";
  color: #ccc;
  font-family: 'icomoon';
  position: absolute;
  -webkit-transition: .3s all ease;
  -o-transition: .3s all ease;
  transition: .3s all ease;
}

.block-8 .accordion-item .body-text {
  font-size: 16px;
  padding: 5px 0;
  padding-left: 30px;
}

.block-4 .nonloop .owl-stage {
  padding-bottom: 2em;
}

.block-4 .nonloop .owl-item {
  -webkit-box-shadow: 0 7px 20px -5px rgba(0, 0, 0, 0.2);
  box-shadow: 0 7px 20px -5px rgba(0, 0, 0, 0.2);
}

.block-4 .nonloop .owl-nav {
  z-index: 2;
  position: absolute;
  width: 100%;
  bottom: -2px;
}

.block-4 .nonloop .owl-nav .owl-prev,
.block-4 .nonloop .owl-nav .owl-next {
  opacity: .2;
  -webkit-transition: .3s all ease;
  -o-transition: .3s all ease;
  transition: .3s all ease;
  position: absolute;
}

.block-4 .nonloop .owl-nav .owl-prev:hover,
.block-4 .nonloop .owl-nav .owl-next:hover {
  opacity: 1;
}

.block-4 .nonloop .owl-nav .owl-prev.disabled,
.block-4 .nonloop .owl-nav .owl-next.disabled {
  display: none;
}

.block-4 .nonloop .owl-nav .owl-prev span,
.block-4 .nonloop .owl-nav .owl-next span {
  font-size: 30px;
}

.block-4 .nonloop .owl-nav .owl-prev {
  left: 50px;
}

.block-4 .nonloop .owl-nav .owl-next {
  right: 50px;
}

.block-4 .nonloop .owl-dots {
  bottom: -40px;
  position: absolute;
  width: 100%;
  text-align: center;
}

.block-4 .nonloop .owl-dots .owl-dot {
  display: inline-block;
  width: 8px;
  height: 8px;
  background: #ccc;
  border-radius: 50%;
  margin-right: 10px;
  margin-bottom: 10px;
  -webkit-transition: .3s all ease;
  -o-transition: .3s all ease;
  transition: .3s all ease;
}

.block-4 .nonloop .owl-dots .owl-dot.active {
  background: #f85959;
}

.contact-section .contact-info p a {
  color: #1a1a1a;
}

.block-9 .form-control {
  outline: none !important;
  -webkit-box-shadow: none !important;
  box-shadow: none !important;
  font-size: 15px;
}

.block-21 .blog-img {
  display: block;
  height: 80px;
  width: 80px;
}

.block-21 .text {
  width: calc(100% - 100px);
}

.block-21 .text .heading {
  font-size: 18px;
  font-weight: 300;
}

.block-21 .text .heading a {
  color: #000000;
}

.block-21 .text .heading a:hover,
.block-21 .text .heading a:active,
.block-21 .text .heading a:focus {
  color: #f85959;
}

.block-21 .text .meta>div {
  display: inline-block;
  font-size: 12px;
  margin-right: 5px;
}

.block-21 .text .meta>div a {
  color: gray;
}

.custom-pagination {
  width: 100%;
  text-align: center;
  display: inline-block;
}

.custom-pagination li {
  display: inline-block;
}

.custom-pagination .prev a,
.custom-pagination .next a {
  font-size: 20px !important;
  line-height: 38px !important;
}

.custom-pagination li a,
.custom-pagination .prev a,
.custom-pagination .next a {
  width: 40px;
  height: 40px;
  line-height: 40px;
  padding: 0;
  margin: 0;
  border-radius: 50% !important;
  font-size: 16px;
}

.custom-pagination li.active a,
.custom-pagination .prev.active a,
.custom-pagination .next.active a {
  display: block;
  width: 40px;
  height: 40px;
  line-height: 40px;
  padding: 0;
  margin: 0;
  border-radius: 50% !important;
  font-size: 16px;
  background: #f85959;
  color: #fff;
}

.custom-pagination li.active a:hover,
.custom-pagination li.active a:focus,
.custom-pagination .prev.active a:hover,
.custom-pagination .prev.active a:focus,
.custom-pagination .next.active a:hover,
.custom-pagination .next.active a:focus {
  color: #fff;
}

.custom-pagination .prev {
  float: left;
}

.custom-pagination .next {
  float: right;
}

/* Blog*/
.post-info {
  font-size: 12px;
  text-transform: uppercase;
  font-weight: bold;
  color: #fff;
  letter-spacing: .1em;
}

.post-info>div {
  display: inline-block;
}

.post-info>div .seperator {
  display: inline-block;
  margin: 0 10px;
  opacity: .5;
}

.tagcloud a {
  text-transform: uppercase;
  display: inline-block;
  padding: 4px 10px;
  margin-bottom: 7px;
  margin-right: 4px;
  border-radius: 4px;
  color: #000000;
  border: 1px solid #ccc;
  font-size: 11px;
}

.tagcloud a:hover {
  border: 1px solid #000;
}

.comment-form-wrap {
  clear: both;
}

.comment-list {
  padding: 0;
  margin: 0;
}

.comment-list .children {
  padding: 50px 0 0 40px;
  margin: 0;
  float: left;
  width: 100%;
}

.comment-list li {
  padding: 0;
  margin: 0 0 30px 0;
  float: left;
  width: 100%;
  clear: both;
  list-style: none;
}

.comment-list li .vcard {
  width: 80px;
  float: left;
}

.comment-list li .vcard img {
  width: 50px;
  border-radius: 50%;
}

.comment-list li .comment-body {
  float: right;
  width: calc(100% - 80px);
}

.comment-list li .comment-body h3 {
  font-size: 20px;
}

.comment-list li .comment-body .meta {
  text-transform: uppercase;
  font-size: 13px;
  letter-spacing: .1em;
  color: #ccc;
}

.comment-list li .comment-body .reply {
  padding: 5px 10px;
  background: #e6e6e6;
  color: #000000;
  text-transform: uppercase;
  font-size: 11px;
  letter-spacing: .1em;
  font-weight: 400;
  border-radius: 4px;
}

.comment-list li .comment-body .reply:hover {
  color: #fff;
  background: black;
}

.search-form {
  background: #f2f2f2;
  padding: 10px;
}

.search-form .form-group {
  position: relative;
}

.search-form .form-group input {
  padding-right: 50px;
}

.search-form .icon {
  position: absolute;
  top: 50%;
  right: 20px;
  -webkit-transform: translateY(-50%);
  -ms-transform: translateY(-50%);
  transform: translateY(-50%);
}

.subscribe-form .form-group {
  position: relative;
  margin-bottom: 0;
  border: 1px solid rgba(255, 255, 255, 0.7);
  -webkit-border-radius: 0;
  -moz-border-radius: 0;
  -ms-border-radius: 0;
  border-radius: 0;
}

.subscribe-form .form-group input {
  background: transparent !important;
  border: 1px solid transparent;
  color: rgba(255, 255, 255, 0.7) !important;
  font-size: 16px;
  -webkit-border-radius: 30px;
  -moz-border-radius: 30px;
  -ms-border-radius: 30px;
  border-radius: 30px;
}

.subscribe-form .form-group input::-webkit-input-placeholder {
  /* Chrome/Opera/Safari */
  color: rgba(255, 255, 255, 0.7) !important;
}

.subscribe-form .form-group input::-moz-placeholder {
  /* Firefox 19+ */
  color: rgba(255, 255, 255, 0.7) !important;
}

.subscribe-form .form-group input:-ms-input-placeholder {
  /* IE 10+ */
  color: rgba(255, 255, 255, 0.7) !important;
}

.subscribe-form .form-group input:-moz-placeholder {
  /* Firefox 18- */
  color: rgba(255, 255, 255, 0.7) !important;
}

.subscribe-form .form-group .submit {
  border-left: 1px solid rgba(255, 255, 255, 0.7);
  color: #fff !important;
  -webkit-border-radius: 0;
  -moz-border-radius: 0;
  -ms-border-radius: 0;
  border-radius: 0;
  font-size: 16px;
}

.subscribe-form .form-group .submit:hover {
  cursor: pointer;
}

.subscribe-form .icon {
  position: absolute;
  top: 50%;
  right: 20px;
  -webkit-transform: translateY(-50%);
  -ms-transform: translateY(-50%);
  transform: translateY(-50%);
  color: rgba(255, 255, 255, 0.8);
}

.sidebar-wrap {
  padding: 20px;
  border: 1px solid #e6e6e6;
  margin-bottom: 30px;
}

.sidebar-wrap .heading {
  font-size: 18px;
  text-transform: uppercase;
}

.sidebar-wrap .fields {
  width: 100%;
  position: relative;
}

.sidebar-wrap .fields .form-control {
  -webkit-box-shadow: none !important;
  box-shadow: none !important;
  border: transparent;
  background: #fff !important;
  color: #4d4d4d !important;
  border: 1px solid #e6e6e6;
  font-size: 14px;
  width: 100%;
  height: 52px !important;
  padding: 10px 20px;
  -webkit-border-radius: 0;
  -moz-border-radius: 0;
  -ms-border-radius: 0;
  border-radius: 0;
}

.sidebar-wrap .fields .form-control::-webkit-input-placeholder {
  /* Chrome/Opera/Safari */
  color: #4d4d4d;
}

.sidebar-wrap .fields .form-control::-moz-placeholder {
  /* Firefox 19+ */
  color: #4d4d4d;
}

.sidebar-wrap .fields .form-control:-ms-input-placeholder {
  /* IE 10+ */
  color: #4d4d4d;
}

.sidebar-wrap .fields .form-control:-moz-placeholder {
  /* Firefox 18- */
  color: #4d4d4d;
}

.sidebar-wrap .fields .icon {
  position: absolute;
  top: 50%;
  right: 30px;
  font-size: 14px;
  -webkit-transform: translateY(-50%);
  -ms-transform: translateY(-50%);
  transform: translateY(-50%);
  color: rgba(0, 0, 0, 0.7);
}

@media (max-width: 767.98px) {
  .sidebar-wrap .fields .icon {
    right: 10px;
  }
}

.sidebar-wrap .fields .select-wrap {
  position: relative;
}

.sidebar-wrap .fields .select-wrap select {
  -webkit-appearance: none;
  -moz-appearance: none;
  appearance: none;
}

.sidebar-wrap .form-group .btn {
  width: 100%;
  display: block !important;
  -webkit-border-radius: 2px;
  -moz-border-radius: 2px;
  -ms-border-radius: 2px;
  border-radius: 2px;
}

.sidebar-wrap .range-slider {
  width: 100%;
  margin: auto;
  position: relative;
  height: 3em;
  margin-bottom: 30px;
}

.sidebar-wrap .range-slider svg,
.sidebar-wrap .range-slider input[type=range] {
  position: absolute;
  left: 0;
  bottom: 0;
}

.sidebar-wrap input[type=number] {
  border: 1px solid transparent;
  text-align: center;
  font-size: 14px;
  -moz-appearance: textfield;
  background: transparent;
  position: relative;
}

.sidebar-wrap input[type=number]::-webkit-outer-spin-button,
.sidebar-wrap input[type=number]::-webkit-inner-spin-button {
  -webkit-appearance: none;
}

.sidebar-wrap input[type=number]:invalid,
.sidebar-wrap input[type=number]:out-of-range {
  border: 2px solid #ff6347;
}

.sidebar-wrap input[type=range] {
  -webkit-appearance: none;
  width: 100%;
}

.sidebar-wrap input[type=range]:focus {
  outline: none;
}

.sidebar-wrap input[type=range]:focus::-webkit-slider-runnable-track {
  background: #f85959;
}

.sidebar-wrap input[type=range]:focus::-ms-fill-lower {
  background: #f85959;
}

.sidebar-wrap input[type=range]:focus::-ms-fill-upper {
  background: #f85959;
}

.sidebar-wrap input[type=range]::-webkit-slider-runnable-track {
  width: 100%;
  height: 5px;
  cursor: pointer;
  animate: 0.2s;
  background: #f85959;
  border-radius: 1px;
  -webkit-box-shadow: none;
  box-shadow: none;
  border: 0;
}

.sidebar-wrap input[type=range]::-webkit-slider-thumb {
  z-index: 2;
  position: relative;
  -webkit-box-shadow: 0px 0px 0px #000;
  box-shadow: 0px 0px 0px #000;
  border: 1px solid #f85959;
  height: 18px;
  width: 18px;
  border-radius: 25px;
  background: #f85959;
  cursor: pointer;
  -webkit-appearance: none;
  margin-top: -7px;
}

.sidebar-wrap input[type=range]::-moz-range-track {
  width: 100%;
  height: 5px;
  cursor: pointer;
  animate: 0.2s;
  background: #f85959;
  border-radius: 1px;
  box-shadow: none;
  border: 0;
}

.sidebar-wrap input[type=range]::-moz-range-thumb {
  z-index: 2;
  position: relative;
  box-shadow: 0px 0px 0px #000;
  border: 1px solid #f85959;
  height: 18px;
  width: 18px;
  border-radius: 25px;
  background: #f85959;
  cursor: pointer;
}

.sidebar-wrap input[type=range]::-ms-track {
  width: 100%;
  height: 5px;
  cursor: pointer;
  animate: 0.2s;
  background: transparent;
  border-color: transparent;
  color: transparent;
}

.sidebar-wrap input[type=range]::-ms-fill-lower,
.sidebar-wrap input[type=range]::-ms-fill-upper {
  background: #f85959;
  border-radius: 1px;
  box-shadow: none;
  border: 0;
}

.sidebar-wrap input[type=range]::-ms-thumb {
  z-index: 2;
  position: relative;
  box-shadow: 0px 0px 0px #000;
  border: 1px solid #f85959;
  height: 18px;
  width: 18px;
  border-radius: 25px;
  background: #f85959;
  cursor: pointer;
}

.rate i {
  color: #f85959;
  margin: 0 4px;
}

.sidebar-box {
  margin-bottom: 30px;
  padding: 25px;
  font-size: 15px;
  width: 100%;
  float: left;
  background: #fff;
}

.sidebar-box *:last-child {
  margin-bottom: 0;
}

.sidebar-box h3 {
  font-size: 18px;
  margin-bottom: 15px;
}

.categories li,
.sidelink li {
  position: relative;
  margin-bottom: 10px;
  padding-bottom: 10px;
  border-bottom: 1px dotted #dee2e6;
  list-style: none;
}

.categories li:last-child,
.sidelink li:last-child {
  margin-bottom: 0;
  border-bottom: none;
  padding-bottom: 0;
}

.categories li a,
.sidelink li a {
  display: block;
}

.categories li a span,
.sidelink li a span {
  position: absolute;
  right: 0;
  top: 0;
  color: #ccc;
}

.categories li.active a,
.sidelink li.active a {
  color: #000000;
  font-style: italic;
}

#ftco-loader {
  position: fixed;
  width: 96px;
  height: 96px;
  left: 50%;
  top: 50%;
  -webkit-transform: translate(-50%, -50%);
  -ms-transform: translate(-50%, -50%);
  transform: translate(-50%, -50%);
  background-color: rgba(255, 255, 255, 0.9);
  -webkit-box-shadow: 0px 24px 64px rgba(0, 0, 0, 0.24);
  box-shadow: 0px 24px 64px rgba(0, 0, 0, 0.24);
  border-radius: 16px;
  opacity: 0;
  visibility: hidden;
  -webkit-transition: opacity .2s ease-out, visibility 0s linear .2s;
  -o-transition: opacity .2s ease-out, visibility 0s linear .2s;
  transition: opacity .2s ease-out, visibility 0s linear .2s;
  z-index: 1000;
}

#ftco-loader.fullscreen {
  padding: 0;
  left: 0;
  top: 0;
  width: 100%;
  height: 100%;
  -webkit-transform: none;
  -ms-transform: none;
  transform: none;
  background-color: #fff;
  border-radius: 0;
  -webkit-box-shadow: none;
  box-shadow: none;
}

#ftco-loader.show {
  -webkit-transition: opacity .4s ease-out, visibility 0s linear 0s;
  -o-transition: opacity .4s ease-out, visibility 0s linear 0s;
  transition: opacity .4s ease-out, visibility 0s linear 0s;
  visibility: visible;
  opacity: 1;
}

#ftco-loader .circular {
  -webkit-animation: loader-rotate 2s linear infinite;
  animation: loader-rotate 2s linear infinite;
  position: absolute;
  left: calc(50% - 24px);
  top: calc(50% - 24px);
  display: block;
  -webkit-transform: rotate(0deg);
  -ms-transform: rotate(0deg);
  transform: rotate(0deg);
}

#ftco-loader .path {
  stroke-dasharray: 1, 200;
  stroke-dashoffset: 0;
  -webkit-animation: loader-dash 1.5s ease-in-out infinite;
  animation: loader-dash 1.5s ease-in-out infinite;
  stroke-linecap: round;
}

@-webkit-keyframes loader-rotate {
  100% {
    -webkit-transform: rotate(360deg);
    transform: rotate(360deg);
  }
}

@keyframes loader-rotate {
  100% {
    -webkit-transform: rotate(360deg);
    transform: rotate(360deg);
  }
}

@-webkit-keyframes loader-dash {
  0% {
    stroke-dasharray: 1, 200;
    stroke-dashoffset: 0;
  }

  50% {
    stroke-dasharray: 89, 200;
    stroke-dashoffset: -35px;
  }

  100% {
    stroke-dasharray: 89, 200;
    stroke-dashoffset: -136px;
  }
}

@keyframes loader-dash {
  0% {
    stroke-dasharray: 1, 200;
    stroke-dashoffset: 0;
  }

  50% {
    stroke-dasharray: 89, 200;
    stroke-dashoffset: -35px;
  }

  100% {
    stroke-dasharray: 89, 200;
    stroke-dashoffset: -136px;
  }
}

/* 1. O Texto "O MELHOR DE" (Reto e Elegante) */
/* ===============================
   HERO HOME – TEXTO PRINCIPAL
   (ex-slider, agora hero fixo)
=============================== */

/* 1. "O MELHOR DE" */
.hero-wrap .slider-text h1 {
  font-family: 'Barlow Condensed', sans-serif !important;
  font-size: 30px !important;
  font-weight: 700 !important;
  color: #fff !important;
  text-transform: uppercase !important;
  letter-spacing: 4px !important;
  text-shadow: 2px 2px 10px rgba(0, 0, 0, 0.5) !important;
  margin-bottom: 0 !important;
  line-height: 1.35 !important; /* CONTROLA O ESPAÇO ENTRE AS LINHAS */
}

/* 2. "Noronha Local" */
.hero-wrap:not(.hero-passeios) .slider-text h1 span {
  font-family: 'Poppins', sans-serif;
  color: #fde02f !important;
  font-size: 100px !important;
  display: block !important;

  text-transform: none !important;
  letter-spacing: 0 !important;
  font-weight: 400 !important;

  margin-top: 0 !important;
  text-shadow: 3px 3px 12px rgba(0, 0, 0, 0.3) !important;

  background-image: url('../images/hero-_ineShape1.png') !important;
  background-repeat: no-repeat !important;
  background-position: bottom center !important;
  background-size: 100% 25% !important;
  padding-bottom: 20px;
}

/* 3. Texto descritivo */
.hero-wrap .slider-text p {
  font-size: 24px !important;
  color: #ffffff !important;
  font-weight: 300 !important;
  text-shadow: 2px 2px 8px rgba(0, 0, 0, 0.8) !important;
  margin-top: 25px !important;
}

/* ===============================
   HERO HOME – MOBILE
=============================== */
@media (max-width: 767.98px) {

  /* 1. "PASSEIOS DE" */
  .hero-wrap .slider-text h1 {
    font-size: 20px !important;
    letter-spacing: 2px !important;
    line-height: 1.3 !important;
  }

  /* 2. "Barco no paraíso" */
  .hero-wrap:not(.hero-passeios) .slider-text h1 span {
    font-size: 56px !important;

    background-size: 100% 20% !important;
    padding-bottom: 14px !important;
  }

  /* 3. Texto descritivo */
  .hero-wrap .slider-text p {
    font-size: 16px !important;
    margin-top: 16px !important;
  }
}


/* Estado NORMAL da navbar (topo da página) */
.ftco-navbar-light:not(.scrolled) {
  background: transparent !important;   /* transparente no topo */
  position: absolute;
  top: 0 !important;                     /* cola no topo */
  z-index: 999;
  transition: background 0.3s ease;
}

/* Estado SCROLLED da navbar (após rolar) */
.ftco-navbar-light.scrolled {
  background: #ffffff !important;        /* fundo branco ao rolar */
  transition: background 0.3s ease;
}


/* 2. Mantém o menu na direita e com letras brancas */
.ftco-navbar-light .navbar-nav > .nav-item > .nav-link {
    color: #000 !important;
}

/* 3. Cor amarela APENAS no texto do link (evita o bloco amarelo) */
.ftco-navbar-light .navbar-nav > .nav-item.active > .nav-link,
.ftco-navbar-light .navbar-nav > .nav-item > .nav-link:hover {
    color: #000 !important;
    background: transparent !important; /* Garante que não crie bloco de cor */
}

/* 2. Ajuste do botão CTA para contrastar com o novo fundo */
.ftco-navbar-light .navbar-nav > .nav-item.cta > .nav-link {
    background: #1a8af9 !important; /* Mantemos o amarelo ouro */
    border: 1px solid #1a8af9 !important;
    color: #0a2b38 !important; /* Texto em azul escuro para ler melhor no amarelo */
    font-weight: 700;
}

/* Hover real do botão CTA */
.ftco-navbar-light .navbar-nav > .nav-item.cta > .nav-link:hover {
    background: #1a8af9 !important; /* Amarelo mais escuro */
    border-color: #ffffff !important;
    color: #1a8af9 !important;
}


/* Garante que o nome da marca (Noronha Local) seja visível e branco */
.navbar-brand {
    color: #ffffff !important;
    opacity: 1 !important;
    display: block !important;
    visibility: visible !important;
}

/* Força a cor branca mesmo quando o rato passa por cima (hover) */
.navbar-brand:hover, .navbar-brand:focus {
    color: #000 !important; /* Muda para amarelo no hover para dar um efeito legal */
}

/* Resolve o problema do menu "sumir" ou piscar no topo */
.ftco_navbar {
    background: #000000 !important; /* Cor da barra Hover Topo */
    top: 0 !important;
}

/* Mantém o alinhamento correto dos itens na direita */
.navbar-nav {
    margin-left: auto !important;
}


.ftco-navbar-light {
  transition: opacity 0.3s ease;
}

/* === APENAS VISUAL DO TEXTO DO MENU === */
.ftco-navbar-light .navbar-nav > .nav-item > .nav-link {
  color: #000 !important;      /* Branco mais forte */
  font-weight: 00;               /* Texto mais encorpado */
  letter-spacing: 0.4px;          /* Melhor leitura */
  font-weight: 500;
}

/* Cor padrão */
.ftco-navbar-light .navbar-nav > .nav-item > .nav-link {
  color: #000 !important; /* cor normal */
}

/* Hover e ativo */
.ftco-navbar-light .navbar-nav > .nav-item.active > .nav-link,
.ftco-navbar-light .navbar-nav > .nav-item > .nav-link:hover {
  color: #1a8af9 !important; /* cor ao passar o mouse ou ativo */
}

/* Estado NORMAL (barra transparente, fonte branca) */
.ftco-navbar-light:not(.scrolled) .navbar-nav > .nav-item > .nav-link { /*BARRA MENU FONTE */
  color: #000 !important; /* fonte branca */
}

/* Estado SCROLLED (barra branca, fonte preta) */
.ftco-navbar-light.scrolled .navbar-nav > .nav-item > .nav-link {
  color: #1a8af9 !important; /* fonte preta */
}

/* Hover em qualquer estado */
.ftco-navbar-light .navbar-nav > .nav-item > .nav-link:hover {
  color: #000 !important; /* azul no hover, por exemplo */
}


.navbar-brand img {
  height: 55px;       /* ideal para desktop */
  width: auto;
}

@media (max-width: 768px) {
  .navbar-brand img {
    height: 45px;
  }
}

/* PREVINE TRAVAMENTO NO LOAD */
.ftco-navbar-light {
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  transform: translateY(0) !important;
}

body {
  padding-top: 0px; /* ajuste para a altura real da navbar */
}

html {
  scroll-behavior: auto !important;
}

/* Customização da Seção de Serviços */
.services-section {
    padding: 7em 0;
    background-color: #f8f9fa !important;
}

.services-section .services {
    background: #fff;
    padding: 30px;
    border-radius: 15px; /* Bordas arredondadas */
    box-shadow: 0px 10px 30px -15px rgba(0,0,0,0.1); /* Sombra suave */
    transition: all 0.3s ease;
    height: 100%;
    border-bottom: 4px solid transparent;
}

/* Efeito ao passar o mouse */
.services-section .services:hover {
    transform: translateY(-10px); /* Card sobe levemente */
    border-bottom: 4px solid #FDE02F; /* Linha amarela da sua logo */
    box-shadow: 0px 20px 40px -15px rgba(0,0,0,0.15);
}

/* Estilo do Ícone */
.services-section .icon {
    line-height: 1.3;
    position: relative;
    margin-bottom: 20px;
}

.services-section .icon span {
    font-size: 60px;
    color: #1a8af9; /* O azul da sua barra */
}

/* Títulos e Textos */
.services-section .heading {
    font-size: 14px;
    font-weight: 700;
    color: #0a2b38;
}

.services-section p {
    font-size: 12px;
    color: #666;
}

/* Paleta */
:root {
  --nl-blue-dark: #1a8af9;
  --nl-blue: #58AEC3;
  --nl-yellow: #FDE02F;
}

/* Escopo da sessão */
.nl-services {
  background: #fff; /* mantém o bg-light do tema */
}

.nl-services .services.d-block {
  background: #ffffff;
  border-radius: 8px;
  box-shadow: 0 6px 18px rgba(0,0,0,0.06);
  padding: 14px 14px;
  transition: transform .2s ease, box-shadow .2s ease;
}

.nl-services .services.d-block:hover {
  transform: translateY(-4px);
  box-shadow: 0 10px 24px rgba(0,0,0,0.1);
}

/* Ícone com fallback: mostra o que estiver disponível */
.nl-services .icon {
  width: 60px;
  height: 60px;
  border-radius: 50%;
  background: var(--nl-yellow);
  display: grid;
  place-items: center;
}

.nl-services .icon .flaticon-boat,
.nl-services .icon .flaticon-hiking,
.nl-services .icon .flaticon-diving,
.nl-services .icon .flaticon-support {
  font-size: 24px;
  color: var(--nl-blue-dark);
}

.nl-services .icon i {
  font-size: 28px;
  color: var(--nl-blue-dark);
}

/* Títulos e textos */
.nl-services .heading {
  color: var(--nl-blue-dark);
  font-weight: 600;
}

.nl-services .media-body p {
  color: #4a4a4a;
}

/* Acentos e foco */
.nl-services .services.d-block:focus-within,
.nl-services .services.d-block:hover .heading {
  color: var(--nl-blue);
}

.slider-img {
  width: 100%;
  height: 480px;
  object-fit: cover;
  border-radius: 15px;
  display: block;
}

/* TRILHAS CARDS - VERSÃO CORRIGIDA */
.trilha-card {
  max-width: 100% !important; 
    margin: 0 !important;
    background: #fff;
    border-radius: 18px;
    overflow: hidden;
    box-shadow: 0 10px 25px rgba(0,0,0,.08);
    /* REMOVEMOS: width, max-width e margin daqui */
}

/* 1. Reset Geral para Mobile (Prioridade: Card Largo) */
.trilhas-section .container {
    width: 100% !important;
    max-width: 100% !important;
    padding-left: 15px !important;  /* Espaço mínimo para não colar na borda física */
    padding-right: 0px !important;
    margin: 0 auto !important;
}

/* 2. Configuração para Desktop (Acima de 992px) */
@media (min-width: 992px) {
    .trilhas-section .container {
        max-width: 1300px !important; /* A largura que você gostou */
        padding-left: 15px !important; /* Recuo para as setas respirarem */
        padding-right: 0px !important;
    }
}

.trilha-img {
  width: 100%;
  height: 420px;
  object-fit: cover;
  position: relative;
}

.trilha-content {
  padding: 45px;
}

.trilha-tag {
  color: #1a8af9;
  font-weight: 700;
  font-size: 13px;
  letter-spacing: 2px;
  text-transform: uppercase;
}

.trilha-title {
  font-family: 'Poppins', sans-serif;
  font-size: 44px;
  margin-top: 10px;
  color: #0a2b38;
}

.trilha-divider {
  width: 70px;
  height: 4px;
  background: #FDE02F;
  margin: 20px 0;
}

.trilha-text {
  font-size: 16px;
  color: #555;
  line-height: 1.7;
}

.trilha-list {
  padding-left: 20px;
}

.trilha-list li {
  margin-bottom: 8px;
  color: #444;
}

.trilha-box {
  background: #f8f9fa;
  padding: 22px;
  border-left: 5px solid #FDE02F;
  border-radius: 8px;
  font-size: 15px;
}

/* Ajuste fino da área de conteúdo das trilhas */
.trilhas-page {
  padding-top: 1em !important;
  padding-bottom: 4em !important;
}

/* Card Passeios */
.destination-card {
  background: #fff;
  border-radius: 18px;
  overflow: hidden;
  box-shadow: 0 12px 30px rgba(0,0,0,0.08);
  transition: all 0.3s ease;
  height: 100%;
}

.destination-card:hover {
  transform: translateY(-6px);
  box-shadow: 0 18px 40px rgba(0,0,0,0.12);
}

/* === CORRETO | Card com imagem de fundo === */
.destination-img {
  display: block;
  position: relative;
  width: 100%;
  height: 100%;

  border-radius: 12px !important;
  overflow: hidden; /* ESSENCIAL */
  
  background-size: cover;
  background-position: center;
  background-repeat: no-repeat;

  transition: transform 0.6s cubic-bezier(0.25, 0.46, 0.45, 0.94);
}


/* A imagem em si */
.destination-img img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
    transition: transform 0.6s cubic-bezier(0.25, 0.46, 0.45, 0.94) !important; /* Transição suave */
    will-change: transform; /* Avisa o navegador para usar aceleração de hardware */
}

/* Efeito ao passar o mouse */
.destination-card:hover .destination-img img {
    transform: scale(1.1);
}

/* Texto */
.destination-info {
  padding: 20px;
  text-align: left;
}

.destination-info h3 {
  font-size: 18px;
  font-weight: 800;
  color: #0b3c5d;
  margin-bottom: 8px;
}

.destination-info p {
  font-size: 14px;
  color: #666;
  margin-bottom: 15px;
  line-height: 1.4;
}

/* Botão */
.btn-detalhes {
  display: inline-block;
  font-size: 14px;
  font-weight: 700;
  color: #1a8af9;
  text-decoration: none;
  border-bottom: 2px solid #1a8af9;
  padding-bottom: 2px;
}

.btn-detalhes:hover {
  color: #005f86;
  border-color: #005f86;
}

/* Garante que TODOS os cards tenham a mesma altura */
.destination {
  display: flex;
  flex-direction: column;
  height: 100%;
}

/* Imagem sempre do mesmo tamanho */
.destination .img {
  background-size: cover;
  background-position: center;
  height: 220px;
}

/* Tablets */
@media (max-width: 991px) {
  .destination .img {
    height: 200px;
  }
}

/* Mobile */
@media (max-width: 991px) {
  .destination-img {
    height: 200px;
  }
}

@media (max-width: 575px) {
  .destination-img {
    height: 180px;
  }
}



/* Área de texto com altura fixa */
.destination .text {
  flex: 1;
  min-height: 110px;
  display: flex;
  flex-direction: column;
  justify-content: center;
}

/* Limita o título a 2 linhas */
.destination .text h3 {
  font-size: 18px;
  line-height: 1.3;
  margin-bottom: 5px;

  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
}

/* Limita texto secundário */
.destination .listing {
  font-size: 13px;
  color: #000
}

/* DESTINATION mais largo para comportar 4 cards */
.ftco-destination .container {
  max-width: 1350px; /* padrão é ~1140 */
}

.destination {
  padding: 0;
}

.destination .text {
  padding: 18px 20px;
}

.destination .text h3 {
  font-size: 17px;
  line-height: 1.4;
}

.boat-card {
  background: #fff;
  border-radius: 20px;
  overflow: hidden;
  box-shadow: 0 20px 45px rgba(0,0,0,.08);
  margin-bottom: 70px;
}

.boat-image {
  height: 340px;
  background-size: cover;
  background-position: center;
}

.boat-content {
  padding: 40px;
}

.badge-passeio {
  background: #1a8af9;
  color: #fff;
  padding: 6px 14px;
  border-radius: 20px;
  font-size: 12px;
  display: inline-block;
  margin-bottom: 10px;
}

.boat-info {
  list-style: none;
  padding: 0;
}

.boat-info li {
  margin-bottom: 8px;
}

.btn-whatsapp {
  display: inline-block;
  margin-top: 25px;
  background: linear-gradient(135deg,#25d366,#128c7e);
  color: #fff;
  padding: 14px 30px;
  border-radius: 30px;
  font-weight: 700;
}

/* ===============================
   SLIDER DE BARCOS (PÁGINA PASSEIOS)
   =============================== */


/* TEXTO DOS DETALHES */
.boat-details {
  font-size: 14px;
  line-height: 1.7;
  color: #333;
}

/* SUMMARY (VER DETALHES) */
.boat-summary {
  cursor: pointer;
  font-weight: 500;
  font-size: 16px;
  color: #1a8af9;
  margin-top: 10px;
}

/* BOTÃO WHATSAPP */
.btn-whatsapp {
  background: linear-gradient(135deg, #25d366, #25d366);
  color: #fff;
  font-weight: 600;
  border-radius: 30px;
  padding: 14px 24px;
  border: none;
  transition: all 0.3s ease;
}

.btn-whatsapp:hover {
  background: linear-gradient(135deg, #1ebe5d, #18a851);
  transform: scale(1.03);
}

/* ===== SETAS DO SLIDER ===== */
.boat-slider {
  position: relative;
}

/* NAVEGAÇÃO SUPERIOR */
.boat-nav-top {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 20px;
  margin-top: 10px;
  margin-bottom: 25px;
  font-size: 15px;
}

/* BOTÕES */
.boat-nav-top button {
  width: 42px;
  height: 42px;
  border-radius: 50%;
  border: none;
  background: linear-gradient(135deg, #1a8af9, #00b4db);
  color: #fff;
  font-size: 26px;
  font-weight: 700;
  line-height: 1;
  cursor: pointer;
  box-shadow: 0 6px 16px rgba(0,0,0,0.25);
  transition: all 0.25s ease;
}

/* HOVER */
.boat-nav-top button:hover {
  transform: scale(1.1);
  background: linear-gradient(135deg, #00b4db, #1a8af9);
}

/* CONTADOR */
#boat-counter,
#boat-counter-bottom {
  font-weight: 700;
  font-size: 16px;
  letter-spacing: 1px;
  color: #222;
}



.boat-card img {
    display: block;      /* remove espaço fantasma */
    margin-bottom: 16px; /* espaço entre imagem e nome */
}

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

.boat-card h3,
.boat-card .boat-name {
    position: static !important;
    display: block;
    margin-top: 18px;
}

/* Espaço entre imagem e conteúdo */
.boat-image-wrapper {
    margin-bottom: 20px;
}

/* Título do barco */
.hotel-single h3 {
  margin-top: 0;
  padding-top: 4px;
  line-height: 1.35;
  font-size: 30px;
  font-weight: 500;
}

/* Setas (topo e base) */
.boat-nav-top button,
.boat-nav-bottom button {
  background: #FDE02F;
  border: none;
  border-radius: 8px;
  width: 50px;
  height: 50px;
  font-size: 20px;
  color: #1a8af9;
  margin: 0 8px;
  cursor: pointer;
  transition: background .3s, color .3s, transform .2s;
}

.boat-nav-top button:hover,
.boat-nav-bottom button:hover {
  background: #58AEC3;
  color: #fff;
  transform: scale(1.1);
}

/* Navegação inferior (evite somar deslocamentos) */
.boat-nav-bottom {
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 10px;
  margin-top: 5px;     /* mantenha positivo para previsibilidade */
  position: relative;
  top: -10px;          /* ajuste fino, reduzi para evitar conflito visual */
}

/* Bloco de detalhes — use especificidade para garantir aplicação */
.boat-details .service-title {
  font-weight: 600;
  margin-bottom: 10px;        /* mais respiro abaixo do título */
}

.boat-details .service-list {
  margin-top: 0;
  margin-bottom: 24px;        /* espaço antes das observações */
}

.boat-details .observations-title {
  font-weight: 600;
  margin-top: 0;              /* evita somar com o anterior */
  margin-bottom: 10px;        /* respiro abaixo do título */
}

.boat-details .observations-list {
  margin-top: 0;              /* define explicitamente */
  margin-bottom: 0;           /* opcional: zera para consistência */
}

/* Se o Bootstrap estiver interferindo nos <ul>, use esta linha:
.boat-details ul { margin-block: 0; }
ou, em último caso:
.boat-details .service-list { margin-bottom: 24px !important; }
*/

.boat-details p {
  margin-bottom: 0;
  padding-bottom: 15px;   /* espaço abaixo de cada título */
  font-weight: 400;
  color: #222;
}

.boat-details ul {
  margin-top: 0;
  margin-bottom: 20px;    /* espaço entre listas e próximo bloco */
  padding-left: 20px;
}

.boat-details ul li {
  margin-bottom: 8px;     /* espaço entre itens */
}

.hero-cta {
  display: inline-block;
  margin-top: 24px;
  padding: 14px 28px;       /* padding mais equilibrado */
  background: #25d366;
  color: #fff;
  border: 1px solid #fff;
  font-size: 18px;          /* aumenta a fonte */
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.5px;
  border-radius: 40px;
  text-decoration: none;
  box-shadow: 0 10px 25px rgba(0,0,0,0.25);
  transition: all 0.25s ease;
  text-align: center;
  white-space: nowrap;      /* impede quebra de linha */
}

@media (max-width: 767.98px) {
  .hero-cta {
    display: flex;
    align-items: center;
    justify-content: center;
    margin-top: 50px;   /* aumenta espaço acima do botão */
    margin-left: auto;  /* centraliza horizontalmente */
    margin-right: auto; /* centraliza horizontalmente */
    padding: 12px 24px;
    font-size: 16px;
    max-width: 280px;
    line-height: 1.2;
    text-align: center;
  }
}


  .navbar-collapse .nav-item.cta .btn {
    width: 100%;              /* botão ocupa toda a largura no mobile */
    max-width: 280px;         /* limite opcional */
    margin: 0 auto;           /* centraliza */
  }


.hero-cta:hover {
  background: #1EBE5D;
  color: #fff;
  border-color: #fff;
  transform: translateY(-2px);
  box-shadow: 0 14px 30px rgba(0,0,0,0.35);
}

.noronha-refined .noronha-why-list {
  list-style: none;
  padding: 0;
  margin-top: 25px;
}

.noronha-refined .noronha-why-list li {
  font-size: 14px;
  color: #444;
  margin-bottom: 14px;
  display: flex;
  align-items: center;
}

.noronha-refined .noronha-why-list i {
  color: #1a8af9;
  font-size: 18px;
  margin-right: 12px;
}

.testimony-refined {
  background: #fff;
  padding: 30px;
  border-radius: 16px;
  box-shadow: 0 10px 25px rgba(0,0,0,0.05);
}

.testimony-refined i {
  color: #1a8af9;
  font-size: 22px;
}

.testimony-refined p {
  font-size: 14px;
  color: #444;
  line-height: 1.7;
  margin: 15px 0;
}

.testimony-refined strong {
  display: block;
  color: #000;
}

.testimony-refined span {
  font-size: 12px;
  color: #777;
}

.noronha-accent-line {
  width: 55px;
  height: 3px;
  background: #FDE02F;
  margin: 15px 0 25px;
  border-radius: 3px;
}

.noronha-refined .heading-section {
  position: relative;
}

.noronha-refined .heading-section::before {
  content: "";
  position: absolute;
  left: -15px;
  top: 5px;
  width: 3px;
  height: 60px;
  background: #1a8af9;
  border-radius: 3px;
}

.testimony-refined i {
  color: #FDE02F;
  background: #1a8af9;
  width: 36px;
  height: 36px;
  border-radius: 50%;
  display: inline-flex;
  align-items: center;
  justify-content: center;
}

.testimony-refined {
  transition: transform 0.3s ease, box-shadow 0.3s ease;
}

.testimony-refined:hover {
  transform: translateY(-4px);
  box-shadow: 0 15px 35px rgba(0,131,184,0.15);
}

.noronha-refined .owl-dot.active span {
  background: #FDE02F;
}

/* Linha amarela padrão */
.noronha-accent-line {
  width: 55px;
  height: 3px;
  background: #FDE02F;
  margin-top: 15px;
  border-radius: 3px;
}

/* Card refinado */
.noronha-blog-card {
  background: #fff;
  border-radius: 16px;
  overflow: hidden;
  box-shadow: 0 10px 30px rgba(0,0,0,0.06);
  transition: transform 0.3s ease, box-shadow 0.3s ease;
  margin-left: 10px !important;
  margin-right: 10px !important;
}

.noronha-blog-card {
  transition: box-shadow .3s ease;
}

.noronha-blog-card:hover {
  box-shadow: 0 12px 25px rgba(0,0,0,0.12);
}


/* Tag */
.noronha-blog-card .tag {
  display: inline-block;
  font-size: 11px;
  font-weight: 700;
  color: #1a8af9;
  background: rgba(0,131,184,0.1);
  padding: 4px 10px;
  border-radius: 20px;
}

/* Título */
.noronha-blog-card h3 a {
  color: #000;
  font-weight: 600;
}

.noronha-blog-card h3 a:hover {
  color: #1a8af9;
  text-decoration: none;
}

/* Subtexto */
.noronha-blog-card .blog-date {
  font-size: 11px;
  color: #777;
}

/* Badge / Tag dos cards */
.noronha-blog-card .tag {
  display: inline-block;
  font-size: 11px;
  font-weight: 700;
  letter-spacing: .3px;
  text-transform: uppercase;

  color: #1a8af9;                 /* azul do site */
  background: #1a8af9;/* azul suave */
  
  padding: 5px 12px;
  border-radius: 20px;
  margin-bottom: 8px;
  position: relative;
}

.noronha-blog-card .tag {
  color: #fff!important;
  font-size: 12px;
  font-weight: 300;
}

/* Card inteiro como flex */
.noronha-blog-card {
  display: flex;
  flex-direction: column;
}

/* Área de texto cresce corretamente */
.noronha-blog-card .text {
  display: flex;
  flex-direction: column;
  flex-grow: 1; /* <-- ESSENCIAL */
}

/* Empurra o texto final para baixo */
.noronha-blog-card .blog-date {
  margin-top: auto;
}

.noronha-blog-card {
  will-change: box-shadow;
  backface-visibility: hidden;
}

/* Deixa a imagem menor e força o arredondamento nos cantos superiores */
.noronha-blog-card .block-20 {
    height: 180px !important; /* Diminuímos de 210 para 180 */
    display: block !important;
    overflow: hidden !important;
}

.noronha-blog-card .block-20 img {
    height: 100% !important;
    border-radius: 8px 8px 0 0 !important;
}

/* ===== SUBMENU NORONHA ===== */

.nav-item.dropdown {
  position: relative;
}

.nav-item .dropdown-menu {
  position: absolute;
  top: 100%;
  left: 0;

  min-width: 230px;
  background: #fff !important;
  border-radius: 14px;
  padding: 10px 0;

  box-shadow: 0 15px 35px rgba(0,0,0,0.12);
  opacity: 0;
  visibility: hidden;
  transform: translateY(10px);
  transition: all .25s ease;
  z-index: 9999;
}

/* Mostrar submenu no desktop */
.nav-item.dropdown:hover .dropdown-menu {
  opacity: 1;
  visibility: visible;
  transform: translateY(0);
  
}

/* Links do submenu */
.dropdown-menu .dropdown-item {
  padding: 12px 22px;
  font-size: 14px;
  color: #333;
  transition: background .2s ease, color .2s ease;
}

.dropdown-menu .dropdown-item:hover {
  background: #9FBCC7;
  color: #fff;
}


/* Setinha do dropdown */
.dropdown-toggle::after {
  content: "▾";
  font-size: 16px;
  margin-left: 6px;
}

/* ===== MOBILE – DROPDOWN IGUAL DESKTOP ===== */
@media (max-width: 991px) {

  

  .nav-item.dropdown.show > .dropdown-menu {
    opacity: 1;
    visibility: visible;
    transform: translateY(0);
  }

}


/* =========================
   HERO / BANNER – PADRÃO
========================= */

.hero-wrap {
  position: relative;
  width: 100%;
  background-size: cover;
  background-position: center;
}


/* Conteúdo */
.hero-content {
  opacity: 1;
  visibility: visible;
}

/* Título */
.hero-title {
  font-family: 'Poppins', Arial, sans-serif;
  font-weight: 800;
  font-size: 50px; /* desktop */
  line-height: 1.2;
  color: #000;
  margin-bottom: 20px;
}

.hero-title span,
.hero-highlight {
  color: #fb8c00;
}

/* Subtítulo */
.hero-subtitle {
  font-size: 18px;
  font-weight: 400;
  color: #000;
  text-shadow: 1px 1px 2px rgba(0,0,0,0.3);
}

/* =========================
   HERO – AJUSTES MOBILE
========================= */

@media (max-width: 768px) {

  /* 1. "O MELHOR DE" */
  .slider-text h1 {
    font-size: 18px !important;
    letter-spacing: 2px !important;
  }

  /* 2. "Noronha Local" – Satisfy */
  .slider-text h1 span {
    font-size: 48px !important;   /* <<< aqui resolve o problema */
    background-size: 100% 18% !important;
    padding-bottom: 12px !important;
    margin-top: 0 !important;
  }

  /* 3. Texto descritivo */
  .slider-text p {
    font-size: 16px !important;
    margin-top: 17px !important;
  }
}

/* Base da navbar */
.ftco-navbar-light {
  position: absolute;
  left: 0;
  right: 0;
  z-index: 999; /* mais alto que 3 para garantir visibilidade */
  transition: background 0.3s ease;
}

/* Estado NORMAL (desktop e mobile) */
.ftco-navbar-light:not(.scrolled) {
  background: #9FBCC7!important; /* transparente no topo */
  top: 0 !important;                  /* cola no topo */
}

/* Estado SCROLLED (desktop e mobile) */
.ftco-navbar-light.scrolled {
  background: #000 !important;     /* cor ao rolar */
  top: 0 !important;
}




.navbar {
  margin-top: 0 !important; /* remove qualquer margem extra */
}
body {
  padding-top: 0 !important; /* garante que não há espaçamento */
}

.hero-wrap,
.ftco-vh-100,
.ftco-vh-75 {
  display: flex;
  align-items: center;
}

/* ===============================
   HERO / BANNER – FINAL ÚNICO
   =============================== */

.hero-wrap {
  /* IMAGEM */
  background-image: url('../images/banner-home.jpg'); /* ajuste o caminho se necessário */
  background-position: center center;
  background-size: cover;
  background-repeat: no-repeat;

  /* ALTURA */
  min-height: 95vh;          /* DESKTOP – AQUI você controla */
  height: auto;

  /* LAYOUT */
  display: flex;
  align-items: center;
  position: relative;
  width: 100%;
}

/* OVERLAY – BANNER HOME */
.hero-wrap .overlay {
  position: absolute;
  inset: 0;
  background: rgba(0, 0, 0, 0.35);
}


/* HERO – MOBILE (FTCO OVERRIDE) */
@media (max-width: 768px) {
  .hero-wrap {
    min-height: 90vh !important;
    height: auto !important;
    display: flex !important;
    align-items: center !important;
    padding: 0 !important;
    margin-top: 0 !important;
  }
}

/* HERO – FINAL */
.hero-wrap {
  background-image: url('../images/home/banner-home.jpg') !important;
  background-position: center center !important;
  background-size: cover !important;
  background-repeat: no-repeat !important;

  min-height: 95vh;
  display: flex;
  align-items: center;
  position: relative;
}

.hero-wrap.hero-passeios {
  background-image: url('../images/passeios/banner-home-passeios1.webp') !important;
  background-position: center center !important;
  background-size: cover !important;
  background-repeat: no-repeat !important;
  height: 600px !important;      /* altura fixa só para passeios */
  min-height: 600px !important;  /* neutraliza min-height global */
  display: flex;
  align-items: center;
  justify-content: center;
  position: relative;
}


@media (max-width: 991.98px) {
  .ftco-navbar-light:not(.scrolled) {
    background: #9FBCC7 !important; /* cor no topo no mobile */
  }

  .ftco-navbar-light.scrolled {
    background: #ffffff !important;     /* cor ao rolar no mobile */
  }
}

/* Espaçamento entre os cards */
.nl-services .row {
  gap: 30px;
}

/* Ajuste de largura para compensar o gap */
.nl-services .col-md-3 {
  flex: 0 0 calc(25% - 30px);
  max-width: calc(25% - 30px);
}

/* Mobile */
@media (max-width: 768px) {
  .nl-services .col-md-3 {
    flex: 0 0 100%;
    max-width: 100%;
  }

  .nl-services .row {
    gap: 20px;
  }
}

.nl-services .services.d-block {
  position: relative;
  overflow: hidden;
}

.nl-services .services.d-block::before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 3px;
  background: linear-gradient(
    90deg,
    var(--nl-yellow),
    var(--nl-blue)
  );
}

.nl-services .services.d-block {
  background: #f9fafb; /* branco suave */
}

.nl-services .services .heading {
  font-size: 16px;   /* <<< ALTERA AQUI */
  line-height: 1.3;
}

.nl-services .media-body p {
  font-size: 15px;   /* <<< ALTERA AQUI */
  line-height: 1.6;
}

/* ===== CTA do menu mobile – ajuste FTCO ===== */
@media (max-width: 991px) {

  /* Container do menu */
  .ftco-navbar-light .navbar-nav {
    align-items: center;
  }

  /* Botão CTA */
  .ftco-navbar-light .navbar-nav .cta {
    width: auto !important;
    display: inline-block;
    margin: 10px auto;
  }

  .ftco-navbar-light .navbar-nav .cta a {
    width: auto !important;
    padding: 10px 18px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    font-size: 14px;
    border-radius: 6px;
    white-space: nowrap;
  }
}

.hero-wrap.hero-passeios {
  height: 700px !important;             /* altura fixa só para passeios */
  min-height: 700px !important;         /* neutraliza min-height global */
  background-size: cover;
  background-position: center;
  display: flex;
  align-items: center;
  justify-content: center;
}

.hero-wrap.hero-passeios h1 {
  font-size: px !important;
  font-weight: 600 !important;
  color: #ffffff !important;
  line-height: 1.1 !important;
  margin-bottom: 15px !important;
  font-family: 'Poppins', sans-serif !important;
}

.hero-wrap.hero-passeios h1 span {
  font-family: 'Satisfy', cursive !important;
  color: #FDE02F !important;
  font-size: 55px !important;
  display: inline-block !important;
  margin-top: 10px !important;
}

/* ===============================
   OVERRIDE – HERO PASSEIOS
=============================== */

.hero-wrap.hero-passeios .slider-text h1 {
  font-size: 24px !important;
  font-weight: 600;
  line-height: 1.45 !important;
  text-transform: none;
}

.hero-wrap.hero-passeios .slider-text h1 span {
  font-size: 60px;
}

/* ===============================
   OVERRIDE – HERO HOME
=============================== */

.hero-wrap:not(.hero-passeios) .slider-text h1 {
  font-size: 30px !important;
  text-transform: uppercase;
}

.hero-wrap:not(.hero-passeios) .slider-text h1 span {
  font-size: 100px;
}



.hero-wrap.hero-passeios p {
  font-size: 18px !important;
  color: #f8f9fa !important;
  max-width: 400px !important;
  line-height: 1.4 !important;
  margin-bottom: 30px !important;
  font-family: 'Poppins', sans-serif !important;
  text-shadow: 1px 1px 5px rgba(0,0,0,0.5) !important;
}

/* SHAPE – BANNER PASSEIOS */
.hero-wrap.hero-passeios .slider-text h1 span {
  background-image: url('../images/hero-_ineShape1.png') !important;
  background-repeat: no-repeat !important;
  background-position: bottom center !important;
  background-size: 140% 35% !important; /* MAIOR E VISÍVEL */
  padding-bottom: 22px !important;
  text-transform: none !important;
}


@media (max-width: 767.98px) {
  .hero-wrap.hero-passeios h1 { font-size: 20px !important; }
  .hero-wrap.hero-passeios h1 span { font-size: 40px !important; }  /* Fonte cursiva no mobile */
  .hero-wrap.hero-passeios p { font-size: 18px !important; }
}

/* ===== Descer botão WhatsApp no menu mobile ===== */
@media (max-width: 991px) {

  .ftco-navbar-light .navbar-nav .nav-item.cta {
    margin-top: 45px;   /* desce o botão */
    margin-bottom: 10px;
  }

}

@media (max-width: 767px) {

  .hero-wrap .slider-text {
    align-items: flex-start !important;
    padding-top: 120px;
  }

}

@media (max-width: 767px) {

  .hero-wrap .hero-cta {
    transform: translateY(30px);
  }

}

@media (max-width: 767px) {

  /* Sobe o título */
  .hero-wrap h1 {
    margin-top: -40px;
  }

  /* Sobe o texto */
  .hero-wrap p {
    margin-top: -20px;
  }

}

@media (max-width: 767.98px) {
  .subheading {
    font-size: 26px !important;   /* aumenta só no mobile */
  }
}


/* ===== LOGO DO RODAPÉ NO MOBILE ===== */
@media (max-width: 767px) {

  .ftco-footer .footer-logo-wrapper {
    text-align: center;        /* centraliza */
    margin-bottom: 20px;       /* espaço abaixo */
  }

  .ftco-footer .footer-logo {
    max-width: 140px;          /* diminui o tamanho */
    width: 100%;
    height: auto;
    margin: 0 auto;            /* garante centralização */
    display: inline-block;
  }

}

@media (max-width: 768px) {
  .footer-logo {
    width: 220px !important;
  }
}



/* ===============================
  "NÃO REMOVER" CORREÇÃO DEFINITIVA VISIBILIDADE
   (FTCO + Waypoints + AOS)
================================ */

.ftco-section,
.ftco-animate,
.testimony-section,
.services-section,
.destination-slider,
.blog-entry,
.destination-card {
  opacity: 1 !important;
  visibility: visible !important;
  transform: none !important;
}


/* FTCO navbar básica */
.ftco_navbar {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  z-index: 9999;
}

/* Fundo transparente no topo */
.ftco_navbar:not(.scrolled) {
  background: transparent;
}

/* Fundo branco ao rolar */
.ftco_navbar.scrolled {
  background: #fff;
}

/* Botão voltar ao topo */
#backToTop {
  position: fixed;
  right: 20px;
  bottom: 30px;
  width: 44px;
  height: 44px;
  border-radius: 50%;
  border: none;
  background: #1a8af9;
  color: #ffffff;
  font-size: 22px;
  cursor: pointer;
  display: none;
  align-items: center;
  justify-content: center;
  z-index: 9999;
  }

#backToTop:hover {
  transform: translateY(-3px);
  background: #FDE02F;
  color: #333; /* Coloque aqui a cor que deseja para a seta no hover */
}

/* AJUSTE DEFINITIVO – ESPAÇO ENTRE AS DUAS LINHAS DO H1 */
.hero-wrap h1 {
  line-height: 1.35; /* aumenta o espaço entre "O melhor de" e "Noronha Local" */
}

.navbar .dropdown-toggle {
  cursor: pointer;
}

/* ===============================
   TÍTULO DA SEÇÃO – PASSEIOS BARCO
=============================== */

.ftco-section .subheading {
  font-size: 20px;
  font-weight: 700;
  letter-spacing: 2px;
  text-transform: uppercase;
  color: #1a8af9;
  display: block;
  margin-bottom: 8px;
}

.ftco-section h2 {
  font-size: 30px;
  font-weight: 700;
  color: #000000;
  line-height: 1.2;
  margin-bottom: 20px;
}

/* ===========================
   MOBILE – TÍTULOS PASSEIOS
   FORÇA AJUSTE
=========================== */
@media (max-width: 767px) {

  /* Subheading */
  .ftco-destination .subheading {
    font-size: 18px !important;
    line-height: 1.2 !important;
  }

  /* Título principal */
  .ftco-destination h2 {
    font-size: 26px !important;
    line-height: 1.3 !important;
  }

}


/* ===========================
   MOBILE – TITULO DO BARCO
=========================== */
@media (max-width: 767px) {

  .boat-card h3,
  .boat-card-fixed h3 {
    font-size: 20px;
    line-height: 1.3;
    font-weight: 600; /* normal (padrão) */
  }

}

.card img {
  max-height: 250px;
  object-fit: cover;
  width: 100%;
}

/* ===============================
   BOAT CARD – MOBILE
   MOSTRAR IMAGEM INTEIRA
   IMPORTANTE:
   Este touch-action é intencional.
   Sem ele, o Owl Carousel recalcula background-image no mobile
   e quebra a exibição das imagens dos cards.
   NÃO REMOVER.
   =============================== */

/* ============================================================
   ESTILO PARA DESKTOP (E GERAL)
   O que você colocar aqui aparece no Computador.
============================================================ */

/* 1. CARDS DE BARCO (Sessão que você queria maior e quadrada) */
.boat-img {
    width: 100% !important;
    height: 550px !important;       /* Altura maior no Desktop */
    border-radius: 20px !important;
    overflow: hidden !important;
    display: block !important;
    position: relative !important;
    z-index: 1 !important;
    margin-bottom: 15px !important;
    background-color: transparent !important;
}

.boat-img img {
    width: 100% !important;
    height: 100% !important;
    object-fit: cover !important;
    border-radius: 20px !important;
    display: block !important;
}

.boat-card-fixed {
    padding: 10px !important;
}

.boat-card-fixed h3.h4 {
    font-size: 22px;
}


  /* Container do Card do Blog */
  .noronha-blog-card {
    background: #fff;
    border-radius: 20px;
    overflow: hidden;
    box-shadow: 0 10px 30px rgba(0,0,0,0.08);
    transition: all 0.3s ease;
    border: 1px solid #f0f0f0;
    margin-bottom: 30px;
    display: flex;
    flex-direction: column;
    height: auto;
  }

  .noronha-blog-card:hover {
    transform: translateY(-10px);
    box-shadow: 0 15px 40px rgba(0,0,0,0.12);
  }

  /* RESOLUÇÃO DA FOTO ESTOURADA */
  .noronha-blog-card .block-20 {
    height: 220px;
    overflow: hidden;
    display: block;
    position: relative;
  }

  .noronha-blog-card .block-20 img {
    width: 100%;
    height: 100%;
    object-fit: cover; /* Faz a foto preencher sem esticar */
    transition: transform 0.5s ease;
    border-radius: 8px 8px 0 0 !important;
  }

  .noronha-blog-card:hover .block-20 img {
    transform: scale(1.1); /* Efeito de zoom no hover */
  }

  /* TEXTO E TAGS */
  .noronha-blog-card .text {
    padding: 25px !important;
    display: flex;
    flex-direction: column;
    flex-grow: 1;
  }

  .noronha-blog-card .tag {
    background: #e1f5fe; /* O cinza azulado clarinho que você pediu */
    color: #546E7A !important; /* Um tom de azul acinzentado mais escuro para o texto */
    padding: 5px 15px;
    border-radius: 50px;
    font-size: 11px;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 1px;
    align-self: flex-start;
}

  .noronha-blog-card .heading {
    min-height: 80px; /* Isso vai impedir que o texto empurre o botão pra baixo de forma desigual */
    font-size: 18px;
    margin-bottom: 20px;
  }

  /* Altera a cor e o tamanho do título do card */
.noronha-blog-card .heading a {
    color: #333333 !important; /* Cor cinza escuro para melhor leitura */
    font-size: 14px;            /* Tamanho da letra */
    font-weight: 400;
    font-family: 'Poppins', sans-serif; /* Sua fonte principal */
    text-decoration: none;      /* Remove o sublinhado de link */
}

/* Altera a cor quando o cliente passa o mouse */
.noronha-blog-card .heading a:hover {
    color: #1a8af9 !important;  /* Muda para o azul do site no hover */
}

  /* BOTÃO/LINK "VER MAIS" (Corrige o esticado no mobile) */
  .blog-date {
    display: inline-block; /* Impede que o botão estique no mobile */
    background-color: #F0F4F8; /* O cinza azulado clarinho */
    color: #1a8af9; /* Azul principal do seu site para o texto */
    padding: 8px 18px;
    border-radius: 50px; /* Deixa o botão oval */
    font-weight: 500;
    font-size: 12px;
    text-transform: uppercase;
    letter-spacing: 0.5px;
    transition: all 0.3s ease;
    width: fit-content; /* Garante que ele só ocupe o espaço do texto */
    border: 1px solid #DCE3E8; /* Uma bordinha sutil para dar profundidade */
}

.blog-date:hover {
    background-color: #1a8af9;
    color: #ffffff;
    cursor: pointer;
    text-decoration: none;
}

  /* AJUSTE MOBILE */
  @media (max-width: 768px) {
    .noronha-blog-card .block-20 {
      height: 200px;
    }
    .noronha-blog-card .heading {
      min-height: auto; /* No mobile pode ser fluido */
    }
  }

/* 3. DESTINATION CARDS (Outra sessão de cards) */
.destination-card {
    background: #fff;
    border-radius: 20px; /* Arredondado também */
    overflow: hidden;
    height: 100%;
    display: flex;
    flex-direction: column;
}


/* 4. TÍTULOS GERAIS */
.ftco-section h2 {
    font-size: 26px;
    font-weight: 700;
    color: #12304e;
    line-height: 1.2;
    margin-bottom: 20px;
}

/* VERSÃO CORRIGIDA E MAIS LEVE */
@media (max-width: 991px) {
  .destination-slider,
  .carousel-testimony,
  .boat-slider {
    /* Permite rolagem vertical (pan-y) e o zoom de pinça (pinch-zoom) */
    touch-action: pan-y pinch-zoom !important;
  }

  /* Garante que a imagem não "agarre" o dedo do usuário */
  .owl-item img {
    pointer-events: none; /* Isso impede que o navegador tente "arrastar" a imagem como arquivo, liberando a rolagem */
  }
}

/* ============================================================
   AJUSTES EXCLUSIVOS PARA MOBILE
   O computador ignora o que está aqui dentro.
============================================================ */
@media (max-width: 768px) {

    /* Ajusta a altura da imagem no celular para não ficar gigante */
    .boat-img {
        height: 250px !important; 
    }

    .destination-img {
        height: 220px;
    }

    /* Ajuste dos títulos no Mobile */
    .ftco-section .col-md-8.text-center .subheading {
        font-size: 16px !important;
    }

    .ftco-section .col-md-8.text-center h2 {
        font-size: 22px !important;
    }

    /* Espaçamento Seção Sobre Nós */
    #sobre-nos .col-md-5 {
        margin-bottom: 60px;
    }

    #sobre-nos .col-md-1 {
        display: none;
    }

  }

  


/* PERMITE ROLAR A PÁGINA SOBRE OS SLIDERS NO MOBILE */
@media (max-width: 991px) {

  .destination-slider,
  .destination-slider .owl-stage,
  .destination-slider .owl-item,

  .carousel-testimony,
  .carousel-testimony .owl-stage,
  .carousel-testimony .owl-item,

  .boat-slider,
  .boat-slider .owl-stage,
  .boat-slider .owl-item,

  /* ⬇️ CARROSSEL TRILHAS */
  .trilhas-carousel,
  .trilhas-carousel .owl-stage,
  .trilhas-carousel .owl-item,

  /* ⬇️ CARROSSEL PREMIUM */
  .carrossel-premium__owl,
  .carrossel-premium__owl .owl-stage,
  .carrossel-premium__owl .owl-item {
    touch-action: pan-y !important;
  }

}



/* ===========================
   PREMIUM SLIDER (HOME)
   =========================== */

.boat-slider-premium {
  display: flex;
  gap: 20px;
  overflow: hidden;
  transition: transform 0.3s ease;
  position: relative;
}

.boat-card-premium {
  flex: 0 0 100%;   /* no mobile ocupa 100% */
  max-width: 300px; /* delicado, não enorme */
  margin: 0 auto;
  background: #fff;
  border-radius: 15px;
  padding: 15px;
  box-shadow: 0 6px 20px rgba(0,0,0,0.05);
  border: 1px solid #eef2f6;
  transition: transform 0.3s ease;
}

.boat-card-premium:hover {
  transform: translateY(-5px);
}

.boat-card-premium .boat-img {
  width: 100%;
  height: 160px;
  overflow: hidden;
  border-radius: 8px;
  margin-bottom: 12px;
  background: #f0f0f0;
}

.boat-card-premium .boat-img img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

.boat-card-premium h3 {
  font-size: 16px;
  font-weight: 700;
  margin-bottom: 10px;
  color: #000;
}

@media (min-width: 768px) {
  .boat-card-premium {
    flex: 1;        /* no desktop ocupa espaço proporcional */
    max-width: none;
  }
}

/* ===========================
   CARROSSEL PREMIUM
=========================== */
.carrossel-premium {
  background: #f8f9fa;
  padding: 70px 0;
}

.carrossel-premium__container {
  max-width: 1400px;
  margin: 0 auto;
  padding: 0 20px;
}

/* Header */
.carrossel-premium__header {
  text-align: center;
  margin-bottom: 40px;
}

/* O texto cursivo (subtítulo) */
.carrossel-premium__subheading {
  font-family: 'Poppins', sans-serif;
  font-size: 18px;
  font-weight: 600;
  letter-spacing: 1px;
  text-transform: uppercase;
  color: #1a8af9;
  margin-bottom: 12px;
}


/* O título principal */
.carrossel-premium__title {
    font-size: 28px !important; /* Voltei para 32px para manter o padrão desktop */
    font-weight: 700 !important;
    color: #000000 !important;
    line-height: 1.2 !important;
    margin-bottom: 20px !important; /* Distância para a linha amarela */
}

/* A linha amarela */
.carrossel-premium__divider {
    width: 60px !important;
    height: 3px !important;
    background: #FDE02F !important;
    margin: 0 auto !important;
}

@media (max-width: 767px) {
  .carrossel-premium__subheading {
  font-size: 18px !important;
  line-height: 1.2 !important;
  font-family: 'Poppins', sans-serif;
  display: block !important;
  color: #1a8af9 !important; /* Cor azul padronizada */
    }
}

/* Card */
.carrossel-premium__card {
  background: #fff;
  border-radius: 18px;
  padding: 20px;
  box-shadow: 0 10px 30px rgba(0,0,0,0.05);
  border: 1px solid #eef2f6;
  height: 100%;
  display: flex;
  flex-direction: column;
}

.carrossel-premium__img {
  height: 220px;
  border-radius: 14px;
  overflow: hidden;
  margin-bottom: 15px;
}

.carrossel-premium__img img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

/* Preço + estrelas */
.carrossel-premium__meta {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: 12px;
}

.carrossel-premium__price {
  font-weight: 700;
  color: #1a8af9;
}

.carrossel-premium__stars {
  color: #f1c40f;
  font-size: 12px;
}

/* Summary */
.carrossel-premium__card summary {
  color: #1a8af9;
  font-weight: 700;
  cursor: pointer;
  font-size: 13px;
  padding: 8px 0;
  border-top: 1px dashed #eee;
}

/* Botão WhatsApp */
.carrossel-premium__card button {
  margin-top: auto;
  background: #25d366;
  color: #fff;
  border: none;
  border-radius: 10px;
  padding: 12px;
  font-weight: 700;
}

/* Navegação mobile */
.carrossel-premium__nav {
  display: none;
  text-align: center;
  margin-top: 15px;
}

.carrossel-premium__nav button {
  border-radius: 50%;
  width: 44px;
  height: 44px;
  margin: 0 8px;
}

/* Mobile */
@media (max-width: 768px) {
  .carrossel-premium__img {
    height: 260px;
  }

  .carrossel-premium__nav {
    display: block;
  }
}

/* SETAS LATERAIS – CARROSSEL PREMIUM */
.carrossel-premium .owl-nav {
  position: absolute;
  top: 50%;
  width: 100%;
  transform: translateY(-50%);
  pointer-events: none; /* permite swipe */
}

/* 1. ESCONDE O SINAL ESTRANHO (O SPAN DO OWL) */
.carrossel-premium .owl-nav button span {
display: none !important;
}

.carrossel-premium .owl-nav button {
  position: absolute;
  top: 0;
  pointer-events: all;
  width: 44px;
  height: 44px;
  border-radius: 50%;
  background: #fff !important;
  box-shadow: 0 8px 20px rgba(0,0,0,0.15);
  font-size: 0;
}

.carrossel-premium .owl-nav button.owl-prev {
  left: -22px;
}

.carrossel-premium .owl-nav button.owl-next {
  right: -22px;
}

/* ÍCONES DAS SETAS */
.carrossel-premium .owl-nav button::before {
  content: '';
  display: block;
  width: 10px;
  height: 10px;
  border-top: 2px solid #1a8af9;
  border-right: 2px solid #1a8af9;
  position: absolute;
  top: 50%;
  left: 50%;
}

.carrossel-premium .owl-nav button.owl-prev::before {
  transform: translate(-40%, -50%) rotate(-135deg);
}

.carrossel-premium .owl-nav button.owl-next::before {
  transform: translate(-60%, -50%) rotate(45deg);
}

/* MOBILE – aproxima do card */
@media (max-width: 768px) {
  .carrossel-premium .owl-nav button.owl-prev {
    left: -12px !important;
  }

  .carrossel-premium .owl-nav button.owl-next {
   right: -8px !important; /* Garante que não saia da borda do celular */
  }
}

/* SETAS MAIS PARA DENTRO (INVADINDO A IMAGEM) */
.carrossel-premium .owl-nav .owl-prev {
  left: 5px !important; /* Garante que não saia da borda do celular */
}

.carrossel-premium .owl-nav .owl-next {
  right: 8px;
}

/* SETAS – CINZA AZULADO + PRETO */
.carrossel-premium .owl-nav button {
  background: #e6edf2 !important; /* cinza azulado */
}

.carrossel-premium .owl-nav button::before {
  border-top: 2px solid #000;
  border-right: 2px solid #000;
}

/* 2. RESOLVE A FOLGA NO MOBILE (TRAVA O CARROSSEL) */
.carrossel-premium {
  overflow: hidden !important; /* Impede que as setas negativas estiquem a tela lateralmente */
  width: 100% !important;
  position: relative;
}

/* Texto MENU ao lado do hamburguer */
.navbar-toggler {
  display: flex;
  align-items: center;
  gap: 8px;
}

.navbar-toggler::after {
  content: 'Menu';
  font-size: 14px;
  font-weight: 600;
  color: #000 !important;
}

/* Cor do ícone hamburguer */
.navbar-toggler i.fa-bars {
  color: #000; /* azul do site */
  font-size: 22px;
}

/* CTA muda cor SOMENTE quando menu mobile está aberto */
@media (max-width: 991px) {

  .navbar-toggler[aria-expanded="true"] ~ .hero-wrap .btn,
  .navbar-toggler[aria-expanded="true"] ~ .container .btn,
  body.menu-open .btn {
    background-color: #fff !important; /* azul */
    color: #0C2B36 !important;
    border-color: #0C2B36 !important;
  }

}

/* TRILHAS CARDS */
.trilhas-section {
  padding: 60px 0;
}

.trilha-card {
    background: #fff;
    border-radius: 18px;
    overflow: hidden;
    box-shadow: 0 10px 25px rgba(0,0,0,.08);
    width: 100%; /* Deixa o carrossel decidir o tamanho */
    margin: 0;    /* Remove o margin auto que causa buracos */
}

/* Para quando você usar a tag <img> (como nos primeiros cards) */
.trilha-card img {
  width: 100%;
  height: 220px !important;
  object-fit: cover;
  display: block;
}

/* Para quando você usar a div com background-image (como no 4º card) */
.trilha-card .img {
  width: 100%;
  height: 220px !important; /* Mesma altura para manter o padrão */
  background-size: cover;
  background-position: center;
  display: block;
}

.trilha-card__body {
  padding: 20px;
}

.trilha-tag {
  font-size: 12px;
  color: #fb8c00;
  font-weight: 700;
}

.trilha-toggle {
  margin-top: 10px;
  background: none;
  border: none;
  color: #1a8af9;
  font-weight: 500;
}

.trilha-details {
  display: none;
  margin-top: 15px;
}

/* TRILHAS SETAS NO MEIO */
.trilhas-carousel .owl-nav button {
  position: absolute;
  top: 40%;
  background: #E1F5FE !important;
  width: 42px;
  height: 42px;
  border-radius: 50%;
  box-shadow: 0 4px 15px rgba(0,0,0,.2);
}
.trilhas-carousel .owl-prev { left: -50px; }
.trilhas-carousel .owl-next { right: -50px; }

@media (min-width: 992px) {
  .trilhas-carousel .owl-nav button {
    width: 48px;
    height: 48px;
    box-shadow: 0 6px 18px rgba(0,0,0,.25);
  }

  .trilhas-carousel .owl-nav button span {
    font-size: 22px;
    color: #1a8af9;
    font-weight: 700;
  }
}


/* ===========================
   TRILHAS ÍCONES DAS TRILHAS
=========================== */
.trilha-meta {
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
  align-items: center;
  margin: 8px 0 4px;
}

.trilha-meta span {
  display: flex;
  align-items: center;
  font-size: 13px;
  line-height: 1;
  color: #555;
}

.trilha-meta i {
  font-size: 14px;
  margin-right: 4px;
  color: #1a8af9;
}

/* ===========================
   TRILHAS ÍCONES / META DOS CARDS
=========================== */
.trilha-meta {
  display: flex;
  align-items: center;
  justify-content: center; /* centralizado no mobile */
  gap: 14px;
  margin: 10px 0 6px;
  flex-wrap: wrap;
}

.trilha-meta span {
  display: inline-flex;
  align-items: center;
  font-size: 13px;
  font-weight: 500;
  color: #555;
  line-height: 1;
  white-space: nowrap;
}

.trilha-meta i {
  font-size: 15px;
  margin-right: 5px;
  color: #1a8af9;
}

/* ===========================
   TRILHAS ÍCONES / META DOS CARDS
=========================== */

@media (min-width: 992px) {
  .trilha-meta {
    justify-content: flex-start;
  }
}

/* ===========================
   TRILHAS – DESCRIÇÃO DETALHADA
=========================== */
.trilha-desc {
  font-size: 14px;
  color: #555;
  line-height: 1.6;
  margin-bottom: 14px;
}

/* Caixa de dica */
.trilha-tip {
  display: flex;
  align-items: flex-start;
  gap: 8px;
  background: rgba(253, 224, 47, 0.15);
  border-left: 4px solid #FDE02F;
  padding: 12px 14px;
  border-radius: 10px;
  font-size: 13px;
  color: #444;
  margin-top: 12px;
}

.trilha-tip i {
  color: #F1B800;
  font-size: 16px;
  margin-top: 2px;
}

/* ===========================
   TÍTULO DA TRILHA (CARD)
=========================== */
.trilha-card__body h3 {
  font-size: 20px;
  font-weight: 600;
  color: #000000; /* azul escuro elegante */
  margin: 6px 0 8px;
  line-height: 1.2;
}

@media (max-width: 576px) {
  .trilha-card__body h3 {
    font-size: 16px;
  }
}

@media (max-width: 768px) {
  .trilha-card {
    width: 90%;         /* ocupa 90% da tela em vez de 100% */
    margin: 0 auto 15px;
  }
}

/* AJUSTE DAS SETAS PARA MOBILE (DENTRO DO CARD) */
@media (max-width: 767px) {
    .trilhas-carousel .owl-nav {
        display: flex !important;
        justify-content: space-between;
        position: absolute;
        top: 50%; /* Centraliza na altura */
        width: 100%;
        transform: translateY(-50%);
        pointer-events: none; /* Garante que a div não bloqueie cliques no card */
        z-index: 10;
    }

    .trilhas-carousel .owl-nav button.owl-prev,
    .trilhas-carousel .owl-nav button.owl-next {
        pointer-events: auto; /* Reativa o clique nos botões */
        background: #f8faff !important; /* Fundo branco semi-transparente */
        color: #1a8af9 !important; /* Cor da seta */
        width: 45px !important; /* TAMANHO DO CÍRCULO */
        height: 45px !important; /* TAMANHO DO CÍRCULO */
        font-size: 28px !important; /* TAMANHO DA SETA */
        border-radius: 50% !important;
        box-shadow: 0 2px 10px rgba(0,0,0,0.2) !important;
        display: flex !important;
        align-items: center;
        justify-content: center;
        margin: 0 10px !important; /* Espaçamento da borda da tela */
    }

    /* Posicionamento exato para não sumir */
    .trilhas-carousel .owl-nav button.owl-prev {
        left: -10px !important; /* 5px para dentro da tela */
    }

    .trilhas-carousel .owl-nav button.owl-next {
        right: -10px !important; /* 5px para dentro da tela */
    }
}

/* REMOVE O CONTORNO AO CLICAR */
.trilhas-carousel .owl-nav button.owl-prev:focus,
.trilhas-carousel .owl-nav button.owl-next:focus,
.trilhas-carousel .owl-nav button:active {
    outline: none !important;
    box-shadow: none !important; /* Remove sombras extras do navegador */
    border: 1px solid #E0E0E0 !important; /* Mantém apenas a sua borda original */
}

/* ===========================
   CTA WHATSAPP – TRILHAS
=========================== */
.cta-whatsapp {
  padding: 60px 0;
}

.cta-whatsapp__box {
  background: linear-gradient(135deg, #25D366, #128C7E);
  border-radius: 18px;
  padding: 36px 40px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 30px;
  color: #fff;
}

.cta-whatsapp__text h3 {
  font-size: 24px;
  font-weight: 700;
  margin-bottom: 8px;
}

.cta-whatsapp__text p {
  font-size: 15px;
  margin: 0;
  max-width: 420px;
  color: rgba(255, 255, 255, 0.95); /* branco mais vivo */
  font-weight: 400;
}


.cta-whatsapp__btn {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  background: #ffffff;
  color: #128C7E;
  font-weight: 700;
  padding: 14px 26px;
  border-radius: 50px;
  text-decoration: none;
  transition: all 0.25s ease;
  white-space: nowrap;
}

.cta-whatsapp__btn i {
  font-size: 20px;
}

.cta-whatsapp__btn:hover {
  background: #f1f1f1;
  transform: translateY(-1px);
  text-decoration: none;
}

@media (max-width: 768px) {

  .cta-whatsapp__box {
    flex-direction: column;
    text-align: center;
    padding: 30px 24px;
  }

  .cta-whatsapp__text h3 {
    font-size: 20px;
  }

  .cta-whatsapp__text p {
    max-width: 100%;
  }

}

/* --- BOTÃO HERO PADRÃO PARA TODO O SITE --- */
.hero-cta {
    display: inline-block !important;
    padding: 14px 24px !important;
    font-size: 16px !important;
    font-weight: 600 !important;
    line-height: 1.2 !important;
    margin-top: 50px !important; /* Distância no Desktop */
    background-color: #25d366 !important;
    color: #fff !important;
    border-radius: 40px !important;
    text-transform: uppercase !important;
    letter-spacing: 0.5px !important;
    box-shadow: 0 10px 25px rgba(0, 0, 0, 0.25) !important; 
    transition: all 0.25s ease !important;
    text-decoration: none !important;
    text-align: center !important;
}

.hero-cta:hover {
    transform: translateY(-2px) !important;
    box-shadow: 0 12px 30px rgba(0, 0, 0, 0.3) !important;
    background-color: #1eb959 !important;
    color: #fff !important;
}

/* --- PADRÃO GLOBAL DE TÍTULOS (HOME, PASSEIOS, TRILHAS) --- */

/* O texto cursivo azul (ex: Explore o Paraíso) */
.subheading {
    font-family: 'Poppins', sans-serif;
    font-size: 18px !important; /* */
    font-weight: 600 !important; 
    color: #1a8af9 !important;  /* */
    display: block !important;
    text-transform: none !important;
    margin-bottom: 5px !important;
}

/* O título principal (ex: Escolha sua embarcação) */
.heading-section h2 {
    font-size: 26px !important; /* */
    font-weight: 600 !important; /* */
    color: #000000 !important;
    text-transform: none !important;
    margin-bottom: 10px !important;
}

/* A linha amarela centralizada */
.line-custom {
    width: 60px;
    height: 3px;
    background: #fde02f;
    margin: 0 auto 20px;
}

/* --- AJUSTE NAVEGAÇÃO DE BARCOS --- */
.boat-nav-top {
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    gap: 20px !important;
    margin-top: 10px !important;
}

.boat-nav-top button {
    background: none !important;
    border: 1px solid #ddd !important;
    border-radius: 50% !important;
    width: 40px !important;
    height: 40px !important;
    cursor: pointer !important;
    transition: all 0.3s ease !important;
}

.boat-nav-top button:hover {
    background: #1a8af9 !important;
    color: #fff !important;
    border-color: #1a8af9 !important;
}

#boat-counter {
    font-weight: 600 !important;
    color: #000000 !important;
    font-size: 14px !important;
}

/* Neutraliza comportamento antigo do Owl */
.owl-theme .owl-nav [class*=owl-] {
  position: static;
}

/* Ajuste equilibrado para não subir demais */
#blog.ftco-section {
    padding-top: 40px !important;    /* Devolvemos um pouco de espaço no topo */
}

#blog .heading-section {
    margin-top: -60px !important;   /* Cortamos o valor pela metade (era -80px) */
}

/* Ajuste Mobile para evitar que suma o título */
@media (max-width: 767px) {
    #blog.ftco-section {
        padding-top: 20px !important;
    }
    #blog .heading-section {
        margin-top: -20px !important; 
    }
}


/* =======================================
===========BANNER TRILHA =================
==========================================*/

/* 1. ESTRUTURA DO BANNER (Fundo e Alinhamento) */
.trilhas-section-independente {
    position: relative !important;
    width: 100% !important;
    height: 600px !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    background-image: url('../images/trilhas/banner-home-trilha3.jpg') !important;
    background-size: cover !important;
    background-position: center center !important;
    background-repeat: no-repeat !important;
    margin-top: 0 !important;
    z-index: 1 !important;
    text-align: center !important;
}

/* 2. CAMADA ESCURA (Para o texto aparecer) */
.overlay-custom {
    position: absolute !important;
    top: 0; left: 0; right: 0; bottom: 0;
    background: rgba(0, 0, 0, 0.50) !important;
    z-index: 0 !important;
    padding-top: 50px !important; /* Valor que você definiu */
}

/* 3. OS TEXTOS DO BANNER (Unificados) */
.trilhas-section-independente .container {
    position: relative !important;
    z-index: 2 !important;
}

/* Texto Cursivo (Subheading) */
.trilhas-section-independente .subheading {
    font-family: 'Satisfy', cursive !important; /* Fonte cursiva */
    color: #FDE02F !important;
    font-size: 50px !important;
    font-weight: 500 !important;
    text-transform: none !important; /* Mantém natural, não tudo maiúsculo */
    display: block !important;
    margin-bottom: 5px !important;
}

/* Texto Trilha (H1) */
.trilhas-section-independente h1 {
    color: #ffffff !important;
    font-size: 50px !important;
    font-weight: 700 !important;
    text-transform: uppercase !important;
    margin-bottom: 15px !important;
}

/* Texto "p" Menor (Descrição) */
.trilhas-section-independente p {
    color: #ffffff !important;
    font-size: 18px !important;
    font-weight: 400 !important;
    max-width: 600px;
    margin: 0 auto 25px !important; /* Centraliza e dá espaço para o botão */
}

/* 4. AJUSTE MOBILE (Celular) */
@media (max-width: 767.98px) {
    .trilhas-section-independente {
        min-height: 450px !important;
    }
    .trilhas-section-independente .subheading {
        font-size: 30px !important; /* Fonte cursiva */
        font-weight: 500 !important;
    }
    .trilhas-section-independente h1 {  /* Texto Trilha (H1) */
        font-size: 24px !important;
        font-weight: 600 !important;
    }
    .trilhas-section-independente .container {
        padding-top: 160px !important; /* /* Empurra o bloco todo para baixo */
    }
    .trilhas-section-independente p {
        margin-bottom: 40px !important; /* Espaçamento menor no mobile */
    }
    
    .trilhas-section-independente p {
        font-size: 14px !important;
        font-weight: 400 !important;
    }
}

/* ===============================================
1. SEÇÃO DO WHATSAPP (A caixa que segura o botão) 
=================================================*/

/* BOTÃO WHATSAPP - ESTILO INDEPENDENTE */
.btn-whatsapp-trilhas-final {
    /* CORES E FORMATO (Igual ao original) */
    background-color: #f85959 !important;
    border: 1px solid #f85959 !important;
    color: #ffffff !important;
    border-radius: 30px !important;
    margin-top: 40px !important; /* Ajuste esse valor para o botão descer mais ou menos */
    
    /* TEXTO */
    font-weight: 700 !important;
    text-transform: uppercase !important;
    font-size: 16px !important;
    text-decoration: none !important;
    
    /* TAMANHO DESKTOP (Substituindo o px-4 py-3) */
    padding: 15px 35px !important;
    display: inline-block !important;
    transition: 0.3s !important;
}

/* HOVER (O efeito que você já tinha) */
.btn-whatsapp-trilhas-final:hover {
    background: transparent !important;
    color: #f85959 !important;
}

/* --- O DETALHE DO CELULAR --- */
@media (max-width: 767.98px) {
    .btn-whatsapp-trilhas-final {
        /* Aqui ele VAI diminuir porque não tem mais nada travando */
        padding: 15px 16px !important; 
        font-size: 13px !important;
        letter-spacing: 0px !important;
    }
}

/* ESTILO DAS SETAS DO CARROSSEL */
.trilhas-carousel .owl-nav {
    position: absolute;
    top: 50%;
    width: 100%;
    display: flex;
    justify-content: space-between;
    transform: translateY(-50%);
    pointer-events: none; /* Garante que o clique passe para o botão se necessário */
}

.trilhas-carousel .owl-nav button {
    pointer-events: all;
    background: #fff !important; /* Fundo branco para destacar */
    width: 45px;
    height: 45px;
    border-radius: 50%;
    box-shadow: 0px 4px 15px rgba(0,0,0,0.15);
    color: #000000 !important; /* Cor escura para o ícone */
    margin: 0 -20px; /* Faz a seta ficar um pouco para fora do card */
    transition: 0.3s;
}

.trilhas-carousel .owl-nav button:hover {
    background: #f85959 !important; /* Fica vermelho ao passar o mouse */
    color: #fff !important;
}

/* ===========================
   SETAS DO CARROSSEL (Geral)
=========================== */
.trilhas-carousel .owl-nav button.owl-prev,
.trilhas-carousel .owl-nav button.owl-next {
    position: absolute;
    top: 35%; /* Ajustado para alinhar com o meio da imagem */
    width: 45px !important;
    height: 45px !important;
    background: #fff !important;
    border-radius: 50% !important;
    box-shadow: 0 4px 12px rgba(0,0,0,0.2) !important;
    display: flex !important;
    align-items: center;
    justify-content: center;
    z-index: 10;
    transform: translateY(-50%);
}

/* Resolve o problema da seta minúscula */
.trilhas-carousel .owl-nav button span {
    font-size: 30px !important; 
    color: #1a8af9 !important;
    display: block;
    line-height: 1;
}

/* POSICIONAMENTO MOBILE */
@media (max-width: 991px) {
    .trilhas-carousel .owl-prev { left: -5px !important; }
    .trilhas-carousel .owl-next { right: -5px !important; }
}

/* POSICIONAMENTO DESKTOP (Fora dos cards) */
@media (min-width: 992px) {
    .trilhas-carousel .owl-prev { left: -60px !important; }
    .trilhas-carousel .owl-next { right: -60px !important; }
}

/* Ajuste interno do Card para o texto não quebrar */
.trilha-card .text {
    padding: 20px 15px !important; /* Diminuímos o padding lateral para o texto ganhar espaço */
    text-align: left;
}

.trilha-card h3 {
    font-size: 16px !important; /* Diminui um pouco a fonte no mobile se necessário */
    line-height: 1.3 !important;
    margin-bottom: 10px;
}

/* Garante que a lista de detalhes (ícones) fique em linha ou não quebre tanto */
.trilha-card .listing-details {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
    font-size: 13px !important;
}

/* ===============================
   HERO – ESTILO TRIPADVISOR
================================ */

.ta-hero {
  padding: 40px 0;
}

/* HERO PRINCIPAL */
.ta-hero-box {
  display: grid;
  grid-template-columns: 1.1fr 1fr;
  background: #1a8af9; /* cor oficial do banner */
  border-radius: 0;
  overflow: hidden;
  min-height: 30vh;   /* ocupa boa parte da tela */
  color: #fff;
  
}

@media (min-width: 769px) {
  .ta-hero-box {
    height: 65vh;          /* 👈 controla desktop */
    min-height: unset;
    max-height: 65vh;
  }
}


/* imagens */
.ta-hero-images {
  position: relative;
  background-size: cover;
  background-position: center;
  border-radius: 0;
  }

.ta-hero-images img {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  opacity: 0;
  transition: opacity 1s ease-in-out;
  border-radius: 0 !important;
}

.ta-hero-images img.active {
  opacity: 1;
  z-index: 2;
}

/* conteúdo */
.ta-hero-content {
  padding: 56px;
  display: flex;
  flex-direction: column;
  
}

.ta-hero-content h1 {
  font-size: 50px;
  font-weight: 800;
  line-height: 1.15;
  margin-bottom: 20px;
  margin-top: 40px;     /* DESCE o texto */
  text-align: center;
  
}

.ta-hero-content p {
  font-size: 24px;
  margin-top: 40px;     /* DESCE o texto */
  margin-bottom: 28px;
  text-align: center;
  color: #fff;
  font-weight: 400;
  
}


.ta-hero-btn {
  align-self: flex-start;
  background: #000;
  color: #fff;
  padding: 12px 24px;
  border-radius: 999px;
  font-weight: 600;
  text-decoration: none;
}

/* mobile */
@media (max-width: 768px) {

  .ta-hero-content h1 {
    font-size: 40px;
    text-align: center !important;
    font-weight: 800;
  }

  .ta-hero-content p {
    font-size: 16px;
    margin-top: 24px;
    margin-bottom: 28px;
  }

  .ta-hero-btn {
    margin-top: -10px !important;
  }

  .ta-image-card {
    border-radius: 0;
  }
}


/* REMOVE QUALQUER HOVER DO HERO */
.ta-hero-images img,
.ta-hero-images img:hover {
  pointer-events: none;
  transform: none !important;
  filter: none !important;
  opacity: inherit;
}

/* Ajuste por causa do header fixo */
.ta-hero {
  margin-top: 70px; /* altura do menu */
}

.ta-hero-btn {
  display: inline-block;
  margin-top: 10px !important;   /* desce o botão */
}

.ta-hero-btn {
  margin-top: 0;
  margin-left: auto;
  margin-right: auto;
}

.ta-hero-btn {
  display: inline-block;
  margin-top: 50px; /* desktop */
}

/* ==============================
   SERVICE PAGE – TRIPADVISOR STYLE
============================== */

.service-page h1 {
  font-size: 28px;
  margin-bottom: 8px;
}

.service-subtitle {
  margin-bottom: 24px;
  color: #555;
}

.ta-hero-images {
  position: relative;
  min-height: 380px;   /* desktop */
}

.ta-hero-images img {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  opacity: 0;
  transition: opacity .8s ease;
}

.ta-hero-images img.active {
  opacity: 1;
}

.ta-hero-video video,
.ta-hero-images img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}


/* GRID */
.service-grid {
  display: grid;
  grid-template-columns: 2.3fr 1fr;
  gap: 32px;
  margin-top: 48px;
}

.service-content h3 {
  margin-top: 30px;
}

/* SIDEBAR */
.service-sidebar {
  position: sticky;
  top: 120px;
  height: fit-content;
}

.sidebar-box {
  background: #fff;
  border-radius: 8px;
  padding: 24px;
  box-shadow: 0 8px 24px rgba(0,0,0,.06);
  margin-bottom: 24px;
}

.sidebar-btn {
  display: block;
  text-align: center;
  background: #25D366;
  color: #fff;
  padding: 14px;
  border-radius: 999px;
  font-weight: 600;
  text-decoration: none;
}

/* MOBILE */
@media (max-width: 768px) {
 
  .service-grid {
    grid-template-columns: 1fr;
  }

  .service-sidebar {
    position: static;
  }
}

.service-page {
  padding-top: 140px; /* altura da navbar */
}

@media (max-width: 768px) {
  .service-page {
    padding-top: 140px;
  }
}

/* =====BANNER PASSEIOS GALERIA ESTILO TRIPADVISOR ===== */

/* Container da Galeria no Desktop */
.ta-gallery {
  display: flex;
  gap: 10px;
  width: 100%;
  max-width: 1140px;
  height: 400px;
  margin: 20px auto;
  position: relative;
}

/* Área da Imagem Grande (66% da largura) */
.ta-gallery-main {
  flex: 2;
  overflow: hidden;
  border-radius: 8px;
}

/* 🔧 CORREÇÃO AQUI */
.ta-gallery-main img {
  width: 100%;
  height: 100%;              /* ocupa o container */
  object-fit: contain;       /* NÃO corta a imagem principal */
  transition: opacity 0.3s ease;
}

/* Área das Imagens Pequenas (33% da largura) */
.ta-gallery-side {
  flex: 1;
  display: flex;
  flex-direction: column;
  gap: 10px;
}

.ta-gallery-side img {
  width: 100%;
  height: calc(50% - 5px);
  object-fit: cover;         /* thumbs podem cortar */
  border-radius: 8px;
  cursor: pointer;
  transition: transform 0.2s ease, filter 0.2s ease;
}

.ta-gallery-side img:hover {
  filter: brightness(0.8);
}

/* MOBILE */
@media (max-width: 991px) {
  .ta-gallery {
    display: block !important;
    height: auto !important;
    padding: 0 10px;
  }

  .ta-gallery-main {
    width: 100%;
    height: 250px;
    border-radius: 8px !important;
    margin-bottom: 0;
  }

  .ta-gallery-side {
    display: none !important;
  }

  .ta-gallery-main img {
    height: 100%;
    object-fit: cover;       /* no mobile pode cortar */
    border-radius: 8px !important;
  }
}

/*========================
=====SIDEBAR MENU========*/

.service-grid {
  display: grid;
  grid-template-columns: 2fr 1fr;
  gap: 40px;
  margin-top: 40px;
}

.service-sidebar {
  position: sticky;
  top: 120px;
}

/* CONTAINER DO MENU */
.service-menu {
  background: #ffffff;
  border-radius: 16px;
  padding: 10px 0;
  box-shadow: 0 10px 30px rgba(0,0,0,0.05);
  border: 1px solid #eeeeee;
  overflow: hidden;
}

.service-menu ul {
  list-style: none;
  margin: 0;
  padding: 0;
}

/* CADA ITEM DA LISTA */
.service-menu li {
  position: relative;
  border-bottom: 1px solid #eeeeee; /* Divisor sutil */
}

.service-menu li:last-child {
  border-bottom: none;
}

/* LINKS */
.service-menu a {
  display: flex;
  align-items: center;
  padding: 16px 24px;
  font-weight: 600;
  color: #000;
  text-decoration: none;
  font-size: 14px;
  transition: all 0.3s ease;
}

/* ÍCONE DE SETA (Invisível por padrão) */
.service-menu a::after {
  content: '\f105'; /* Ícone de seta do FontAwesome */
  font-family: 'Font Awesome 5 Free';
  font-weight: 900;
  margin-left: auto;
  opacity: 0;
  transition: all 0.3s ease;
  transform: translateX(-10px);
}

/* HOVER (Passar o mouse) */
.service-menu a:hover {
  background: #fcfdfd;
  color: #1a8af9;
  padding-left: 30px; /* Efeito de deslize */
}

.service-menu a:hover::after {
  opacity: 1;
  transform: translateX(0);
}

/* ITEM ATIVO (Onde o cliente está) */
.service-menu a.active {
  background: linear-gradient(to right, rgba(0, 131, 184, 0.05), rgba(0, 131, 184, 0.01));
  color: #1a8af9;
  border-left: 4px solid #1a8af9; /* A barrinha aqui volta, mas só no ativo */
}

.service-menu a.active::after {
  opacity: 1;
  transform: translateX(0);
  color: #1a8af9;
}


/* ==================================================
   DESCRIÇÃO DO PASSEIO – MODELO TRIPADVISOR
   ================================================== */

.service-section {
  margin-bottom: 20px;
  padding-top: 50px; /* 🔑 distancia os mini cards da descrição */
}


.service-eyebrow {
  display: inline-block;
  font-size: 28px;
  font-weight: 400;
  text-transform: none !important;
  color: #1a8af9;
  margin-bottom: 20px;
  margin-top: 0;
  line-height: 1.19; 
}

.service-section h2 {
  font-size: 26px;
  margin-bottom: 16px;
}

.service-section h3 {
  font-size: 22px;
  margin-bottom: 16px;
  color: #1a8af9;
}

.service-intro {
  max-width: 650px;
  color: #555;
  line-height: 1.6;
}

.service-list {
  list-style: none;
  padding: 0;
}

.service-list li {
  display: flex;
  gap: 10px;
  margin-bottom: 12px;
  line-height: 1.5;
}

.service-list .icon {
  font-size: 18px;
}

.service-warning {
  background: #fff4e5;
  padding: 24px;
  border-radius: 10px;
}

.service-alerts {
  list-style: none;
  padding: 0;
  margin: 0;
}

.service-alerts li {
  margin-bottom: 10px;
  font-size: 14px;
  color: #000;
}

/* ===============================
   ROTEIRO – DESCRIÇÃO DO PASSEIO
================================ */

.roteiro-list {
  display: flex;
  flex-direction: column;
  gap: 18px;
}

.roteiro-item {
  display: flex;
  align-items: flex-start;
  gap: 14px;
}

.roteiro-icon {
  font-size: 22px;
  line-height: 1;
  flex-shrink: 0;
  margin-top: 2px;
}

.roteiro-text strong {
  font-size: 15px;
  display: block;
  font-weight: 600;
  color: #000;
  margin-bottom: 4px;
}

.roteiro-text p {
  margin: 0;
  font-size: 15px;
  line-height: 1.4;
  color: #444;
  font-weight: 400;
}

/* ===============================
   HERO HOME – MOBILE (FINAL LIMPO)
================================ */
@media (max-width: 768px) {

  /* HERO */
  .ta-hero {
    margin-left: calc(-1 * var(--container-padding, 16px));
    margin-right: calc(-1 * var(--container-padding, 16px));
    margin-left: -15px;
    margin-right: -15px;
    margin-top: 0 !important;
    padding-top: 40px !important;
  }

  /* CAIXA PRINCIPAL */
  .ta-hero-box {
    display: block;
    width: 100%;
    max-width: 100%;
    margin-left: calc(-50vw + 50%);
    margin-right: calc(-50vw + 50%);
    height: auto;          /* 🔥 NÃO trava altura */
    border-radius: 0 !important;
    overflow: hidden;
  }

  /* IMAGEM / VÍDEO */
  .ta-hero-images {
    height: 40vh;          /* 👈 CONTROLE REAL AQUI */
    min-height: 280px;     /* segurança */
    max-height: 520px;     /* não exagera */
    overflow: hidden;
    width: 100%;
    max-width: 100%;
    
  }

  .ta-hero-images img,
  .ta-hero-images video {
    width: 100%;
    height: 100%;
    object-fit: cover;
  }

  /* CONTEÚDO */
  .ta-hero-content {
    padding: 28px 20px;
    text-align: center;
  }

  .ta-hero-content h1 {
    font-size: 30px;
    line-height: 1.2;
    margin-bottom: 30px;
    margin-top: 5px;
  }

  .ta-hero-content p {
    font-size: 18px;
    line-height: 1.65;    /* 🔥 abre o texto */
    max-width: 100%;
    margin-top: 5px;
    margin-bottom: 15px;
  }

  /* BOTÃO */
  .ta-hero-btn {
    margin-top: 40px;
    margin-bottom: 20px;
    
  }

  /* remove qualquer radius do hero */
 .ta-hero-box,
  .ta-hero-images,
  .ta-hero-video,
  .ta-hero-video::after {
    border-radius: 0 !important;
  }
}



/* ===== MOBILE MENU ESTILO DESKTOP ===== */
@media (max-width: 991px) {
  /* Forçamos o menu a ser um bloco fixo que a gente controla */
  .navbar-collapse {
    position: absolute !important;
    top: 100%;
    left: 0;
    right: 0;
    background: #fff;
    border-radius: 16px;
    z-index: 999;
    box-shadow: 0 8px 24px rgba(0,0,0,0.15);
    
    /* Estado Fechado: Invisível e deslocado para baixo */
    opacity: 0;
    visibility: hidden;
    transform: translateY(15px);
    transition: all 0.3s ease-in-out;
    
    display: block !important; /* Impede o Bootstrap de dar display:none */
    height: auto !important;   /* Impede o Bootstrap de achatar a altura */
  }

  /* Estado Aberto: Bootstrap adiciona a classe .show */
  .navbar-collapse.show {
    opacity: 1;
    visibility: visible;
    transform: translateY(0);
  }

  /* Anulamos a classe de transição do Bootstrap para não dar conflito */
  .collapsing {
    display: block !important;
    height: auto !important;
    transition: none !important;
  }
}

@media (max-width: 767px) {
  .service-eyebrow {
  display: block;
  margin-bottom: 16px;
  margin-top: 5px; /* 🔑 controla a distância dos mini cards */
  display: inline-block; /* garante que o margin funcione */
  font-size: 26px;
  font-weight: 400;
  }

  #visao-geral h2 {
    margin-top: 0;
  }
}


@media (max-width: 767px) {
  #visao-geral {
    overflow: hidden;
  }
}

@media (max-width: 767px) {
  .service-page > section.container:first-of-type {
    margin-bottom: 40px;
    padding-bottom: 80px;
  }
}

.ta-gallery-main img,
.ta-gallery-side img {
  filter: brightness(0.92);
  transition: filter 0.35s ease;
}

@media (min-width: 992px) {
  .ta-gallery-main:hover img,
  .ta-gallery-side:hover img {
    filter: brightness(1);
  }
}

/* === ALTERAÇÃO | border-radius 12px nos cards de destino === */
.destination {
  border-radius: 8px;
  overflow: hidden; /* ESSENCIAL para recortar a imagem */
}

/* === ALTERAÇÃO | estrelas azuis === */
.destination .rate i {
  color: #0066FF;
}

/* === ALTERAÇÃO | botão verde === */
.btn-verde {
  background: #28a745;
  color: #fff;
  padding: 6px 10px;
  border-radius: 4px;
  font-size: 12px;
}

.btn-verde:hover {
  background: #218838;
  color: #fff;
}

#experiencias .col-sm,
#experiencias .col-md-6,
#experiencias .col-lg {
  padding-left: 10px;
  padding-right: 10px;
}

/* === AJUSTE | títulos dos cards em uma linha === */
.destination .text h3 {
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

@media (min-width: 992px) {
  .ta-hero .container {
    max-width: 1350px; /* ou 1240px */
  }
}

@media (min-width: 1400px) {
  .ta-hero .container {
    max-width: 1350px;
  }
}

/* ===============================
   MINI NAVEGAÇÃO PASSEIOS (MOBILE)
================================ */

/* trava overflow lateral global */
html, body {
  max-width: 100%;
  overflow-x: hidden;
}

/* wrapper geral */
.mobile-passeios-nav {
  position: relative;
  width: 100%;
  margin: 20px 0 28px;
  padding: 0 44px; /* espaço real das setas */
  overflow: hidden;
}

/* trilho horizontal */
.mobile-passeios-track {
  display: flex;
  gap: 12px;
  overflow-x: auto;
  scroll-behavior: smooth;
  -webkit-overflow-scrolling: touch;
}

/* esconde scrollbar */
.mobile-passeios-track::-webkit-scrollbar {
  display: none;
}

/* ===============================
   CARDS
   3 visíveis no mobile
================================ */

.mobile-passeio-card {
  flex: 0 0 calc((100% - 24px) / 3);
  text-align: center;
  text-decoration: none;
  color: #222;
}

/* imagem quadrada */
.mobile-passeio-card img {
  width: 100%;
  aspect-ratio: 1 / 1;
  object-fit: cover;
  border-radius: 8px;
  display: block;
  transition: transform 0.25s ease;
}

/* texto */
.mobile-passeio-card span {
  display: block;
  margin-top: 20px !important;
  font-size: 12px;
  font-weight: 500;
  line-height: 1.2;
}

/* ativo */
.mobile-passeio-card.active {
  box-shadow: 0 0 0 2px #1a8af9;
  border-radius: 10px;
}


/* ===============================
   SETAS (BOTÃO LIMPO E CORRETO)
================================ */

  .mp-arrow {
  all: unset;
  position: absolute;
  top: 60%;
  transform: translateY(-50%);
  width: 36px;
  height: 36px;
  border-radius: 50%;
  background: #f1f1f1;
  box-shadow: 0 2px 6px rgba(0,0,0,.18);
  display: flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  z-index: 5;
  pointer-events: auto;
  touch-action: manipulation;
}

/* ícone da seta */
.mp-arrow i {
  font-size: 18px !important; /* seta maior */
  color: #000;     /* seta preta */
  line-height: 1;
  pointer-events: none;
}

/* feedback ao clicar (sem deformar) */
.mp-arrow:active {
  transform: translateY(-50%) scale(0.94);
}

/* posições */
.mp-left {
  left: 2px;
}

.mp-right {
  right: 2px;
}

/* ===============================
   DESKTOP
================================ */

@media (max-width: 767px) {
  .mobile-passeios-nav {
    position: relative;
    width: 100%;

    /* volta a respeitar o container */
    margin-left: 0;
    margin-right: 0;

    /* padding igual ao conteúdo */
    padding-left: 15px;
    padding-right: 15px;

    overflow-x: hidden;
    overflow-y: visible; /* 🔑 ISSO RESOLVE */
  }
}

@media (max-width: 767px) {

  .mobile-passeios-track {
    padding-left: 10px !important;   /* 🔑 empurra o primeiro card pra dentro */
    padding-right: 10px;  /* mantém simetria */
  }
}

.mobile-passeios-track {
  scroll-padding-left: 30px;
  scroll-padding-right: 4px;
}

@media (max-width: 767px) {
  .mobile-passeio-card {
    margin: 0;
  }
}

.mobile-passeio-card {
  flex: 0 0 calc((100% - 24px) / 3);
}


/* remove qualquer contorno / destaque ativo */
.mobile-passeio-card.active,
.mobile-passeio-card.active img {
  outline: none !important;
  box-shadow: none !important;
}

/* =================================================
   PÁGINA INDIVIDUAL — ISOLAMENTO TOTAL
   ================================================= */
.service-single .mp-arrow,
.service-single .mobile-passeios-nav {
  display: none;
}


/* ============================
   DESKTOP — CARROSSEL COM SETAS
============================ */
@media (min-width: 992px) {

  .mobile-passeios-nav {
    position: relative;
    margin-bottom: 16px !important; /* 🔑 empurra a descrição pra baixo */
    width: 100%;
    padding: 0 44px;
    overflow: hidden;
  }

  .mobile-passeios-track {
    display: flex;              /* carrossel */
    gap: 20px;
    overflow-x: auto;           /* scroll real */
    scroll-behavior: smooth;
  }

  .mobile-passeio-card {
    flex: 0 0 calc((100% - 60px) / 4); /* 4 visíveis */
  }

  .mp-arrow {
    display: flex;              /* setas ativas */
    
  }
}

@media (max-width: 767px) {
  .mp-arrow {
    top: 60%;
  }
}


@media (max-width: 767px) {
  .service-list #visao-geral {
    padding-top: 20px; /* mantém o espaçamento da página PASSEIOS */
  }

  .service-single #visao-geral {
    padding-top: 0; /* sobe o conteúdo na página INDIVIDUAL */
  }
}


@media (max-width: 767px) {
  .service-section {
    padding-top: 20px; /* 🔑 distancia os mini cards da descrição */
  }
}

.mp-arrow i {
  font-size: 22px;
  font-weight: 700;
}

@media (max-width: 767.98px) {
  .ftco-section {
    padding: 3em 0 !important;
  }
}

/*===NÃO REMOVER DAQUI PRA CIMA 27-01-2026===/*

/* --- CONFIGURAÇÃO MOBILE (SOMENTE TELAS PEQUENAS) --- */
@media (max-width: 991.98px) {
    /* Overlay */
    .menu-overlay {
        position: fixed;
        top: 0; left: 0; width: 100%; height: 100%;
        background: rgba(0,0,0,0.5);
        z-index: 999998;
        display: none;
    }
    body.menu-open .menu-overlay { display: block; }

    /* Bloco Lateral Branco */
    #ftco-nav.collapse.show {
        display: flex !important;
        position: fixed !important;
        top: 0 !important;
        right: 0 !important;
        width: 340px !important;
        height: 100vh !important;
        background: #ffffff !important;
        z-index: 999999 !important;
        flex-direction: column !important;
        padding: 0 !important;
        margin: 0 !important;
        border-radius: 0 !important;
        box-shadow: -5px 0 15px rgba(0,0,0,0.1) !important;
        overflow-y: auto !important; /* Permite rolar se o menu for grande */
    }

    /* Nome Noronha Local */
    .mobile-menu-header {
        display: block !important;
        padding: 30px 20px 20px 25px !important;
        border-bottom: 1px solid #f0f0f0 !important;
        width: 100% !important;
    }
    .mobile-menu-header h2.heading-section {
        font-family: "Poppins", Arial, sans-serif !important;
        font-size: 22px !important;
        color: #000 !important;
        font-weight: 800 !important;
        margin: 0 !important;
        text-transform: none !important;
    }
    .mobile-menu-header h2.heading-section span {
        font-weight: 300 !important;
        padding-left: 4px;
    }

    /* Menus Próximos (Compactos) */
    #ftco-nav .navbar-nav {
        width: 100% !important;
        margin: 0 !important;
        padding: 0 !important;
    }
    #ftco-nav .nav-item {
        border-bottom: 1px solid #f8f8f8 !important;
        width: 100% !important;
    }
    #ftco-nav .nav-link {
        padding: 10px 16px !important;
        color: #333 !important;
        font-size: 15px !important;
        text-align: left !important;
        display: flex !important;
        justify-content: space-between;
        align-items: center;
    }

    /* --- AJUSTE DO SUBMENU (ESTILO ACORDEÃO) --- */
    #ftco-nav .dropdown-menu {
        position: static !important; /* Faz os itens de baixo descerem ao abrir */
        float: none !important;
        display: none !important; /* Escondido por padrão no mobile */
        background: #fafafa !important;
        border: none !important;
        padding: 0 !important;
        margin: 0 !important;
        box-shadow: none !important;
    }

    /* Abre o submenu quando o item pai for clicado */
    #ftco-nav .nav-item.dropdown.show .dropdown-menu {
        display: block !important;
    }

    .dropdown-item {
        padding: 12px 40px !important; /* Recuo para parecer sub-item */
        font-size: 14px !important;
        color: #666 !important;
        border-bottom: 1px solid #f0f0f0!important;
    }

    /* Botão fechar (X) */
    .navbar-toggler[aria-expanded="true"] i::before { content: "\f00d" !important; }
    .navbar-toggler {
        z-index: 1000000 !important;
        position: fixed !important;
        right: 15px; top: 22px;
        border: none !important;
        color: #000 !important;
    }
}

/* --- RESET ABSOLUTO PARA DESKTOP (PROTEÇÃO) --- */
@media (min-width: 992px) {
    .mobile-menu-header { display: none !important; }
    .menu-overlay { display: none !important; }

    #ftco-nav.collapse {
        display: flex !important;
        position: static !important;
        width: auto !important;
        height: auto !important;
        background: transparent !important;
        box-shadow: none !important;
        flex-direction: row !important;
    }
    
    #ftco-nav .navbar-nav {
        flex-direction: row !important;
    }

    #ftco-nav .dropdown-menu {
        position: absolute !important;
        display: none !important; /* Escondido no PC */
    }
    
    #ftco-nav .nav-item:hover .dropdown-menu {
        display: block !important; /* Abre no mouse no PC */
    }
}

/* --- OVERLAY ISOLADO --- */

@media (max-width: 991.98px) {
    /* O MENU LATERAL */
    #ftco-nav.collapse.show {
        display: flex !important;
        position: fixed !important;
        top: 0 !important;
        right: 0 !important;
        width: 300px !important;
        height: 100vh !important;
        background: #ffffff !important;
        z-index: 999999 !important;
        flex-direction: column !important;
        padding: 0 !important;
        
        /* O SEGREDO: Uma sombra de 100 view-widths que escurece o site */
        /* Isso cria o efeito SIM sem precisar de script ou div extra */
        box-shadow: 0 0 0 100vw rgba(0,0,0,0.5) !important;
    }

    /* Título Noronha Local (Forte e Fino) */
    .mobile-menu-header {
        display: block !important;
        padding: 30px 20px 20px 25px !important;
        border-bottom: 1px solid #f0f0f0 !important;
    }
    .mobile-menu-header h2 {
        font-family: "Poppins", Arial, sans-serif !important;
        font-weight: 800 !important;
        font-size: 22px !important;
        color: #000 !important;
        margin: 0 !important;
    }
    .mobile-menu-header h2 span {
        font-weight: 300 !important;
    }

    /* SUBMENU ESTILO LISTA (ACORDEÃO) */
    #ftco-nav .dropdown-menu {
        position: static !important;
        float: none !important;
        display: none !important; /* Começa fechado */
        background: #fafafa !important;
        border: none !important;
        padding: 0 0 0 15px !important;
    }
    /* Só abre quando o Bootstrap coloca a classe .show */
    #ftco-nav .nav-item.dropdown.show .dropdown-menu {
        display: block !important;
    }

    /* BOTÃO DE FECHAR (X) */
    .navbar-toggler[aria-expanded="true"] i::before,
    .navbar-toggler[aria-expanded="true"] .fa-bars::before {
        content: "\f00d" !important; /* Ícone do X */
    }
    .navbar-toggler {
        z-index: 1000000 !important;
        position: fixed !important;
        right: 15px;
        top: 22px;
    }
}

/* Trava para o Desktop não herdar a sombra gigante */
@media (min-width: 992px) {
    #ftco-nav.collapse {
        box-shadow: none !important;
    }
}

@media (max-width: 991.98px) {
    /* 1. O BOTÃO (Link) - Aqui controlamos a caixa azul */
    #ftco-nav .nav-item.cta .nav-link {
        padding: 10px 20px !important; 
        background: #1a8af9 !important; 
        border: 1px solid #1a8af9 !important; 
        
        display: table !important; /* Melhor para centralizar com margin auto */
        width: auto !important;
        
        /* Centralização e posição do botão no menu */
        margin-left: auto !important;
        margin-right: auto !important;
        margin-top: 15px !important; 
        margin-bottom: 15px !important;
        
        font-size: 14px !important;
        border-radius: 30px !important; 
        text-align: center !important;
        color: #fff !important;
        
        /* REMOVI o transform daqui para o texto não descer junto */
    }

    /* 2. O ÍCONE - Aqui controlamos APENAS o desenho do WhatsApp */
    #ftco-nav .nav-item.cta .nav-link i {
        font-size: 20px !important;
        color: #ffffff !important;
        margin-right: 8px !important;
        display: inline-block !important;
        
        /* O SEGREDO: Só o ícone desce agora */
        transform: translateY(3px) !important; 
        /* Ou use margin-top se preferir, mas o transform é mais preciso */
    }

    /* 3. EFEITO HOVER */
    #ftco-nav .nav-item.cta .nav-link:hover {
        background: #007bff !important;
        border-color: #007bff !important;
    }
}

.navbar-toggler[aria-expanded="true"] i {
    color: #000000 !important;
}

/* ============================
   FIX DEFINITIVO – ESPAÇO ENTRE CARDS
   Seção: Experiências (mobile)
============================ */
@media (max-width: 767.98px) {

  /* devolve padding vertical da seção */
  #experiencias.ftco-section {
    padding-top: 32px !important;
    padding-bottom: 32px !important;
  }

   
  /* espaço ENTRE os cards */
  #experiencias .col-sm {
    margin-bottom: 24px !important;
  }

  /* último card sem sobra */
  #experiencias .col-sm:last-child {
    margin-bottom: 0 !important;
  }

}

/* ============================
   FIX BORDA DO BANNER (HERO)
============================ */
.ta-hero-box {
  border-radius: 8px !important;
  overflow: hidden; /* corta tudo dentro */
}

.ta-hero-images {
  border-radius: 0 !important;
}

@media (max-width: 991.98px) {
    /* 1. Adiciona a transição suave no painel do menu */
    #ftco-nav.collapse {
        transition: all 0.4s ease-in-out !important;
        /* Garante que o menu comece fora da tela ou invisível para o efeito funcionar */
        visibility: hidden;
        display: block !important;
        transform: translateX(-100%); 
    }

    /* 2. Quando o menu estiver aberto (.show), ele volta para a posição original */
    #ftco-nav.collapse.show {
        visibility: visible;
        transform: translateX(0);
    }
}

/* Footer isolado – não interfere no site */
.ftco-footer {
  padding: 60px 0;
}


/* ============================
   BLOG – BORDA ARREDONDADA DOS CARDS
============================ */

/* Card inteiro */
#blog .blog-entry {
  border-radius: 8px !important;
  overflow: hidden; /* corta tudo */
  background: #fff;
}

/* Wrapper da imagem */
#blog .blog-entry .block-20 {
  border-top-left-radius: 8px;
  border-top-right-radius: 8px;
  overflow: hidden;
}

/* Imagem */
#blog .blog-entry .block-20 img {
  border-radius: 0; /* evita conflito */
  display: block;
}

/* ============================
   BLOG – CARDS MAIS ROBUSTOS NO DESKTOP
   (mantém 4 colunas)
============================ */
@media (min-width: 992px) {

  /* aumenta a altura da imagem */
  #blog .blog-entry .block-20 {
    height: 220px;
  }

  /* garante que a imagem preencha */
  #blog .blog-entry .block-20 img {
    height: 100%;
    object-fit: cover;
  }

  /* mais respiro no conteúdo */
  #blog .blog-entry .text {
    padding: 20px 22px;
  }

}

/* ============================
   BLOG – CONTAINER MAIS LARGO NO DESKTOP
============================ */
@media (min-width: 992px) {
  #blog .container {
    max-width: 1320px; /* mais largo que o padrão */
  }
}

@media (min-width: 992px) {
  #blog .row {
    margin-left: -10px;
    margin-right: -10px;
  }

  #blog .col-md-3 {
    padding-left: 10px;
    padding-right: 10px;
  }
}

/* ============================
   HERO PASSEIOS – VÍDEO
============================ */

@media (max-width: 768px) {
  /* GALERIA DE IMAGEM (não vídeo) */
  .ta-gallery-main:not(.ta-video) {
    height: auto;          /* 🔑 deixa a imagem definir a altura */
    overflow: visible;     /* 🔑 para de cortar */
  }

  .ta-gallery-main:not(.ta-video) img {
    width: 100%;
    height: auto;          /* 🔑 imagem natural */
    object-fit: contain;  /* 🔑 igual página Passeios */
    display: block;
    margin: 0 auto;
  }
}

/* APENAS IMAGEM (NÃO VÍDEO) */
.ta-gallery-main:not(.ta-video) img {
  width: 100%;
  height: auto;
  object-fit: initial;
  display: block;
}

.ta-gallery-main.ta-video video {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.ta-hero-video video {
  width: 100%;
  height: 100%;
  object-fit: cover;
  border-radius: 0px; /* mantém o visual atual */
}

/* Segurança mobile */
.ta-hero-video {
  overflow: hidden;
}

.ta-hero-video::after {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(
    to bottom,
    rgba(0,0,0,0.15),
    rgba(0,0,0,0.25)
  );
}

 /* =========================
   MENU SUPERIOR – ESTILO CLEAN
========================= */

#ftco-navbar {
  background: #ffffff !important;
  border-bottom: 1px solid rgba(0, 0, 0, 0.08);
  box-shadow: none;
}

#ftco-navbar .nav-link {
  color: #111 !important;
  font-weight: 500;
}

#ftco-navbar .nav-link:hover {
  color: #000 !important;
}

.nav-item.cta .nav-link {
  background: #00bfa5;
  color: #fff !important;
  border-radius: 30px;
  padding: 8px 18px;
}

/* LOGO */
.logo-icon {
  height: 30px !important; /* mobile */
  width: auto;
}

.logo-text {
  font-size: 18px !important;
  font-weight: 600;
}

/* Desktop */
@media (min-width: 992px) {
  .logo-icon {
    height: 40px !important;
  }

  .logo-text {
    font-size: 24px !important;
  }
}

/* =========================
   LOGO TEXTO SEMPRE VISÍVEL
========================= */

.navbar-brand,
.logo-brand {
  opacity: 1 !important;
}

.logo-text {
  color: #111 !important;
  opacity: 1 !important;
  visibility: visible !important;
}

.navbar-brand:hover .logo-text {
  color: #000 !important;
}

@media (max-width: 768px) {
  .ta-hero-media,
  .ta-hero-images {
    border-radius: 0 !important;
    overflow: visible !important;
  }
}

/* Header do menu mobile */
.mobile-menu-header {
  padding: 24px 20px;
  border-bottom: 1px solid #eee;
}

/* Logo + texto */
.mobile-logo {
  display: flex;
  align-items: center;
  gap: 10px;
}

/* Arraia */
.mobile-logo img {
  height: 28px; /* ajuste aqui */
  width: auto;
}

/* Texto */
.logo-text {
  font-size: 22px;
  line-height: 1;
  color: #000;
}

.logo-text strong {
  font-weight: 700;
}

.logo-text span {
  font-weight: 400;
  color: #555;
}

/* Container Principal do Card */
.card-reserva-sidebar {
    background: #ffffff;
    border-radius: 16px;
    padding: 24px;
    margin-top: 24px;
    box-shadow: 0 8px 24px rgba(0, 0, 0, 0.06);
    border: 1px solid #f0f0f0;
    text-align: center;
    box-sizing: border-box; /* Importante para não desconfigurar largura */
}

.card-reserva-title {
    color: #00838f; /* Azul Noronha */
    font-size: 18px;
    font-weight: 700;
    margin-bottom: 10px;
}

.card-reserva-text {
    font-size: 14px;
    color: #666;
    line-height: 1.4;
    margin-bottom: 20px;
}

/* Botão Premium sem a borda do degradê */
.btn-reserva-premium {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 10px;
    
    background: #00a884; /* Cor base */
    background: linear-gradient(to right, #00a884, #00d084);
    
    color: #ffffff !important;
    text-decoration: none !important;
    padding: 14px 20px;
    border-radius: 12px;
    font-weight: 700;
    font-size: 13px;
    text-transform: uppercase;
    letter-spacing: 0.5px;
    
    /* Remove bordas fantasmas */
    border: none !important;
    outline: none !important;
    box-shadow: 0 4px 12px rgba(0, 168, 132, 0.25);
    transition: 0.3s ease;
}

.btn-reserva-premium:hover {
    transform: translateY(-2px);
    filter: brightness(1.1);
    box-shadow: 0 6px 18px rgba(0, 168, 132, 0.35);
}

.btn-reserva-premium i {
    font-size: 18px;
}

/* Card dentro da seção de Observações */
.cta-observacoes-card {
    margin-top: 30px;
    background: #fdfdfd; /* Um branco quase gelo para destacar do fundo bege/creme */
    border: 1px dashed #00a884; /* Borda tracejada para dar charme */
    border-radius: 15px;
    padding: 30px;
    text-align: center;
    box-shadow: 0 10px 20px rgba(0,0,0,0.03);
}

.cta-obs-badge {
    background: rgba(0, 168, 132, 0.1);
    color: #00a884;
    padding: 4px 12px;
    border-radius: 20px;
    font-size: 11px;
    font-weight: 700;
    text-transform: uppercase;
    display: inline-block;
    margin-bottom: 15px;
}

.cta-obs-content h4 {
    font-size: 22px;
    color: #333;
    margin-bottom: 10px;
    font-weight: 700;
}

.cta-obs-content p {
    color: #666;
    margin-bottom: 25px;
    max-width: 500px;
    margin-left: auto;
    margin-right: auto;
}

/* Reutilizando o botão com ajuste de largura */
.cta-observacoes-card .btn-reserva-premium {
    max-width: 320px;
    margin: 0 auto;
}

/* Ajuste Mobile */
@media (max-width: 480px) {
    .cta-observacoes-card {
        padding: 20px 15px;
    }
    .cta-obs-content h4 {
        font-size: 18px;
    }
}

.card-reserva-sidebar {
    background: #ffffff;
    border-radius: 16px;
    padding: 25px;
    margin-top: 25px;
    
    /* Efeito de profundidade: sombra mais suave e espalhada */
    box-shadow: 0 15px 35px rgba(0, 0, 0, 0.08); 
    
    /* Borda lateral sutil para conectar com a cor da marca */
    border-left: 4px solid #00a884; 
    
    border-top: 1px solid #f0f0f0;
    border-right: 1px solid #f0f0f0;
    border-bottom: 1px solid #f0f0f0;
    
    transition: transform 0.3s ease, box-shadow 0.3s ease;
    text-align: center;
    box-sizing: border-box;
}

/* Efeito interativo: o card "flutua" levemente quando o mouse passa */
.card-reserva-sidebar:hover {
    transform: translateY(-5px);
    box-shadow: 0 20px 40px rgba(0, 0, 0, 0.12);
}

.card-reserva-title {
    color: #00838f; 
    font-size: 18px;
    font-weight: 800; /* Mais peso no título */
    margin-bottom: 12px;
    letter-spacing: -0.5px;
}

.card-reserva-text {
    font-size: 13px;
    color: #555;
    line-height: 1.5;
    margin-bottom: 20px;
    padding: 0 5px; /* Evita que o texto encoste na borda interna */
}

/* --- CORREÇÃO DE LAYOUT MOBILE --- */
@media (max-width: 991px) {
  /* Esconde a sidebar lateral no mobile para não quebrar o grid */
  .service-sidebar {
    display: none !important;
  }
  
  /* Garante que o conteúdo principal use 100% da tela */
  .service-grid, .service-body-container {
    display: block !important;
    width: 100% !important;
  }
}

/* --- ESTILO DOS CARDS DE PASSEIOS --- */
.related-tours-section {
  margin-top: 50px;
  padding-top: 30px;
  border-top: 1px solid #eee;
}

.related-title {
  font-size: 20px;
  font-weight: 700;
  color: #333;
  margin-bottom: 20px;
}

.tours-grid-premium {
  display: flex;
  flex-direction: column;
  gap: 12px;
}

.tour-card-premium {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 20px;
  background: #ffffff;
  border: 1px solid #eeeeee;
  border-radius: 14px;
  text-decoration: none !important;
  transition: all 0.3s ease;
}

.tour-card-premium:hover {
  border-color: #1a8af9;
  transform: translateX(5px);
  box-shadow: 0 5px 15px rgba(0,0,0,0.05);
}

.tour-card-info strong {
  display: block;
  font-size: 16px;
  color: #1a8af9;
  margin-bottom: 2px;
}

.tour-card-info span {
  font-size: 14px;
  color: #777;
}

.tour-card-premium i {
  color: #ddd;
  font-size: 14px;
}

.link-back-all {
  display: inline-block;
  margin-top: 25px;
  font-size: 14px;
  font-weight: 600;
  color: #000;
  text-decoration: none;
}

.link-back-all:hover {
  color: #1a8af9;
}

/* Espaçamento final para o rodapé */
.spacer-bottom {
    height: 60px; /* Ajuste aqui se quiser mais ou menos espaço */
    width: 100%;
    display: block;
}

@media (max-width: 991px) {
    .service-sidebar {
        display: none !important;
    }
    .service-main {
        width: 100% !important;
        padding-bottom: 20px; /* Reforço de espaço no mobile */
    }
    /* Garante que o footer não suba */
    .ftco-footer {
        margin-top: 0 !important;
        clear: both;
    }
}

@media (max-width: 767px) {

  /* FORÇA o hero a colar no topo, independente do resto */
  body .service-hero {
    margin-top: -40px;
    padding-top: 0;
  }

  /* Ajuste fino do conteúdo interno */
  body .service-hero h1 {
    margin-top: 8px;
    margin-bottom: 6px;
  }

  body .service-hero .ta-rating {
    margin-top: 0;
    margin-bottom: 6px;
  }

}

.service-cards-intro {
  margin: 24px 0 12px;
}

.service-cards-intro h3 {
  font-size: 1.1rem;
  margin-bottom: 4px;
}

.service-cards-intro p {
  font-size: 0.9rem;
  opacity: 0.8;
}

@media (max-width: 767px) {
  .ta-gallery .owl-nav {
    top: 40%;
  }
}

.service-single .service-eyebrow {
  line-height: 1.15;
  display: block;
  margin-top: -40px;          /* NÃO puxa para o banner */
  margin-bottom: 8px;
}

@media (max-width: 767px) {
  .service-single .service-eyebrow {
    display: block;
    margin-top: 0;          /* NÃO puxa para o banner */
    margin-bottom: 8px;     /* controla a distância */
    line-height: 1.19;      /* controla distância entre linhas */
  }
}

/* ===== VÍDEO APENAS ===== */
.ta-video {
  position: relative;
  width: 100%;
  height: 420px;
  overflow: hidden;
}

.ta-video video {
  position: absolute;
  top: 50%;
  left: 50%;
  width: 100%;
  height: 100%;
  object-fit: cover;
  transform: translate(-50%, -50%);
}

@media (max-width: 768px) {
  .ta-video {
    height: 260px;
  }
}



/*====================================
=====NOVA PAGINA PASSEIOS GRID========
====================================*/

.page-boats-list .boats-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 24px;
}

@media (max-width: 1024px) {
  .page-boats-list .boats-grid {
    grid-template-columns: repeat(2, 1fr);
  }
}

@media (max-width: 640px) {
  .page-boats-list .boats-grid {
    grid-template-columns: 1fr;
  }
}

/* CARD */
.page-boats-list .boat-card {
  background: #fff;
  border-radius: 8px;
  overflow: hidden;
  box-shadow: 0 10px 30px rgba(0,0,0,.08);
  transition: transform .3s ease, box-shadow .3s ease;
}

.page-boats-list .boat-card:hover {
  transform: translateY(-4px);
  box-shadow: 0 16px 40px rgba(0,0,0,.12);
}

.boat-card img {
  width: 100%;
  height: 220px;          /* altura fixa */
  object-fit: cover;
  flex-shrink: 0;         /* 🔑 ISSO impede a imagem de encolher */
}


.page-boats-list .boat-card-body {
  padding: 16px;
}

.page-boats-list .boat-card h3 {
  font-size: 18px;
  margin-bottom: 6px;
}

.page-boats-list .boat-card p {
  font-size: 14px;
  color: #666;
  margin-bottom: 12px;
}

/* BOTÃO */
.page-boats-list .btn-card {
  display: inline-block;
  padding: 10px 16px;
  border-radius: 999px;
  background: #1a8af9;
  color: #fff;
  font-size: 14px;
  text-decoration: none;
  font-weight: 300;
  -webkit-tap-highlight-color: transparent;
}

.page-boats-list .btn-card:hover {
  color: #fde02f;
}

/* HERO VÍDEO */
.page-boats-list .boats-hero {
  position: relative;
  width: 100%;
  height: 52vh;
  max-height: 520px;
  overflow: hidden;
  border-radius: 8px;
  margin: 40px auto 60px;
}

.page-boats-list .boats-hero video {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.page-boats-list .boats-hero-overlay {
  position: absolute;
  inset: 0;
  background: linear-gradient(
    to bottom,
    rgba(0,0,0,.15),
    rgba(0,0,0,.35)
  );
}


/* MOBILE */
@media (max-width: 768px) {
  .page-boats-list .boats-hero {
    height: 28vh;
    min-height: 180px;
    max-height: 260px;
    border-radius: 8px;
    margin: 24px 0 32px;
  }
}

/* CTA */
.page-boats-list .cta-final {
  margin: 80px auto 120px;
  text-align: center;
}

/* FEEDBACK TOQUE */
@media (hover: none) {
  .page-boats-list .btn-card:focus {
    color: #fde02f;
  }
}

@media (max-width: 768px) {

  /* aproxima texto do vídeo */
  .service-hero.small .boats-hero {
    margin-bottom: -60px;
  }

  
  /* diminui texto da avaliação */
  .service-hero.small .ta-rating {
    font-size: 0.85rem;
  }

}

@media (max-width: 768px) {
  .service-page .service-summary h2 {
    font-size: 24px !important;
    line-height: 1.2;
    margin-top: 0; /* mantém o ajuste que você já fez */
  }
}

@media (max-width: 768px) {

  /* diminui espaço entre os cards */
  .boats-grid {
    gap: 28px; /* antes era 24px */
  }

  /* garante que o card não empurre mais espaço */
  .boat-card {
    margin-bottom: 10px;
    margin-top: 12px;
  }

}

.rate {
  display: flex;
  align-items: center;
  gap: 4px;
  margin-bottom: 15px;
  font-size: 13px;
}

.rate i {
  color: #0066FF; /* azul premium */
  font-size: 12px;
}

.rate span {
  margin-left: 6px;
  font-size: 12px;
  color: #666;
}

/* Ajuste fino do conteúdo dos cards */
.boats-grid .boat-card-body {
  padding-top: 10px; /* antes ~16px */
}

/* Sobe o título em todos os tamanhos */
.boats-grid .boat-card h3 {
  margin-top: 0;
  margin-bottom: 6px;
}

.boat-highlight {
  font-size: 13px;
  color: #444;
  margin-bottom: 10px;
}

.boat-card {
  display: flex;
  flex-direction: column;
}

.boat-card-body {
  display: flex;
  flex-direction: column;
  height: 100%;
}

/* empurra o botão sempre para o final */
.boat-card .btn-card {
  margin-top: 25px;
}

@media (max-width: 768px) {
  .boat-card .btn-card {
    margin-top: 20px;
  }
}

.ta-gallery-main img.ta-gallery-image {
  width: 100%;
  display: block;
}

/* BOTÃO WHATSAPP FIXO */
.whatsapp-float {
  position: fixed;
  bottom: 16px;
  left: 50%;
  transform: translateX(-50%);
  z-index: 9999;
  opacity: 0;
  pointer-events: none;
  transition: opacity 0.3s ease, transform 0.3s ease;
  transform: translateX(-50%) translateY(10px);
  white-space: nowrap;
  
  

  display: flex;
  align-items: center;
  gap: 10px;

  background: #25D366;
  color: #fff;
  padding: 14px 22px;
  border-radius: 999px;

  font-size: 15px;
  font-weight: 500;
  text-decoration: none;

  box-shadow: 0 10px 30px rgba(0, 0, 0, 0.25);
  transition: transform 0.3s ease, box-shadow 0.3s ease;
}

/* Hover (desktop) */
.whatsapp-float:hover {
  transform: translateX(-50%) scale(1.03);
  box-shadow: 0 14px 40px rgba(0, 0, 0, 0.35);
}

/* Ícone */
.whatsapp-float i {
  font-size: 20px;
}

/* Esconde no desktop */
@media (min-width: 769px) {
  .whatsapp-float {
    display: none;
    
  }
}

.boats-hero-content {
    position: absolute;
    bottom: 30px;
    left: 30%; /* Move para o meio da tela */
    transform: translateX(-50%); /* Puxa de volta metade da largura dele */
    width: 100%;
    max-width: 1140px; /* MESMA LARGURA que você colocou no .ta-gallery ou .boats-hero */
    padding: 0 40px; /* Margem interna para o texto não encostar na borda do vídeo */
    z-index: 5;
    color: #fff;
    box-sizing: border-box;
}

/* Garante que o título e as estrelas fiquem alinhados à esquerda DENTRO desse bloco centralizado */
.boats-hero-content h1, 
.ta-rating-hero {
    text-align: left;
    margin-left: 0;
}

/* HERO VIDEO */
/* ===== HERO VIDEO – PÁGINA PASSEIOS ===== */
.boats-video-hero {
  position: relative;
  width: 100%;
  height: 60vh;
  min-height: 420px;
  overflow: hidden;
}

.boats-video-hero video {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

/* Este seletor garante que a camada escura apareça sobre as fotos */
.boats-video-overlay {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    /* Gradiente que escurece a parte de baixo para o texto aparecer */
    background: linear-gradient(to bottom, rgba(0,0,0,0.1) 0%, rgba(0,0,0,0.6) 100%);
    z-index: 2; /* Fica acima das imagens */
    pointer-events: none;
}

.boats-video-content {
  position: absolute;
  bottom: 40px;
  left: 50%;
  transform: translateX(-50%);
  width: 100%;
  color: #fff;
  text-align: left;
}

.boats-video-content h1 {
  color: #fff;
  margin-bottom: 8px;
}

.boats-video-content .ta-rating {
  color: #fff;
}

/* MOBILE */
@media (max-width: 768px) {
  .boats-video-hero {
    height: 45vh;
    min-height: 320px;
  }

  .boats-video-content {
    bottom: 24px;
    text-align: center;
  }
}



/* CTA FINAL */
.cta-final {
  padding: 80px 20px;
}

.cta-final-box {
  max-width: 720px;
  margin: 0 auto;
  text-align: center;

  background: #f8fbfd;
  border-radius: 20px;
  padding: 50px 30px;
}

.cta-final-box h2 {
  font-size: 28px;
  margin-bottom: 16px;
}

.cta-sub {
  font-size: 16px;
  color: #555;
  margin-bottom: 18px;
}

.cta-proof {
  font-size: 14px;
  color: #333;
  margin-bottom: 30px;
}

/* Botão */
.btn-cta-final {
  display: inline-block;
  background: #25D366;
  color: #fff;
  padding: 16px 30px;
  border-radius: 999px;

  font-size: 16px;
  font-weight: 500;
  text-decoration: none;

  box-shadow: 0 12px 30px rgba(0, 0, 0, 0.25);
  transition: transform 0.3s ease, box-shadow 0.3s ease;
}

.btn-cta-final:hover {
  transform: scale(1.05);
  box-shadow: 0 16px 40px rgba(0, 0, 0, 0.35);
}

/* Mobile */
@media (max-width: 768px) {
  .cta-final-box h2 {
    font-size: 24px;
  }
}

@media (max-width: 360px) {
  .whatsapp-float {
    padding: 12px 18px;
    font-size: 14px;
  }
}


/* ===== GALERIA BANNER NOVA ===== */
.gallery-banner {
  display: grid;
  grid-template-columns: 2fr 1fr;
  gap: 16px;
  margin-top: 24px;
}

/* IMAGEM PRINCIPAL */
.gallery-main {
  border-radius: 12px;
  overflow: hidden;
}

.gallery-main img {
  width: 100%;
  height: auto;          /* imagem manda */
  display: block;
}

/* IMAGENS LATERAIS */
.gallery-side {
  display: grid;
  grid-template-rows: 1fr 1fr;
  gap: 16px;
}

.gallery-side img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  border-radius: 12px;
  display: block;
}

/* ===== MOBILE ===== */
@media (max-width: 768px) {
  .gallery-banner {
    grid-template-columns: 1fr;
  }

  .gallery-side {
    display: none; /* mobile mostra só a principal */
  }
}

/* ===== FIX REAL HERO MOBILE ===== */
@media (max-width: 768px) {

  .service-hero.container {
    max-width: 100%;
    padding-left: 16px;
    padding-right: 16px;
  }

  .service-hero h1,
  .service-hero .ta-rating {
    width: 100%;
    margin: 0 auto;
    text-align: center;
  }

}

/* ================================================================
   AJUSTES GERAIS - RESOLVE TEXTO ESCONDIDO E VÍDEO BAIXO
   ================================================================ */

/* 1. Garante que o conteúdo comece logo após o menu, sem sumir */
.service-page.page-boats-list {
    padding-top: 100px !important; /* Ajuste esse valor se o menu for maior/menor */
}

/* 2. Cabeçalho: Remove espaços vazios que empurram o vídeo para baixo */
.page-boats-list .boats-list-header {
    padding: 0 10px;
    margin-top: 0 !important;
    margin-bottom: 5px !important; /* Espaço exato entre texto e vídeo */
}

.page-boats-list .boats-list-header h1 {
    font-size: 28px;
    font-weight: 700;
    color: #333;
    line-height: 1.2;
    margin: 0 0 5px 0 !important;
}

/* Pinta apenas as estrelas */
.page-boats-list .ta-rating .star-color {
    color: #0A6CFF !important; /* Agora vai ficar dourada! */
    font-size: 16px;            /* Ajuste o tamanho aqui */
    margin-right: 2px;
    letter-spacing: 2px;       /* Dá um respiro entre elas */
}

.page-boats-list .ta-rating span:last-child {
    color: #666 !important;    /* Mantém o texto rating em cinza */
    font-size: 13px;
}

/* 3. Vídeo Hero: Trava a altura e remove margens de afastamento */
.page-boats-list .boats-video-hero {
    position: relative;
    width: 100%;
    height: 400px !important; /* Altura ideal mobile */
    margin-top: -70px !important;
    margin-bottom: 24px;
    overflow: hidden;
    z-index: 1; /* Garante que o vídeo não cubra o clique do menu */
}

.page-boats-list .boats-video-hero video {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
}

/* 4. Textos dentro do Vídeo (Fontes e Sombras) */
.page-boats-list .boats-video-cta {
    display: block; 
    position: absolute;
    /* 1. Subimos de 20px para 50px para ele não ficar tão colado embaixo */
    bottom: 30px; 
    left: 20px;
    z-index: 10 !important;
    color: #fff;
    text-align: left;
}

.page-boats-list .boats-video-cta strong {
    display: block;
    font-size: 24px;
    font-weight: 600;
    text-shadow: 0 2px 6px rgba(0,0,0,0.8);
    /* 2. Aumentamos para 1.2 para as letras não baterem uma na outra */
    line-height: 1.2; 
    /* 3. Ajuste fino do espaço entre o Título e o Subtítulo */
    margin-bottom: 12px !important; 
}

.page-boats-list .boats-video-cta span {
    display: block;
    font-size: 14px;
    line-height: 1.2;
}

/* ================================================================
   AJUSTES PARA DESKTOP (TELAS GRANDES)
   ================================================================ */
@media (min-width: 769px) {
    .service-page.page-boats-list {
        padding-top: 130px !important; /* Mais espaço no desktop */
    }

    .page-boats-list .boats-list-header {
        max-width: 1140px;
        margin: 0 auto 20px !important;
        padding: 0;
    }

    .page-boats-list .boats-list-header h1 {
        font-size: 32px;
    }

    .page-boats-list .boats-video-hero {
      width: 100%;
      max-width: 1160px;
      margin: 0 auto 20px !important;
      border-radius: 8px;
      height: 500px !important;
      overflow: hidden;
      padding: 0; /* 👈 SEM padding aqui */
      
        
    }
}

@media (max-width: 768px) {
  .page-boats-list .boats-video-hero {
    margin-bottom: 0 !important;
    margin-top: 0 !important;
  }

  .texto-introducao {
    margin-bottom: 14px;
  }
}


/* --- ESTILO PARA DESKTOP ---
------TEXTO ESCOLHA SUA EMBARCAÇÃO-- */

main.service-page .service-summary h2 {
    font-size: 32px !important; 
    line-height: 1.2;
    color: #000;
    font-weight: 700;
    text-align: left;
    /* Alinhamento e Espaçamento */
    max-width: 1140px; /* Mesma largura do seu container de fotos */
    margin: 40px auto 20px; /* Centraliza o bloco e dá espaço do vídeo */
    padding: 0; /* Garante que encoste na borda esquerda do container */
}

/* --- ESTILO PARA MOBILE --- */
@media (max-width: 768px) {
    main.service-page .service-summary h2 {
        font-size: 26px !important;
        line-height: 1.25;
        color: #000;
        font-weight: 700;
        text-align: left;
        /* Correção de Posição */
        margin-top: 30px !important;  /* DESCE O TEXTO (Remove o negativo) */
        margin-bottom: 10px !important;
        padding-left: 0 !important; /* Alinha com o 'padding' padrão dos seus cards */
        padding-right: 15px !important;
    }
}

/* Centraliza o bloco inteiro do rodapé */
.cta-proof {
    display: flex;
    justify-content: center; /* Centraliza horizontalmente */
    align-items: center;     /* Alinha verticalmente estrelas e texto */
    gap: 8px;                /* Espaçamento entre estrelas e frase */
    flex-wrap: wrap;         /* Garante que quebre linha se o celular for muito pequeno */
    margin: 15px auto 30px;     /* Espaço superior e centralização do container */
    color: #666;
    font-size: 14px;
    text-align: center;
}

/* Cor dourada para as estrelas do rodapé */
.cta-proof .stars-gold {
    color: #0A6CFF !important; /* Cor Ouro */
    font-size: 20px;
    letter-spacing: 2px;
}

/* Garante que o número 4.9 se destaque */
.cta-proof strong {
    color: #333;
    font-weight: 700;
    font-size: 12px;
}

/* Padronização de todos os blocos de descrição */
.trip-card-style {
    background: #ffffff !important;
    border: 1px solid #e0e0e0 !important;
    border-radius: 12px !important;
    padding: 25px 30px !important;
    margin-bottom: 20px !important;
    box-shadow: 0 4px 10px rgba(0,0,0,0.02) !important;
}

/* Alinhamento dos Títulos internos */
.trip-card-style h3 {
    margin-top: 0;
    margin-bottom: 15px;
    font-size: 1.2rem;
    color: #000;
    display: flex;
    align-items: center;
    gap: 10px;
}

/* Ajuste do Roteiro para o novo alinhamento */
.roteiro-list {
    margin-top: 20px;
    display: flex;
    flex-direction: column;
    gap: 15px;
}

.roteiro-item {
    display: flex;
    align-items: flex-start;
    gap: 15px;
    padding-bottom: 15px;
}

.roteiro-item:not(:last-child) {
    border-bottom: 1px dashed #eee; /* Linha sutil entre itens */
}

.roteiro-icon {
    font-size: 20px;
    min-width: 30px;
}

/* Garante que o container de alerta (service-warning) mantenha o destaque */
.service-warning.trip-card-style {
    border-left: 5px solid #ffc107 !important; /* Cor de destaque para avisos */
}

/* Container que centraliza a seção no site */
.related-tours-section {
    max-width: 1200px; /* Ou a largura do seu container padrão */
    margin: 40px auto;
    padding: 30px;
}

/* O segredo para não quebrar: Scroll Horizontal */
.tours-slider-container {
    width: 100%;
    overflow-x: auto; /* Cria a barra de rolagem */
    padding-bottom: 20px;
    -webkit-overflow-scrolling: touch; /* Suavidade no celular */
}

.tours-slider-premium {
    display: flex; /* Coloca um ao lado do outro */
    flex-wrap: nowrap; /* Impede de pular linha */
    gap: 15px;
}

/* Tamanho de cada barquinho */
.tour-card-premium {
    flex: 0 0 280px; /* Fixa a largura em 280px, não deixa esmagar */
    background: #f8fafc;
    border: 1px solid #e2e8f0;
    padding: 15px 20px;
    border-radius: 12px;
    display: flex;
    justify-content: space-between;
    align-items: center;
    text-decoration: none;
    color: inherit;
}

/* Esconde a barra de rolagem para ficar mais limpo */
.tours-slider-container::-webkit-scrollbar {
    height: 6px;
}
.tours-slider-container::-webkit-scrollbar-thumb {
    background: #000;
    border-radius: 10px;
}

/* Container da Seção */
.related-tours-section {
    padding: 30px 0;
    margin-top: 20px;
}

.related-title {
    font-size: 20px;
    margin-bottom: 20px;
    color: #2c2c2c;
}

/* Mecanismo de Scroll */
.tours-slider-container {
    width: 100%;
    overflow-x: auto;
    padding-bottom: 15px;
    -webkit-overflow-scrolling: touch;
}

.tours-slider-premium {
    display: flex;
    gap: 16px;
    width: max-content;
}

/* Card Minimalista */
.tour-card-standard {
    flex: 0 0 220px; /* Largura leve e discreta */
    text-decoration: none;
    color: #2c2c2c;
    border: 1px solid #e0e0e0;
    border-radius: 12px;
    overflow: hidden;
    background: #fff;
    transition: transform 0.2s ease;
}

.tour-card-standard:hover {
    transform: translateY(-4px);
    box-shadow: 0 6px 15px rgba(0,0,0,0.08);
}

/* Imagem */
.tour-card-image {
    width: 100%;
    height: 140px;
    overflow: hidden;
}

.tour-card-image img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

/* Conteúdo */
.tour-card-content {
    padding: 12px;
}

.tour-location {
    display: block;
    font-size: 11px;
    text-transform: uppercase;
    letter-spacing: 0.5px;
    color: #767676;
    margin-bottom: 4px;
}

.tour-name {
    display: block;
    font-size: 15px;
    font-weight: 700;
    margin-bottom: 8px;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis; /* Corta o nome se for muito longo */
}

.tour-rating {
    display: flex;
    align-items: center;
    gap: 6px;
    font-size: 12px;
}

.stars {
    color: #00aa6c; /* O verde das bolinhas do TripAdvisor */
    letter-spacing: -1px;
    font-size: 14px;
}

.rating-count {
    color: #767676;
}

/* Isso cria o respiro na lateral esquerda no celular */
.slider-mobile-wrapper {
    padding: 0 15px; /* Ajuste o 15px se quiser mais ou menos espaço */
}

/* Garante que o container de scroll ocupe a largura disponível sem vazar */
.tours-slider-container {
    width: 100%;
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
}

/* Mantém os cards em linha e com estrelinhas amarelas */
.stars-gold {
    color: #ffb400;
}

/* AJUSTE APENAS PARA MOBILE (CELULAR) */
@media (max-width: 768px) {
    .related-tours-section {
        padding-left: 20px !important;  /* Empurra o conteúdo para a direita */
        padding-right: 20px !important; /* Dá respiro na lateral direita também */
    }

    .related-title {
        margin-left: 0; /* Garante que o título acompanhe o alinhamento */
    }
}

/* Aumenta o texto da Visão Geral */
#visao-geral p {
    font-size: 15px; /* Aumente ou diminua este número conforme o seu gosto */
    line-height: 1.6; /* Deixa o espaço entre as linhas mais confortável para leitura */
    color: #444;      /* Uma cor cinza escuro profissional */
    margin-bottom: 15px; /* Espaço entre os parágrafos se você usar mais de um */
    font-weight: 400;
}

/* ======================================================
   MOSAICO – HERO IMAGENS
====================================================== */

.mosaico-ativo {
    position: relative;
    width: 100%;
    overflow: hidden;
}

.mosaico-wrapper {
    width: 100%;
}

.mosaico-item img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    transition: none !important;
    opacity: 1 !important;
    cursor: pointer;
}

/* ---------- DESKTOP ---------- */
@media (min-width: 992px) {

    .mosaico-wrapper {
        display: grid !important;
        grid-template-columns: 1.5fr 1fr;
        grid-template-rows: 250px 250px;
        gap: 10px;
        overflow: hidden !important;
    }

    .item-1 {
        grid-row: 1 / span 2;
    }
}

/* ---------- MOBILE / TABLET ---------- */
/* MOBILE – MOSAICO CORRETO */
@media (max-width: 991px) {

  .mosaico-ativo {
    aspect-ratio: 9 / 16;
    position: relative;
    overflow: hidden;
  }

  .mosaico-wrapper {
    position: relative;
    width: 100%;
    height: 100%;
  }

  .mosaico-item {
    position: absolute;      /* 🔥 ESSENCIAL PARA FADE */
    inset: 0;
    opacity: 0;              /* 🔥 ESSENCIAL PARA FADE */
    transition: opacity 0.6s ease;
    pointer-events: none;    /* evita clique fantasma */
  }

  .mosaico-item.active {
    opacity: 1;
    z-index: 1;
    pointer-events: auto;
  }

  .mosaico-item img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
  }
}



/* =========================================
   MOSAICO – IMAGENS SEM FADE (overlay intacto)
========================================= */

.mosaico-item img {
    opacity: 1 !important;
    transition: none !important;
    animation: none !important;
    filter: none !important;
    will-change: auto !important;
}

.mosaico-item {
    transition: none !important;
}



/* ======================================================
   HERO VIDEO + OVERLAYS + CTA
====================================================== */

.page-boats-list .boats-video-hero {
    position: relative;
    
}

.boats-video-overlay {
    position: absolute;
    inset: 0;
    background: none !important;
    pointer-events: none;
    z-index: 1;
}

.page-boats-list .boats-video-overlay {
    background: linear-gradient(
        to bottom,
        rgba(0,0,0,0) 55%,
        rgba(0,0,0,0.75) 100%
        
    );
}

.page-boats-list .boats-video-hero::after {
    content: "";
    position: absolute;
    left: 0;
    right: 0;
    bottom: 0;
    height: 45%;
    background: linear-gradient(
        to top,
        rgba(0,0,0,0.55),
        rgba(0,0,0,0)
    );
    pointer-events: none;
    z-index: 1;
}

/* CTA */
.page-boats-list .boats-video-cta {
    position: absolute;
    bottom: 24px;
    left: 24px;
    z-index: 2;
    color: #fff;
}

.page-boats-list .boats-video-cta strong {
    font-size: 24px;
    font-weight: 600;
    text-shadow: 0 2px 6px rgba(0,0,0,0.75);
}

.page-boats-list .boats-video-cta span {
    font-size: 14px;
    text-shadow: 0 1px 4px rgba(0,0,0,0.65);
}

/* CTA – ajustes por breakpoint */
@media (min-width: 769px) {

    .page-boats-list .boats-video-cta {
        bottom: 32px;
        left: 32px;
    }

    .page-boats-list .boats-video-hero::after {
        height: 38%;
    }
}

@media (max-width: 768px) {

    .page-boats-list .boats-video-cta {
        bottom: 24px;
        left: 20px;
        right: 20px;
        max-width: none;
        background: none !important;
        pointer-events: none;
    }

    .page-boats-list .boats-video-hero::after {
        height: 50%;
    }
}

/* ======================================================
   SLIDER DE CARDS – DESKTOP
====================================================== */

@media (min-width: 992px) {

    .tours-slider-container {
        width: 100% !important;
        overflow-x: auto !important;
        padding-bottom: 10px;
    }

    .tours-slider-premium {
        display: flex !important;
        flex-wrap: nowrap !important;
        gap: 20px !important;
        width: max-content !important;
        padding-right: 100px !important;
    }

    .tour-card-standard {
        flex: 0 0 280px !important;
        width: 280px !important;
        min-width: 280px !important;
    }

    /* Scrollbar */
    .tours-slider-container::-webkit-scrollbar {
        height: 12px;
    }

    .tours-slider-container::-webkit-scrollbar-track {
        background: #f1f1f1;
        border-radius: 8px;
    }

    .tours-slider-container::-webkit-scrollbar-thumb {
        background: #0088cc;
        border-radius: 8px;
    }

    .tours-slider-container::-webkit-scrollbar-thumb:hover {
        background: #005f99;
    }
}

/*==========DIVISÃO============*/

/* Container que centraliza e dá o espaço lateral de 40px */
/* FORÇA O ALINHAMENTO DO PAI */
body, main {
    display: flex;
    flex-direction: column;
    width: 100%;
}

.secao-barcos {
    display: block !important;
    width: 100% !important;
    max-width: 1280px !important; /* Mesma largura do seu banner */
    margin: 34px auto !important; /* O auto aqui VAI funcionar agora */
    padding: 0 40px; 
    box-sizing: border-box; /* Garante que o padding não aumente a largura total */
    align-self: stretch; /* 👈 ISSO RESOLVE */
}

/* DESKTOP – alinhado com o banner */
.texto-introducao {
  max-width: 1160px;      /* 👈 MESMO width do banner */
  margin: 0 auto 30px;   /* centraliza o container */
  padding: 0;   
  padding-left: 0;   /* 👈 empurra pra direita */         /* sem empurrar texto */
}

.texto-introducao h2 {
  font-size: 28px;
  font-weight: 700;
  margin-bottom: 10px;
}

.texto-introducao p {
  color: #666;
  font-size: 16px;
}

@media (max-width: 768px) {
  .texto-introducao {
    padding-left: 16px;   /* empurra pra direita */
    padding-right: 16px;  /* mantém simetria */
  }

  .texto-introducao h2 {
  font-size: 28px;
  font-weight: 700;
  margin-bottom: 10px;
  padding-left: 0;   /* empurra pra direita */
  padding-right: 0;  /* mantém simetria */
}

  texto-introducao p {
  color: #666;
  font-size: 16px;
  padding-left: 5px;   /* empurra pra direita */
  padding-right: 5px;  /* mantém simetria */
}
}



/* Wrapper para segurar as setas em posição absoluta */
.wrapper-carrossel {
  position: relative;
  width: 100%;
}

/* Janela que esconde o que sobra e a barra */
.janela-scroll {
  width: 100%;
  overflow-x: auto;
  scroll-behavior: smooth;
  display: flex;
 
  padding-left: 10px;
  padding-right: 18px;
  box-sizing: border-box;
}

@media (max-width: 768px) {
  .janela-scroll {
    display: block;          /* 🔑 muda aqui */
    padding-left: 14px;      /* mais confortável no mobile */
    padding-right: 20px;
  }
}


/* Esconde a barra em todos os navegadores */
.janela-scroll::-webkit-scrollbar { display: none; }
.janela-scroll { -ms-overflow-style: none; scrollbar-width: none; }

/* O Trilho que impede o corte do último card */
.trilho-cards {
  display: flex;
  gap: 20px;
  padding: 10px 0 30px 0;
}

/* O Card */
.card-item {
  flex: 0 0 280px;
  background: #fff;
  border: 1px solid #ddd;
  border-radius: 8px;
  display: flex;
  flex-direction: column;
  box-shadow: 0 4px 10px rgba(0,0,0,0.05);
  overflow: hidden; /* garante que nada vaze */
}

/* Container da imagem */
.card-img-box {
  height: 180px;
  border-radius: 8px 8px 0 0;
  overflow: hidden; /* 👈 ESSENCIAL */
}

/* Imagem */
.card-img-box img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

/* Conteúdo */
.card-txt {
  padding: 15px;
  flex-grow: 1;
  display: flex;
  flex-direction: column;
}

.card-txt h3 {
  font-size: 18px;
  margin-bottom: 8px;
  min-height: 40px;
}

.stars {
  color: #0A6CFF;
  font-size: 14px;
  margin-bottom: 6px;
  letter-spacing: -1px;
}

.card-txt p {
  font-size: 15px;
  color: #555;
  margin-bottom: 15px;
}


.btn-ir {
  margin-top: auto;
  background: #1A8AF9;
  color: #fff !important;
  text-align: center;
  padding: 10px;
  border-radius: 999px;
  text-decoration: none !important;
  font-weight: 600;
}

/* Setas - Agora elas usam o padding da secao-barcos para se posicionarem */
.seta-btn {
  position: absolute;
  top: 40%;
  width: 40px;
  height: 40px;
  background: #fff;
  border: 1px solid #ccc;
  border-radius: 50%;
  cursor: pointer;
  z-index: 10;
  box-shadow: 0 2px 5px rgba(0,0,0,0.1);
}
.prev { left: -10px; }
.next { right: -10px; }

@media (max-width: 768px) {
  .secao-barcos {
    padding: 0;
  }

  .seta-btn { 
    display: none;
  }

  .card-item { 
    flex: 0 0 70vw; 
  }

  .trilho-cards {
    margin-left: 0;     /* mantém alinhado */
    gap: 10px;          /* diminui espaço entre cards */
    padding-right: 20px; /* espaço no final do último card */
    
  }
}

@media (max-width: 768px) {
  .trilho-cards::after {
    content: "";
    flex: 0 0 5px; /* espaço no final */
  }
}



.card-title-rate {
  display: flex;
  align-items: center;
  gap: 8px;
  margin-bottom: 6px;
}

.card-title-rate h3 {
  font-size: 14px;
  font-weight: 600;
  margin: 0;
  line-height: 1.2;
}

.card-title-rate .rate {
  display: flex;
  align-items: center;
  gap: 2px;
  font-size: 10px;
  color: #1a73e8; /* azul das estrelas */
  white-space: nowrap;
}

.card-title-rate .rate span {
  margin-left: 4px;
  color: #777;
  font-size: 8px;
}

@media (max-width: 768px) {
  .card-title-rate h3 {
    font-size: 10px;
  }

  .card-title-rate .rate {
    font-size: 8px;
  }
}

.intro-tags {
  display: flex;
  gap: 8px;
  flex-wrap: wrap;
  margin: 12px 0 24px;
  padding-left: 16px;   /* 👈 empurra pra direita */
}

.intro-tags .tag {
  background: #f1f5f9;
  color: #1a1a1a;
  font-size: 13px;
  padding: 6px 12px;
  border-radius: 999px;
  font-weight: 500;
}

/* SOMENTE cards do carrossel */
.secao-barcos .card-txt h3 {
  margin-bottom: -12px; /* cola no rate */
}

.secao-barcos .card-txt .rate {
  margin: 0; /* zera qualquer resíduo */
}

.secao-barcos .card-txt p {
  margin-top: 10px; /* controla o texto abaixo das estrelas */
}

/* Força o botão a ficar em uma única linha, não importa o tamanho do texto */
.btn-reserva-premium, .btn-whatsapp-dynamic {
    white-space: nowrap !important; /* Impede a quebra de linha */
    display: inline-flex !important; /* Alinha o ícone e o texto lado a lado */
    align-items: center;
    justify-content: center;
    min-width: max-content; /* Garante que o botão cresça conforme o texto */
    padding: 10px 25px; /* Ajuste o respiro interno se necessário */
}

@media (max-width: 768px) {
  .ta-hero-box {
    border-radius: 0 !important;
  }

  .ta-hero-images,
  .ta-hero-images img,
  .ta-hero-images video {
    border-radius: 0 !important;
  }
}

/* ===============================
   CTA FAIXA – TRILHAS
================================ */

.cta-trilhas-faixa {
  position: relative;
  background-image: url('../images/trilhas/banner-cta-meio.jpg'); /* imagem de trilha */
  background-size: cover;
  background-position: center;
  padding: 80px 0;
  margin-top: 40px;
  overflow: hidden;
}

.cta-trilhas-overlay {
  position: absolute;
  inset: 0;
  background: rgba(0, 120, 90, 0.85); /* VERDE overlay */
  z-index: 1;
}

.cta-trilhas-content {
  position: relative;
  z-index: 2;
  text-align: center;
  max-width: 820px;
}

.cta-trilhas-content h2 {
  color: #ffffff;
  font-weight: 700;
  font-size: 32px;
  margin-bottom: 16px;
}

.cta-trilhas-content p {
  color: rgba(255, 255, 255, 0.9);
  font-size: 18px;
  margin-bottom: 32px;
  line-height: 1.6;
}

/* BOTÃO */
.cta-trilhas-btn {
  display: inline-block;
  background: #fdd835; /* amarelo Noronha */
  color: #0b3a2e;
  padding: 14px 36px;
  border-radius: 999px;
  font-weight: 600;
  text-decoration: none;
  transition: all 0.25s ease;
}

.cta-trilhas-btn:hover {
  background: #ffe45c;
  transform: translateY(-2px);
}

/* MOBILE */
@media (max-width: 768px) {
  .cta-trilhas-faixa {
    padding: 60px 20px;
  }

  .cta-trilhas-content h2 {
    font-size: 24px;
  }

  .cta-trilhas-content p {
    font-size: 16px;
  }
}

/* =========================================
   MOBILE – EXPLORE OUTRAS EXPERIÊNCIAS
========================================= */
@media (max-width: 991px) {

  /* SEÇÃO */
  .explore-experiencias {
    padding: 40px 0;
  }

  /* TÍTULO */
  .explore-title {
    font-size: 22px;
    margin-bottom: 16px;
    padding-right: 20px;
  }

  /* GRID → 1 coluna */
  .explore-grid {
    grid-template-columns: 1fr;
    gap: 16px;
  }

  /* CARD */
  .explore-card {
    aspect-ratio: 1 / 1;
    border-radius: 12px;
  }

  /* TEXTO NO CARD */
  .explore-label {
    min-height: 70px;
    padding: 14px;

    font-size: 20px;
    line-height: 1.05;
  }

  /* TAGS (intro-tags da página de trilhas) */
  .intro-tags {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;

    margin-top: 12px;
    margin-bottom: 24px;
  }

  .intro-tags .tag {
    font-size: 13px;
    padding: 6px 12px;
    border-radius: 999px;
  }
}

@media (max-width: 768px) {
  .trilho-cards .card-item h3 {
    margin-bottom: 0; /* espaço entre título e estrelas */
    line-height: 1.25;  /* melhora leitura em 2 linhas */
  }

  .trilho-cards .rate {
    margin-top: 4px; /* respiro extra se precisar */
  }
}


/* ===============================
   BOTÃO CTA – FAIXA TRILHAS
   =============================== */

.cta-trilhas-faixa .cta-trilhas-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;

  max-width: 100%;
  width: auto;

  padding: 14px 28px;
  font-size: 16px;
  font-weight: 600;
  line-height: 1.2;

  white-space: normal;       /* permite quebrar linha se precisar */
  text-align: center;

  border-radius: 999px;
}

/* MOBILE – controla melhor o texto */
@media (max-width: 768px) {
  .cta-trilhas-faixa .cta-trilhas-btn {
    font-size: 15px;
    padding: 14px 22px;
  }
}

@media (max-width: 480px) {
  .cta-trilhas-faixa .cta-trilhas-btn {
    max-width: 260px;
  }
}

/* ===============================
   EXPLORE OUTRAS EXPERIÊNCIAS
================================ */

.explore-experiencias {
  padding: 60px 0;
  background: #fff;
}

.explore-title {
  font-size: 28px;
  font-weight: 700;
  margin-bottom: 24px;
  transform: translateX(9px); /* MUDA SÓ ESSE NÚMERO */
  line-height: 1.05;
}

/* GRID */
.explore-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 20px;
}

/* CARD 1:1 */
.explore-card {
  position: relative;
  aspect-ratio: 1 / 1;
  border-radius: 14px;
  overflow: hidden;

  background-size: cover;
  background-position: center;

  display: flex;
  align-items: flex-end;
  text-decoration: none;

  transition: opacity 0.25s ease; /* FADE */
}

/* TEXTO + OVERLAY LOCAL */
.explore-label {
  width: 100%;
  min-height: 80px;
  padding: 16px;

  display: flex;
  align-items: flex-end;

  color: #fff;
  font-size: 28px;
  font-weight: 800;
  line-height: 1.05;

  background: linear-gradient(
    to top,
    rgba(0,0,0,0.65),
    rgba(0,0,0,0.25),
    rgba(0,0,0,0)
  );
}

/* HOVER DESKTOP – FADE */
@media (hover: hover) {
  .explore-card:hover {
    opacity: 0.85;
  }
}

/* IMAGENS DOS CARDS – EXPLORE */

.explore-barco {
  background-image: url('../images/trilhas/cards-experiencias/card-barco.jpg');
}

.explore-mergulho {
  background-image: url('../images/trilhas/cards-experiencias/card-mergulho.jpg');
}

.explore-pesca {
  background-image: url('../images/trilhas/cards-experiencias/card-pesca.jpg');
}

.explore-aquatico {
  background-image: url('../images/trilhas/cards-experiencias/card-caiaque.jpg');
}


/* MOBILE */
@media (max-width: 991px) {

  /* MOVE O TÍTULO (não alinha o texto) */
  .explore-title {
    margin-left: auto;       /* joga o bloco pra direita */
    margin-right: 7px;
    max-width: fit-content;  /* título ocupa só o tamanho do texto */
  }

  /* GRID MAIS ESTREITO (cards menores) */
  .explore-grid {
    grid-template-columns: 1fr;
    max-width: 320px;
    margin-left: auto;
    margin-right: auto;
  }

  /* TEXTO DO CARD */
  .explore-label {
    font-size: 28px;
    font-weight: 800;
  }
}

.card-item {
  position: relative;
  cursor: pointer;
}

.card-item * {
  pointer-events: none;
}

.card-item a {
  pointer-events: auto;
}

.btn-white {
    background: #eaf7f3;
    color: #1f8a70;
    border-radius: 999px;
    font-weight: 600;
    transition: 0.3s;
}
.btn-white:hover {
    background: #FDE02F;
    color: #333;
}

/* --- ESTILO GLOBAL DO BLOG NORONHA LOCAL --- */

.blog-hero-custom {
    position: relative;
    width: 100%;
    min-height: 480px;
    background-image: url('../images/blog/cta-blog3.jpg'); /* Verifique se o caminho da imagem está correto */
    background-size: cover;
    background-position: center center;
    background-attachment: fixed;
    display: flex;
    align-items: center;
    padding-top: 160px; /* Ajuste para descer da Navbar */
    padding-bottom: 60px;
}

.blog-hero-overlay {
    position: absolute;
    inset: 0;
    background: linear-gradient(to right, rgba(0, 74, 111, 0.9) 0%, rgba(0, 74, 111, 0.2) 100%);
    z-index: 1;
}

.blog-hero-content {
    position: relative;
    z-index: 2;
}

.blog-badge {
    background-color: #FDE02F;
    color: #333;
    padding: 6px 18px;
    font-size: 12px;
    font-weight: 700;
    border-radius: 50px;
    display: inline-block;
    margin-bottom: 20px;
}

.blog-title {
    color: #fff;
    font-weight: 700;
}

.blog-title .highlight {
    color: #FDE02F;
}

.blog-divider {
    width: 60px;
    height: 4px;
    background: #FDE02F;
    margin-bottom: 25px;
}

.blog-lead {
    color: rgba(255, 255, 255, 0.8);
    font-size: 1.15rem;
}

/* Curadoria no Hero */
.blog-curator {
    display: flex;
    align-items: center;
    margin-top: 35px;
}

.curator-img img {
    width: 48px;
    border-radius: 50%;
    border: 2px solid rgba(255, 255, 255, 0.3);
    margin-right: 15px;
}

.curator-name {
    display: block;
    color: #fff;
    font-weight: 700;
    font-size: 14px;
}

.curator-tag {
    color: rgba(255, 255, 255, 0.6);
    font-size: 12px;
}

/* Cards e Artigos */
.tag-category {
    color: #0083B8;
    font-weight: 700;
    font-size: 13px;
}

.tag-category-small {
    color: #0083B8;
    font-weight: 700;
    font-size: 11px;
    text-transform: uppercase;
    letter-spacing: 1px;
}

/* Ajuste para o Card em Destaque */
.featured-post {
    display: flex;
    flex-direction: row; /* Lado a lado no computador */
    min-height: 400px;
}

.featured-img {
    background-repeat: no-repeat;
    background-size: cover;
    background-position: center;
    /* Adicione isso para o navegador reservar o espaço antes da foto carregar */
    aspect-ratio: 16 / 9;
}

.featured-text {
    width: 50%; /* Metade da largura no PC */
    padding: 40px;
}

/* --- CORREÇÃO PARA MOBILE (Onde a foto some ou fica pequena) --- */
@media (max-width: 768px) {
    .featured-post {
        flex-direction: column; /* Foto em cima, texto embaixo */
    }

    .featured-img {
        width: 100%; /* Largura total */
        min-height: 250px; /* Altura fixa para a foto aparecer bem */
    }

    .featured-text {
        width: 100%; /* Largura total */
        padding: 30px 20px;
    }
}

.card-img-top {
    height: 200px;
    background-size: cover;
    background-position: center;
}

.link-more {
    font-weight: 700;
    font-size: 13px;
    color: #0083B8;
    text-decoration: none;
}

/* Banner de CTA Final */
.blog-cta-box {
    background: #fff;
    border: 1px solid #eee;
    border-radius: 12px;
    padding: 40px;
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    justify-content: space-between;
}


.cta-title {
    font-weight: 700;
    margin-bottom: 5px;
}

.cta-text {
    color: #777;
    margin-bottom: 0;
}

.btn-cta-wa {
    padding: 15px 30px;
    border-radius: 50px;
    font-weight: 700;
}

/* Ajustes Responsivos */
@media (max-width: 768px) {
    .blog-hero-custom {
        min-height: 350px; /* Reduzimos a altura no celular para não ocupar a tela toda */
        padding-top: 100px; /* Ajuste para não ficar colado no topo */
        padding-bottom: 40px;
        text-align: center; /* Centraliza o texto no mobile */
        background-attachment: scroll; /* Melhora a performance do scroll no celular */
    }

    .blog-hero-overlay {
        /* Overlay mais escura no mobile para garantir que o texto branco seja lido */
        background: rgba(0, 74, 111, 0.8); 
    }

    .blog-title {
        font-size: 26px !important; /* Diminui o título para não quebrar em muitas linhas */
        line-height: 1.2;
    }

    .blog-lead {
        font-size: 1rem;
        padding: 0 10px;
    }

    .blog-divider {
        margin: 0 auto 20px auto; /* Centraliza a barrinha amarela */
    }

    .blog-curator {
        justify-content: center; /* Centraliza a foto e o nome do curador */
        margin-top: 25px;
    }
    
    /* Breadcrumb no Mobile */
    .blog-breadcrumb-outer {
        text-align: center;
        font-size: 12px;
        padding: 15px 0;
    }
}

/* Previne saltos de layout antes do carregamento total */
.ftco-animate {
    opacity: 1 !important;
    visibility: visible !important;
    transition: opacity 0.3s ease-in-out;
}

/* Otimização de GPU para o Hero */
.blog-hero-custom {
    backface-visibility: hidden;
    transform: translateZ(0);
    -webkit-font-smoothing: antialiased;
}

/* Estilização dos Breadcrumbs no Banner */
.blog-breadcrumb {
    margin-bottom: 15px;
    font-size: 13px;
    color: rgba(255, 255, 255, 0.6); /* Cor do texto e das barras / */
    text-transform: uppercase;
    letter-spacing: 1px;
    font-weight: 500;
}

.blog-breadcrumb a {
    color: rgba(255, 255, 255, 0.8);
    text-decoration: none;
    transition: 0.3s;
}

.blog-breadcrumb a:hover {
    color: #FDE02F; /* Amarelo Noronha ao passar o mouse */
}

.blog-breadcrumb span {
    color: #fff; /* A página atual fica em branco sólido */
    font-weight: 700;
}

/* Ajuste de espaçamento para o título não colar no breadcrumb */
.blog-title {
    margin-top: 10px;
}


/* ESTRUTURA DO MOSAICO - TRAVADA */
.custom-gallery-mosaic {
    display: flex !important;
    flex-wrap: wrap !important;
    margin: 0 !important;
    width: 100% !important;
}

.gallery-item-premium {
    display: block !important;
    width: 100% !important;
    position: relative !important;
    overflow: hidden !important;
    border-radius: 8px;
}

/* ALTURAS FIXAS (Garante que nada pule) */
.gallery-item-premium.large { height: 500px !important; }
.gallery-item-premium.medium { height: 245px !important; }
.gallery-item-premium:not(.large):not(.medium) { height: 245px !important; }

.gallery-item-premium img {
    width: 100% !important;
    height: 100% !important;
    object-fit: cover !important;
}

/* GALERIA (O que abre ao clicar) */
.mfp-bg {
    z-index: 999999 !important;
    cursor: pointer !important; /* Força o clique fora */
}

.mfp-wrap {
    z-index: 1000000 !important;
}

/* Remove scroll duplo ao abrir imagem */
html.mfp-helper {
    overflow: hidden !important;
}

.custom-gallery-mosaic { display: flex !important; flex-wrap: wrap !important; }
.gallery-item-premium { display: block; overflow: hidden; width: 100%; position: relative; }
.gallery-item-premium.large { height: 500px !important; }
.gallery-item-premium:not(.large) { height: 245px !important; }
.gallery-item-premium img { width: 100%; height: 100%; object-fit: cover; }

/* Garante o fundo preto e o X visível */
.mfp-bg { z-index: 10000 !important; background: #000; opacity: 0.8; }
.mfp-wrap { z-index: 10001 !important; }
.mfp-close { color: #FFF !important; font-size: 50px !important; cursor: pointer !important; }

.mfp-close {
  color: #FFF !important;
  font-size: 40px !important;
  top: 10px !important;
  right: 10px !important;
  position: absolute !important;
  z-index: 10002 !important;
  cursor: pointer !important;
}

@media (max-width: 768px) {
  .mfp-arrow {
    display: none !important;
  }
}


/* FAQ INTERATIVO */
.custom-faq .btn-link { 
    text-decoration: none !important; 
    font-size: 1.1rem;
}

.custom-faq .btn-link i.fa-chevron-down { 
    transition: transform 0.3s ease; 
}

.custom-faq .btn-link:not(.collapsed) i.fa-chevron-down { 
    transform: rotate(180deg); 
    color: #0083B8;
}

.custom-faq .card { 
    transition: all 0.3s ease; 
}

.custom-faq .card:hover { 
    transform: translateY(-2px);
    box-shadow: 0 10px 20px rgba(0,0,0,0.1) !important;
}

@media (max-width: 767.98px) {
    /* Ajusta o Banner que estava sumido/escondido */
    .page-adventures-hero {
        height: 300px !important;
        display: flex !important;
        align-items: center !important;
        justify-content: center !important;
       
    }

    /* Diminui os textos do topo que estavam enormes */
    .page-adventures-hero h1 {
        font-size: 2rem !important;
        line-height: 1.2 !important;
    }
    
    .service-page h2 {
        font-size: 1.8rem !important;
    }

    .lead {
        font-size: 14px !important;
    }

    /* Corrige o FAQ ultrapassando as bordas */
    .custom-faq {
        padding: 0 5px !important;
        width: 100% !important;
    }

    .custom-faq .card-header button {
        font-size: 0.95rem !important;
        padding: 15px !important;
        white-space: normal !important; /* Faz o texto da pergunta quebrar linha */
    }

    .ftco-section.pt-0 {
    padding-top: 0 !important; /* Diminua esse valor (ex: 0 ou 1em) para subir mais */
    margin-top: -60px !important; /* Ajuste negativo para compensar o padding e evitar espaço extra */
  }

  
}

@media (min-width: 992px) {
    /* Ajusta o parágrafo "Aqui não existem apenas clientes..." */
    .service-page .lead {
        font-size: 16px !important; /* Diminua para 1rem ou o valor que desejar */
        max-width: 700px; /* Opcional: limita a largura para não ficar uma linha gigante */
        margin-left: auto;
        margin-right: auto;
    }
}
    
/* Ajustes exclusivos para Desktop */
@media (min-width: 992px) {
    /* Força o banner a aparecer e ter altura */
    .page-adventures-hero {
        display: block !important;
        height: 450px !important; /* Altura ideal para desktop */
        min-height: 400px !important;
        background-size: cover !important;
        background-position: center 30% !important;
        margin-top: -65px !important;
    }

    /* Diminui a fonte da descrição do título */
    .service-page .lead {
        font-size: 16px !important; /* Tamanho menor que o padrão lead */
        max-width: 800px;
        margin: 0 auto 30px auto !important;
    }
}

/* Reset seguro – NÃO afeta banners */
.service-page section:not(.page-adventures-hero):not(.page-water-experiences-hero):not(.page-fishing-hero):not(.boats-video-hero) {
  position: relative;
}

.page-adventures-hero {
  position: relative;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  margin-top: -65px !important;
  padding-top: 0 !important;
  top: 0 !important;
}

.page-adventures-hero .adventures-hero-cta {
  position: relative;
  z-index: 2;
  text-align: center;
  max-width: 900px;
  padding: 0 20px;
}

@media (max-width: 767.98px) {
    /* 1. Sobe o banner até o topo absoluto */
    .service-page .page-adventures-hero {
        margin-top: -80px !important; /* Puxa o banner para cima do limite do menu */
        padding-top: 0 !important;
        height: 350px !important; /* Garante que o banner apareça */
        display: flex !important;
        align-items: center !important;
    }

    /* 2. Remove o espaço branco entre o banner e o menu */
    .service-page main {
        padding-top: 0 !important;
        margin-top: 0 !important;
    }
  }

 /* HERO – alinhado corretamente abaixo da navbar */
.page-essence-hero {
  position: relative;
  z-index: 1;

  width: 100%;
  min-height: 460px;

  /* FUNDAÇÃO VISUAL */
  background-size: cover;
  background-position: center;
  background-repeat: no-repeat;

  /* ISSO É O QUE DESCE O BANNER */
  margin-top: 75px; /* altura real da navbar */

  /* CENTRALIZA CONTEÚDO */
  display: flex;
  align-items: center;
  justify-content: center;
}


/* Overlay elegante, mais institucional */
.page-essence-hero .essence-hero-overlay {
  position: absolute;
  inset: 0;
  background: rgba(0, 40, 70, 0.55); /* azul profundo emocional */
  z-index: 1;
}

/* Texto */
.page-essence-hero .essence-hero-cta {
  position: relative;
  z-index: 2;
  text-align: center;
  color: #fff;
  padding: 0 20px;
  max-width: 900px;
}

.page-essence-hero .essence-hero-cta strong {
  display: block;
  font-size: 2.5rem;
  font-weight: 600;
  line-height: 1.15;
}

.page-essence-hero .essence-hero-cta span {
  display: block;
  margin-top: 14px;
  font-size: 0.9rem;
  letter-spacing: 0.08em;
  opacity: 0.85;
  text-transform: none;
}

.page-essence-hero .essence-hero-cta strong {
    font-size: 38px;
  }


@media (max-width: 768px) {
  .blog-cta-box {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    text-align: center;

    padding: 22px 16px;
    gap: 14px;
    border-radius: 10px;
  }

  .blog-cta-box h3,
  .blog-cta-box h4 {
    font-size: 1.15rem;
    margin-bottom: 6px;
  }

  .blog-cta-box p {
    font-size: 0.95rem;
    line-height: 1.4;
    margin-bottom: 8px;
  }

  .blog-cta-box .btn {
    width: 100%;
    max-width: 240px;
    margin: 0 auto;
    padding: 10px 20px;
    font-size: 0.95rem;
  }
}

@media (max-width: 768px) {

  .blog-final-cta {
    padding: 20px 16px !important;
    text-align: center;
  }

  .blog-final-cta h3 {
    font-size: 1.15rem !important;
    line-height: 1.3;
    margin-bottom: 8px;
  }

  .blog-final-cta p {
    font-size: 0.9rem !important;
    line-height: 1.4;
    margin-bottom: 14px;
    max-width: 100%;
  }

  .blog-final-cta .btn {
    display: inline-flex !important;
    align-items: center;
    justify-content: center;
    white-space: nowrap;          /* 🔴 ISSO resolve o problema */
    width: auto;
    max-width: 100%;
    padding: 10px 18px;
    font-size: 0.9rem;
    margin: 0 auto;
  }
}

@media (max-width: 768px) {

  .boat-details-body .d-flex.align-items-center.justify-content-between {
    flex-direction: column !important;
    align-items: stretch !important;
    gap: 10px;
  }

  .boat-details-body .d-flex.align-items-center.justify-content-between > div {
    text-align: center;
    font-size: 0.9rem;
  }

  .boat-details-body .d-flex.align-items-center.justify-content-between .btn {
    width: 100%;
    justify-content: center;
  }

}

/* Layout da Página Individual */
.aquatic-premium-section {
    padding-bottom: 80px !important; /* Evita colar no rodapé */
}

.pesca-card-individual {
    background: #fff;
    border-radius: 2px !important;   /* um pouco mais discreto */
    overflow: hidden;
    box-shadow: 0 10px 30px rgba(90, 90, 90, 0.08);
    border: none !important;         /* REMOVE a borda */
    .pesca-card-individual img 
    
    {
    border-radius: inherit !important;
}

}


.main-boat-img {
    position: relative;
    height: 450px; /* Proporção ideal para desktop */
}

.main-boat-img img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.premium-card-tag-floating {
    position: absolute;
    top: 20px;
    left: 20px;
    /* Fundo totalmente transparente */
    background: transparent !important; 
    /* Texto em cinza escuro/preto para leitura */
    color: #333 !important; 
    /* Borda escura fina e elegante */
    border: 1.5px solid #333 !important; 
    padding: 6px 18px;
    border-radius: 50px;
    font-size: 11px;
    font-weight: 800;
    letter-spacing: 0.5px;
    z-index: 10;
}

/* Sidebar de Navegação */
.mini-card-nav {
    display: flex;
    align-items: center;
    padding: 12px;
    background: #fff;
    border: 1px solid #eee;
    border-radius: 12px;
    margin-bottom: 12px;
    transition: all 0.3s ease;
    text-decoration: none !important;
}

.mini-card-nav:hover {
    transform: translateX(5px);
    border-color: #0083b8;
}

.mini-card-nav.active {
    border-color: #0083b8;
    background: #f0faff;
}

.mini-card-img {
    width: 65px;
    height: 65px;
    border-radius: 10px;
    object-fit: cover;
    margin-right: 15px;
}

.mini-card-info h5 {
    font-size: 15px;
    margin: 0;
    color: #333;
    font-weight: 700;
}

.mini-card-info span {
    font-size: 10px;
    text-transform: uppercase;
    color: #0083b8;
    font-weight: 800;
}

/* Responsivo */
@media (max-width: 991px) {
    .main-boat-img { height: 320px; }
}

@media (max-width: 767px) {
    .main-boat-img { height: 250px; }
    .boat-footer-cta { flex-direction: column; text-align: center; gap: 20px; }
    .boat-footer-cta .btn { width: 100%; }
    .aquatic-premium-section { padding-bottom: 50px !important; }
}

/* =========================================
   HERO CTA – PÁGINA DE PESCA
========================================= */

.page-fishing-hero {
  position: relative;
  width: 100%;
  min-height: 480px;

  background-image: url("../images/pesca/banner-cta-pesca.jpg");
  background-size: cover;
  background-position: center;
  background-repeat: no-repeat;

  display: flex;
  align-items: center;
  justify-content: center;
}

/* Overlay verde */
.page-fishing-hero .fishing-hero-overlay {
  position: absolute;
  inset: 0;
  background: rgba(10, 60, 40, 0.55); /* verde oceânico */
  z-index: 1;
}

/* Texto */
.page-fishing-hero .fishing-hero-cta {
  position: relative;
  z-index: 2;
  text-align: center;
  color: #fff;
  padding: 0 20px;
  max-width: 900px;
  
}

.page-fishing-hero .fishing-hero-cta strong {
  display: block;
  font-size: 2.4rem;
  font-weight: 600;
  line-height: 1.2;
}

.page-fishing-hero .fishing-hero-cta span {
  display: block;
  margin-top: 12px;
  font-size: 0.9rem;
  letter-spacing: 0.08em;
  opacity: 0.85;
  text-transform: none !important;
}

/* ===============================
   MOBILE
================================ */

/* Ajuste Geral */
.page-fishing-hero {
    margin-top: 0 !important;
    padding-top: 0 !important;
    top: 0;
    position: relative;
    display: flex;
    align-items: center;
}

@media (max-width: 768px) {
  .page-fishing-hero {
    height: 400px;
    min-height: 350px !important;
    max-height: 350px !important;
    margin-top: 0 !important; /* Garante que não tenha margem no mobile */
  }

  .page-fishing-hero .fishing-hero-cta strong {
    font-size: 1.6rem;
  }
}

@media (max-width: 480px) {
  .page-fishing-hero {
    min-height: 260px;
    margin-top: 0 !important;
  }

  .page-fishing-hero .fishing-hero-cta strong {
    font-size: 1.4rem;
  }
}

/* --- RESET E ESTRUTURA --- */
.custom-gallery-container {
    position: relative;
    width: 100%;
    height: 450px;
    background: #111;
    overflow: hidden;
    border-radius: 15px 15px 0 0;
}

.custom-gallery-wrapper {
    display: flex;
    width: 100%;
    height: 100%;
    overflow-x: auto;
    scroll-snap-type: x mandatory;
    scroll-behavior: smooth;
    -webkit-overflow-scrolling: touch;
}

.custom-gallery-wrapper::-webkit-scrollbar { display: none; }

.gallery-item {
    flex: 0 0 100%;
    height: 100%;
    scroll-snap-align: start;
}

.gallery-item img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

/* --- SETAS (SÓ APARECEM NO DESKTOP) --- */
.gallery-nav {
    position: absolute;
    top: 50%;
    transform: translateY(-50%);
    background: rgba(0, 0, 0, 0.4);
    color: white;
    border: none;
    width: 45px;
    height: 45px;
    border-radius: 50%;
    cursor: pointer;
    z-index: 10;
    font-size: 18px;
}

.gallery-nav.prev { left: 15px; }
.gallery-nav.next { right: 15px; }

/* --- PONTINHOS --- */
.gallery-dots {
    position: absolute;
    bottom: 20px;
    left: 50%;
    transform: translateX(-50%);
    display: flex;
    gap: 8px;
    z-index: 10;
}

.dot {
    width: 10px;
    height: 10px;
    background: rgba(255, 255, 255, 0.4);
    border-radius: 50%;
    cursor: pointer;
}

.dot.active {
    background: #fff;
    width: 20px;
    border-radius: 10px;
}

/* --- AJUSTE MOBILE CORRIGIDO --- */
@media (max-width: 991px) {
    .custom-gallery-container { 
        height: 280px; 
        position: relative;
        overflow: hidden;
    }
    .gallery-nav { display: none; }
}

.custom-gallery-wrapper {
    display: flex !important;
    width: 100%;
    height: 100%;
    overflow-x: auto !important;
    scroll-snap-type: x mandatory;
    /* O SEGREDO: pan-x permite o carrossel, pan-y permite o scroll da página */
    touch-action: pan-x pan-y !important; 
    -webkit-overflow-scrolling: touch;
    scroll-behavior: smooth;
    gap: 0;
}

.gallery-item {
    flex: 0 0 100% !important;
    min-width: 100% !important;
    height: 100%;
    scroll-snap-align: start;
    scroll-snap-stop: always;
    /* Garante que o item também aceite ambos os movimentos */
    touch-action: pan-x pan-y !important;
}

.gallery-item img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    /* VOLTAMOS PARA AUTO: Se for none, o scroll horizontal para de funcionar no mobile */
    pointer-events: auto; 
    user-select: none;
    -webkit-user-drag: none;
    /* Reforça que a imagem não deve bloquear o scroll da página */
    touch-action: pan-x pan-y !important;
}

@media (max-width: 768px) {
  .main-service-page {
    padding-top: 0 !important;
  }

  .page-fishing-hero {
    margin-top: -38px !important;
    padding-top: 0 !important;
  }
}

/* ===== COLAR HERO NO TOPO – DESKTOP ===== */

/* Remove empurrão do layout base */
main.main-service-page {
  padding-top: 0 !important;
  margin-top: 0 !important;
}

/* Garante que o banner encoste */
.page-fishing-hero {
  margin-top: -55px !important;
  padding-top: 0 !important;
}

/* ==============================
   HERO CTA – AVENTURAS
============================== */

.page-adventures-hero {
  position: relative;
  width: 100%;
  min-height: 480px;

  background-image: url("../images/aventuras/cta-banner3.jpg");
  background-size: cover;
  background-position: center;
  background-repeat: no-repeat;

  display: flex;
  align-items: center;
  justify-content: center;
}

/* Texto */
.page-adventures-hero .adventures-hero-cta {
  position: relative;
  z-index: 2;
  text-align: center;
  color: #fff;
  padding: 0 20px;
  max-width: 900px;
}

.page-adventures-hero .adventures-hero-cta strong {
  display: block;
  font-size: 34px;
  font-weight: 700;
  line-height: 1.2;
  text-transform: none !important;
}

.page-adventures-hero .adventures-hero-cta span {
  display: block;
  margin-top: 12px;
  font-size: 0.9rem;
  letter-spacing: 0.08em;
  opacity: 0.8;
}

/* ===============================
   MOBILE
================================ */

@media (max-width: 768px) {
  .page-adventures-hero {
    min-height: 300px;
  }

  .page-adventures-hero .adventures-hero-cta strong {
    font-size: 1.6rem;
  }
}

@media (max-width: 480px) {
  .page-adventures-hero {
    min-height: 260px;
  }

  .page-adventures-hero .adventures-hero-cta strong {
    font-size: 1.4rem;
  }
}

/* 2. Sobe o banner CTA de Aventuras para encostar na Navbar */
.page-adventures-hero {
  margin-top: -55px !important; /* ajuste fino se a navbar for maior/menor */
  position: relative;
  z-index: 1;
}

/* 3. Garante que o container principal não tenha respiro no topo */
main.service-page,
.service-page-header {
  padding-top: 0 !important;
  margin-top: 0 !important;
}

/* OVERLAY AZUL VIBRANTE (AGORA APARECE) */
.page-adventures-hero::before {
  content: "";
  position: absolute;
  inset: 0;
  background: rgba(0, 110, 170, 0.65);
  z-index: 1;
}


@media (max-width: 768px) {

  /* Remove o empurrão do layout base */
  main.service-page,
  main.main-service-page {
    padding-top: 0 !important;
    margin-top: 0 !important;
  }

  /* Sobe o banner de Aventuras */
  .page-adventures-hero {
    margin-top: -55px !important; /* ajuste se a navbar for maior */
  }

}

/* CONTAINER ESTRUTURAL */
.aquatic-premium-section {
    margin-top: 10px !important; /* Puxa a seção para cima do vídeo */
    position: relative;
    z-index: 10;
    background: #fff; /* Garante que o fundo branco cubra o vídeo se necessário */
    padding-top: 50px;
    margin-top: 0 !important;
    
}

/* SIDEBAR PREMIUM ESTILO TRIPADVISOR */
.premium-sidebar-nav {
    position: -webkit-sticky;
    position: sticky;
    top: 100px;
}

.premium-nav-title {
    font-size: 1.2rem;
    font-weight: 700;
    color: #2c3e50;
    margin-bottom: 25px;
    padding-left: 12px;
    border-left: 4px solid #0083b8;
}

/* MINI CARDS DA SIDEBAR */
.mini-card-nav {
    display: flex;
    align-items: center;
    background: #fff;
    border-radius: 12px;
    padding: 12px;
    margin-bottom: 15px;
    text-decoration: none !important;
    border: 1px solid #eee;
    transition: opacity 0.4s ease; /* Efeito Fade solicitado */
}

.mini-card-nav:hover {
    opacity: 0.6; /* Fade no hover */
}

.mini-card-img {
    width: 65px;
    height: 65px;
    border-radius: 10px;
    object-fit: cover;
    margin-right: 15px;
}

.mini-card-info h5 {
    font-size: 0.95rem;
    margin: 0;
    color: #333;
    font-weight: 600;
}

.mini-card-info span {
    font-size: 0.75rem;
    color: #0083b8;
    text-transform: uppercase;
    font-weight: 700;
    letter-spacing: 0.5px;
}

/* CARDS PRINCIPAIS DE SERVIÇO (CONTEÚDO) */
.premium-service-card {
    background: #fff;
    border-radius: 16px;
    overflow: hidden;
    border: 1px solid #efefef;
    margin-bottom: 30px;
    transition: opacity 0.4s ease;
}

.premium-service-card:hover {
    opacity: 0.85; /* Fade sutil no card principal */
}

.premium-card-tag {
    display: inline-block;
    padding: 4px 12px;
    border-radius: 50px;
    font-size: 0.7rem;
    font-weight: 700;
    text-transform: uppercase;
    margin-bottom: 10px;
}

/* RESPONSIVIDADE MOBILE */
@media (max-width: 991px) {
    .premium-sidebar-nav {
        display: flex;
        overflow-x: auto;
        padding: 10px 0 20px 0;
        gap: 12px;
        white-space: nowrap;
        position: static;
    }
    .mini-card-nav {
        flex: 0 0 280px;
        margin-bottom: 0;
    }
    .premium-nav-title {
        display: block !important;
    }
}

/* AJUSTE PARA O CONTEÚDO DA SIDEBAR APARECER CORRETAMENTE NO MOBILE */
@media (max-width: 991px) {
    /* Força a coluna da sidebar a descer para baixo dos cards principais */
    aside.col-lg-4 {
        display: block !important;
        width: 100% !important;
        max-width: 100% !important;
        flex: 0 0 100% !important;
        margin-top: 10px !important; /* Espaço para não grudar no card de cima */
        padding: 0 15px !important;
    }

    /* Garante que os mini-cards e o CTA fiquem visíveis e em bloco */
    .premium-sidebar-nav {
        display: block !important;
        position: relative !important;
        top: 0 !important;
    }

    /* Garante que o link flexível dos mini-cards não quebre o layout */
    .mini-card-nav {
        display: flex !important;
        width: 100% !important;
    }
}

/* AJUSTE ESPECÍFICO PARA O TEXTO DO BOX WHATSAPP NO MOBILE */
@media (max-width: 991px) {
    /* Seleciona o box azul de CTA para ele expandir a altura conforme o texto */
    .premium-sidebar-nav .text-center {
        display: block !important;    /* Remove o flex que estava esmagando o texto */
        height: auto !important;      /* Permite que o box cresça verticalmente */
        padding: 25px 20px !important; /* Dá espaço para o texto respirar */
    }

    /* Garante que o parágrafo dentro do box ocupe a largura total e não corte */
    .premium-sidebar-nav .text-center p {
        width: 100% !important;
        white-space: normal !important; /* Permite a quebra de linha natural */
        margin-bottom: 20px !important;
    }

    /* Ajusta o botão para não ficar colado nas bordas */
    .premium-sidebar-nav .btn-primary {
        display: block !important;
        width: 100% !important;
        white-space: normal !important;
    }
}

/* =========================================
   HERO IMAGEM FIXA – PÁGINA ÁGUA / MERGULHO
========================================= */

.page-water-experiences-hero {
  position: relative;
  width: 100%;
  min-height: 480px;

  background-image: url("../images/experiencias/banner-cta.jpg");
  background-size: cover;
  background-position: center;
  background-repeat: no-repeat;

  display: flex;
  align-items: center;
  justify-content: center;
}

/* Overlay */
.page-water-experiences-hero .water-hero-overlay {
  position: absolute;
  inset: 0;
  background: rgba(0, 0, 0, 0.45);
  z-index: 1;
}

/* Texto */
.page-water-experiences-hero .water-hero-cta {
  position: relative;
  z-index: 2;
  text-align: center;
  color: #fff;
  padding: 0 20px;
  max-width: 900px;
}

.page-water-experiences-hero .water-hero-cta span {
  display: block;
  margin-top: 12px;
  font-size: 14px;
  letter-spacing: 0.08em;
  opacity: 0.8;
  font-weight: 600;
  color: #fff;
  
}

/* ===============================
   MOBILE
================================ */

@media (max-width: 768px) {
  .page-water-experiences-hero {
    /* Força o tamanho e impede que o padding aumente o total */
    height: 400px !important;
    min-height: 400px !important;
    max-height: 400px !important;
    
    /* Garante que o cálculo da altura inclua as bordas/paddings */
    box-sizing: border-box !important;
    
    /* Remove paddings excessivos que podem estar somando na altura */
    padding-top: 0 !important;
    padding-bottom: 0 !important;
    
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    overflow: hidden !important;
  }

  /* Se houver um conteúdo interno ocupando muito espaço */
  .page-water-experiences-hero .container,
  .page-water-experiences-hero .water-hero-cta {
    margin: 0 !important;
    padding: 20px !important;
  }
}

  @media (max-width: 480px) {
  .page-water-experiences-hero {
    min-height: 260px;
    
  }  
}

/* --- COMPORTAMENTO NO DESKTOP (PC) --- */
@media (min-width: 769px) {
  .page-water-experiences-hero .water-hero-cta strong {
    font-size: 36px !important;
    font-weight: 700;
    text-transform: none !important;
    display: block;
  }
}

/* --- COMPORTAMENTO NO MOBILE (CELULAR) --- */
@media (max-width: 768px) {
  /* Ajusta o banner para 400px exatos */
  .page-water-experiences-hero {
    height: 390px !important;
    min-height: 350px !important;
    max-height: 350px !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    padding: 0 !important;
  }

  /* Ajusta o texto para não ficar gigante no celular */
  .page-water-experiences-hero .water-hero-cta strong {
    font-size: 26px !important; /* Diminuído para caber bem nos 400px */
    font-weight: 700;
    line-height: 1.2;
    text-transform: none !important;
    display: block !important;
    padding: 0 15px; /* Margem interna para o texto não bater nas bordas */
  }
}

/* Cabeçalho da seção */
.experiences-header h2 {
  font-weight: 800;
  color: #222;
  margin-bottom: 8px;
  font-size: 28px;
}

/* Estrelinhas */
.experiences-header .ta-rating {
  display: flex;
  align-items: center;
  gap: 8px;
  margin-bottom: 14px; /* 👈 espaço correto antes do texto */
  font-size: 0.95rem;
  color: #555;
}

/* Texto descritivo */
.experiences-header .lead {
  margin-top: 0; /* evita cola estranha */
  max-width: 640px;
  line-height: 1.6;
  font-size: 18px;
}

@media (max-width: 991px) {
    /* 1. Remove o espaço do header para o banner subir */
    .boats-list-header {
        margin-bottom: 0 !important;
        padding-bottom: 10px !important;
    }

    /* 2. Força o banner a subir e encostar no menu */
    .boats-video-hero, 
    .page-water-experiences-hero {
        margin-top: -35px !important; /* Ajuste esse valor conforme necessário */
        position: relative;
        z-index: 1;
    }

    /* 3. Se houver um padding no topo do body ou main que esteja empurrando tudo */
    main.service-page {
        padding-top: 0 !important;
    }
}

@media (max-width: 767px) {
    /* 1. Transforma o card em uma linha (estilo lista) */
    .premium-service-card .row.no-gutters {
        display: flex !important;
        flex-direction: row !important;
        flex-wrap: nowrap !important;
        align-items: center !important;
    }

    /* 2. Ajusta a proporção da imagem (quadrada e pequena) */
    .premium-service-card .col-md-5 {
        flex: 0 0 100px !important; /* Largura fixa da imagem */
        max-width: 100px !important;
        height: 100px !important;    /* Altura fixa da imagem */
        margin: 10px !important;
    }

    .premium-service-card img {
        border-radius: 8px !important;
        height: 100% !important;
        width: 100% !important;
        object-fit: cover !important; /* Garante que a imagem não distorça */
    }

    /* 3. Ajusta o texto para caber ao lado */
    .premium-service-card .col-md-7 {
        padding: 10px 10px 10px 0 !important;
        flex: 1 !important;
    }

    /* 4. Diminui tudo para ser bem slim */
    .premium-service-card h4 {
        font-size: 0.95rem !important;
        margin-bottom: 2px !important;
        line-height: 1.2;
    }

    .premium-service-card p.small {
        font-size: 0.75rem !important;
        display: -webkit-box !important;
        -webkit-line-clamp: 2; /* Limita a 2 linhas de texto */
        -webkit-box-orient: vertical;
        overflow: hidden;
        margin-bottom: 5px !important;
    }

    /* Esconde as informações extras (ícones de tempo/dificuldade) no mobile para enxugar */
    .premium-service-card .d-flex.mb-3, 
    .premium-card-tag {
        display: none !important;
    }

    /* Botão bem pequeno */
    .premium-service-card .btn-sm {
        padding: 2px 10px !important;
        font-size: 0.7rem !important;
    }
}

/* AJUSTE PARA COLAR O BANNER NO MENU (DESKTOP) */
@media (min-width: 992px) {
    /* 1. Remove margens do header que empurram o banner para baixo */
    .boats-list-header {
        margin-top: 0 !important;
        margin-bottom: 0 !important;
        padding-top: 0 !important;
    }

    /* 2. Sobe o banner para encostar na Navbar */
    .boats-video-hero, 
    .page-water-experiences-hero {
        margin-top: -55px !important; /* Ajuste este valor até encostar no seu menu */
        position: relative;
        z-index: 1;
    }

    /* 3. Garante que o container principal não tenha respiro no topo */
    main.service-page, 
    .service-page-header {
        padding-top: 0 !important;
        margin-top: 0 !important;
    }
}

/* Ajusta o ponto de parada do scroll para não ficar atrás do menu */
#mergulho, #pesca, #aventuras {
    scroll-margin-top: 100px; /* Ajuste este valor de acordo com a altura do seu menu */
}

.page-essence-hero {
  position: relative;
  width: 100%;
  min-height: 460px;
  margin-top: 75px; /* mantém seu ajuste atual */
  overflow: hidden;

  display: flex;
  align-items: center;
  justify-content: center;
}

/* VÍDEO */
.page-essence-hero .hero-video {
  position: absolute;
  top: 50%;
  left: 50%;
  width: 100%;
  height: 100%;
  object-fit: cover;
  transform: translate(-50%, -50%);
  z-index: 0;
}

/* OVERLAY */
.essence-hero-overlay {
  position: absolute;
  inset: 0;
  background: rgba(0, 40, 60, 0.45);
  z-index: 1;
}

/* CTA */
.essence-hero-cta {
  position: relative;
  z-index: 2;
  text-align: center;
  color: #fff;
}

@media (max-width: 768px) {
  .page-essence-hero {
    height: 400px;
    min-height: 400px;
    margin-top: 60px; /* antes 75px */
  }
 
}

@media (max-width: 768px) {
.page-essence-hero .essence-hero-cta strong {
    font-size: 26px;
  }
}

/* Container */
.trip-details {
  display: flex;
  justify-content: space-between;
  text-align: center;
  gap: 16px;
}

/* Cada item */
.trip-detail {
  flex: 1;
}

.trip-detail span {
  display: block;
  font-weight: 700;
  font-size: 1.2rem;
}

.trip-detail small {
  color: #666;
}

/* Destaque do meio */
.trip-detail.highlight {
  border-left: 1px solid #ddd;
  border-right: 1px solid #ddd;
  padding: 0 20px;
}

.trip-detail.highlight span {
  color: #e67e22;
}

/* 📱 MOBILE — cada item em uma linha */
@media (max-width: 768px) {
  .trip-details {
    flex-direction: column;
    gap: 12px;
  }

  .trip-detail.highlight {
    border: none;
    padding: 0;
  }
}

.page-contact-hero {
  height: 60vh !important;
  min-height: 400px;
  background-size: cover;
  background-position: center center;
  margin-top: -55px !important;
  display: flex;
  align-items: center;
  position: relative;
  margin-top: 30px;
}

@media (max-width: 768px) {
  .page-contact-hero {
    height: 390px !important;
    min-height: 400px !important;
    margin-top: 50px;
  }
}

@media (max-width: 768px) {
  .page-contact-hero h1 {
    font-size: 1.9rem;
    line-height: 1.2;
    letter-spacing: -0.5px;
  }
}

.btn-whatsapp-noronha {
  background: linear-gradient(135deg, #1f8a70 0%, #2bb0a6 100%);
  border: none;
  color: #ffffff;

  font-weight: 600;
  font-size: 0.95rem;   /* ↓ menor */
  letter-spacing: 0.15px;

  border-radius: 999px;

  display: flex;
  align-items: center;
  justify-content: center;
  gap: 6px;             /* ↓ menor */

  padding: 12px 20px;   /* ↓ mais compacto */

  box-shadow: 0 8px 20px rgba(31, 138, 112, 0.3);
  transition: all 0.25s ease;
}

.btn-whatsapp-noronha:hover,
.btn-whatsapp-noronha:focus {
  background: linear-gradient(135deg, #1e6f5c 0%, #239d93 100%);
  box-shadow: 0 12px 28px rgba(31, 138, 112, 0.4);
  transform: translateY(-1px);
  color: #ffffff;
}

/* Ícone mais proporcional */
.btn-whatsapp-noronha i {
  font-size: 1.05rem;
}

/* 📱 Mobile */
@media (max-width: 768px) {
  .btn-whatsapp-noronha {
    font-size: 0.95rem;
    padding: 13px 18px;
  }
}

/* ==============================
   HERO CTA – PÁGINA CONTATO
============================== */

.contact-hero {
  position: relative;
  height: 420px;          /* ALTURA DESKTOP */
  margin-top: 75px;       /* SUBIR/DESCER BANNER */

  background-size: cover;
  background-position: center;

  display: flex;
  align-items: center;
  justify-content: center;
}

/* Overlay */
.contact-hero-overlay {
  position: absolute;
  inset: 0;
  background: linear-gradient(
    rgba(0, 40, 60, 0.45),
    rgba(0, 40, 60, 0.75)
  );
}

/* Conteúdo */
.contact-hero-content {
  position: relative;
  text-align: center;
  max-width: 560px;
  padding: 0 20px;

  transform: translateY(0px); /* SUBIR/DESCER TEXTO */
}

/* Texto */
.contact-hero-title {
  font-size: 36px;
  line-height: 36px;
  font-weight: 700;
  color: #fff;
  margin-bottom: 30px;
}

.contact-hero-text {
  font-size: 17px;
  line-height: 23px;
  color: rgba(255,255,255,.88);
}

/* MOBILE */
@media (max-width: 768px) {
  .contact-hero {
    height: 400px;
    min-height: 350px !important;
    max-height: 350px !important;
    margin-top: 40px;
  }

  .contact-hero-title {
    font-size: 24px;
    line-height: 28px;
  }

  .contact-hero-text {
    font-size: 15px;
    line-height: 21px;
  }
}

/* Estilo para posicionar as bolinhas */
.gallery-indicators {
    position: absolute;
    bottom: 15px; /* Altura em relação ao fundo da imagem */
    left: 50%;
    transform: translateX(-50%);
    display: flex;
    gap: 8px;
    z-index: 5;
}

.dot {
    width: 8px;
    height: 8px;
    background-color: rgba(255, 255, 255, 0.5); /* Bolinha apagada */
    border-radius: 50%;
    transition: all 0.3s ease;
}

.dot.active {
    background-color: #fff; /* Bolinha acesa */
    width: 18px; /* Transforma em tracinho quando ativa */
    border-radius: 4px;
}

/* Overlay para destacar os indicadores */
.custom-gallery-container::after {
    content: "";
    position: absolute;
    bottom: 0;
    left: 0;
    width: 100%;
    height: 40%; /* Pega só a parte de baixo */
    background: linear-gradient(to top, rgba(0, 0, 0, 0.5) 0%, transparent 100%);
    pointer-events: none; /* Deixa os cliques passarem para as setas/bolinhas */
    z-index: 4; /* Fica atrás das bolinhas (z-index 5) */
}

/* Garantir que as bolinhas e setas fiquem acima do gradiente */
.gallery-indicators {
    z-index: 5 !important;
}

.gallery-nav {
    z-index: 7 !important;
}

@media (max-width: 768px) {
  section.page-essence-hero {
    height: 390px !important;
    min-height: 350px !important;
    max-height: 350px !important;
    overflow: hidden;
  }
}

/* Cria uma área sensível invisível acima do submenu */
.seu-submenu-classe::before {
    content: "";
    position: absolute;
    top: -20px; /* Aumente ou diminua conforme a distância do seu menu */
    left: 0;
    width: 100%;
    height: 20px;
    display: block;
    background: transparent; /* Invisível ao usuário, mas captado pelo mouse */
}

.destination-img,
.blog-entry .img,
.card-img-top {
  height: 260px;
  overflow: hidden;
}

.destination-img img,
.blog-entry .img img,
.card-img-top img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

@media (max-width: 768px) {
  .destination-img,
  .blog-entry .img,
  .card-img-top {
    height: 200px;
  }
}
